packed-integers

Crates.iopacked-integers
lib.rspacked-integers
version0.2.0
sourcesrc
created_at2020-11-05 10:58:11.132193
updated_at2023-09-04 07:34:26.163461
descriptionA growable array for integer types in the range `u1` to `u31`.
homepage
repositoryhttps://github.com/adrianwong/packed-integers
max_upload_size
id308855
size38,282
Adrian Wong (adrianwong)

documentation

README

packed-integers

packed_integers provides a growable array for integer types in the range u1 to u31.

Use case

Assume you have a sequence of unsigned integers in the range [0, 100000] that you would like to hold in memory. That range of values can be represented using 17 bits per integer, since 217 - 1 = 131071. As Rust has no u17 type, you would typically store these values in a u32 array, wasting 15 bits per integer.

packed-integers helps alleviate this issue by packing these integers at the bit level, essentially trading time for space.

API

Where possible, packed-integers mimics the API for Rust's Vec in order to provide a set of methods you're probably already familiar with.

Inspiration / Resources

Commit count: 41

cargo fmt