1pub mod product;
2pub mod scalar;
3
4pub use product::ProductQuantizer;
5pub use scalar::ScalarQuantizer;
6
7use std::fmt::Debug;
8
9pub trait VectorQuantizer: Send + Sync + Debug {
11 fn compress(&self, vectors: &[Vec<f32>]) -> Vec<Vec<u8>>;
13
14 fn decompress(&self, quantized: &[Vec<u8>]) -> Vec<Vec<f32>>;
16}
17
18#[derive(Debug)]
20pub struct NoopQuantizer;
21
22impl VectorQuantizer for NoopQuantizer {
23 fn compress(&self, vectors: &[Vec<f32>]) -> Vec<Vec<u8>> {
24 vectors.iter().map(|v| v.iter().flat_map(|f| f.to_le_bytes()).collect()).collect()
25 }
26
27 fn decompress(&self, quantized: &[Vec<u8>]) -> Vec<Vec<f32>> {
28 quantized.iter().map(|bytes| {
29 bytes.chunks(4).map(|c| {
30 let arr: [u8; 4] = c.try_into().unwrap_or([0; 4]);
31 f32::from_le_bytes(arr)
32 }).collect()
33 }).collect()
34 }
35}