#numbers #benchmark #parameters #generator #experiment #results #guacamole

dev bin+lib statslicer

Guacamole provides a linearly-seekable random number generator

7 releases (breaking)

0.7.0 Dec 4, 2024
0.6.0 Oct 8, 2024
0.5.0 Sep 17, 2024
0.4.0 Aug 19, 2024
0.1.0 Jan 15, 2024

#105 in Profiling

Download history 117/week @ 2024-09-11 71/week @ 2024-09-18 19/week @ 2024-09-25 106/week @ 2024-10-02 84/week @ 2024-10-09 6/week @ 2024-10-16 3/week @ 2024-10-23 1/week @ 2024-10-30 2/week @ 2024-11-06 2/week @ 2024-11-13 5/week @ 2024-11-20 142/week @ 2024-12-04 20/week @ 2024-12-11

162 downloads per month
Used in 4 crates

Apache-2.0

110KB
2K SLoC

statslicer

Statslicer is a platform for running experiments and collecting their results.

use guacamole::combinators::*;
use guacamole::Guacamole;

use statslicer::{benchmark, black_box, statslicer_main, Bencher, Parameter, Parameters};

#[derive(Debug, Default, Eq, PartialEq)]
struct MyParameters {
    elements: usize,
}

impl Parameters for MyParameters {
    fn params(&self) -> Vec<(&'static str, Parameter)> {
        vec![
            ("elements", Parameter::Integer(self.elements as u64)),
        ]
    }
}

fn bench_sort(params: &MyParameters, b: &mut Bencher) {
    let mut guac = Guacamole::new(b.seed());
    let array = to_vec(constant(params.elements), any::<u64>)(&mut guac);
    let bin_searches = to_vec(constant(b.size()), any::<u64>)(&mut guac);
    b.run(|| {
        for needle in bin_searches.iter() {
            let _ = black_box(array.binary_search(needle));
        }
    });
}

benchmark! {
    name = my_sort_benchmark;
    MyParameters {
        elements in [0, 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024],
    }
    bench_sort
}

statslicer_main! { my_sort_benchmark }

Status

Experimental. Likely to change in the near future.

Scope

This library provides the statslicer benchmark tools and a binary to derive data and colate histograms.

Warts

Documentation

The latest documentation is always available at docs.rs.

Dependencies

~3MB
~58K SLoC