Skip to main content

Nfa

Struct Nfa 

Source
pub struct Nfa<'a, T> { /* private fields */ }
Expand description

A non-deterministic fintie automaton.

Implementations§

Source§

impl<'a, const TARGETS_HINT: usize, Σ: Eq + Hash + Copy> Nfa<'a, State<TARGETS_HINT, Σ>>
where [NonNull<State<TARGETS_HINT, Σ>>; TARGETS_HINT]: Array<Item = NonNull<State<TARGETS_HINT, Σ>>>,

Source

pub fn new(start_node: &'a State<TARGETS_HINT, Σ>) -> Self

Creates a new NFA with the given start node, consumes the arena where the nodes were made. TODO: This can just take any arena, and then we would be able to change the NFA after creation. is that a good idea?

Source

pub fn as_dfa(&self, arena: &Corrida) -> Dfa<'a, Σ, PartialState<Σ>>

Converts the NFA to a DFA using subset construction.

Source

pub fn simulate_iter(&self, input: impl Iterator<Item = Σ>) -> bool

Simulates the NFA on the given input, returning if the NFA accepts the input.

Source

pub fn simulate_slice(&self, input: &[Σ]) -> bool

Simulates the NFA on the given input, returning if the NFA accepts the input.

Source

pub fn simulate_iter_friendly(&self, input: impl Iterator<Item = Σ>) -> bool

Simulates the NFA on the given input, returning if the NFA accepts the input. Will infinite loop on epsilon loops, so only use for ‘friendly’ NFAs where specific states are not reached many times at the same token.

Source

pub fn simulate_slice_friendly(&self, input: &[Σ]) -> bool

Simulates the NFA on the given input, returning if the NFA accepts the input. Will infinite loop on epsilon loops, so only use for ‘friendly’ NFAs where specific states are not reached many times at the same token.

Auto Trait Implementations§

§

impl<'a, T> Freeze for Nfa<'a, T>

§

impl<'a, T> RefUnwindSafe for Nfa<'a, T>
where T: RefUnwindSafe,

§

impl<'a, T> Send for Nfa<'a, T>
where T: Sync,

§

impl<'a, T> Sync for Nfa<'a, T>
where T: Sync,

§

impl<'a, T> Unpin for Nfa<'a, T>

§

impl<'a, T> UnsafeUnpin for Nfa<'a, T>

§

impl<'a, T> UnwindSafe for Nfa<'a, T>
where T: RefUnwindSafe,

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.