Autòmat finit no determinista

Un autòmat finit no determinista (abreujat AFND ) és un autòmat finit que, a diferència dels autòmats finits deterministes (AFD), té almenys un estat q Q , tal que per a un símbol a ∈ Σ de l'alfabet, hi ha més d'una transició δ ( q , a ) possible.

En aquest exemple, δ ( q 0 , b ) = q 0 i δ ( q 0 , b ) = q 1 . Per tant, es tracta d'un autòmat finit no determinista, que reconeix l'expressió regular (a | b) * b +.

En un AFND pot donar-se qualsevol d'aquests dos casos:

  • Que hi hagi transicions del tipus δ ( q , a ) = q 1 i δ ( q , a ) = q 2 , sent q 1 q 2 ;
  • Que hi hagi transicions del tipus δ ( q , ε), sent q un estat no-final, o bé un estat final però amb transicions cap a altres estats.

Quan es compleix el segon cas, es diu que l'autòmat és un autòmat finit no determinista amb transicions buides o transicions ε (abreujat AFND-ε ). Aquestes transicions permeten l'autòmat canviar d'estat sense processar cap símbol d'entrada. Considerem una modificació al model de l'autòmat finit per permetre cap, una o més transicions d'un estat sobre el mateix símbol d'entrada.

Definició formal modifica

Formalment, si bé un autòmat finit determinista es defineix com una 5 - tupla ( Q , Σ, q 0 , δ, A ) on:[1]

  •   és un conjunt d'estats;
  •   és un alfabet;
  •   és l'estat inicial;
  •   és una funció de transició;
  •   és un conjunt d'estats finals o d'acceptació.

en un AFND la funció de transició es defineix com:

 

Per al cas dels AFND-ε, se sol expressar la funció de transició de la forma:

 

on P (Q) és el conjunt potència de Q . Això significa que els autòmats finits deterministes són un cas particular dels no deterministes, ja que Q pertany al conjunt P (Q) .

La interpretació que se sol fer en el còmput d'un AFND és que l'autòmat pot passar per diversos estats al mateix temps, generant-se una ramificació de les configuracions existents en un moment donat. Així mateix, en un autòmat finit no determinista podem acceptar l'existència de més d'un node inicial.

Funcionament modifica

La màquina comença en l'estat inicial especificat i llegeix una cadena de caràcters pertanyents a l'alfabet. L'autòmat utilitza la funció de transició d'estats T per determinar l'estat següent, utilitzant l'estat actual i el símbol que acaba de llegir o la cadena buida. No obstant això, "l'estat següent d'un AFND no només depèn de l'esdeveniment d'entrada actual, sinó que també en un nombre arbitrari dels esdeveniments d'entrada posterior. Fins que es produeixen aquests esdeveniments posteriors no és possible determinar en quin estat es troba la màquina ". Quan l'autòmat ha acabat de llegir, i es troba en un estat d'acceptació, es diu que el AFND accepta la cadena, en cas contrari es diu que la cadena de caràcters és rebutjada. Tant per a un AFND com per a un autòmat finit determinista (AFD) es pot acceptar el mateix llenguatge. Per tant, és possible convertir un AFND existent en un AFD per al desenvolupament d'una màquina potser més simple. Això es pot dur a terme utilitzant la construcció del conjunt potència, que pot conduir a un augment exponencial en el nombre d'estats necessaris.

Implementació modifica

Hi ha moltes formes d'implementar una ANFD:

  • Convertir l'equivalent AFE: en alguns casos això pot causar una explosió exponencial en la grandària de l'autòmat, i així un espai auxiliar proporcional al nombre d'estats en el ANFD (com l'emmagatzematge del valor de l'estat requereix en la majoria d'un bit per cada estat en el ANFD).
  • Mantenir un conjunt de dades de tots els estats en què la màquina podria estar en l'actualitat. En consumir l'últim caràcter d'entrada, si un d'aquests estats és un estat final, la màquina accepta la cadena. En el pitjor dels casos, això pot requerir espai addicional proporcional al nombre d'estats en el ANFD, si l'estructura del conjunt fa servir un bit per estat del ANFD, llavors aquesta solució és exactament equivalent a l'anterior.
  • Crear múltiples còpies. Per cada n forma de la decisió, el ANFD crea fins n-1 còpies de la màquina. Cada un d'ells entrés en un estat independent. Si, al moment de consumir l'últim símbol de l'entrada, almenys una còpia del ANFD està en un estat d'acceptació, el ANFD ho acceptarà. (Això també requereix un emmagatzematge lineal pel que fa al nombre d'estats del ANFD, ja que pot haver-hi una màquina per cada estat del ANFD).

AFND-ε modifica

Propietats modifica

Per tot  , s'escriu   si i només si a   es pot arribar des  , anant al llarg de zero o més fletxes  . En altres paraules,   si i només si existeix   on   tal que

 .

Per a qualsevol  , el conjunt d'estats que es pot arribar a partir de p s'anomena epsilon-closure o ε-closure de p i s'escriu com

 .

Per a qualsevol subconjunt  , definir el ε-closure de P com

 .

Les transicions epsilon són transitive, ja que pot demostrar que per a tot   i  , si   i  , llavors  .

De la mateixa manera, si   i   llavors   Sigui x una cadena de l'alfabet Σ ∪{ε}. Un AFND-ε M accepta la cadena x si existeix tant una representació de x de la forma x 1 x 2 ... x n , on x i ∈ (Σ ∪{ε}), i una seqüència d'estats

p 0 , p 1 , ..., p n , on p i Q , compleixen les següents condicions:

  1. p 0   E ({ q 0 })
  2. p i   E ( T ( p i-1 , x i )) per i = 1, ..., n
  3. p n   F .

Aplicació modifica

El AFND i el AFD són equivalents en això, ja que si un llenguatge és reconegut pel AFND, també serà reconegut per un AFD, i viceversa. L'establiment d'aquesta equivalència és útil perquè de vegades la construcció d'un AFND per reconèixer un llenguatge determinat és més fàcil que construir un AFD per a aquest llenguatge. També és important perquè el AFND es pot utilitzar per reduir la complexitat del treball matemàtic necessari per establir moltes propietats importants en la teoria de la computació. Per exemple, és molt més fàcil demostrar les següents propietats utilitzant un AFND que un AFD:

Exemple modifica

L'exemple següent mostra un AFND M , amb un alfabet binari que determina si l'entrada conté un nombre parell de 0s o un nombre parell de 1s. Llavors M = ( Q , Σ, T , s 0 , F ) on:

  • Σ ={0, 1},
  • Q ={ s 0 , s 1 , s 2 , s 3 , s 4 },
  • E ({ es 0 }) ={s 0 , s 1 , s 3 }
  • F ={ s 1 , s 3 }, i
  • La funció de transició T pot ser definida per aquesta taula de transició d'estats:
0
1
Ε
S 0
{}
{}
{ S 1 , S 3 }
S 1
{ S 2 }
{ S 1 }
{}
S 2
{ S 1 }
{ S 2 }
{}
S 3
{ S 3 }
{ S 4 }
{}
S 4
{ S 4 }
{ S 3 }
{}

El diagrama d'estats per M és:

 

M pot ser vist com la unió de dos AFDs: un amb els estats{ S 1 , S 2 }i l'altre amb els estats{ S 3 , S 4 }.

El llenguatge de M pot ser descrit pel llenguatge regular donat per l'expressió regular:

 

Vegeu també modifica

Referències modifica

  1. Chakraborty, Samarjit «Formal Languages and Automata Theory. Regular Expressions and Finite Automata» (en anglès). Computer Engineering and Networks Laboratory. Swiss Federal Institute of Technology (ETH) Zürich, 17-03-2003, p. 17 [Consulta: 30 març 2010].

Bibliografia modifica

A Wikimedia Commons hi ha contingut multimèdia relatiu a: Autòmat finit no determinista
  • M. O. Rabin and D. Scott, "Finite Automata and their Decision Problems", IBM Journal of Research and Development , 3 : 2 (1959) pp.115-125.
  • Michael Sips, Introduction to the Theory of Computation . PWS, Boston. 1997.
  • John E. Hopcroft and Jeffrey D. Ullman, Introduction to Automata Theory, Languages, and Computation , Addison-Wesley Publishing, Reading Massachusetts, 1979.