pub enum PostingFormat {
HorizontalBP128,
VerticalBP128,
EliasFano,
PartitionedEF,
Roaring,
OptP4D,
}Expand description
Posting list format selector
Variants§
HorizontalBP128
Horizontal BP128 layout (fastest encoding + decoding with SIMD)
VerticalBP128
Vertical BP128 with bit-interleaved layout (optimal for SIMD scatter)
EliasFano
Elias-Fano for long posting lists
PartitionedEF
Partitioned Elias-Fano (very long lists, better compression)
Roaring
Roaring bitmap for very frequent terms
OptP4D
OptP4D (Optimized Patched Frame-of-Reference Delta) - optimal bit-width selection with exceptions
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: HorizontalBP128 (fastest encoding + decoding with SIMD, optimal compression)
Note: HorizontalBP128 now has SIMD optimizations (NEON/SSE) and outperforms SIMD-BP128:
- Faster encoding (horizontal layout vs vertical bit-interleaved)
- Faster decoding with 64-bit unaligned reads (236K vs 199K ints/μs)
- Same compression ratio
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