6 releases

Uses old Rust 2015

0.1.5 Nov 29, 2019
0.1.4 Nov 20, 2019
0.1.1 Aug 18, 2016

#847 in Data structures

Download history 401/week @ 2024-07-23 526/week @ 2024-07-30 435/week @ 2024-08-06 427/week @ 2024-08-13 603/week @ 2024-08-20 320/week @ 2024-08-27 313/week @ 2024-09-03 667/week @ 2024-09-10 493/week @ 2024-09-17 408/week @ 2024-09-24 385/week @ 2024-10-01 607/week @ 2024-10-08 580/week @ 2024-10-15 763/week @ 2024-10-22 378/week @ 2024-10-29 442/week @ 2024-11-05

2,238 downloads per month
Used in 9 crates (3 directly)

MIT license

39KB
960 lines

bitvector, a simple bitvector implementation in Rust-lang

This crate is a modification of librustc_data_structures/bitvec.rs for set operator support.

Documentation

Visit the online documentation or run

cargo doc

to generate a local copy.

How to use

Add the following line to [dependencies] in your Cargo.toml file:

bitvector = 0.1

Then you can use the BitVector:

extern crate bitvector;
use bitvector::*;

fn main() {
    let mut test_vec = BitVector::new(50);
    for i in vec![0,1,3,5,7,11,13,17,19,23] { test_vec.insert(i); }

    let mut test_vec2 = BitVector::new(50);
    for i in vec![3,5,9,13,19,40,45] { test_vec2.insert(i); }

    // union of test_vec and test_vec2
    // other possible operators: intersection, difference
    let union = test_vec.union(&test_vec2);


    assert!(union.contains(3));
    assert!(union.contains(5));
    assert!(union.contains(13));
    assert!(union.contains(19));
    assert!(union.contains(9));
    assert!(union.contains(40));

    // all the operators also have `*_inplace` variants
    // which directly modify `self` to avoid extra memory operations.
    test_vec.union_inplace(&test_vec2);

    assert!(test_vec.contains(3));
    assert!(test_vec.contains(5));
    assert!(test_vec.contains(13));
    assert!(test_vec.contains(19));
    assert!(test_vec.contains(0));
    assert!(test_vec.contains(9));
    assert!(test_vec.contains(40));
}

Performance Comparison against std/collections/Set

test bench::bench_bitset_operator         ... bench:         222 ns/iter (+/- 22)
test bench::bench_bitset_operator_inplace ... bench:         122 ns/iter (+/- 5)
test bench::bench_btreeset_operator       ... bench:       1,675 ns/iter (+/- 115)
test bench::bench_hashset_operator        ... bench:       1,748 ns/iter (+/- 37)

LICENSE

MIT

No runtime deps