Unambiguous finite automaton

In automata theory, an unambiguous finite automaton (UFA) is a nondeterministic finite automaton (NFA) such that each word has at most one accepting path. Each deterministic finite automaton (DFA) is an UFA, but not vice versa. DFA, UFA, and NFA recognize exactly the same class of formal languages. On the one hand, an NFA can be exponentially smaller than an equivalent DFA. On the other hand, some problems are easily solved on DFAs and not on UFAs. For example, given an automaton A, an automaton A which accepts the complement of A can be computed in linear time when A is a DFA, it is not known whether it can be done in polynomial time for UFA. Hence UFAs are a mix of the worlds of DFA and of NFA; in some cases, they lead to smaller automata than DFA and quicker algorithms than NFA.

Formal definition

An NFA is represented formally by a 5-tuple, A=(Q, Σ, Δ, q0, F). An UFA is an NFA such that, for each word w = a1a2 … an, there exists at most one sequence of states r0,r1, …, rn, in Q with the following conditions:

  1. r0 = q0
  2. ri+1 ∈ Δ(ri, ai+1), for i = 0, …, n−1
  3. rnF.

In words, those conditions state that, if w is accepted by A, there is exactly one accepting path, that is, one path from an initial state to a final state, labelled by w.

Example

Let L be the set of words over the alphabet {a,b} whose nth last letter is an a. The figures show a DFA and a UFA accepting this language for n=2.

Deterministic automaton (DFA) for the language L for n=2
Unambiguous finite automaton (UFA) for the language L for n=2

The minimal DFA accepting L has 2n states, one for each subset of {1...n}. There is an UFA of n+1 states which accepts L: it guesses the nth last letter, and then verifies that only n-1 letters remain. It is indeed unambiguous as there exists only one nth last letter.

Three PSPACE-hard problems for general NFA belong to PTIME for DFA and are now considered.

Inclusion

It is decidable in polynomial-time whether an UFA's language is a subset of another UFA's language.

Sketch of the proof of inclusion

Let A and B be two UFAs. Let L(A) and L(B) be the languages accepted by those automata. Then L(A)⊆L(B) if and only if L(AB)=L(A), where AB denotes the Cartesian product automaton, which can be proven to be also unambiguous. Now, L(AB) is a subset of L(A) by construction; hence both sets are equal if and only if for each length n∈ℕ, the number of words of length n in L(AB) is equal to the number of words of length n in L(A). It can be proved that is sufficient to check each n up to the product of the number of states of A and B.

The number of words of length n accepted by an automaton can be computed in polynomial time using dynamic programming, which ends the proof.[1]

The problem of universality[note 1] and of equivalence,[note 2] also belong to PTIME, by reduction to the inclusion problem.

Checking whether an automaton in unambiguous

For a nondeterministic finite automaton A with n states and an m letter alphabet, it is decidable in time O(n2m) whether A is unambiguous.[2]

Sketch of the proof of unambiguity

It suffices to use a fixpoint algorithm to compute the set of pairs of states q and q' such that there exists a word w which leads both to q and to q' . The automaton is unambiguous if and only if there is no such a pair such that both states are accepting. There are at most O(n2) state pairs, and for each pair there are m letters to consider to resume the fixpoint algorithm, hence the computation time.

Some properties

  • The cartesian product of two UFAs is a UFA.[3]
  • The notion of unambiguity extends to finite state transducers and weighted automata. If a finite state transducer T is unambiguous, then each input word is associated by T to at most one output word. If a weighted automaton A is unambiguous, then the set of weight does not need to be a semiring, instead it suffices to consider a monoid. Indeed, there is at most one accepting path.

State complexity

Mathematical proofs that every UFA for a language needs a certain number of states were pioneered by Schmidt.[4] Leung proved that a DFA equivalent to an -state UFA requires states in the worst case. and a UFA equivalent to an -state NFA requires states.[5]

Jirásek, Jirásková and Šebej[6] researched the number of states necessary to represent basic operations on languages. They proved in particular that for every -state UFA the complement of the language it accepts is accepted by a UFA with states.

For a one-letter alphabet Okhotin proved that a DFA equivalent to an -state UFA requires states in the worst case.[7]

Notes

  1. i.e.: given a UFA, does it accept every string of Σ*?
  2. i.e.: given two UFAs, do they accept the same set of strings?
gollark: musl is pretty small, but still more than that.
gollark: I assume it's dynamically linked and the 8KB is overhead from including it.
gollark: You can meddle with some compile flags.
gollark: Hey, reimplement your wordsearch program in x86-64.
gollark: It would be easy enough if I could figure out how to convert the hexgrid into axial/cube coords.

References

  • Christof Löding, Unambiguous Finite Automata, Developments in Language Theory, (2013) pp. 29–30 (Slides)
  1. Christof Löding, Unambiguous Finite Automata, Slide 8
  2. Sakarovitch, Jacques; Thomas, Reuben. Elements of Automata Theory. Cambridge: Cambridge university press. p. 75. ISBN 978-0-521-84425-3.
  3. Christof Löding, Unambiguous Finite Automata, Slide 8
  4. Schmidt, Erik M. (1978). Succinctness of Description of Context-Free, Regular and Unambiguous Languages (Ph.D.). Cornell University.
  5. Leung, Hing (2005). "Descriptional complexity of NFA of different ambiguity". International Journal of Foundations of Computer Science. 16 (05): 975–984. doi:10.1142/S0129054105003418. ISSN 0129-0541.
  6. Jirásek, Jozef; Jirásková, Galina; Šebej, Juraj (2016). "Operations on Unambiguous Finite Automata". 9840: 243–255. doi:10.1007/978-3-662-53132-7_20. ISSN 0302-9743. Cite journal requires |journal= (help)
  7. Okhotin, Alexander (2012). "Unambiguous finite automata over a unary alphabet". Information and Computation. 212: 15–36. doi:10.1016/j.ic.2012.01.003. ISSN 0890-5401.
This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.