Struct IntVecReader

Source
pub struct IntVecReader<'a, E: Endianness>
where for<'b> BufBitReader<E, MemWordReader<u64, &'b Vec<u64>>, DefaultReadParams>: BitRead<E, Error = Infallible> + CodesRead<E> + BitSeek<Error = Infallible>,
{ /* private fields */ }
Expand description

A stateful reader for an IntVec that provides fast random access.

This reader is created by the IntVec::reader method. It maintains an internal, reusable bitstream reader, which makes it highly efficient for performing multiple random lookups, especially when the access pattern is not known in advance (e.g., indices are generated on-the-fly in a loop).

By reusing the same underlying reader, it amortizes the setup cost across many get operations.

§When to use IntVecReader

  • When you need to perform multiple lookups and the indices are determined dynamically.
  • When the next lookup index might depend on the result of the previous one.

For batch lookups where all indices are known beforehand, using IntVec::get_many is still preferable as it can perform global optimizations like sorting the indices. There is a parallel version of this method, IntVec::par_get_many.

§Example

use compressed_intvec::prelude::*;

let data: &[u64] = &[10, 20, 30, 40, 50];
let intvec = LEIntVec::builder(data).build().unwrap();

// Create a reusable reader from the IntVec.
let mut reader = intvec.reader();

// Perform multiple lookups. The reader efficiently handles seeks.
assert_eq!(reader.get(3).unwrap(), Some(40));
assert_eq!(reader.get(1).unwrap(), Some(20));
assert_eq!(reader.get(0).unwrap(), Some(10));

Implementations§

Source§

impl<'a, E: Endianness> IntVecReader<'a, E>
where for<'b> BufBitReader<E, MemWordReader<u64, &'b Vec<u64>>, DefaultReadParams>: BitRead<E, Error = Infallible> + CodesRead<E> + BitSeek<Error = Infallible>,

Source

pub fn get(&mut self, index: usize) -> Result<Option<u64>, IntVecError>

Retrieves the element at the specified index using the reusable reader.

This method leverages the stateful nature of the reader to perform efficient random access.

§Implementation Notes

The access strategy is identical to that of IntVec::get, but because this method operates on a long-lived reader instance, it avoids the setup overhead associated with calling IntVec::get repeatedly.

  • For fixed-width integer encoding: Access is O(1). The bit position is calculated and the reader seeks directly to it.
  • For variable-length, bit-level codes: The reader seeks to the nearest preceding sample point and decodes sequentially from there.
§Example
use compressed_intvec::prelude::*;

let data: &[u64] = &[10, 20, 30, 40, 50];
let intvec = LEIntVec::builder(data).build().unwrap();
let mut reader = intvec.reader();

assert_eq!(reader.get(2).unwrap(), Some(30));
assert_eq!(reader.get(10).unwrap(), None); // Out of bounds

Auto Trait Implementations§

§

impl<'a, E> Freeze for IntVecReader<'a, E>

§

impl<'a, E> RefUnwindSafe for IntVecReader<'a, E>
where E: RefUnwindSafe,

§

impl<'a, E> Send for IntVecReader<'a, E>

§

impl<'a, E> Sync for IntVecReader<'a, E>

§

impl<'a, E> Unpin for IntVecReader<'a, E>
where E: Unpin,

§

impl<'a, E> UnwindSafe for IntVecReader<'a, E>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CastableFrom<T> for T

Source§

fn cast_from(value: T) -> T

Call Self as W
Source§

impl<T, U> CastableInto<U> for T
where U: CastableFrom<T>,

Source§

fn cast(self) -> U

Call W::cast_from(self)
Source§

impl<T> DowncastableFrom<T> for T

Source§

fn downcast_from(value: T) -> T

Truncate the current UnsignedInt to a possibly smaller size
Source§

impl<T, U> DowncastableInto<U> for T
where U: DowncastableFrom<T>,

Source§

fn downcast(self) -> U

Call W::downcast_from(self)
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Splat<T> for T

Source§

fn splat(value: T) -> T

Source§

impl<T> To<T> for T

Source§

fn to(self) -> T

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> UpcastableFrom<T> for T

Source§

fn upcast_from(value: T) -> T

Extend the current UnsignedInt to a possibly bigger size.
Source§

impl<T, U> UpcastableInto<U> for T
where U: UpcastableFrom<T>,

Source§

fn upcast(self) -> U

Call W::upcast_from(self)
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V