pub enum QuantizationBits {
Bits1,
Bits2,
Bits3,
Bits4,
Bits5,
Bits7,
Bits8,
}Expand description
Number of bits per dimension for quantization
Variants§
Bits1
1 bit per dimension (32x compression) - Binary/BBQ
Bits2
2 bits per dimension (16x compression)
Bits3
3 bits per dimension (~10x compression)
Bits4
4 bits per dimension (8x compression)
Bits5
5 bits per dimension (~6x compression)
Bits7
7 bits per dimension (~4x compression)
Bits8
8 bits per dimension (4x compression)
Implementations§
Source§impl QuantizationBits
impl QuantizationBits
Sourcepub fn compression_ratio(self) -> f32
pub fn compression_ratio(self) -> f32
Get compression ratio vs f32 (32 bits / bits_per_dim)
Sourcepub fn values_per_byte(self) -> usize
pub fn values_per_byte(self) -> usize
Get number of values that fit in one byte
Trait Implementations§
Source§impl Clone for QuantizationBits
impl Clone for QuantizationBits
Source§fn clone(&self) -> QuantizationBits
fn clone(&self) -> QuantizationBits
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 QuantizationBits
impl Debug for QuantizationBits
Source§impl<'de> Deserialize<'de> for QuantizationBits
impl<'de> Deserialize<'de> for QuantizationBits
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
Source§impl Display for QuantizationBits
impl Display for QuantizationBits
Source§impl PartialEq for QuantizationBits
impl PartialEq for QuantizationBits
Source§impl Serialize for QuantizationBits
impl Serialize for QuantizationBits
impl Copy for QuantizationBits
impl Eq for QuantizationBits
impl StructuralPartialEq for QuantizationBits
Auto Trait Implementations§
impl Freeze for QuantizationBits
impl RefUnwindSafe for QuantizationBits
impl Send for QuantizationBits
impl Sync for QuantizationBits
impl Unpin for QuantizationBits
impl UnwindSafe for QuantizationBits
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> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Converts
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be
downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Converts
Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further
downcast into Rc<ConcreteType> where ConcreteType implements Trait.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Converts
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Converts
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.Source§impl<T> DowncastSend for T
impl<T> DowncastSend for T
Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.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