mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-05-30 22:11:02 +00:00
Move hashing benches to Criterion. (#2487)
This commit is contained in:
@@ -12,48 +12,62 @@
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
// TODO: Move benchmark to criterion #2354
|
||||
#![feature(test)]
|
||||
|
||||
extern crate test;
|
||||
use hex_literal::hex;
|
||||
#[macro_use]
|
||||
extern crate criterion;
|
||||
|
||||
use criterion::{Criterion, black_box, Bencher, Fun};
|
||||
use std::time::Duration;
|
||||
use substrate_primitives::hashing::{twox_128, blake2_128};
|
||||
|
||||
const MAX_KEY_SIZE: u32 = 32;
|
||||
|
||||
fn data_set() -> Vec<Vec<u8>> {
|
||||
fn get_key(key_size: u32) -> Vec<u8> {
|
||||
use rand::SeedableRng;
|
||||
use rand::Rng;
|
||||
|
||||
let rnd: [u8; 32] = rand::rngs::StdRng::seed_from_u64(12).gen();
|
||||
let mut rnd = rnd.iter().cycle();
|
||||
let mut res = Vec::new();
|
||||
for size in 1..=MAX_KEY_SIZE {
|
||||
for _ in 0..1_000 {
|
||||
let value = (0..size)
|
||||
.map(|_| rnd.next().unwrap().clone())
|
||||
.collect();
|
||||
res.push(value);
|
||||
}
|
||||
}
|
||||
res
|
||||
|
||||
(0..key_size)
|
||||
.map(|_| rnd.next().unwrap().clone())
|
||||
.collect()
|
||||
}
|
||||
|
||||
fn bench_hash_128(b: &mut test::Bencher, f: &Fn(&[u8]) -> [u8; 16]) {
|
||||
let data_set = data_set();
|
||||
fn bench_blake2_128(b: &mut Bencher, key: &Vec<u8>) {
|
||||
b.iter(|| {
|
||||
for data in &data_set {
|
||||
let _a = f(data);
|
||||
}
|
||||
let _a = blake2_128(black_box(key));
|
||||
});
|
||||
}
|
||||
|
||||
#[bench]
|
||||
fn bench_blake2_128(b: &mut test::Bencher) {
|
||||
bench_hash_128(b, &blake2_128);
|
||||
fn bench_twox_128(b: &mut Bencher, key: &Vec<u8>) {
|
||||
b.iter(|| {
|
||||
let _a = twox_128(black_box(key));
|
||||
});
|
||||
}
|
||||
|
||||
#[bench]
|
||||
fn bench_twox_128(b: &mut test::Bencher) {
|
||||
bench_hash_128(b, &twox_128);
|
||||
fn bench_hash_128_fix_size(c: &mut Criterion) {
|
||||
let key = get_key(MAX_KEY_SIZE);
|
||||
let blake_fn = Fun::new("blake2_128", bench_blake2_128);
|
||||
let twox_fn = Fun::new("twox_128", bench_twox_128);
|
||||
let fns = vec![blake_fn, twox_fn];
|
||||
|
||||
c.bench_functions("fixed size hashing", fns, key);
|
||||
}
|
||||
|
||||
fn bench_hash_128_dyn_size(c: &mut Criterion) {
|
||||
let mut keys = Vec::new();
|
||||
for i in (2..MAX_KEY_SIZE).step_by(4) {
|
||||
keys.push(get_key(i).clone())
|
||||
}
|
||||
|
||||
c.bench_function_over_inputs("dyn size hashing - blake2", |b, key| bench_blake2_128(b, &key), keys.clone());
|
||||
c.bench_function_over_inputs("dyn size hashing - twox", |b, key| bench_twox_128(b, &key), keys);
|
||||
}
|
||||
|
||||
criterion_group!{
|
||||
name = benches;
|
||||
config = Criterion::default().warm_up_time(Duration::from_millis(500)).without_plots();
|
||||
targets = bench_hash_128_fix_size, bench_hash_128_dyn_size
|
||||
}
|
||||
criterion_main!(benches);
|
||||
|
||||
Reference in New Issue
Block a user