Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/disruptek/criterion
statistics-driven micro-benchmarking framework
https://github.com/disruptek/criterion
benchmark criterion lemonboy measurement metrics micro nim performance statistics
Last synced: about 1 month ago
JSON representation
statistics-driven micro-benchmarking framework
- Host: GitHub
- URL: https://github.com/disruptek/criterion
- Owner: disruptek
- Created: 2020-09-06T22:28:12.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-03-14T04:07:32.000Z (11 months ago)
- Last Synced: 2024-11-15T05:32:33.453Z (2 months ago)
- Topics: benchmark, criterion, lemonboy, measurement, metrics, micro, nim, performance, statistics
- Language: Nim
- Homepage:
- Size: 290 KB
- Stars: 24
- Watchers: 1
- Forks: 3
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
Awesome Lists containing this project
- awesome-nim - criterion - Statistic-driven micro-benchmark framework. (Development Tools / Benchmarking)
README
# criterion
[![Test Matrix](https://github.com/disruptek/criterion/workflows/CI/badge.svg)](https://github.com/disruptek/criterion/actions?query=workflow%3ACI)
[![GitHub release (latest by date)](https://img.shields.io/github/v/release/disruptek/criterion?style=flat)](https://github.com/disruptek/criterion/releases/latest)
![Minimum supported Nim version](https://img.shields.io/badge/nim-1.0.8%2B-informational?style=flat&logo=nim)
[![License](https://img.shields.io/github/license/disruptek/criterion?style=flat)](#license)A statistics-driven micro-benchmarking framework heavily inspired by the
wonderful [criterion](https://github.com/bos/criterion) library for Haskell;
originally created by [LemonBoy](https://github.com/LemonBoy).## Status
Works, API is still not 100% stable yet.
## Example
```nim
import criterionvar cfg = newDefaultConfig()
benchmark cfg:
func fib(n: int): int =
case n
of 0: 1
of 1: 1
else: fib(n-1) + fib(n-2)# on nim-1.0 you have to use {.measure: [].} instead
proc fib5() {.measure.} =
var n = 5
blackBox fib(n)# ... equivalent to ...
iterator argFactory(): int =
for x in [5]:
yield xproc fibN(x: int) {.measure: argFactory.} =
blackBox fib(x)# ... equivalent to ...
proc fibN1(x: int) {.measure: [5].} =
blackBox fib(x)
```Gives the following output:
![fib](docs/fib.svg "fib")A bit too much info? Just set `cfg.brief = true` and the results will be output
in a condensed format:![brief](docs/brief.svg "brief")
Much easier to parse, isn't it?
If you need to pass more than a single argument to your benchmark fixture just
use a tuple: they are automagically unpacked at compile-time.```nim
import criterionlet cfg = newDefaultConfig()
benchmark cfg:
proc foo(x: int, y: float) {.measure: [(1,1.0),(2,2.0)].} =
discard x.float + y
```## Export the measurements
If you need the measurement data in order to compare different benchmarks, to
plot the results or to post-process them you can do so by adding a single line
to your benchmark setup:```nim
let cfg = newDefaultConfig()# Your usual config goes here...
cfg.outputPath = "my_benchmark.json"benchmark(cfg):
# Your benchmark code goes here...
```The data will be dumped once the block has been completed into a json file
that's ready for consumption by other tools.## Documentation
See [the documentation for the criterion module](https://disruptek.github.io/criterion/criterion.html) as generated directly from the source.## More Test Output
[The source of the `many` test.](https://github.com/disruptek/criterion/blob/master/tests/many.nim)
![many](docs/many.svg "many")
## License
MIT