Struct 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 symbols: SymbolScope, }
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

§symbols: SymbolScope

symbol scope, including table

Implementations§

Source§

impl<F, O> Graph<F, O>
where F: Fact + Clone + 'static, O: Debug + Display + AsRef<dyn Op> + AsMut<dyn Op> + Clone + 'static, Graph<F, O>: SpecialOps<F, O>,

Source

pub fn add_source( &mut self, name: impl Into<String>, fact: F, ) -> Result<OutletId, Error>

Source§

impl<F, O> Graph<F, O>
where F: Fact + Clone + 'static, O: Debug + Display + AsRef<dyn Op> + AsMut<dyn Op> + Clone + 'static,

Source

pub fn add_node( &mut self, name: impl Into<String>, op: impl Into<O>, output_facts: SmallVec<[F; 4]>, ) -> Result<usize, Error>

Source

pub fn add_edge( &mut self, outlet: OutletId, inlet: InletId, ) -> Result<(), Error>

Connect a node outlet to a node inlet.

Source

pub fn input_outlets(&self) -> Result<&[OutletId], Error>

Get model inputs.

Source

pub fn set_input_outlets(&mut self, inputs: &[OutletId]) -> Result<(), Error>

Change model inputs.

Source

pub fn with_input_outlets( self, inputs: &[OutletId], ) -> Result<Graph<F, O>, Error>

Change model inputs and return self.

Source

pub fn set_input_names( &mut self, inputs: impl IntoIterator<Item = impl AsRef<str>>, ) -> Result<(), Error>

Set model inputs by the node name.

Source

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.

Source

pub fn input_fact(&self, ix: usize) -> Result<&F, Error>

Get the ix-th input tensor type information.

Source

pub fn input_fact_mut(&mut self, ix: usize) -> Result<&mut F, Error>

Get the ix-th input tensor type information, mutably.

Source

pub fn set_input_fact(&mut self, input: usize, fact: F) -> Result<(), Error>

Set the ix-th input tensor type information.

Source

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.

Source

pub fn output_outlets(&self) -> Result<&[OutletId], Error>

Get model outputs.

Source

pub fn auto_outputs(&mut self) -> Result<(), Error>

Guess outputs from the topology: node or nodes with no successors.

Source

pub fn set_output_outlets(&mut self, outputs: &[OutletId]) -> Result<(), Error>

Change model outputs.

Source

pub fn with_output_outlets( self, outputs: &[OutletId], ) -> Result<Graph<F, O>, Error>

Change model outputs and return self.

Source

pub fn set_output_names( &mut self, outputs: impl IntoIterator<Item = impl AsRef<str>>, ) -> Result<(), Error>

Set model outputs by node names.

Source

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.

Source

pub fn output_fact(&self, ix: usize) -> Result<&F, Error>

Get the ix-th input tensor type information.

Source

pub fn output_fact_mut(&mut self, ix: usize) -> Result<&mut F, Error>

Get the ix-th input tensor type information, mutably.

Source

pub fn set_output_fact(&mut self, output: usize, fact: F) -> Result<(), Error>

Set the ix-th output tensor type information.

Source

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.

Source

pub fn node_names(&self) -> impl Iterator<Item = &str>

Iterate over all node names.

Source

pub fn node_id_by_name(&self, name: &str) -> Result<usize, Error>

Source

pub fn node_by_name(&self, name: impl AsRef<str>) -> Result<&Node<F, O>, Error>

Find a node by its name.

Source

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.

Source

pub fn rename_node(&mut self, id: usize, name: &str) -> Result<(), Error>

Source

pub fn node(&self, id: usize) -> &Node<F, O>

Find a node by its id.

Source

pub fn node_mut(&mut self, id: usize) -> &mut Node<F, O>

Find a node by its id.

Source

pub fn nodes(&self) -> &[Node<F, O>]

Access the nodes table.

Source

pub fn nodes_mut(&mut self) -> &mut [Node<F, O>]

Access the nodes table.

Source

pub fn node_facts( &self, id: usize, ) -> Result<(SmallVec<[&F; 4]>, SmallVec<[&F; 4]>), Error>

Get input and output tensor information for a node.

Source

pub fn node_input_facts( &self, node_id: usize, ) -> Result<SmallVec<[&F; 4]>, Error>

Get input tensor information for a node.

Source

pub fn node_output_facts( &self, node_id: usize, ) -> Result<SmallVec<[&F; 4]>, Error>

Get output tensor information for a node.

Source

pub fn outlet_fact(&self, outlet: OutletId) -> Result<&F, Error>

Get tensor information for a single outlet.

Source

pub fn outlet_fact_mut(&mut self, outlet: OutletId) -> Result<&mut F, Error>

Get tensor information for a single outlet.

Source

pub fn outlets_fact_mut( &mut self, outlets: &[OutletId], ) -> Result<SmallVec<[&mut F; 4]>, Error>

Get multiple mutable tensor information for outlets.

Source

pub fn set_outlet_fact( &mut self, outlet: OutletId, fact: F, ) -> Result<(), Error>

Set tensor information for a single outlet.

Source

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.

Source

pub fn outlet_label(&self, outlet: OutletId) -> Option<&str>

Get label for an outlet.

Source

pub fn set_outlet_label( &mut self, outlet: OutletId, label: String, ) -> Result<(), Error>

Set label for an outlet.

Source

pub fn with_outlet_label( self, outlet: OutletId, label: String, ) -> Result<Graph<F, O>, Error>

Set label for an outlet and return self.

Source

pub fn find_outlet_label(&self, label: &str) -> Option<OutletId>

Find outlet by label.

Source

pub fn eval_order(&self) -> Result<Vec<usize>, Error>

Computes an evalutation order for the graph inputs and outputs

Source

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.

Source

pub fn check_edges(&self) -> Result<(), Error>

Source

pub fn eval_tmp_memory_usage<Flushable>( &self, order: &[usize], flushable: Flushable, ) -> Result<SmallVec<[(usize, TDim); 4]>, Error>
where Flushable: Fn(&Node<F, O>) -> bool,

Evaluate temporary memory usage with its related node at each step of the given order.

Source

pub fn check_names(&self) -> Result<(), Error>

Source

pub fn into_runnable(self) -> Result<SimplePlan<F, O, Graph<F, O>>, Error>

Converts the model into a RunnableModel to actually process user data.

Source

pub fn into_runnable_with_options( self, options: &PlanOptions, ) -> Result<SimplePlan<F, O, Graph<F, O>>, Error>

Converts the model into a RunnableModel to actually process user data. This variant accepts options.

Source

pub fn single_prec(&self, id: usize) -> Result<Option<&Node<F, O>>, Error>

Source

pub fn single_prec_at( &self, id: usize, count: usize, ) -> Result<Option<&Node<F, O>>, Error>

Source

pub fn single_succ_at( &self, id: usize, count: usize, ) -> Result<Option<&Node<F, O>>, Error>

Source

pub fn single_succ(&self, id: usize) -> Result<Option<&Node<F, O>>, Error>

single_succ is only intended for optimisation of simple operators with 1 output, and only 1 output successors (successor with only 1 input)

Source

pub fn outlet_successors(&self, outlet: OutletId) -> &[InletId]

Source

pub fn sym(&self, s: &str) -> Symbol

retrieve of create a symbol

Source

pub fn new_sym_with_prefix(&self, prefix: &str) -> Symbol

create a new symbol with the prefix

Source

pub fn unique_name<'n>(&self, prefix: impl Into<Cow<'n, str>>) -> Cow<'n, str>

generates a name for a new node in the model that will not conflict (by suffixing with a dot and number)

Source§

impl<F, O> Graph<F, O>
where F: Fact + Clone + 'static + for<'a> From<&'a F>, O: Display + Debug + Clone + AsRef<dyn Op> + AsMut<dyn Op> + 'static + for<'a> From<&'a O>, Graph<F, O>: SpecialOps<F, O>,

Source

pub fn check_compact(&self) -> Result<(), Error>

Source

pub fn compact(&mut self) -> Result<(), Error>

Source

pub fn into_compact(self) -> Result<Graph<F, O>, Error>

Source§

impl Graph<TypedFact, Box<dyn TypedOp>>

Source

pub fn into_optimized(self) -> Result<Graph<TypedFact, Box<dyn TypedOp>>, Error>

Source

pub fn check_consistency(&self) -> Result<(), Error>

Source

pub fn into_decluttered( self, ) -> Result<Graph<TypedFact, Box<dyn TypedOp>>, Error>

Source

pub fn transform(&mut self, transform: &dyn ModelTransform) -> Result<(), Error>

Perform declutter passes on the network.

Source

pub fn declutter(&mut self) -> Result<(), Error>

Perform declutter passes on the network.

Source

pub fn optimize_with_session( &mut self, session: &mut OptimizerSession<'_>, ) -> Result<(), Error>

Perform optimization passes on the model, using a given optimizer session.

Source

pub fn concretize_dims( &self, values: &SymbolValues, ) -> Result<Graph<TypedFact, Box<dyn TypedOp>>, Error>

Source

pub fn prop_consts(&mut self) -> Result<(), Error>

Source

pub fn optimize(&mut self) -> Result<(), Error>

Translate the graph to locally optimized operators (LIR or MIR ops).

Source

pub fn node_axes_mapping(&self, id: usize) -> Result<AxesMapping, Error>

Source

pub fn axes_mapping(&self) -> Result<AxesMapping, Error>

Source

pub fn compute_const_facts(&mut self) -> Result<(), Error>

Trait Implementations§

Source§

impl<F, O> Clone for Graph<F, O>
where F: Clone + Fact + 'static, O: Clone + Debug + Display + AsRef<dyn Op> + AsMut<dyn Op> + 'static,

Source§

fn clone(&self) -> Graph<F, O>

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<F, O> Debug for Graph<F, O>
where F: Debug + Fact + Clone + 'static, O: Debug + Display + AsRef<dyn Op> + AsMut<dyn Op> + Clone + 'static,

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
Source§

impl<F, O> Default for Graph<F, O>
where F: Fact + Clone + 'static, O: Debug + Display + AsRef<dyn Op> + AsMut<dyn Op> + Clone + 'static,

Source§

fn default() -> Graph<F, O>

Returns the “default value” for a type. Read more
Source§

impl<F, O> Display for Graph<F, O>
where F: Fact + Clone + 'static, O: Debug + Display + AsRef<dyn Op> + AsMut<dyn Op> + Clone + 'static,

Source§

fn fmt(&self, fmt: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
Source§

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>

Build a model from a filename.
Source§

fn proto_model_for_path( &self, path: impl AsRef<Path>, ) -> Result<ProtoModel, Error>

Read a proto model from a filename.
Source§

fn proto_model_for_read( &self, reader: &mut dyn Read, ) -> Result<ProtoModel, Error>

Parse a proto model from a reader.
Source§

fn model_for_proto_model_with_model_template( &self, proto: &ProtoModel, template: Graph<TypedFact, Box<dyn TypedOp>>, ) -> Result<Graph<TypedFact, Box<dyn TypedOp>>, Error>

Translate a proto model into a model, with some symbols already listed.
Source§

fn model_for_proto_model(&self, proto: &ProtoModel) -> Result<Model, Error>

Translate a proto model into a model.
Source§

fn model_for_read(&self, r: &mut dyn Read) -> Result<Model, Error>

Read a model from a reader
Source§

impl InnerModel for Graph<TypedFact, Box<dyn TypedOp>>

Source§

fn output_facts( &self, _inputs: &[&TypedFact], ) -> Result<SmallVec<[TypedFact; 4]>, Error>

Source§

fn is_stateless(&self) -> bool

Source§

fn state( &self, session: &mut SessionState, node_id: usize, ) -> Result<Option<Box<dyn OpState>>, Error>

Source§

fn declutter(&mut self) -> Result<(), Error>

Source§

fn codegen(&mut self) -> Result<(), Error>

Source§

fn as_typed(&self) -> &Graph<TypedFact, Box<dyn TypedOp>>

Source§

impl SpecialOps<TypedFact, Box<dyn TypedOp>> for Graph<TypedFact, Box<dyn TypedOp>>

Source§

fn is_source(op: &Box<dyn TypedOp>) -> bool

Source§

fn create_dummy(&self) -> Box<dyn TypedOp>

Source§

fn create_source(&self, fact: TypedFact) -> Box<dyn TypedOp>

Source§

fn wire_node( &mut self, name: impl Into<String>, op: impl Into<Box<dyn TypedOp>>, inputs: &[OutletId], ) -> Result<SmallVec<[OutletId; 4]>, Error>

Source§

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>

§

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>
where O: Unpin, F: Unpin,

§

impl<F, O> !UnwindSafe for Graph<F, O>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> Downcast for T
where T: Any,

Source§

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>

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)

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)

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
where T: Any + Send + Sync,

Source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Sync + Send>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
Source§

impl<T> DynClone for T
where T: Clone,

Source§

fn __clone_box(&self, _: Private) -> *mut ()

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> CloneAny for T
where T: Any + Clone,