mirror of
https://github.com/vacp2p/zerokit.git
synced 2025-01-10 22:36:17 +00:00
d3d85c3e3c
* add function for empty leaves * fix from linter * fix rebase * update test in utils * fix * fix(trees): inconsistencies in override_range (#250) * fix tests --------- Co-authored-by: Aaryamann Challani <43716372+rymnc@users.noreply.github.com>
57 lines
1.4 KiB
Rust
57 lines
1.4 KiB
Rust
use criterion::{criterion_group, criterion_main, Criterion};
|
|
use rln::{circuit::Fr, pm_tree_adapter::PmTree};
|
|
use utils::ZerokitMerkleTree;
|
|
|
|
pub fn pmtree_benchmark(c: &mut Criterion) {
|
|
let mut tree = PmTree::default(2).unwrap();
|
|
|
|
let leaves: Vec<Fr> = (0..4).map(|s| Fr::from(s)).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(), [0, 1, 2, 3])
|
|
.unwrap();
|
|
})
|
|
});
|
|
|
|
c.bench_function("Pmtree::compute_root", |b| {
|
|
b.iter(|| {
|
|
tree.compute_root().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);
|