Minimization of deterministic finite automata is a largely studied problem of the Theory of Automata and Formal Languages. It consists in finding the unique (up to isomorphism) minimal deterministic automaton recognizing a set of words. The first approaches to this topic can be traced back to the 1950's with the works of Huffman and Moore (cf. [12,15]). Over the years several methods to solve this problem have been proposed but the most efficient algorithm in the worst case was given by Hopcroft in [11]. Such an algorithm computes in O(nlogn) the minimal automaton equivalent to a given automaton with nstates. The Hopcroft's algorithm has been widely studied, described and implemented by many authors (cf. [13,4,16,2]). In particular, in [4] the worst case of the algorithm is considered. The authors of [4] introduce an infinite family of automata associated to circular words. The circular words taken into account are the de Bruijn words, and, by using the associated automata, it is shown that the complexity of the algorithm is tight. More precisely, the Hopcroft's algorithm has some degrees of freedom (see Section 3) in the sense that there can be several executions of the algorithm on a given deterministic automaton. The running time of such executions can be different. With regard to the family of automata proposed in [4] it is shown that there exist some "unlucky" sequences of choices that slow down the computation to achieve the bound Ω(nlogn). However, there are also executions that run in linear time for the same automata. The authors of [4] leave the open problem whether there are automata on which all the executions of Hopcroft's algorithm do not run in linear time. In [16] the author proves that the exact worst case (i.e. in terms of the exact number of operations) of the algorithm for unary languages is reached only for the family of automata given in [4] when a queue is used in the implementation. He remarks that a stack implementation is more convenient for such automata. At the same time in [16] the author conjectures that there is a strategy for processing the stack used in the implementation such that the minimization of all unary languages will be realized in linear time by the Hopcroft's algorithm.
[1]
Olivier Carton,et al.
On the Complexity of Hopcroft's State Minimization Algorithm
,
2004,
CIAA.
[2]
Edward F. Moore,et al.
Gedanken-Experiments on Sequential Machines
,
1956
.
[3]
J. Brzozowski.
Canonical regular expressions and minimal state graphs for definite events
,
1962
.
[4]
Claire Pagetti,et al.
Around Hopcroft's Algorithm
,
2006,
CIAA.
[5]
Borivoj Melichar,et al.
Finding Common Motifs with Gaps Using Finite Automata
,
2006,
CIAA.
[6]
Timo Knuutila,et al.
Re-describing an algorithm by Hopcroft
,
2001,
Theor. Comput. Sci..
[7]
David A. Huffman,et al.
The synthesis of sequential switching circuits
,
1954
.
[8]
N. J. A. Sloane,et al.
The On-Line Encyclopedia of Integer Sequences
,
2003,
Electron. J. Comb..
[9]
Jan Daciuk,et al.
Incremental Construction of Minimal Acyclic Finite State Automata and Transducers
,
1998
.
[10]
Dominique Revuz,et al.
Minimisation of Acyclic Deterministic Automata in Linear Time
,
1992,
Theor. Comput. Sci..
[11]
Andrei Paun,et al.
On the Hopcroft's minimization algorithm
,
2007,
ArXiv.
[12]
David Gries,et al.
Describing an algorithm by Hopcroft
,
1973,
Acta Informatica.
[13]
John E. Hopcroft,et al.
An n log n algorithm for minimizing states in a finite automaton
,
1971
.
[14]
Maxime Crochemore,et al.
Minimizing local automata
,
2007,
2007 IEEE International Symposium on Information Theory.
[15]
Ahmed Khorsi,et al.
Split and join for minimizing: Brzozowski's algorithm
,
2002,
Stringology.
[16]
B. Watson.
A taxonomy of finite automata minimization algorithms
,
1993
.
[17]
Christophe Reutenauer,et al.
On Christoffel classes
,
2006,
RAIRO Theor. Informatics Appl..
[18]
Moshe Y. Vardi,et al.
Experimental Evaluation of Classical Automata Constructions
,
2005,
LPAR.