NewPFD-rs
Rust library implementing the NewPFD integer compression/decompression algorithm. It's currently lacking optimization for speed, but it's decently fast:
- Encoding: 150ms/ 1M integers
- Decoding: 20ms/ 1M integers
See benchmarks for details.
Fibonacci encoding/decoding is up to speed with other rust implementations, e.g. fibonnaci_codec crate (which I took some code from):
- Fibonacci encoding: 182ms/ 1M integers (fibonnaci_codec: 170ms)
- Fibonacci encoding: 160ms/ 1M integers (fibonnaci_codec: 140ms)
Examples
For more examples, see the rust-docs.
// Encode some data using NewPFD
use ;
let data = vec!;
let blocksize = 32; // needs to be a mutliple of 32
// encode
let = encode;
// compressed_data is a `bitvec::BitVec` (similar to a Vec<bool>)
// decode
let = decode;
assert_eq!;
assert_eq!; // the entire bitstream was consumed