Struct tract_pulse::internal::tract_core::prelude::Graph    
[−]pub struct Graph<F, O> where
    F: 'static + Fact + Hash + Clone,
    O: 'static + Debug + Display + AsRef<dyn Op + 'static> + AsMut<dyn Op + 'static> + Clone + Hash,  {
    pub nodes: Vec<Node<F, O>, Global>,
    pub inputs: Vec<OutletId, Global>,
    pub outputs: Vec<OutletId, Global>,
    pub outlet_labels: HashMap<OutletId, String, RandomState>,
    pub properties: HashMap<String, Arc<Tensor>, RandomState>,
}Expand description
Main model class
Parameterized by a Fact class.
Fields
nodes: Vec<Node<F, O>, Global>all nodes in the model
inputs: Vec<OutletId, Global>model inputs
outputs: Vec<OutletId, Global>model outputs
outlet_labels: HashMap<OutletId, String, RandomState>outlet labels
properties: HashMap<String, Arc<Tensor>, RandomState>model properties
Implementations
impl<F, O> Graph<F, O> where
    F: 'static + Fact + Hash + Clone,
    O: 'static + Debug + Display + AsRef<dyn Op + 'static> + AsMut<dyn Op + 'static> + Clone + Hash,
    Graph<F, O>: SpecialOps<F, O>, 
impl<F, O> Graph<F, O> where
    F: 'static + Fact + Hash + Clone,
    O: 'static + Debug + Display + AsRef<dyn Op + 'static> + AsMut<dyn Op + 'static> + Clone + Hash,
    Graph<F, O>: SpecialOps<F, O>, 
impl<F, O> Graph<F, O> where
    F: 'static + Fact + Hash + Clone,
    O: 'static + Debug + Display + AsRef<dyn Op + 'static> + AsMut<dyn Op + 'static> + Clone + Hash, 
impl<F, O> Graph<F, O> where
    F: 'static + Fact + Hash + Clone,
    O: 'static + Debug + Display + AsRef<dyn Op + 'static> + AsMut<dyn Op + 'static> + Clone + Hash, 
pub fn add_node(
    &mut self, 
    name: impl Into<String>, 
    op: impl Into<O>, 
    output_facts: SmallVec<[F; 4]>
) -> Result<usize, Error>
pub 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.
pub 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.
pub 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.
pub 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.
pub 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.
pub 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.
pub 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.
pub 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.
pub 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.
pub fn set_output_outlets(&mut self, outputs: &[OutletId]) -> Result<(), Error>
pub fn set_output_outlets(&mut self, outputs: &[OutletId]) -> Result<(), Error>
Change model outputs.
pub 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.
pub 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.
pub 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.
pub 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.
pub 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.
pub 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.
pub 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.
pub 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>
pub 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.
pub 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>
pub 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.
pub 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.
pub 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.
pub 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.
pub 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.
pub 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.
pub 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.
pub 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.
pub fn outlet_label(&self, outlet: OutletId) -> Option<&str>
pub fn outlet_label(&self, outlet: OutletId) -> Option<&str>
Get label for an outlet.
pub 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.
pub 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.
pub fn find_outlet_label(&self, label: &str) -> Option<OutletId>
pub fn find_outlet_label(&self, label: &str) -> Option<OutletId>
Find outlet by label.
pub fn eval_order(&self) -> Result<Vec<usize, Global>, Error>
pub fn eval_order(&self) -> Result<Vec<usize, Global>, Error>
Computes an evalutation order for the graph inputs and outputs
pub fn check_edges(&self) -> Result<(), Error>
pub 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.
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]
impl<F, O> Graph<F, O> where
    F: 'static + Fact + Clone + From<Arc<Tensor>> + Hash,
    O: 'static + Debug + Display + From<Const> + AsRef<dyn Op + 'static> + AsMut<dyn Op + 'static> + Clone + Hash, 
impl<F, O> Graph<F, O> where
    F: 'static + Fact + Clone + From<Arc<Tensor>> + Hash,
    O: 'static + Debug + Display + From<Const> + AsRef<dyn Op + 'static> + AsMut<dyn Op + 'static> + Clone + Hash, 
impl<F, O> Graph<F, O> where
    F: 'static + Fact + Clone + Hash + for<'a> From<&'a F>,
    O: 'static + Display + Debug + Clone + AsRef<dyn Op + 'static> + AsMut<dyn Op + 'static> + Hash + for<'a> From<&'a O>,
    Graph<F, O>: SpecialOps<F, O>, 
impl<F, O> Graph<F, O> where
    F: 'static + Fact + Clone + Hash + for<'a> From<&'a F>,
    O: 'static + Display + Debug + Clone + AsRef<dyn Op + 'static> + AsMut<dyn Op + 'static> + Hash + for<'a> From<&'a O>,
    Graph<F, O>: SpecialOps<F, O>, 
impl Graph<TypedFact, Box<dyn TypedOp + 'static, Global>>
impl Graph<TypedFact, Box<dyn TypedOp + 'static, Global>>
pub fn signature(&self) -> u64
pub fn into_optimized(
    self
) -> Result<Graph<TypedFact, Box<dyn TypedOp + 'static, Global>>, Error>
pub fn check_consistency(&self) -> Result<(), Error>
pub fn into_decluttered(
    self
) -> Result<Graph<TypedFact, Box<dyn TypedOp + 'static, Global>>, Error>
pub 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 + 'static, Global>>, Error>
pub 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 invariants(&self) -> Result<Invariants, Error>
Trait Implementations
impl<F, O> Clone for Graph<F, O> where
    F: Clone + 'static + Fact + Hash,
    O: Clone + 'static + Debug + Display + AsRef<dyn Op + 'static> + AsMut<dyn Op + 'static> + Hash, 
impl<F, O> Clone for Graph<F, O> where
    F: Clone + 'static + Fact + Hash,
    O: Clone + 'static + Debug + Display + AsRef<dyn Op + 'static> + AsMut<dyn Op + 'static> + Hash, 
impl<F, O> Debug for Graph<F, O> where
    F: Debug + 'static + Fact + Hash + Clone,
    O: Debug + 'static + Display + AsRef<dyn Op + 'static> + AsMut<dyn Op + 'static> + Clone + Hash, 
impl<F, O> Debug for Graph<F, O> where
    F: Debug + 'static + Fact + Hash + Clone,
    O: Debug + 'static + Display + AsRef<dyn Op + 'static> + AsMut<dyn Op + 'static> + Clone + Hash, 
impl<F, O> Default for Graph<F, O> where
    F: 'static + Fact + Hash + Clone,
    O: 'static + Debug + Display + AsRef<dyn Op + 'static> + AsMut<dyn Op + 'static> + Clone + Hash, 
impl<F, O> Default for Graph<F, O> where
    F: 'static + Fact + Hash + Clone,
    O: 'static + Debug + Display + AsRef<dyn Op + 'static> + AsMut<dyn Op + 'static> + Clone + Hash, 
impl<F, O> Display for Graph<F, O> where
    F: 'static + Fact + Hash + Clone,
    O: 'static + Debug + Display + AsRef<dyn Op + 'static> + AsMut<dyn Op + 'static> + Clone + Hash, 
impl<F, O> Display for Graph<F, O> where
    F: 'static + Fact + Hash + Clone,
    O: 'static + Debug + Display + AsRef<dyn Op + 'static> + AsMut<dyn Op + 'static> + Clone + Hash, 
impl<F, O> DynHash for Graph<F, O> where
    F: 'static + Fact + Hash + Clone,
    O: 'static + Debug + Display + AsRef<dyn Op + 'static> + AsMut<dyn Op + 'static> + Clone + Hash, 
impl<F, O> DynHash for Graph<F, O> where
    F: 'static + Fact + Hash + Clone,
    O: 'static + Debug + Display + AsRef<dyn Op + 'static> + AsMut<dyn Op + 'static> + Clone + Hash, 
impl Framework<ProtoModel, Graph<TypedFact, Box<dyn TypedOp + 'static, Global>>> for Nnef
impl Framework<ProtoModel, Graph<TypedFact, Box<dyn TypedOp + 'static, Global>>> for Nnef
fn model_for_path(
    &self, 
    p: impl AsRef<Path>
) -> Result<Graph<TypedFact, Box<dyn TypedOp + 'static, Global>>, Error>
fn model_for_path(
    &self, 
    p: impl AsRef<Path>
) -> Result<Graph<TypedFact, Box<dyn TypedOp + 'static, Global>>, Error>
Build a model from a filename.
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>
Read a proto model from a filename.
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>
Parse a proto model from a reader.
fn model_for_proto_model(
    &self, 
    proto: &ProtoModel
) -> Result<Graph<TypedFact, Box<dyn TypedOp + 'static, Global>>, Error>
fn model_for_proto_model(
    &self, 
    proto: &ProtoModel
) -> Result<Graph<TypedFact, Box<dyn TypedOp + 'static, Global>>, Error>
Translate a proto model into a model.
fn model_for_read(&self, r: &mut dyn Read) -> Result<Model, Error>
fn model_for_read(&self, r: &mut dyn Read) -> Result<Model, Error>
Read a model from a reader
impl<F, O> Hash for Graph<F, O> where
    F: 'static + Fact + Hash + Clone,
    O: 'static + Debug + Display + AsRef<dyn Op + 'static> + AsMut<dyn Op + 'static> + Clone + Hash, 
impl<F, O> Hash for Graph<F, O> where
    F: 'static + Fact + Hash + Clone,
    O: 'static + Debug + Display + AsRef<dyn Op + 'static> + AsMut<dyn Op + 'static> + Clone + Hash, 
impl SpecialOps<TypedFact, Box<dyn TypedOp + 'static, Global>> for Graph<TypedFact, Box<dyn TypedOp + 'static, Global>>
impl SpecialOps<TypedFact, Box<dyn TypedOp + 'static, Global>> for Graph<TypedFact, Box<dyn TypedOp + 'static, Global>>
fn is_source(op: &Box<dyn TypedOp + 'static, Global>) -> bool
fn create_dummy(&self) -> Box<dyn TypedOp + 'static, Global>ⓘNotable traits for Box<W, Global>impl<W> Write for Box<W, Global> where
    W: Write + ?Sized, impl<R> Read for Box<R, Global> where
    R: Read + ?Sized, impl<F, A> Future for Box<F, A> where
    F: Future + Unpin + ?Sized,
    A: Allocator + 'static,     type Output = <F as Future>::Output;impl<I, A> Iterator for Box<I, A> where
    I: Iterator + ?Sized,
    A: Allocator,     type Item = <I as Iterator>::Item;
W: Write + ?Sized, impl<R> Read for Box<R, Global> where
R: Read + ?Sized, impl<F, A> Future for Box<F, A> where
F: Future + Unpin + ?Sized,
A: Allocator + 'static, type Output = <F as Future>::Output;impl<I, A> Iterator for Box<I, A> where
I: Iterator + ?Sized,
A: Allocator, type Item = <I as Iterator>::Item;
fn create_source(&self, fact: TypedFact) -> Box<dyn TypedOp + 'static, Global>ⓘNotable traits for Box<W, Global>impl<W> Write for Box<W, Global> where
    W: Write + ?Sized, impl<R> Read for Box<R, Global> where
    R: Read + ?Sized, impl<F, A> Future for Box<F, A> where
    F: Future + Unpin + ?Sized,
    A: Allocator + 'static,     type Output = <F as Future>::Output;impl<I, A> Iterator for Box<I, A> where
    I: Iterator + ?Sized,
    A: Allocator,     type Item = <I as Iterator>::Item;
W: Write + ?Sized, impl<R> Read for Box<R, Global> where
R: Read + ?Sized, impl<F, A> Future for Box<F, A> where
F: Future + Unpin + ?Sized,
A: Allocator + 'static, type Output = <F as Future>::Output;impl<I, A> Iterator for Box<I, A> where
I: Iterator + ?Sized,
A: Allocator, type Item = <I as Iterator>::Item;
fn wire_node(
    &mut self, 
    name: impl Into<String>, 
    op: impl Into<Box<dyn TypedOp + 'static, Global>>, 
    inputs: &[OutletId]
) -> Result<SmallVec<[OutletId; 4]>, Error>
Auto Trait Implementations
impl<F, O> RefUnwindSafe for Graph<F, O> where
    F: RefUnwindSafe,
    O: 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> where
    F: Unpin,
    O: Unpin, 
impl<F, O> UnwindSafe for Graph<F, O> where
    F: UnwindSafe + RefUnwindSafe,
    O: UnwindSafe, 
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
    T: ?Sized, 
 
impl<T> BorrowMut<T> for T where
    T: ?Sized, 
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> Downcast for T where
    T: Any, 
 
impl<T> Downcast for T where
    T: Any, 
sourcefn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>ⓘNotable traits for Box<W, Global>impl<W> Write for Box<W, Global> where
    W: Write + ?Sized, impl<R> Read for Box<R, Global> where
    R: Read + ?Sized, impl<F, A> Future for Box<F, A> where
    F: Future + Unpin + ?Sized,
    A: Allocator + 'static,     type Output = <F as Future>::Output;impl<I, A> Iterator for Box<I, A> where
    I: Iterator + ?Sized,
    A: Allocator,     type Item = <I as Iterator>::Item;
 
fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>ⓘNotable traits for Box<W, Global>impl<W> Write for Box<W, Global> where
    W: Write + ?Sized, impl<R> Read for Box<R, Global> where
    R: Read + ?Sized, impl<F, A> Future for Box<F, A> where
    F: Future + Unpin + ?Sized,
    A: Allocator + 'static,     type Output = <F as Future>::Output;impl<I, A> Iterator for Box<I, A> where
    I: Iterator + ?Sized,
    A: Allocator,     type Item = <I as Iterator>::Item;
W: Write + ?Sized, impl<R> Read for Box<R, Global> where
R: Read + ?Sized, impl<F, A> Future for Box<F, A> where
F: Future + Unpin + ?Sized,
A: Allocator + 'static, type Output = <F as Future>::Output;impl<I, A> Iterator for Box<I, A> where
I: Iterator + ?Sized,
A: Allocator, type Item = <I as Iterator>::Item;
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. Read more
sourcefn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
 
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait. Read more
sourcefn 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. Read more
sourcefn 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. Read more