Zásobníkový automat: Rozdiel medzi revíziami
dBez shrnutí editace |
d Robot: Adding Category:Články_bez_interwiki |
||
Riadok 37: | Riadok 37: | ||
[[Category:Formálne jazyky a automaty]] |
[[Category:Formálne jazyky a automaty]] |
||
[[Category:Články bez interwiki]] |
Verzia z 00:33, 4. máj 2005
Zásobníkový automat je názov pre triedu abstraktných matematických strojov.
Zásobníkové automaty (ďalej len ZA) umožňujú reprezentovanie bezkontextových jazykov ich rozpoznávaním. Oproti konečným automatom sú rozšírené o špeciálny typ pamäte, zásobník. ZA M možno definovať ako usporiadanú sedmicu:
M=(Q,T,G,D,q0,Z0,F)
kde:
- Q - konečná neprázdna množina stavov
- T - konečná neprázdna množina vstupných symbolov - vstupná abeceda
- G - konečná neprázdna množina zásobníkových symbolov - zásobníková abeceda
- D - prechodová funkcia
- q0 - začiatočný stav, patrí do množiny Q
- Z0 - symbol na dne zásobníka, patrí G
- F - konečná množina koncových (finálových) stavov
ZA disponuje vstupnou páskou, na ktorej sú symboly zo zásobníkovej abecedy, tie sú čítané zľava doprava čítacou hlavou. Tá sa môže posúvať vždy iba doprava o jeden symbol, čítanie symbolov sa však môže zastaviť. Symboly na vstupnej páske nemôže ZA meniť. Zásobník je potenciálne nekonečná pamäť s prístupom LIFO (Last In First Out). ZA je v určitom stave, ktorý je popísaný neprečítanou časťou pásky, stavom, v ktorom sa nachádza riadiaca jednotka ZA a obsahom zásobníka. ZA je matematickým modelom vykonávajúcim syntaktickú analýzu metódou zhora nadol, derivačný strom sa konštruuje od koreňa k listom a vykonáva sa ľavý rozklad analyzovanej vety.
ZA môžu byť v zásade dvojakého typu:
- Deterministické
- Nedeterministické
Vo všeobecnosti je ZA nedeterministický, pri prechode ZA z jedného stavu do iného nemusí byť jasné:
- do akého stavu má ZA prejsť a akým reťazcom má byť prepísaný symbol z vrcholu zásobníka
- či čítať ďalší vstup z pásky alebo nie
Nedeterministický ZA možno determinizovať, neplatí však, že ku každému nedeterministickému ZA existuje deterministický ZA. Platí, že ku každej bezkontextovej gramatike G =(N, T, P, S) existuje nedeterministický ZA M taký, že L(M)=G(M).
K obrázku:
- VP - vstupná páska
- KRJ - Konečnostavová riadiaca jednotka
- H - Čítacia hlava
- Z - Zásobník