#benchmark #bench #simple

no-std dev benchmark-simple

A tiny, super simple and portable benchmarking library

10 releases

0.1.9 Feb 9, 2024
0.1.8 May 23, 2023
0.1.7 Oct 20, 2021

#103 in WebAssembly

Download history 38/week @ 2023-12-22 17/week @ 2023-12-29 51/week @ 2024-01-05 48/week @ 2024-01-12 26/week @ 2024-01-19 26/week @ 2024-01-26 14/week @ 2024-02-02 58/week @ 2024-02-09 61/week @ 2024-02-16 62/week @ 2024-02-23 75/week @ 2024-03-01 60/week @ 2024-03-08 102/week @ 2024-03-15 49/week @ 2024-03-22 106/week @ 2024-03-29 34/week @ 2024-04-05

294 downloads per month
Used in 16 crates

MIT license

14KB
245 lines

benchmark-simple

A tiny benchmarking library for Rust.

  • Trivial to use
  • Works pretty much everywhere, including WebAssembly (WASI, but also in-browser)
use benchmark_simple::*;

fn test_function() {
    // ...
}

let bench = Bench::new();
let options = Options::default();
let res = bench.run(&options, || test_function());
println!("result: {}", res);

Throughput computation:

use benchmark_simple::*;

fn test_function(m: &mut [u8]) {
    // ...
}

let mut m = vec![0u8; 1_000_000];
let bench = Bench::new();
let options = Options::default();
let res = bench.run(&options, || test_function(&mut m));
let throughput = res.throughput(m.len() as _);
println!("throughput: {}", throughput);

Options:

pub struct Options {
    /// Number of iterations to perform.
    pub iterations: u64,
    /// Number of warm-up iterations to perform.
    pub warmup_iterations: u64,
    /// Minimum number of samples to collect.
    pub min_samples: usize,
    /// Maximum number of samples to collect.
    pub max_samples: usize,
    /// Maximum RSD to tolerate (in 0...100).
    pub max_rsd: f64,
    /// Maximum benchmark duration time.
    pub max_duration: Option<std::time::Duration>,
    /// Verbose output
    pub verbose: bool,
}

Benchmark results can be made verbose by setting verbose to true in the Options struct, or by defining a BENCHMARK_VERBOSE environment variable.

Dependencies

~16–385KB