Table of Contents

Public classSealed LevenshteinAutomaton

Namespace
Rowles.LeanLucene.Codecs.Fst
Assembly
Rowles.LeanLucene.dll

Levenshtein DFA accepting strings within edit distance maxEdits of a reference term. Built via NFA-to-DFA subset construction at construction time to correctly handle deletions (ε-transitions that advance position without consuming input). Operates on UTF-8 bytes.

public sealed class LevenshteinAutomaton : IAutomaton
LevenshteinAutomaton
Implements

Public constructor LevenshteinAutomaton(ReadOnlySpan<byte>, int)

Initialises a new LevenshteinAutomaton from a raw UTF-8 byte representation of the term.

Public constructor LevenshteinAutomaton(string, int)

Initialises a new LevenshteinAutomaton for the given term and maximum edit distance.

Public property Start

Initial state of the automaton.

Public method CanMatch(int)

Returns true if the automaton could potentially accept any string starting from the given state. Used for early pruning during intersection. Returns false only if the state is dead (no path to any accept state).

Public method IsAccept(int)

Returns true if the given state is an accepting state.

Public method Step(int, byte)

Transition function: returns next state given current state and input byte, or -1 if no transition.