Struct tract_pulse::internal::tract_core::ops::nn::Graph     
source · pub struct Graph<F, O>where
    F: Fact + Clone + 'static,
    O: Debug + Display + AsRef<dyn Op> + AsMut<dyn Op> + Clone + 'static,{
    pub nodes: Vec<Node<F, O>>,
    pub inputs: Vec<OutletId>,
    pub outputs: Vec<OutletId>,
    pub outlet_labels: HashMap<OutletId, String>,
    pub properties: HashMap<String, Arc<Tensor>>,
    pub symbol_table: SymbolTable,
}Expand description
Main model class
Parameterized by a Fact class.
Fields§
§nodes: Vec<Node<F, O>>all nodes in the model
inputs: Vec<OutletId>model inputs
outputs: Vec<OutletId>model outputs
outlet_labels: HashMap<OutletId, String>outlet labels
properties: HashMap<String, Arc<Tensor>>model properties
symbol_table: SymbolTablesymbol table
Implementations§
source§impl<F, O> Graph<F, O>
 
impl<F, O> Graph<F, O>
pub fn add_node( &mut self, name: impl Into<String>, op: impl Into<O>, output_facts: SmallVec<[F; 4]> ) -> Result<usize, Error>
sourcepub fn add_edge(
    &mut self,
    outlet: OutletId,
    inlet: InletId
) -> Result<(), Error>
 
pub fn add_edge( &mut self, outlet: OutletId, inlet: InletId ) -> Result<(), Error>
Connect a node outlet to a node inlet.
sourcepub fn input_outlets(&self) -> Result<&[OutletId], Error>
 
pub fn input_outlets(&self) -> Result<&[OutletId], Error>
Get model inputs.
sourcepub fn set_input_outlets(&mut self, inputs: &[OutletId]) -> Result<(), Error>
 
pub fn set_input_outlets(&mut self, inputs: &[OutletId]) -> Result<(), Error>
Change model inputs.
sourcepub fn with_input_outlets(
    self,
    inputs: &[OutletId]
) -> Result<Graph<F, O>, Error>
 
pub fn with_input_outlets( self, inputs: &[OutletId] ) -> Result<Graph<F, O>, Error>
Change model inputs and return self.
sourcepub fn set_input_names(
    &mut self,
    inputs: impl IntoIterator<Item = impl AsRef<str>>
) -> Result<(), Error>
 
pub fn set_input_names( &mut self, inputs: impl IntoIterator<Item = impl AsRef<str>> ) -> Result<(), Error>
Set model inputs by the node name.
sourcepub fn with_input_names(
    self,
    inputs: impl IntoIterator<Item = impl AsRef<str>>
) -> Result<Graph<F, O>, Error>
 
pub fn with_input_names( self, inputs: impl IntoIterator<Item = impl AsRef<str>> ) -> Result<Graph<F, O>, Error>
Set model inputs by the node name and return self.
sourcepub fn input_fact(&self, ix: usize) -> Result<&F, Error>
 
pub fn input_fact(&self, ix: usize) -> Result<&F, Error>
Get the ix-th input tensor type information.
sourcepub fn input_fact_mut(&mut self, ix: usize) -> Result<&mut F, Error>
 
pub fn input_fact_mut(&mut self, ix: usize) -> Result<&mut F, Error>
Get the ix-th input tensor type information, mutably.
sourcepub fn set_input_fact(&mut self, input: usize, fact: F) -> Result<(), Error>
 
pub fn set_input_fact(&mut self, input: usize, fact: F) -> Result<(), Error>
Set the ix-th input tensor type information.
sourcepub fn with_input_fact(
    self,
    input: usize,
    fact: F
) -> Result<Graph<F, O>, Error>
 
pub fn with_input_fact( self, input: usize, fact: F ) -> Result<Graph<F, O>, Error>
Set the ix-th input tensor type information and return self.
sourcepub fn output_outlets(&self) -> Result<&[OutletId], Error>
 
pub fn output_outlets(&self) -> Result<&[OutletId], Error>
Get model outputs.
sourcepub fn auto_outputs(&mut self) -> Result<(), Error>
 
pub fn auto_outputs(&mut self) -> Result<(), Error>
Guess outputs from the topology: node or nodes with no successors.
sourcepub fn set_output_outlets(&mut self, outputs: &[OutletId]) -> Result<(), Error>
 
pub fn set_output_outlets(&mut self, outputs: &[OutletId]) -> Result<(), Error>
Change model outputs.
sourcepub fn with_output_outlets(
    self,
    outputs: &[OutletId]
) -> Result<Graph<F, O>, Error>
 
pub fn with_output_outlets( self, outputs: &[OutletId] ) -> Result<Graph<F, O>, Error>
Change model outputs and return self.
sourcepub fn set_output_names(
    &mut self,
    outputs: impl IntoIterator<Item = impl AsRef<str>>
) -> Result<(), Error>
 
pub fn set_output_names( &mut self, outputs: impl IntoIterator<Item = impl AsRef<str>> ) -> Result<(), Error>
Set model outputs by node names.
sourcepub fn with_output_names(
    self,
    outputs: impl IntoIterator<Item = impl AsRef<str>>
) -> Result<Graph<F, O>, Error>
 
pub fn with_output_names( self, outputs: impl IntoIterator<Item = impl AsRef<str>> ) -> Result<Graph<F, O>, Error>
Set model outputs by node names and return self.
sourcepub fn output_fact(&self, ix: usize) -> Result<&F, Error>
 
pub fn output_fact(&self, ix: usize) -> Result<&F, Error>
Get the ix-th input tensor type information.
sourcepub fn output_fact_mut(&mut self, ix: usize) -> Result<&mut F, Error>
 
pub fn output_fact_mut(&mut self, ix: usize) -> Result<&mut F, Error>
Get the ix-th input tensor type information, mutably.
sourcepub fn set_output_fact(&mut self, output: usize, fact: F) -> Result<(), Error>
 
pub fn set_output_fact(&mut self, output: usize, fact: F) -> Result<(), Error>
Set the ix-th output tensor type information.
sourcepub fn with_output_fact(
    self,
    output: usize,
    fact: F
) -> Result<Graph<F, O>, Error>
 
pub fn with_output_fact( self, output: usize, fact: F ) -> Result<Graph<F, O>, Error>
Set the ix-th output tensor type information and return self.
sourcepub fn node_names(&self) -> impl Iterator<Item = &str>
 
pub fn node_names(&self) -> impl Iterator<Item = &str>
Iterate over all node names.
pub fn node_id_by_name(&self, name: &str) -> Result<usize, Error>
sourcepub fn node_by_name(&self, name: impl AsRef<str>) -> Result<&Node<F, O>, Error>
 
pub fn node_by_name(&self, name: impl AsRef<str>) -> Result<&Node<F, O>, Error>
Find a node by its name.
sourcepub fn node_by_name_mut(
    &mut self,
    name: impl AsRef<str>
) -> Result<&mut Node<F, O>, Error>
 
pub fn node_by_name_mut( &mut self, name: impl AsRef<str> ) -> Result<&mut Node<F, O>, Error>
Borrow mutably a node by its name.
pub fn rename_node(&mut self, id: usize, name: &str) -> Result<(), Error>
sourcepub fn node_facts(
    &self,
    id: usize
) -> Result<(SmallVec<[&F; 4]>, SmallVec<[&F; 4]>), Error>
 
pub fn node_facts( &self, id: usize ) -> Result<(SmallVec<[&F; 4]>, SmallVec<[&F; 4]>), Error>
Get input and output tensor information for a node.
sourcepub fn node_input_facts(
    &self,
    node_id: usize
) -> Result<SmallVec<[&F; 4]>, Error>
 
pub fn node_input_facts( &self, node_id: usize ) -> Result<SmallVec<[&F; 4]>, Error>
Get input tensor information for a node.
sourcepub fn node_output_facts(
    &self,
    node_id: usize
) -> Result<SmallVec<[&F; 4]>, Error>
 
pub fn node_output_facts( &self, node_id: usize ) -> Result<SmallVec<[&F; 4]>, Error>
Get output tensor information for a node.
sourcepub fn outlet_fact(&self, outlet: OutletId) -> Result<&F, Error>
 
pub fn outlet_fact(&self, outlet: OutletId) -> Result<&F, Error>
Get tensor information for a single outlet.
sourcepub fn outlet_fact_mut(&mut self, outlet: OutletId) -> Result<&mut F, Error>
 
pub fn outlet_fact_mut(&mut self, outlet: OutletId) -> Result<&mut F, Error>
Get tensor information for a single outlet.
sourcepub fn outlets_fact_mut(
    &mut self,
    outlets: &[OutletId]
) -> Result<SmallVec<[&mut F; 4]>, Error>
 
pub fn outlets_fact_mut( &mut self, outlets: &[OutletId] ) -> Result<SmallVec<[&mut F; 4]>, Error>
Get multiple mutable tensor information for outlets.
sourcepub fn set_outlet_fact(
    &mut self,
    outlet: OutletId,
    fact: F
) -> Result<(), Error>
 
pub fn set_outlet_fact( &mut self, outlet: OutletId, fact: F ) -> Result<(), Error>
Set tensor information for a single outlet.
sourcepub fn with_outlet_fact(
    self,
    outlet: OutletId,
    fact: F
) -> Result<Graph<F, O>, Error>
 
pub fn with_outlet_fact( self, outlet: OutletId, fact: F ) -> Result<Graph<F, O>, Error>
Set tensor information for a single outlet and return self.
sourcepub fn outlet_label(&self, outlet: OutletId) -> Option<&str>
 
pub fn outlet_label(&self, outlet: OutletId) -> Option<&str>
Get label for an outlet.
sourcepub fn set_outlet_label(
    &mut self,
    outlet: OutletId,
    label: String
) -> Result<(), Error>
 
pub fn set_outlet_label( &mut self, outlet: OutletId, label: String ) -> Result<(), Error>
Set label for an outlet.
sourcepub fn with_outlet_label(
    self,
    outlet: OutletId,
    label: String
) -> Result<Graph<F, O>, Error>
 
pub fn with_outlet_label( self, outlet: OutletId, label: String ) -> Result<Graph<F, O>, Error>
Set label for an outlet and return self.
sourcepub fn find_outlet_label(&self, label: &str) -> Option<OutletId>
 
pub fn find_outlet_label(&self, label: &str) -> Option<OutletId>
Find outlet by label.
sourcepub fn eval_order(&self) -> Result<Vec<usize>, Error>
 
pub fn eval_order(&self) -> Result<Vec<usize>, Error>
Computes an evalutation order for the graph inputs and outputs
sourcepub fn eval_order_opt_ram(&self) -> Result<Vec<usize>, Error>
 
pub fn eval_order_opt_ram(&self) -> Result<Vec<usize>, Error>
Computes an evalutation order for the graph inputs and outputs. This order will minimize temporary buffers.
pub fn check_edges(&self) -> Result<(), Error>
pub fn check_names(&self) -> Result<(), Error>
sourcepub fn into_runnable(self) -> Result<SimplePlan<F, O, Graph<F, O>>, Error>
 
pub fn into_runnable(self) -> Result<SimplePlan<F, O, Graph<F, O>>, Error>
Converts the model into a RunnableModel which fixes the inputs and outputs and allows passing data through the model.
sourcepub fn into_runnable_with_options(
    self,
    options: &PlanOptions
) -> Result<SimplePlan<F, O, Graph<F, O>>, Error>
 
pub fn into_runnable_with_options( self, options: &PlanOptions ) -> Result<SimplePlan<F, O, Graph<F, O>>, Error>
Converts the model into a RunnableModel which fixes the inputs and outputs and allows passing data through the model.
pub fn single_prec(&self, id: usize) -> Result<Option<&Node<F, O>>, Error>
pub fn single_prec_at( &self, id: usize, count: usize ) -> Result<Option<&Node<F, O>>, Error>
pub fn single_succ_at( &self, id: usize, count: usize ) -> Result<Option<&Node<F, O>>, Error>
pub fn single_succ(&self, id: usize) -> Result<Option<&Node<F, O>>, Error>
pub fn outlet_successors(&self, outlet: OutletId) -> &[InletId]
source§impl Graph<TypedFact, Box<dyn TypedOp>>
 
impl Graph<TypedFact, Box<dyn TypedOp>>
pub fn into_optimized(self) -> Result<Graph<TypedFact, Box<dyn TypedOp>>, Error>
pub fn check_consistency(&self) -> Result<(), Error>
pub fn into_decluttered( self ) -> Result<Graph<TypedFact, Box<dyn TypedOp>>, Error>
sourcepub fn transform(&mut self, transform: &dyn ModelTransform) -> Result<(), Error>
 
pub fn transform(&mut self, transform: &dyn ModelTransform) -> Result<(), Error>
Perform declutter passes on the network.
sourcepub fn optimize_with_session(
    &mut self,
    session: &mut OptimizerSession<'_>
) -> Result<(), Error>
 
pub fn optimize_with_session( &mut self, session: &mut OptimizerSession<'_> ) -> Result<(), Error>
Perform optimization passes on the model, using a given optimizer session.
pub fn concretize_dims( &self, values: &SymbolValues ) -> Result<Graph<TypedFact, Box<dyn TypedOp>>, Error>
sourcepub fn optimize(&mut self) -> Result<(), Error>
 
pub fn optimize(&mut self) -> Result<(), Error>
Translate the graph to locally optimized operators (LIR or MIR ops).
pub fn node_axes_mapping(&self, id: usize) -> Result<AxesMapping, Error>
pub fn axes_mapping(&self) -> Result<AxesMapping, Error>
Trait Implementations§
source§impl Framework<ProtoModel, Graph<TypedFact, Box<dyn TypedOp>>> for Nnef
 
impl Framework<ProtoModel, Graph<TypedFact, Box<dyn TypedOp>>> for Nnef
source§fn model_for_path(
    &self,
    p: impl AsRef<Path>
) -> Result<Graph<TypedFact, Box<dyn TypedOp>>, Error>
 
fn model_for_path( &self, p: impl AsRef<Path> ) -> Result<Graph<TypedFact, Box<dyn TypedOp>>, Error>
source§fn proto_model_for_path(
    &self,
    path: impl AsRef<Path>
) -> Result<ProtoModel, Error>
 
fn proto_model_for_path( &self, path: impl AsRef<Path> ) -> Result<ProtoModel, Error>
source§fn proto_model_for_read(
    &self,
    reader: &mut dyn Read
) -> Result<ProtoModel, Error>
 
fn proto_model_for_read( &self, reader: &mut dyn Read ) -> Result<ProtoModel, Error>
source§fn model_for_proto_model_with_symbols(
    &self,
    proto: &ProtoModel,
    symbols: &SymbolTable
) -> Result<Graph<TypedFact, Box<dyn TypedOp>>, Error>
 
fn model_for_proto_model_with_symbols( &self, proto: &ProtoModel, symbols: &SymbolTable ) -> Result<Graph<TypedFact, Box<dyn TypedOp>>, Error>
source§fn model_for_proto_model(&self, proto: &ProtoModel) -> Result<Model, Error>
 
fn model_for_proto_model(&self, proto: &ProtoModel) -> Result<Model, Error>
source§impl InnerModel for Graph<TypedFact, Box<dyn TypedOp>>
 
impl InnerModel for Graph<TypedFact, Box<dyn TypedOp>>
fn output_facts( &self, _inputs: &[&TypedFact] ) -> Result<SmallVec<[TypedFact; 4]>, Error>
fn is_stateless(&self) -> bool
fn state( &self, session: &mut SessionState, node_id: usize ) -> Result<Option<Box<dyn OpState>>, Error>
fn declutter(&mut self) -> Result<(), Error>
fn codegen(&mut self) -> Result<(), Error>
fn as_typed(&self) -> &Graph<TypedFact, Box<dyn TypedOp>>
source§impl SpecialOps<TypedFact, Box<dyn TypedOp>> for Graph<TypedFact, Box<dyn TypedOp>>
 
impl SpecialOps<TypedFact, Box<dyn TypedOp>> for Graph<TypedFact, Box<dyn TypedOp>>
fn is_source(op: &Box<dyn TypedOp>) -> bool
fn create_dummy(&self) -> Box<dyn TypedOp>
fn create_source(&self, fact: TypedFact) -> Box<dyn TypedOp>
fn wire_node( &mut self, name: impl Into<String>, op: impl Into<Box<dyn TypedOp>>, inputs: &[OutletId] ) -> Result<SmallVec<[OutletId; 4]>, Error>
fn add_const( &mut self, name: impl Into<String>, v: impl IntoArcTensor ) -> Result<OutletId, Error>
Auto Trait Implementations§
impl<F, O> Freeze for Graph<F, O>
impl<F, O> RefUnwindSafe for Graph<F, O>where
    O: RefUnwindSafe,
    F: RefUnwindSafe,
impl<F, O> Send for Graph<F, O>where
    O: Send,
impl<F, O> Sync for Graph<F, O>where
    O: Sync,
impl<F, O> Unpin for Graph<F, O>
impl<F, O> UnwindSafe for Graph<F, O>
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
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>
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>
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)
&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)
&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> ⓘ
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> ⓘ
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