use criterion::{criterion_group, criterion_main, Criterion}; use rln::prelude::*; use utils::ZerokitMerkleTree; pub fn pmtree_benchmark(c: &mut Criterion) { let mut tree = PmTree::default(2).unwrap(); let leaves: Vec = (0..4).map(Fr::from).collect(); c.bench_function("Pmtree::set", |b| { b.iter(|| { tree.set(0, leaves[0]).unwrap(); }) }); c.bench_function("Pmtree::delete", |b| { b.iter(|| { tree.delete(0).unwrap(); }) }); c.bench_function("Pmtree::override_range", |b| { b.iter(|| { tree.override_range(0, leaves.clone().into_iter(), [0, 1, 2, 3].into_iter()) .unwrap(); }) }); c.bench_function("Pmtree::get", |b| { b.iter(|| { tree.get(0).unwrap(); }) }); // check intermediate node getter which required additional computation of sub root index c.bench_function("Pmtree::get_subtree_root", |b| { b.iter(|| { tree.get_subtree_root(1, 0).unwrap(); }) }); c.bench_function("Pmtree::get_empty_leaves_indices", |b| { b.iter(|| { tree.get_empty_leaves_indices(); }) }); } criterion_group!(benches, pmtree_benchmark); criterion_main!(benches);