pub enum PostingFormat {
Bitpacked,
SimdBp128,
EliasFano,
PartitionedEF,
Roaring,
}Expand description
Posting list format selector
Variants§
Bitpacked
Standard bitpacked format (default for small lists)
SimdBp128
SIMD-BP128 with vertical layout (medium lists, fast decoding)
EliasFano
Elias-Fano for long posting lists
PartitionedEF
Partitioned Elias-Fano (very long lists, better compression)
Roaring
Roaring bitmap for very frequent terms
Implementations§
Source§impl PostingFormat
impl PostingFormat
Sourcepub fn select(doc_count: usize, total_docs: usize) -> Self
pub fn select(doc_count: usize, total_docs: usize) -> Self
Select optimal format based on posting list characteristics
Simplified format selection (based on benchmarks):
- Very frequent (>1% of corpus, >20K docs): Roaring (fastest iteration, set ops)
- Large (≥20K docs): Partitioned EF (best compression 15.9%)
- All other lists: SIMD-BP128 (fastest decoding 198K ints/μs, optimal compression 16.3%)
Note: SIMD-BP128 replaces both Bitpacked and plain Elias-Fano as it has:
- Same compression as Bitpacked (16.3%)
- Faster decoding than Bitpacked (198K vs 192K ints/μs)
- Much faster than Elias-Fano (198K vs 9.6K ints/μs)
Trait Implementations§
Source§impl Clone for PostingFormat
impl Clone for PostingFormat
Source§fn clone(&self) -> PostingFormat
fn clone(&self) -> PostingFormat
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 Debug for PostingFormat
impl Debug for PostingFormat
Source§impl PartialEq for PostingFormat
impl PartialEq for PostingFormat
impl Copy for PostingFormat
impl Eq for PostingFormat
impl StructuralPartialEq for PostingFormat
Auto Trait Implementations§
impl Freeze for PostingFormat
impl RefUnwindSafe for PostingFormat
impl Send for PostingFormat
impl Sync for PostingFormat
impl Unpin for PostingFormat
impl UnwindSafe for PostingFormat
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more