Struct burn::tensor::quantization::AffineQuantization
pub struct AffineQuantization<E, Q, A>{
pub scale: E,
pub offset: Q,
/* private fields */
}
Expand description
Affine quantization scheme.
Note that the accumulation type A
should have a bigger range than quantized type Q
.
Fields§
§scale: E
The scaling factor.
offset: Q
The zero-point offset.
Implementations§
§impl<E, Q, A> AffineQuantization<E, Q, A>
impl<E, Q, A> AffineQuantization<E, Q, A>
pub fn init(scale: E, offset: Q) -> AffineQuantization<E, Q, A>
pub fn init(scale: E, offset: Q) -> AffineQuantization<E, Q, A>
Initialize an affine quantization scheme with the given parameters.
Trait Implementations§
§impl<E, Q, A> Clone for AffineQuantization<E, Q, A>
impl<E, Q, A> Clone for AffineQuantization<E, Q, A>
§fn clone(&self) -> AffineQuantization<E, Q, A>
fn clone(&self) -> AffineQuantization<E, Q, A>
Returns a copy 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 more§impl<E, Q, A> Debug for AffineQuantization<E, Q, A>
impl<E, Q, A> Debug for AffineQuantization<E, Q, A>
§impl<'de, E, Q, A> Deserialize<'de> for AffineQuantization<E, Q, A>
impl<'de, E, Q, A> Deserialize<'de> for AffineQuantization<E, Q, A>
§fn deserialize<__D>(
__deserializer: __D,
) -> Result<AffineQuantization<E, Q, A>, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<AffineQuantization<E, Q, A>, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
§impl<E, Q, A> Hash for AffineQuantization<E, Q, A>
impl<E, Q, A> Hash for AffineQuantization<E, Q, A>
§impl<E, Q, A> PartialEq for AffineQuantization<E, Q, A>
impl<E, Q, A> PartialEq for AffineQuantization<E, Q, A>
§impl<E, Q, A> Quantization<E, Q> for AffineQuantization<E, Q, A>
impl<E, Q, A> Quantization<E, Q> for AffineQuantization<E, Q, A>
§fn new(alpha: E, beta: E) -> AffineQuantization<E, Q, A>
fn new(alpha: E, beta: E) -> AffineQuantization<E, Q, A>
Create a new quantization scheme for an input range
[alpha, beta]
.§fn dequantize(&self, values: &[Q]) -> Vec<E>
fn dequantize(&self, values: &[Q]) -> Vec<E>
Convert the values back to a higher precision data type.
§impl<E, Q, A> Serialize for AffineQuantization<E, Q, A>
impl<E, Q, A> Serialize for AffineQuantization<E, Q, A>
§fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
Serialize this value into the given Serde serializer. Read more
impl<E, Q, A> Copy for AffineQuantization<E, Q, A>
impl<E, Q, A> Eq for AffineQuantization<E, Q, A>
Auto Trait Implementations§
impl<E, Q, A> Freeze for AffineQuantization<E, Q, A>
impl<E, Q, A> RefUnwindSafe for AffineQuantization<E, Q, A>
impl<E, Q, A> Send for AffineQuantization<E, Q, A>
impl<E, Q, A> Sync for AffineQuantization<E, Q, A>
impl<E, Q, A> Unpin for AffineQuantization<E, Q, A>
impl<E, Q, A> UnwindSafe for AffineQuantization<E, Q, A>
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§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Checks if this value is equivalent to the given key. Read more
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§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