20 releases

Uses old Rust 2015

0.6.4 Sep 16, 2023
0.6.3 Feb 16, 2020
0.6.2 Jul 26, 2019
0.5.4 Jan 4, 2019
0.1.3 Jun 15, 2017

#115 in Data structures

Download history 6668/week @ 2024-09-11 6316/week @ 2024-09-18 6894/week @ 2024-09-25 6469/week @ 2024-10-02 6198/week @ 2024-10-09 5986/week @ 2024-10-16 6568/week @ 2024-10-23 6424/week @ 2024-10-30 5259/week @ 2024-11-06 5350/week @ 2024-11-13 6047/week @ 2024-11-20 5539/week @ 2024-11-27 4874/week @ 2024-12-04 6291/week @ 2024-12-11 3784/week @ 2024-12-18 2241/week @ 2024-12-25

18,181 downloads per month
Used in 183 crates (25 directly)

MIT/Apache

87KB
2K SLoC

hibitset

Build Status Crates.io

Provides hierarchical bit sets, which allow very fast iteration on sparse data structures.

Usage

Just add this to your Cargo.toml:

[dependencies]
hibitset = "0.6"

License

This library is licensed under the Apache License 2.0, see the LICENSE file for more information.


lib.rs:

hibitset

Provides hierarchical bit sets, which allow very fast iteration on sparse data structures.

What it does

A BitSet may be considered analogous to a HashSet<u32>. It tracks whether or not certain indices exist within it. Its implementation is very different, however.

At its root, a BitSet relies on an array of bits, which express whether or not indices exist. This provides the functionality to add( ) and remove( ) indices.

This array is referred to as Layer 0. Above it, there is another layer: Layer 1. Layer 1 acts as a 'summary' of Layer 0. It contains one bit for each usize bits of Layer 0. If any bit in that usize of Layer 0 is set, the bit in Layer 1 will be set.

There are, in total, four layers. Layers 1 through 3 are each a summary of the layer immediately below them.

Example, with an imaginary 4-bit usize:

Layer 3: 1------------------------------------------------ ...
Layer 2: 1------------------ 1------------------ 0-------- ...
Layer 1: 1--- 0--- 0--- 0--- 1--- 0--- 1--- 0--- 0--- 0--- ...
Layer 0: 0010 0000 0000 0000 0011 0000 1111 0000 0000 0000 ...

This method makes operations that operate over the whole BitSet, such as unions, intersections, and iteration, very fast (because if any bit in any summary layer is zero, an entire range of bits below it can be skipped.)

However, there is a maximum on index size. The top layer (Layer 3) of the BitSet is a single usize long. This makes the maximum index usize**4 (1,048,576 for a 32-bit usize, 16,777,216 for a 64-bit usize). Attempting to add indices larger than that will cause the BitSet to panic.

Dependencies

~0–265KB