Skip to main content

ReductionStrategy

Enum ReductionStrategy 

Source
pub enum ReductionStrategy {
    WHNF,
    NF,
    OneStep,
    CBV,
    CBN,
    HeadOnly,
}
Expand description

Reduction strategy for expression simplification.

Different strategies trade off between completeness and efficiency. Most use cases should use ReductionStrategy::WHNF or ReductionStrategy::NF.

Variants§

§

WHNF

Reduce to weak head normal form.

Only reduces the outermost redex; sub-expressions may remain unreduced. Efficient for most type-checking purposes.

§

NF

Reduce to normal form.

Fully reduces all sub-expressions. More expensive than WHNF.

§

OneStep

Reduce exactly one step.

Finds and reduces the outermost leftmost redex.

§

CBV

Call-by-value reduction.

Evaluates arguments before applying functions (strict evaluation).

§

CBN

Call-by-name reduction.

Applies functions before evaluating arguments (lazy evaluation).

§

HeadOnly

Head reduction only.

Like OneStep but restricted to the head position.

Implementations§

Source§

impl ReductionStrategy

Source

pub fn name(&self) -> &'static str

Returns a human-readable name for the strategy.

Source

pub fn is_complete(&self) -> bool

Returns true if this strategy reduces to a complete normal form.

Source

pub fn is_lazy(&self) -> bool

Returns true if this is a lazy strategy.

Source

pub fn is_eager(&self) -> bool

Returns true if this is an eager/strict strategy.

Trait Implementations§

Source§

impl Clone for ReductionStrategy

Source§

fn clone(&self) -> ReductionStrategy

Returns a duplicate 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 Debug for ReductionStrategy

Source§

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

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

impl Display for ReductionStrategy

Source§

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

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

impl Hash for ReductionStrategy

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl PartialEq for ReductionStrategy

Source§

fn eq(&self, other: &ReductionStrategy) -> 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 Copy for ReductionStrategy

Source§

impl Eq for ReductionStrategy

Source§

impl StructuralPartialEq for ReductionStrategy

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. 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.