fid-rs

High performance FID (Fully Indexable Dictionary) library.

Master API Docs | Released API Docs | Benchmark Results | Changelog

Build Status Crates.io Minimum rustc version License: MIT License: Apache 2.0

Quickstart

To use fid-rs, add the following to your Cargo.toml file:

toml [dependencies] fid_rs = "0.1"

Usage Overview

```rust use fid_rs::Fid;

let fid = Fid::from("01001"); // Tips: Fid::from::<&str>() ignores ''.

// Basic operations --------------------- asserteq!(fid[0], false); // [0]1001; 0th bit is '0' (false) asserteq!(fid[1], true); // 0[1]001; 1st bit is '1' (true) assert_eq!(fid[4], true); // 0100[1]; 4th bit is '1' (true)

asserteq!(fid.rank(0), 0); // [0]1001; Range [0, 0] has no '1' asserteq!(fid.rank(3), 1); // [0100]1; Range [0, 3] has 1 '1' assert_eq!(fid.rank(4), 2); // [01001]; Range [0, 4] has 2 '1's

asserteq!(fid.select(0), Some(0)); // []01001; Minimum i where range [0, i] has 0 '1's is i=0 asserteq!(fid.select(1), Some(1)); // 0[1]001; Minimum i where range [0, i] has 1 '1's is i=1 asserteq!(fid.select(2), Some(4)); // 0100[1]; Minimum i where range [0, i] has 2 '1's is i=4 asserteq!(fid.select(3), None); // There is no i where range [0, i] has 3 '1's

// rank0, select0 ----------------------- asserteq!(fid.rank0(0), 1); // [0]1001; Range [0, 0] has no '0' asserteq!(fid.rank0(3), 3); // [0100]1; Range [0, 3] has 3 '0's assert_eq!(fid.rank0(4), 3); // [01001]; Range [0, 4] has 3 '0's

asserteq!(fid.select0(0), Some(0)); // []01001; Minimum i where range [0, i] has 0 '0's is i=0 asserteq!(fid.select0(1), Some(0)); // [0]1001; Minimum i where range [0, i] has 1 '0's is i=0 asserteq!(fid.select0(2), Some(2)); // 01[0]01; Minimum i where range [0, i] has 2 '0's is i=2 asserteq!(fid.select0(4), None); // There is no i where range [0, i] has 4 '0's ```

Constructors

```rust use fid_rs::Fid;

// Most human-friendly way: Fid::from::<&str>() let fid = Fid::from("0100_1");

// Complex construction in simple way: Fid::from::<&[bool]>() let mut arr = [false; 5]; arr[1] = true; arr[4] = true; let fid = Fid::from(&arr[..]); ```

Iterator

```rust use fid_rs::Fid;

let fid = Fid::from("0100_1");

for bit in fid.iter() { println!("{}", bit); } // => // false // true // false // false // true ```

Utility Methods

```rust use fid_rs::Fid;

let fid = Fid::from("0100_1");

assert_eq!(fid.len(), 5); ```

Features

Complexity

When the length of a Fid is N:

| Operation | Time-complexity | Space-complexity | |-----------|-----------------|------------------| | Fid::from::<&str>() | O(N) | N + o(N) | | Fid::from::<&[bool]>() | O(N) | N + o(N) | | Index<u64> | O(1) | 0 | | Fid::rank() | O(1) | O(1) | | Fid::rank0() | O(1) | O(1) | | Fid::select() | O(log N) | O(1) | | Fid::select0() | O(log N) | O(1) |

(Actually, select()'s time-complexity can be O(1) with complex implementation but fid-rs, like many other libraries, uses binary search of rank()'s result).

Versions

fid-rs uses semantic versioning.

Since current major version is 0, minor version update might involve breaking public API change (although it is carefully avoided).

Rust Version Supports

fid-rs is continuously tested with these Rust versions in Travis CI:

So it expectedly works with Rust 1.33.0 and any newer versions.

Older versions may also work, but are not tested or guaranteed.

Contributing

Any kind of pull requests are appreciated.

Guidelines

License

MIT OR Apache-2.0