** Overview
Implementation of [[http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.62.7953&rep=rep1&type=pdf][Scalable Bloom Filters]] which also provides serde serialization and deserialize.
A bloom filter lets you =insert= items, and then test association with =contains=. It's space and time efficient, at the cost of false positives. In particular, if =contains= returns =true=, it may be in filter. But if =contains= returns false, it's definitely not in the bloom filter.
You can control the failure rate by setting =desirederrorprob= and =est_insertions= appropriately.
use serdejson; use growablebloom_filter::GrowableBloom;
let mut gbloom = GrowableBloom::new(0.05, 1000); gbloom.insert(&0); assert!(gbloom.contains(&0));
let s = serdejson::tostring(&gbloom).unwrap(); let desgbloom: GrowableBloom = serdejson::fromstr(&s).unwrap(); assert!(desgbloom.contains(&0));
** Applications
Bloom filters are typically used as a pre-cache to avoid expensive operations. For example, if you need to ask ten thousand servers if they have data XYZ, you could use GrowableBloom to figure out which ones do NOT have XYZ.