pub struct BinaryQuantizer {
pub dimension: usize,
pub thresholds: Vec<f32>,
}Expand description
Binary quantizer
Maps float32 values to binary {0, 1}, achieving 32x compression. Each dimension becomes a single bit based on sign or threshold.
Fields§
§dimension: usizeVector dimension
thresholds: Vec<f32>Threshold per dimension (typically mean or median)
Implementations§
Source§impl BinaryQuantizer
impl BinaryQuantizer
Sourcepub fn train_sign_based(dimension: usize) -> Self
pub fn train_sign_based(dimension: usize) -> Self
Train using zero threshold (sign-based binarization)
Sourcepub fn encode(&self, vector: &[f32]) -> Result<Vec<u8>>
pub fn encode(&self, vector: &[f32]) -> Result<Vec<u8>>
Encode a vector to binary representation
Returns packed bits: each byte stores 8 dimensions
Sourcepub fn hamming_distance(&self, a: &[u8], b: &[u8]) -> u32
pub fn hamming_distance(&self, a: &[u8], b: &[u8]) -> u32
Hamming distance between binary vectors
Counts differing bits (fast XOR + popcount)
Sourcepub fn approximate_cosine(&self, a: &[u8], b: &[u8]) -> f32
pub fn approximate_cosine(&self, a: &[u8], b: &[u8]) -> f32
Approximate cosine similarity from Hamming distance
cos(θ) ≈ 1 - 2 * (hamming_distance / dimension)
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 BinaryQuantizer
impl Clone for BinaryQuantizer
Source§fn clone(&self) -> BinaryQuantizer
fn clone(&self) -> BinaryQuantizer
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 BinaryQuantizer
impl Debug for BinaryQuantizer
Source§impl<'de> Deserialize<'de> for BinaryQuantizer
impl<'de> Deserialize<'de> for BinaryQuantizer
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 BinaryQuantizer
impl RefUnwindSafe for BinaryQuantizer
impl Send for BinaryQuantizer
impl Sync for BinaryQuantizer
impl Unpin for BinaryQuantizer
impl UnwindSafe for BinaryQuantizer
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