mirror of
https://github.com/0glabs/0g-storage-node.git
synced 2025-01-24 14:05:17 +00:00
169 lines
3.6 KiB
Rust
169 lines
3.6 KiB
Rust
|
//! cargo bench --features "crypto_bench" --verbose
|
||
|
#![cfg(feature = "crypto_bench")]
|
||
|
#![feature(test)]
|
||
|
#![feature(rand)]
|
||
|
|
||
|
mod hash512;
|
||
|
mod ringx;
|
||
|
|
||
|
extern crate merkle_light;
|
||
|
extern crate rand;
|
||
|
extern crate test;
|
||
|
|
||
|
use hash512::Hash512;
|
||
|
use merkle_light::hash::{Algorithm, Hashable};
|
||
|
use merkle_light::merkle::MerkleTree;
|
||
|
use rand::Rng;
|
||
|
use ringx::Context;
|
||
|
use ringx::SHA512;
|
||
|
use std::hash::Hasher;
|
||
|
use std::iter::FromIterator;
|
||
|
use test::Bencher;
|
||
|
|
||
|
#[derive(Clone)]
|
||
|
struct B(Context);
|
||
|
|
||
|
impl B {
|
||
|
fn new() -> B {
|
||
|
B(Context::new(&SHA512))
|
||
|
}
|
||
|
}
|
||
|
|
||
|
impl Default for B {
|
||
|
fn default() -> Self {
|
||
|
B::new()
|
||
|
}
|
||
|
}
|
||
|
|
||
|
impl Hasher for B {
|
||
|
#[inline]
|
||
|
fn write(&mut self, msg: &[u8]) {
|
||
|
self.0.update(msg)
|
||
|
}
|
||
|
|
||
|
#[inline]
|
||
|
fn finish(&self) -> u64 {
|
||
|
unimplemented!()
|
||
|
}
|
||
|
}
|
||
|
|
||
|
impl Algorithm<Hash512> for B {
|
||
|
#[inline]
|
||
|
fn hash(&mut self) -> Hash512 {
|
||
|
let mut h = [0u8; 64];
|
||
|
h.copy_from_slice(self.0.finish().as_ref());
|
||
|
Hash512(h)
|
||
|
}
|
||
|
|
||
|
#[inline]
|
||
|
fn reset(&mut self) {
|
||
|
self.0.reset();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
fn tree_5() -> Vec<Hash512> {
|
||
|
["one", "two", "three", "four"]
|
||
|
.iter()
|
||
|
.map(|x| {
|
||
|
let mut a = B::new();
|
||
|
Hashable::hash(x, &mut a);
|
||
|
a.hash()
|
||
|
})
|
||
|
.collect::<Vec<Hash512>>()
|
||
|
}
|
||
|
|
||
|
fn tree_160() -> Vec<Hash512> {
|
||
|
let mut values = vec![vec![0u8; 256]; 160];
|
||
|
let mut rng = rand::IsaacRng::new_unseeded();
|
||
|
|
||
|
for mut v in &mut values {
|
||
|
rng.fill_bytes(&mut v);
|
||
|
}
|
||
|
|
||
|
values
|
||
|
.iter()
|
||
|
.map(|x| {
|
||
|
let mut a = B::new();
|
||
|
a.write(x.as_ref());
|
||
|
a.hash()
|
||
|
})
|
||
|
.collect::<Vec<Hash512>>()
|
||
|
}
|
||
|
|
||
|
#[bench]
|
||
|
fn bench_ringx_sha512(b: &mut Bencher) {
|
||
|
b.iter(|| {
|
||
|
let mut x = Context::new(&SHA512);
|
||
|
x.update("12345".as_ref());
|
||
|
x.finish();
|
||
|
});
|
||
|
}
|
||
|
|
||
|
#[bench]
|
||
|
fn bench_ringx_sha512_from_data_5(b: &mut Bencher) {
|
||
|
let values = tree_5();
|
||
|
b.iter(|| MerkleTree::<Hash512, B>::from_iter(values.clone()));
|
||
|
}
|
||
|
|
||
|
#[bench]
|
||
|
fn bench_ringx_sha512_from_data_5_proof(b: &mut Bencher) {
|
||
|
let values = tree_5();
|
||
|
let tree: MerkleTree<Hash512, B> = MerkleTree::from_iter(values.clone());
|
||
|
|
||
|
b.iter(|| {
|
||
|
for i in 0..values.len() {
|
||
|
let proof = tree.gen_proof(i);
|
||
|
test::black_box(proof);
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
|
||
|
#[bench]
|
||
|
fn bench_ringx_sha512_from_data_5_proof_check(b: &mut Bencher) {
|
||
|
let values = tree_5();
|
||
|
let tree: MerkleTree<Hash512, B> = MerkleTree::from_iter(values.clone());
|
||
|
let proofs = (0..values.len())
|
||
|
.map(|i| tree.gen_proof(i))
|
||
|
.collect::<Vec<_>>();
|
||
|
|
||
|
b.iter(|| {
|
||
|
for proof in &proofs {
|
||
|
test::black_box(proof.validate::<B>());
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
|
||
|
#[bench]
|
||
|
fn bench_ringx_sha512_from_data_160(b: &mut Bencher) {
|
||
|
let values = tree_160();
|
||
|
b.iter(|| MerkleTree::<Hash512, B>::from_iter(values.clone()));
|
||
|
}
|
||
|
|
||
|
#[bench]
|
||
|
fn bench_ringx_sha512_from_data_160_proof(b: &mut Bencher) {
|
||
|
let values = tree_160();
|
||
|
let tree: MerkleTree<Hash512, B> = MerkleTree::from_iter(values.clone());
|
||
|
|
||
|
b.iter(|| {
|
||
|
for i in 0..values.len() {
|
||
|
let proof = tree.gen_proof(i);
|
||
|
test::black_box(proof);
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
|
||
|
#[bench]
|
||
|
fn bench_ringx_sha512_from_data_160_proof_check(b: &mut Bencher) {
|
||
|
let values = tree_160();
|
||
|
let tree: MerkleTree<Hash512, B> = MerkleTree::from_iter(values.clone());
|
||
|
let proofs = (0..values.len())
|
||
|
.map(|i| tree.gen_proof(i))
|
||
|
.collect::<Vec<_>>();
|
||
|
|
||
|
b.iter(|| {
|
||
|
for proof in &proofs {
|
||
|
test::black_box(proof.validate::<B>());
|
||
|
}
|
||
|
});
|
||
|
}
|