pub struct ScalarQuantizer4 {
pub dimension: usize,
pub min_values: Vec<f32>,
pub ranges: Vec<f32>,
}Expand description
4-bit scalar quantizer
Maps float32 values to 4-bit [0, 15], achieving 8x compression.
Fields§
§dimension: usizeVector dimension
min_values: Vec<f32>Minimum value per dimension
ranges: Vec<f32>Ranges per dimension
Implementations§
Source§impl ScalarQuantizer4
impl ScalarQuantizer4
Sourcepub fn encode(&self, vector: &[f32]) -> Result<Vec<u8>>
pub fn encode(&self, vector: &[f32]) -> Result<Vec<u8>>
Encode a vector to 4-bit representation (packed)
Each byte stores two 4-bit values
Sourcepub fn decode(&self, quantized: &[u8]) -> Result<Vec<f32>>
pub fn decode(&self, quantized: &[u8]) -> Result<Vec<f32>>
Decode 4-bit representation back to float32
Sourcepub fn memory_usage(&self, num_vectors: usize) -> usize
pub fn memory_usage(&self, num_vectors: usize) -> usize
Memory footprint in bytes
Trait Implementations§
Source§impl Clone for ScalarQuantizer4
impl Clone for ScalarQuantizer4
Source§fn clone(&self) -> ScalarQuantizer4
fn clone(&self) -> ScalarQuantizer4
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 ScalarQuantizer4
impl Debug for ScalarQuantizer4
Source§impl<'de> Deserialize<'de> for ScalarQuantizer4
impl<'de> Deserialize<'de> for ScalarQuantizer4
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Auto Trait Implementations§
impl Freeze for ScalarQuantizer4
impl RefUnwindSafe for ScalarQuantizer4
impl Send for ScalarQuantizer4
impl Sync for ScalarQuantizer4
impl Unpin for ScalarQuantizer4
impl UnwindSafe for ScalarQuantizer4
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> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
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