Struct TreeNode

Source
pub struct TreeNode<T> { /* private fields */ }

Implementations§

Source§

impl<T> TreeNode<T>

Source

pub fn new(val: T) -> Self

Source

pub fn with_arity(val: T, arity: Arity) -> Self

Source

pub fn with_children<N>(val: T, children: Vec<N>) -> Self
where N: Into<TreeNode<T>>,

Source

pub fn is_leaf(&self) -> bool

Source

pub fn add_child(&mut self, child: impl Into<TreeNode<T>>)

Source

pub fn attach(self, other: impl Into<TreeNode<T>>) -> Self

Source

pub fn children(&self) -> Option<&Vec<TreeNode<T>>>

Source

pub fn children_mut(&mut self) -> Option<&mut Vec<TreeNode<T>>>

Source

pub fn size(&self) -> usize

Source

pub fn height(&self) -> usize

Source

pub fn swap_subtrees( &mut self, other: &mut TreeNode<T>, self_idx: usize, other_idx: usize, )

Source

pub fn get_mut(&mut self, index: usize) -> Option<&mut TreeNode<T>>

Trait Implementations§

Source§

impl<T> AsMut<TreeNode<T>> for Tree<T>

Source§

fn as_mut(&mut self) -> &mut TreeNode<T>

Converts this type into a mutable reference of the (usually inferred) input type.
Source§

impl<T> AsRef<TreeNode<T>> for Tree<T>

Source§

fn as_ref(&self) -> &TreeNode<T>

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl<T: Clone> Clone for TreeNode<T>

Source§

fn clone(&self) -> Self

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<T, V> Eval<[V], V> for TreeNode<T>
where T: Eval<[V], V>, V: Clone,

Implements the Reduce trait for TreeNode<T> where T is Eval<[V], V>. This is where the real work is done. It recursively evaluates the TreeNode and its children until it reaches a leaf node, at which point it applies the T’s eval fn to the input.

Because a Tree has only a single root node, this can only be used to return a single value. We assume here that each leaf can eval the incoming input - this is a safe and the only real logical assumption we can make.

Source§

fn eval(&self, input: &[V]) -> V

Source§

impl<T: Clone + Default> Factory<NodeType, TreeNode<T>> for NodeStore<T>

Source§

fn new_instance(&self, input: NodeType) -> TreeNode<T>

Source§

impl<T> Gene for TreeNode<T>
where T: Clone + PartialEq + Default,

Source§

type Allele = T

Source§

fn allele(&self) -> &Self::Allele

Get the allele of the Gene. This is the value that the Gene represents or “expresses”.
Source§

fn new_instance(&self) -> Self

Create a new instance of the Gene.
Source§

fn with_allele(&self, allele: &Self::Allele) -> Self

Create a new Gene with the given allele.
Source§

impl<T> Into<Tree<T>> for TreeNode<T>

Source§

fn into(self) -> Tree<T>

Converts this type into the (usually inferred) input type.
Source§

impl<T> Into<TreeNode<Op<T>>> for Op<T>

Source§

fn into(self) -> TreeNode<Op<T>>

Converts this type into the (usually inferred) input type.
Source§

impl Into<TreeNode<String>> for String

Source§

fn into(self) -> TreeNode<String>

Converts this type into the (usually inferred) input type.
Source§

impl Into<TreeNode<bool>> for bool

Source§

fn into(self) -> TreeNode<bool>

Converts this type into the (usually inferred) input type.
Source§

impl Into<TreeNode<char>> for char

Source§

fn into(self) -> TreeNode<char>

Converts this type into the (usually inferred) input type.
Source§

impl Into<TreeNode<f64>> for f64

Source§

fn into(self) -> TreeNode<f64>

Converts this type into the (usually inferred) input type.
Source§

impl Into<TreeNode<i32>> for i32

Source§

fn into(self) -> TreeNode<i32>

Converts this type into the (usually inferred) input type.
Source§

impl Into<TreeNode<usize>> for usize

Source§

fn into(self) -> TreeNode<usize>

Converts this type into the (usually inferred) input type.
Source§

impl<T> Node for TreeNode<T>

Source§

type Value = T

Source§

fn value(&self) -> &Self::Value

Source§

fn node_type(&self) -> NodeType

Source§

fn arity(&self) -> Arity

Source§

impl<T: PartialEq> PartialEq for TreeNode<T>

Source§

fn eq(&self, other: &TreeNode<T>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<T> TreeIterator<T> for TreeNode<T>

Implement the TreeIterator trait for TreeNode

This allows for traversal of a single node and its children in pre-order, post-order, and breadth-first order.

Source§

fn iter_pre_order(&self) -> PreOrderIterator<'_, T>

Source§

fn iter_post_order(&self) -> PostOrderIterator<'_, T>

Source§

fn iter_breadth_first(&self) -> TreeBreadthFirstIterator<'_, T>

Source§

impl<T> Valid for TreeNode<T>

Source§

fn is_valid(&self) -> bool

Source§

impl<T> StructuralPartialEq for TreeNode<T>

Auto Trait Implementations§

§

impl<T> Freeze for TreeNode<T>
where T: Freeze,

§

impl<T> RefUnwindSafe for TreeNode<T>
where T: RefUnwindSafe,

§

impl<T> Send for TreeNode<T>
where T: Send,

§

impl<T> Sync for TreeNode<T>
where T: Sync,

§

impl<T> Unpin for TreeNode<T>
where T: Unpin,

§

impl<T> UnwindSafe for TreeNode<T>
where T: UnwindSafe,

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, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
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> 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, 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<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V