2019-01-17 18:22:21 -08:00
|
|
|
#![feature(test)]
|
|
|
|
|
|
|
|
extern crate test;
|
|
|
|
use bv::BitVec;
|
|
|
|
use fnv::FnvHasher;
|
|
|
|
use solana::bloom::{Bloom, BloomHashIndex};
|
|
|
|
use solana_sdk::hash::{hash, Hash};
|
|
|
|
use solana_sdk::signature::Signature;
|
|
|
|
//use std::collections::HashSet;
|
|
|
|
use hashbrown::HashSet;
|
|
|
|
use std::hash::Hasher;
|
|
|
|
use test::Bencher;
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
#[ignore]
|
|
|
|
fn bench_bits_set(bencher: &mut Bencher) {
|
|
|
|
let mut bits: BitVec<u8> = BitVec::new_fill(false, 38_340_234 as u64);
|
2019-02-09 09:20:43 -08:00
|
|
|
let mut hasher = FnvHasher::default();
|
2019-01-17 18:22:21 -08:00
|
|
|
|
|
|
|
bencher.iter(|| {
|
|
|
|
let idx = hasher.finish() % bits.len();
|
|
|
|
bits.set(idx, true);
|
|
|
|
hasher.write_u64(idx);
|
|
|
|
});
|
|
|
|
// subtract the next bencher result from this one to get a number for raw
|
|
|
|
// bits.set()
|
|
|
|
}
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
#[ignore]
|
|
|
|
fn bench_bits_set_hasher(bencher: &mut Bencher) {
|
|
|
|
let bits: BitVec<u8> = BitVec::new_fill(false, 38_340_234 as u64);
|
2019-02-09 09:20:43 -08:00
|
|
|
let mut hasher = FnvHasher::default();
|
2019-01-17 18:22:21 -08:00
|
|
|
|
|
|
|
bencher.iter(|| {
|
|
|
|
let idx = hasher.finish() % bits.len();
|
|
|
|
hasher.write_u64(idx);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
#[ignore]
|
|
|
|
fn bench_sigs_bloom(bencher: &mut Bencher) {
|
|
|
|
// 1M TPS * 1s (length of block in sigs) == 1M items in filter
|
|
|
|
// 1.0E-8 false positive rate
|
|
|
|
// https://hur.st/bloomfilter/?n=1000000&p=1.0E-8&m=&k=
|
|
|
|
let last_id = hash(Hash::default().as_ref());
|
|
|
|
// eprintln!("last_id = {:?}", last_id);
|
|
|
|
let keys = (0..27)
|
|
|
|
.into_iter()
|
|
|
|
.map(|i| last_id.hash_at_index(i))
|
|
|
|
.collect();
|
|
|
|
let mut sigs: Bloom<Signature> = Bloom::new(38_340_234, keys);
|
|
|
|
|
|
|
|
let mut id = last_id;
|
|
|
|
let mut falses = 0;
|
|
|
|
let mut iterations = 0;
|
|
|
|
bencher.iter(|| {
|
|
|
|
id = hash(id.as_ref());
|
|
|
|
let mut sigbytes = Vec::from(id.as_ref());
|
|
|
|
id = hash(id.as_ref());
|
|
|
|
sigbytes.extend(id.as_ref());
|
|
|
|
|
|
|
|
let sig = Signature::new(&sigbytes);
|
|
|
|
if sigs.contains(&sig) {
|
|
|
|
falses += 1;
|
|
|
|
}
|
|
|
|
sigs.add(&sig);
|
|
|
|
sigs.contains(&sig);
|
|
|
|
iterations += 1;
|
|
|
|
});
|
|
|
|
assert_eq!(falses, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
#[ignore]
|
|
|
|
fn bench_sigs_hashmap(bencher: &mut Bencher) {
|
|
|
|
// same structure as above, new
|
|
|
|
let last_id = hash(Hash::default().as_ref());
|
|
|
|
// eprintln!("last_id = {:?}", last_id);
|
|
|
|
let mut sigs: HashSet<Signature> = HashSet::new();
|
|
|
|
|
|
|
|
let mut id = last_id;
|
|
|
|
let mut falses = 0;
|
|
|
|
let mut iterations = 0;
|
|
|
|
bencher.iter(|| {
|
|
|
|
id = hash(id.as_ref());
|
|
|
|
let mut sigbytes = Vec::from(id.as_ref());
|
|
|
|
id = hash(id.as_ref());
|
|
|
|
sigbytes.extend(id.as_ref());
|
|
|
|
|
|
|
|
let sig = Signature::new(&sigbytes);
|
|
|
|
if sigs.contains(&sig) {
|
|
|
|
falses += 1;
|
|
|
|
}
|
|
|
|
sigs.insert(sig);
|
|
|
|
sigs.contains(&sig);
|
|
|
|
iterations += 1;
|
|
|
|
});
|
|
|
|
assert_eq!(falses, 0);
|
|
|
|
}
|