Skip to main content

LeaderFinder

Struct LeaderFinder 

Source
pub struct LeaderFinder { /* private fields */ }
Expand description

Finds the leader of an equivalence class — the canonical variable that dominates all other members of the class.

In LCNF, dominance is determined by binding order (earlier binding dominates later bindings in the same scope).

Implementations§

Source§

impl LeaderFinder

Source

pub fn new() -> Self

Source

pub fn record(&mut self, vn: ValueNumber, var: LcnfVarId)

Record that var belongs to equivalence class vn.

Source

pub fn leader(&self, vn: ValueNumber) -> Option<LcnfVarId>

Return the leader of the equivalence class for vn.

Source

pub fn members(&self, vn: ValueNumber) -> &[LcnfVarId]

Return all members of the equivalence class for vn.

Source

pub fn num_redundancies(&self) -> usize

Return the number of non-singleton equivalence classes.

Trait Implementations§

Source§

impl Debug for LeaderFinder

Source§

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

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

impl Default for LeaderFinder

Source§

fn default() -> LeaderFinder

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

Auto Trait Implementations§

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, 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.