6 releases

0.2.1 May 24, 2024
0.2.0 Jun 9, 2023
0.1.3 Jun 12, 2020
0.1.2 Jul 30, 2018
0.1.1 May 9, 2018

#98 in Compression

Download history 479/week @ 2024-08-19 188/week @ 2024-08-26 191/week @ 2024-09-02 289/week @ 2024-09-09 405/week @ 2024-09-16 937/week @ 2024-09-23 332/week @ 2024-09-30 702/week @ 2024-10-07 371/week @ 2024-10-14 636/week @ 2024-10-21 644/week @ 2024-10-28 597/week @ 2024-11-04 554/week @ 2024-11-11 425/week @ 2024-11-18 686/week @ 2024-11-25 1017/week @ 2024-12-02

2,685 downloads per month
Used in seripack

MIT license

41KB
405 lines

Blosc

Rust bindings for the C-Blosc compression library.

Build Status

The blosc crate provides Rusty bindings for C-Blosc, a compression library for binary data, especially numeric arrays.

Usage

# Cargo.toml
[dependencies]
blosc = "0.1"
extern crate blosc;

fn main() {
    let data: Vec<u32> = vec![1, 1, 2, 5, 8, 13, 21, 34, 55, 89, 144];
    let ctx = blosc::Context::new();
    let compressed = ctx.compress(&data[..]);
    let decompressed = decompress(&compressed).unwrap();
    assert_eq!(data, decompressed);
}

License

blosc is distributed under the MIT license. See LICENSE-MIT for details.


lib.rs:

Rust bindings for the C-Blosc block-oriented compression library.

Blosc is a high performance compressor optimized for binary data. It is especially good at compressing arrays of similar data. For example, floats that fit a particular statistical distribution, integers from a restricted range, or pointers that all share the same alignment. It also works well on arrays of Structs with similar content.

Unlike most other compression libraries, Blosc is block-oriented, rather than stream-oriented. This works well when the entire dataset to be compressed/decompressed is available at once.

Example

let data: Vec<u32> = vec![1, 1, 2, 5, 8, 13, 21, 34, 55, 89, 144];
let ctx = Context::new();
let compressed = ctx.compress(&data[..]);
let decompressed = decompress(&compressed).unwrap();
assert_eq!(data, decompressed);

Dependencies

~240–740KB
~17K SLoC