Loading AI tools
Smallest monoid that recognizes a formal language From Wikipedia, the free encyclopedia
In mathematics and computer science, the syntactic monoid of a formal language is the smallest monoid that recognizes the language .
The free monoid on a given set is the monoid whose elements are all the strings of zero or more elements from that set, with string concatenation as the monoid operation and the empty string as the identity element. Given a subset of a free monoid , one may define sets that consist of formal left or right inverses of elements in . These are called quotients, and one may define right or left quotients, depending on which side one is concatenating. Thus, the right quotient of by an element from is the set
Similarly, the left quotient is
The syntactic quotient[clarification needed] induces an equivalence relation on , called the syntactic relation, or syntactic equivalence (induced by ).
The right syntactic equivalence is the equivalence relation
Similarly, the left syntactic equivalence is
Observe that the right syntactic equivalence is a left congruence with respect to string concatenation and vice versa; i.e., for all .
The syntactic congruence or Myhill congruence[1] is defined as[2]
The definition extends to a congruence defined by a subset of a general monoid . A disjunctive set is a subset such that the syntactic congruence defined by is the equality relation.[3]
Let us call the equivalence class of for the syntactic congruence. The syntactic congruence is compatible with concatenation in the monoid, in that one has
for all . Thus, the syntactic quotient is a monoid morphism, and induces a quotient monoid
This monoid is called the syntactic monoid of . It can be shown that it is the smallest monoid that recognizes ; that is, recognizes , and for every monoid recognizing , is a quotient of a submonoid of . The syntactic monoid of is also the transition monoid of the minimal automaton of .[1][2][4]
A group language is one for which the syntactic monoid is a group.[5]
The Myhill–Nerode theorem states: a language is regular if and only if the family of quotients is finite, or equivalently, the left syntactic equivalence has finite index (meaning it partitions into finitely many equivalence classes).[6]
This theorem was first proved by Anil Nerode (Nerode 1958) and the relation is thus referred to as Nerode congruence by some authors.[7][8]
The proof of the "only if" part is as follows. Assume that a finite automaton recognizing reads input , which leads to state . If is another string read by the machine, also terminating in the same state , then clearly one has . Thus, the number of elements in is at most equal to the number of states of the automaton and is at most the number of final states.
For a proof of the "if" part, assume that the number of elements in is finite. One can then construct an automaton where is the set of states, is the set of final states, the language is the initial state, and the transition function is given by . Clearly, this automaton recognizes .
Thus, a language is recognizable if and only if the set is finite. Note that this proof also builds the minimal automaton.
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.