Benchy is a Rust crate for benchmarking long-running tasks. Unlike other benchmarking libraries such as Criterion, which are optimized for high-frequency, nanosecond-level performance, Benchy is designed for tasks that take a significant amount of time to execute. It provides a flexible and customizable environment, allowing you to set custom iteration counts and even measure memory usage metrics.
sh
cargo add benchy
benches/bench.rs
:
```rust use benchy::{benchmark, BenchmarkRun};
fn fibonaccisingle(b: &mut BenchmarkRun) { let mut x = 0; let mut y = 1; b.run(|| { for _ in 0..1000_000 { let temp = x; x = y; y = temp + y; } }); }
("1 million iterations", 1_000_000),
("2 million iterations", 2_000_000),
])] fn fibonacci_parametrized(b: &mut BenchmarkRun, iterations: usize) { let mut x = 0; let mut y = 1; b.run(|| { for _ in 0..iterations { let temp = x; x = y; y = temp + y; } }); }
benchy::main!(fibonaccisingle, fibonacciparametrized); ```
Cargo.toml
:
toml
[[bench]]
name = "bench"
harness = false
For more advanced usage, check the zk-bench repository that utilizes this crate, or refer to the documentation.
BENCHY_QUICK
(default: false) - if true, runs only the first parameter of each benchmark.BENCHY_OUTPUT_DIR
(default: None) - directory to output the JSON benchmark results to.BENCHY_MAX_DEFAULT_ITERATIONS_DURATION
(default: 10s) - the maximum total duration for the default (10) iterations of a single benchmark.