pub struct DequantizeLinearF32 {
pub scale: f32,
pub zero_point: i32,
}
Fields§
§scale: f32
§zero_point: i32
Implementations§
Source§impl DequantizeLinearF32
impl DequantizeLinearF32
Sourcepub fn new(scale: f32, zero_point: i32) -> DequantizeLinearF32
pub fn new(scale: f32, zero_point: i32) -> DequantizeLinearF32
Constructs a new DequantizeLinearF32
.
Trait Implementations§
Source§impl Clone for DequantizeLinearF32
impl Clone for DequantizeLinearF32
Source§fn clone(&self) -> DequantizeLinearF32
fn clone(&self) -> DequantizeLinearF32
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 moreSource§impl Debug for DequantizeLinearF32
impl Debug for DequantizeLinearF32
Source§impl EvalOp for DequantizeLinearF32
impl EvalOp for DequantizeLinearF32
fn is_stateless(&self) -> bool
fn eval( &self, inputs: SmallVec<[TValue; 4]>, ) -> Result<SmallVec<[TValue; 4]>, Error>
fn eval_with_session( &self, session: &SessionState, inputs: SmallVec<[TValue; 4]>, ) -> Result<SmallVec<[TValue; 4]>, Error>
fn state( &self, session: &mut SessionState, node_id: usize, ) -> Result<Option<Box<dyn OpState>>, Error>
Source§impl Op for DequantizeLinearF32
impl Op for DequantizeLinearF32
fn name(&self) -> Cow<'_, str>
Source§fn info(&self) -> Result<Vec<String>, Error>
fn info(&self) -> Result<Vec<String>, Error>
Short (one-line) strings giving hints on internal implementation or
important configuration details to be displayed in dumps.
Source§fn validation(&self) -> Validation
fn validation(&self) -> Validation
The kind of accuracy check that should be performed on operation when
testing them.
fn as_typed(&self) -> Option<&(dyn TypedOp + 'static)>
Source§impl TypedOp for DequantizeLinearF32
impl TypedOp for DequantizeLinearF32
Source§fn output_facts(
&self,
inputs: &[&TypedFact],
) -> Result<SmallVec<[TypedFact; 4]>, Error>
fn output_facts( &self, inputs: &[&TypedFact], ) -> Result<SmallVec<[TypedFact; 4]>, Error>
Deduce output facts from input facts.
fn axes_mapping( &self, inputs: &[&TypedFact], outputs: &[&TypedFact], ) -> Result<AxesMapping, Error>
fn change_axes( &self, model: &Graph<TypedFact, Box<dyn TypedOp>>, node: &Node<TypedFact, Box<dyn TypedOp>>, _io: InOut, change: &AxisOp, ) -> Result<Option<AxisChangeConsequence>, Error>
Source§fn declutter(
&self,
model: &Graph<TypedFact, Box<dyn TypedOp>>,
dequant: &Node<TypedFact, Box<dyn TypedOp>>,
) -> Result<Option<ModelPatch<TypedFact, Box<dyn TypedOp>>>, Error>
fn declutter( &self, model: &Graph<TypedFact, Box<dyn TypedOp>>, dequant: &Node<TypedFact, Box<dyn TypedOp>>, ) -> Result<Option<ModelPatch<TypedFact, Box<dyn TypedOp>>>, Error>
Declutter the op to the tract_core operator set as much as possible.
Source§fn fuse(
&self,
_model: &Graph<TypedFact, Box<dyn TypedOp>>,
_node: &Node<TypedFact, Box<dyn TypedOp>>,
) -> Result<Option<ModelPatch<TypedFact, Box<dyn TypedOp>>>, Error>
fn fuse( &self, _model: &Graph<TypedFact, Box<dyn TypedOp>>, _node: &Node<TypedFact, Box<dyn TypedOp>>, ) -> Result<Option<ModelPatch<TypedFact, Box<dyn TypedOp>>>, Error>
Fuse op after codegen to deal with local optimisations.
Source§fn declutter_with_session(
&self,
session: &mut OptimizerSession<'_>,
model: &Graph<TypedFact, Box<dyn TypedOp>>,
node: &Node<TypedFact, Box<dyn TypedOp>>,
) -> Result<Option<ModelPatch<TypedFact, Box<dyn TypedOp>>>, Error>
fn declutter_with_session( &self, session: &mut OptimizerSession<'_>, model: &Graph<TypedFact, Box<dyn TypedOp>>, node: &Node<TypedFact, Box<dyn TypedOp>>, ) -> Result<Option<ModelPatch<TypedFact, Box<dyn TypedOp>>>, Error>
Declutter the op to the tract_core operator set as much as possible.
Source§fn cost(
&self,
_inputs: &[&TypedFact],
) -> Result<SmallVec<[(Cost, TDim); 4]>, Error>
fn cost( &self, _inputs: &[&TypedFact], ) -> Result<SmallVec<[(Cost, TDim); 4]>, Error>
Computes a cost hint of the operation. Read more
fn suggested_axis_changes( &self, ) -> Result<SmallVec<[(InOut, AxisOp); 4]>, Error>
fn slice( &self, patch: &mut ModelPatch<TypedFact, Box<dyn TypedOp>>, model: &Graph<TypedFact, Box<dyn TypedOp>>, node: &Node<TypedFact, Box<dyn TypedOp>>, prefix: &str, inputs: &[OutletId], output_axis: usize, start: &TDim, end: &TDim, ) -> Result<Option<SmallVec<[OutletId; 4]>>, Error>
Source§fn quantize(
&self,
model: &Graph<TypedFact, Box<dyn TypedOp>>,
node: &Node<TypedFact, Box<dyn TypedOp>>,
dt: DatumType,
scale: f32,
zero_point: i32,
) -> Result<Option<Box<dyn TypedOp>>, Error>
fn quantize( &self, model: &Graph<TypedFact, Box<dyn TypedOp>>, node: &Node<TypedFact, Box<dyn TypedOp>>, dt: DatumType, scale: f32, zero_point: i32, ) -> Result<Option<Box<dyn TypedOp>>, Error>
Transforms the op in an equivalent one, operating on dt (i8 or u8). Read more
Source§fn concretize_dims(
&self,
source: &Graph<TypedFact, Box<dyn TypedOp>>,
node: &Node<TypedFact, Box<dyn TypedOp>>,
target: &mut Graph<TypedFact, Box<dyn TypedOp>>,
mapping: &HashMap<OutletId, OutletId>,
values: &SymbolValues,
) -> Result<SmallVec<[OutletId; 4]>, Error>
fn concretize_dims( &self, source: &Graph<TypedFact, Box<dyn TypedOp>>, node: &Node<TypedFact, Box<dyn TypedOp>>, target: &mut Graph<TypedFact, Box<dyn TypedOp>>, mapping: &HashMap<OutletId, OutletId>, values: &SymbolValues, ) -> Result<SmallVec<[OutletId; 4]>, Error>
Transform the op into by providing a value to one or more symbols.
Auto Trait Implementations§
impl Freeze for DequantizeLinearF32
impl RefUnwindSafe for DequantizeLinearF32
impl Send for DequantizeLinearF32
impl Sync for DequantizeLinearF32
impl Unpin for DequantizeLinearF32
impl UnwindSafe for DequantizeLinearF32
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>
Convert
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<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>
Convert
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
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)
Convert
&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)
Convert
&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> DowncastSync for T
impl<T> DowncastSync for T
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