Skip to content

plenkl/xorfilter

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

60 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Rust library implementing xor filters

Implementation of Xor Filters: Faster and Smaller Than Bloom and Cuckoo Filters in rust-lang, Journal of Experimental Algorithmics (to appear).

This package is a port from its golang implementation.

How to use xorfilter in my rust project ?

Add the following under project's Cargo.toml:

[dependencies] xorfilter-rs = "0.2.0"

or

[dependencies] xorfilter-rs = { git = "https://github.com/bnclabs/xorfilter" }
use xorfilter::Xor8; let mut keys: Vec<u64> = vec![]; for _ in 0..num_keys { keys.push(rng.gen()); } let mut filter = Xor8::new(); // new filter. filter.populate_keys(&keys); // populate keys. filter.build(); // build bitmap. for key in 0..lookup { // there can be false positives, but no false negatives. filter.contains_key(key); }

Open issues

  • Serialize / Deserialize Xor8 type.
  • Incrementally adding keys to a pre-built Xor8 instance.

Benchmarks

Benchmark number for original golang implementation.

BenchmarkPopulate100000-32 2000 695796 ns/op BenchmarkContains100000-32 200000000 7.03 ns/op 

Benchmark number for this rust-lang implementation.

test bench_populate_100000 ... bench: 274,349 ns/iter (+/- 18,650) test bench_contains_100000 ... bench: 7 ns/iter (+/- 0) 

Measure of false-positive-rate and bits-per-entry in original golang implementation, using random set of keys.

bits per entry 9.864 false positive rate 0.3874 

Measure of false-positive-rate and bits-per-entry in this rust-lang implementation, using random set of keys.

bits per entry 9.864 bits false positive rate 0.3866% 

Resources

About

Rust library implementing xor-filters

Resources

License

Stars

Watchers

Forks

Packages

 
 
 

Contributors

Languages

  • Rust 99.2%
  • Makefile 0.8%