Unfold

Struct Unfold 

Source
pub struct Unfold<State> {
    pub kernel: fn(&mut TrieFnState<(i64, State), State>, (i64, State)) -> State,
}
Expand description

Combinator struct for kernels that use the TrieFnState DSL (sample_at and trace_at) and automatically implement the GFI. Supports memory-efficient extension via the GfDiff::Extend flag (eg. as passed during a ParticleSystem::step).

Fields§

§kernel: fn(&mut TrieFnState<(i64, State), State>, (i64, State)) -> State

A random kernel that takes in a mutable reference to a TrieFnState<A,T> and some State, effectfully mutates it, and produces a new State.

Trait Implementations§

Source§

impl<State: Clone> GenFn<(i64, State), Vec<Trie<(Rc<dyn Any>, f64)>>, Vec<State>> for Unfold<State>

Source§

fn simulate( &self, T_and_args: (i64, State), ) -> Trace<(i64, State), Vec<Trie<(Rc<dyn Any>, f64)>>, Vec<State>>

Execute the generative function and return a sampled trace.
Source§

fn generate( &self, T_and_args: (i64, State), vec_constraints: Vec<Trie<(Rc<dyn Any>, f64)>>, ) -> (Trace<(i64, State), Vec<Trie<(Rc<dyn Any>, f64)>>, Vec<State>>, f64)

Execute the generative function consistent with constraints. Return the log probability log[p(t; args) / q(t; constraints, args)]
Source§

fn update( &self, vec_trace: Trace<(i64, State), Vec<Trie<(Rc<dyn Any>, f64)>>, Vec<State>>, T_and_args: (i64, State), diff: GfDiff, vec_constraints: Vec<Trie<(Rc<dyn Any>, f64)>>, ) -> (Trace<(i64, State), Vec<Trie<(Rc<dyn Any>, f64)>>, Vec<State>>, Vec<Trie<(Rc<dyn Any>, f64)>>, f64)

Update a trace
Source§

fn call(&self, args: Args) -> Ret

Call a generative function and return the output.
Source§

fn propose(&self, args: Args) -> (Data, f64)

Use a generative function to propose some data.
Source§

fn assess(&self, args: Args, constraints: Data) -> f64

Assess the conditional probability of some proposed constraints under a generative function.

Auto Trait Implementations§

§

impl<State> Freeze for Unfold<State>

§

impl<State> RefUnwindSafe for Unfold<State>

§

impl<State> Send for Unfold<State>

§

impl<State> Sync for Unfold<State>

§

impl<State> Unpin for Unfold<State>

§

impl<State> UnwindSafe for Unfold<State>

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

Source§

type Output = T

Should always be Self
Source§

impl<SS, SP> SupersetOf<SS> for SP
where SS: SubsetOf<SP>,

Source§

fn to_subset(&self) -> Option<SS>

The inverse inclusion map: attempts to construct self from the equivalent element of its superset. Read more
Source§

fn is_in_subset(&self) -> bool

Checks if self is actually part of its subset T (and can be converted to it).
Source§

fn to_subset_unchecked(&self) -> SS

Use with care! Same as self.to_subset but without any property checks. Always succeeds.
Source§

fn from_subset(element: &SS) -> SP

The inclusion map: converts self to the equivalent element of its superset.
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