use commonware_cryptography::{sha256, Sha256};
use commonware_math::algebra::Random as _;
use commonware_storage::bmt::Builder;
use criterion::{criterion_group, Criterion};
use rand::{rngs::StdRng, SeedableRng};
fn bench_new(c: &mut Criterion) {
for n in [100, 1_000, 5_000, 10_000, 25_000, 50_000, 100_000] {
let mut elements = Vec::with_capacity(n);
let mut sampler = StdRng::seed_from_u64(0);
for _ in 0..n {
let element = sha256::Digest::random(&mut sampler);
elements.push(element);
}
c.bench_function(&format!("{}/n={}", module_path!(), n), |b| {
b.iter(|| {
let mut builder = Builder::<Sha256>::new(elements.len());
for element in &elements {
builder.add(element);
}
builder.build();
})
});
}
}
criterion_group! {
name = benches;
config = Criterion::default().sample_size(10);
targets = bench_new
}