17 unstable releases (4 breaking)

0.4.1 Nov 23, 2024
0.3.1 Jul 6, 2024
0.2.2 Mar 22, 2024
0.1.2 Dec 15, 2023
0.0.0-alpha.0 Jul 7, 2023

#44 in Compression

Download history 216/week @ 2024-09-27 159/week @ 2024-10-04 257/week @ 2024-10-11 208/week @ 2024-10-18 177/week @ 2024-10-25 365/week @ 2024-11-01 441/week @ 2024-11-08 374/week @ 2024-11-15 366/week @ 2024-11-22 247/week @ 2024-11-29 318/week @ 2024-12-06 155/week @ 2024-12-13 100/week @ 2024-12-20 94/week @ 2024-12-27 67/week @ 2025-01-03 124/week @ 2025-01-10

422 downloads per month
Used in 7 crates (6 directly)

Apache-2.0

345KB
9K SLoC

Pco logo: a pico-scale, compressed version of the Pyramid of Khafre in the palm of your hand

Pco (Pcodec) losslessly compresses and decompresses numerical sequences with high compression ratio and moderately fast speed.

Quick Start

use pco::standalone::{simpler_compress, simple_decompress};
use pco::DEFAULT_COMPRESSION_LEVEL;
use pco::errors::PcoResult;

fn main() -> PcoResult<()> {
  // your data
  let mut my_nums = Vec::new();
  for i in 0..100000 {
    my_nums.push(i as i64);
  }

  // compress
  let compressed: Vec<u8> = simpler_compress(&my_nums, DEFAULT_COMPRESSION_LEVEL)?;
  println!("compressed down to {} bytes", compressed.len());

  // decompress
  let recovered = simple_decompress::<i64>(&compressed)?;
  println!("got back {} ints from {} to {}", recovered.len(), recovered[0], recovered.last().unwrap());
  Ok(())
}

Compilation Notes

For best performance on x86_64, compile with any bmi* and avx* instruction sets your hardware supports. Almost all x86_64 hardware these days supports bmi1, bmi2, and avx2. This improves compression speed slightly and decompression speed substantially! To make sure you're using these, you can:

  • Add the following to your ~/.cargo/config.toml:
[target.'cfg(target_arch = "x86_64")']
rustflags = ["-C", "target-feature=+bmi1,+bmi2,+avx2"]
  • OR compile with RUSTFLAGS="-C target-feature=+bmi1,+bmi2,+avx2" cargo build --release ...

Note that settings target-cpu=native does not always have the same effect, since LLVM compiles for the lowest common denominator of instructions for a broad CPU family.

Dependencies

~370KB