pub struct RankSelect<CC = Vec<u64>, VC = Vec<u64>, WC = u64> {
    pub counts: CC,
    pub values: Bools<VC, WC>,
}Expand description
A store for maintaining Vec<bool> with fast rank and select access.
The design is to have u64 running counts for each block of 1024 bits,
which are roughly the size of a cache line. This is roughly 6% overhead,
above the bits themselves, which seems pretty solid.
Fields§
§counts: CCCounts of the number of cumulative set (true) bits, after each block of 1024 bits.
values: Bools<VC, WC>The bits themselves.
Implementations§
Source§impl<CC: PushIndexAs<u64>, VC: PushIndexAs<u64>> RankSelect<CC, VC>
 
impl<CC: PushIndexAs<u64>, VC: PushIndexAs<u64>> RankSelect<CC, VC>
Source§impl<CC: Len + IndexAs<u64>, VC: Len + IndexAs<u64>, WC: CopyAs<u64>> RankSelect<CC, VC, WC>
 
impl<CC: Len + IndexAs<u64>, VC: Len + IndexAs<u64>, WC: CopyAs<u64>> RankSelect<CC, VC, WC>
Sourcepub fn rank(&self, index: usize) -> usize
 
pub fn rank(&self, index: usize) -> usize
The number of set bits strictly preceding index.
This number is accumulated first by reading out of self.counts at the correct position,
then by summing the ones in strictly prior u64 entries, then by counting the ones in the
masked u64 in which the bit lives.
Trait Implementations§
Source§impl<CC: Clone, VC: Clone, WC: Clone> Clone for RankSelect<CC, VC, WC>
 
impl<CC: Clone, VC: Clone, WC: Clone> Clone for RankSelect<CC, VC, WC>
Source§fn clone(&self) -> RankSelect<CC, VC, WC>
 
fn clone(&self) -> RankSelect<CC, VC, WC>
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
 
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from 
source. Read moreSource§impl<CC: Default, VC: Default, WC: Default> Default for RankSelect<CC, VC, WC>
 
impl<CC: Default, VC: Default, WC: Default> Default for RankSelect<CC, VC, WC>
Source§fn default() -> RankSelect<CC, VC, WC>
 
fn default() -> RankSelect<CC, VC, WC>
Returns the “default value” for a type. Read more
impl<CC: Copy, VC: Copy, WC: Copy> Copy for RankSelect<CC, VC, WC>
impl<CC, VC, WC> StructuralPartialEq for RankSelect<CC, VC, WC>
Auto Trait Implementations§
impl<CC, VC, WC> Freeze for RankSelect<CC, VC, WC>
impl<CC, VC, WC> RefUnwindSafe for RankSelect<CC, VC, WC>
impl<CC, VC, WC> Send for RankSelect<CC, VC, WC>
impl<CC, VC, WC> Sync for RankSelect<CC, VC, WC>
impl<CC, VC, WC> Unpin for RankSelect<CC, VC, WC>
impl<CC, VC, WC> UnwindSafe for RankSelect<CC, VC, WC>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more