scaling

A lightweight benchmarking library that measures scaling behavior

4 releases

0.1.3 Mar 30, 2021
0.1.2 Mar 30, 2021
0.1.1 Mar 30, 2021
0.1.0 Mar 30, 2021
Download history 558/week @ 2024-06-20 1475/week @ 2024-06-27 1314/week @ 2024-07-04 1949/week @ 2024-07-11 1745/week @ 2024-07-18 1879/week @ 2024-07-25 1752/week @ 2024-08-01 1532/week @ 2024-08-08 1611/week @ 2024-08-15 2863/week @ 2024-08-22 2158/week @ 2024-08-29 3082/week @ 2024-09-05 1941/week @ 2024-09-12 2005/week @ 2024-09-19 1586/week @ 2024-09-26 714/week @ 2024-10-03

6,692 downloads per month
Used in 3 crates

MIT/Apache

39KB
568 lines

A lightweight benchmarking library which:

  • uses linear regression to screen off sources of constant error;
  • handles benchmarks which must mutate some state;
  • has a very simple API!
use easybench::{bench,bench_env};

// Simple benchmarks are performed with `bench`.
println!("fib 200: {}", bench(|| fib(200) ));
println!("fib 500: {}", bench(|| fib(500) ));

// If a function needs to mutate some state, use `bench_env`.
println!("reverse: {}", bench_env(vec![1,2,3], |xs| xs.reverse()));
println!("sort:    {}", bench_env(vec![1,2,3], |xs| xs.sort()));

Running the above yields the following:

fib 200:         38 ns   (R²=1.000, 26053498 iterations in 155 samples)
fib 500:        109 ns   (R²=1.000, 9131585 iterations in 144 samples)
reverse:          3 ns   (R²=0.998, 23684997 iterations in 154 samples)
sort:             3 ns   (R²=0.999, 23684997 iterations in 154 samples)

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

No runtime deps