Struct TreeLearning

Source
pub struct TreeLearning<'a, 'b> {
    pub size: usize,
    root: SubProb<'a>,
    pub subproblems: Vec<SubProb<'a>>,
    limit: usize,
    pub conditions: &'b [(&'static Expr, Bits)],
    pub options: Vec<(&'static Expr, Bits)>,
    pub bump: &'a Bump,
    pub solved: bool,
}
Expand description

A struct encapsulating the state and parameters for a decision tree learning process in string synthesis.

Fields§

§size: usize§root: SubProb<'a>§subproblems: Vec<SubProb<'a>>§limit: usize§conditions: &'b [(&'static Expr, Bits)]§options: Vec<(&'static Expr, Bits)>§bump: &'a Bump§solved: bool

Implementations§

Source§

impl<'a, 'b> TreeLearning<'a, 'b>

Source

pub fn new_in( size: usize, conditions: &'b [(&'static Expr, Bits)], options: Vec<(&'static Expr, Bits)>, bump: &'a Bump, limit: usize, ) -> Self

Creates a new instance with specified parameters including size, conditions, options, memory allocator, and limit.

Source

pub fn entropy(&self, bits: &Bits) -> f32

Calculates the entropy of a given set of bits within the context of the TreeLearning algorithm’s options.

Source

pub fn cond_entropy( &self, bits: &Bits, condition: &Bits, ) -> (f32, (Bits, f32), (Bits, f32))

Calculates the conditional entropy of a given set of bits based on a specified condition bitset.

Source

pub fn select(&self, unsolved: &SubProblem<'a>) -> SelectResult

Determines the next action for an unsolved subproblem in the tree learning process.

Source

pub fn run(&mut self) -> bool

Executes the learning algorithm by iterating over the subproblems within the decision tree.

Source

fn fmt_recursive( &self, f: &mut Formatter<'_>, node: SubProb<'a>, indent: &mut String, ) -> Result

Facilitates the recursive formatting of the decision tree contained within the TreeLearning structure for display purposes.

Source

fn size_recursive(&self, node: SubProb<'a>) -> usize

Determines the size of the decision tree by recursively traversing through its nodes.

Source

fn cover_recursive(&self, node: SubProb<'a>) -> Bits

Covers a decision tree recursively starting from a given node and determining the set of bits covered by the tree structure.

Source

fn expr_recursizve(&self, node: SubProb<'a>) -> &'static Expr

Returns the expression representation of a given node in the decision tree.

Source

fn unsolved_recursive(&self, node: SubProb<'a>, result: &mut Vec<Box<[u128]>>)

Recursively traverses through a decision tree to collect bits from unsolved subproblems.

Source

fn unsolved(&self) -> Vec<Box<[u128]>>

Returns a vector of boxed slices containing u128 values that represent unsolved components of a decision tree.

Source

pub fn expr(&self) -> &'static Expr

Returns the expression associated with the root of the decision tree. This function utilizes a recursive approach by invoking expr_recursizve on the tree’s root node to retrieve the expression efficiently, leveraging the recursive structure to navigate through potentially complex tree configurations within the TreeLearning context.

Source

pub fn result_size(&self) -> usize

Calculates the result size of a decision tree by recursively determining the size starting from the root node. This implementation utilizes the size_recursive function on the root to compute the cumulative size of the tree structure, which includes all subproblems, branches, and accepted solutions present in the tree.

Trait Implementations§

Source§

impl<'a, 'b> Debug for TreeLearning<'a, 'b>

Source§

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

Formats the decision tree within the TreeLearning instance for display.

Auto Trait Implementations§

§

impl<'a, 'b> Freeze for TreeLearning<'a, 'b>

§

impl<'a, 'b> !RefUnwindSafe for TreeLearning<'a, 'b>

§

impl<'a, 'b> !Send for TreeLearning<'a, 'b>

§

impl<'a, 'b> !Sync for TreeLearning<'a, 'b>

§

impl<'a, 'b> Unpin for TreeLearning<'a, 'b>

§

impl<'a, 'b> !UnwindSafe for TreeLearning<'a, 'b>

Blanket Implementations§

Source§

impl<T> AllocForAny<T> for T

Source§

fn galloc(self) -> &'static T

Provides a method to allocate an instance of T on the heap with a static lifetime.

This implementation of galloc takes ownership of the T instance and uses the alloc function to place it in a location with a static lifetime, presumably managing it in a way that ensures its persistence for the duration of the program. This can be particularly useful for scenarios where a static lifetime is required, such as when interfacing with systems or patterns that necessitate global state or long-lived data.

Source§

fn galloc_mut(self) -> &'static T

Provides a method that moves the instance and returns a reference to it allocated with a static lifetime.

This method utilizes alloc_mut to perform the allocation, likely involving allocating the resource in a manner that ensures it lives for the entire duration of the application. These semantics allow the user to safely assume that the reference will not expire during the program’s execution, making it suitable for long-lived data structures or operations that require such guarantees.

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> 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> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. 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