2020-09-09 08:28:17 -07:00
|
|
|
#![feature(test)]
|
|
|
|
|
|
|
|
extern crate test;
|
|
|
|
|
2021-05-26 08:15:46 -07:00
|
|
|
use {
|
|
|
|
rand::{thread_rng, Rng},
|
|
|
|
rayon::ThreadPoolBuilder,
|
|
|
|
solana_gossip::{
|
|
|
|
cluster_info::MAX_BLOOM_SIZE,
|
|
|
|
crds::Crds,
|
|
|
|
crds_gossip_pull::{CrdsFilter, CrdsGossipPull},
|
|
|
|
crds_value::CrdsValue,
|
|
|
|
},
|
|
|
|
solana_sdk::hash,
|
|
|
|
test::Bencher,
|
|
|
|
};
|
2020-09-09 08:28:17 -07:00
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn bench_hash_as_u64(bencher: &mut Bencher) {
|
|
|
|
let mut rng = thread_rng();
|
2020-10-19 12:23:14 -07:00
|
|
|
let hashes: Vec<_> = std::iter::repeat_with(|| hash::new_rand(&mut rng))
|
2020-09-29 16:06:02 -07:00
|
|
|
.take(1000)
|
2020-09-09 08:28:17 -07:00
|
|
|
.collect();
|
|
|
|
bencher.iter(|| {
|
|
|
|
hashes
|
|
|
|
.iter()
|
|
|
|
.map(CrdsFilter::hash_as_u64)
|
|
|
|
.collect::<Vec<_>>()
|
|
|
|
});
|
|
|
|
}
|
2020-09-29 16:06:02 -07:00
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn bench_build_crds_filters(bencher: &mut Bencher) {
|
|
|
|
let thread_pool = ThreadPoolBuilder::new().build().unwrap();
|
|
|
|
let mut rng = thread_rng();
|
2021-05-24 06:47:21 -07:00
|
|
|
let crds_gossip_pull = CrdsGossipPull::default();
|
2020-09-29 16:06:02 -07:00
|
|
|
let mut crds = Crds::default();
|
|
|
|
let mut num_inserts = 0;
|
|
|
|
for _ in 0..90_000 {
|
|
|
|
if crds
|
2020-11-15 08:38:04 -08:00
|
|
|
.insert(CrdsValue::new_rand(&mut rng, None), rng.gen())
|
2020-09-29 16:06:02 -07:00
|
|
|
.is_ok()
|
|
|
|
{
|
|
|
|
num_inserts += 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
assert_eq!(num_inserts, 90_000);
|
|
|
|
bencher.iter(|| {
|
|
|
|
let filters = crds_gossip_pull.build_crds_filters(&thread_pool, &crds, MAX_BLOOM_SIZE);
|
|
|
|
assert_eq!(filters.len(), 128);
|
|
|
|
});
|
|
|
|
}
|