Expand description
§This crate is deprecated
This crate can be replaced with vob if you add this trait to your code:
// u32 is slightly faster for random access w/o any bit operations
pub(crate) type VobU32 = vob::Vob<u32>;
pub(crate) trait GrowingVob {
/// Will create a new Vob and fill it with `default`
fn fill(initial_size: usize, default:bool) -> VobU32;
/// Grow to fit new size, set ´bit´ to ´state´ value
fn set_grow(&mut self, bit: usize, state: bool) -> bool;
/// get() with default value `false`
fn get_f(&self, bit: usize) -> bool;
}
impl GrowingVob for VobU32 {
#[inline]
fn fill(initial_size: usize, default:bool) -> Self {
let mut v = Self::new_with_storage_type(0);
v.resize(initial_size, default);
v
}
#[inline]
fn set_grow(&mut self, bit: usize, state: bool) -> bool {
if bit >= self.len() {
self.resize(bit + 64, false);
}
self.set(bit, state)
}
#[inline]
fn get_f(&self, bit: usize) -> bool {
self.get(bit).unwrap_or(false)
}
}
§Yabf
Just what the world needed - yet another bit field struct.
This is a small and simple implementation. It only has the basic functionality of a bit field:
- Set arbitary bit (if you set the millionth bit the list will use at least 125KB of heap space)
- Get bit value
- An iterator over the set bit indices. O(size of container)
- The container never shrinks.
The bits are stored in plain (non-sparse) arrays/vectors.
use yabf::Yabf;
let mut a = Yabf::default();
let mut b = Yabf::with_capacity(12345);
a.set_bit(45,true);
b.set_bit(12345,true);
assert!(!a.bit(12345));
assert!(a.bit(45));
assert!(b.bit(12345));
# #[cfg(feature = "smallvec")] {
use yabf::SmallYabf;
let mut a = SmallYabf::default();
let mut b = SmallYabf::with_capacity(12345);
a.set_bit(45,true);
b.set_bit(12345,true);
assert!(!a.bit(12345));
assert!(a.bit(45));
assert!(b.bit(12345));
# }
Structs§
- Small
Yabf - Yet another bit field implementation. This is a simple, small and hopefully efficient bit field implementation. It uses SmallVec as an internal container. The first 128 bits will be stored on the stack.
- Small
Yabf Iterator - Iterator over the bits set to true in the bit field container. Will iterate over the bits from lowest to to highest. This is a relatively expensive O(size of container) operation.
- Yabf
- Yet another bit field implementation. This is a simple, small and hopefully efficient bit field implementation.
- Yabf
Iterator - Iterator over the bits set to true in the bit field container. Will iterate over the bits from lowest to to highest. This is a relatively expensive O(size of container) operation.