Překladový automat

Technology
12 hours ago
8
4
2
Avatar
Author
Albert Flores

Překladový automat je v podstatě zásobníkový automat, který však obsahuje navíc ještě výstupní pásku a je definován rozkladovou tabulkou.

Definice překladového automatu

Tvar konfigurace (stav) překladového automatu: (x, Z, π) * x = nepřečtená část vstupní pásky * Z = obsah zásobníku * π = obsah výstupní pásky

Tvar počáteční konfigurace: (w, S#, ε) * w = vstupní řetězec * S = startovací symbol * # = zásobníkový symbol, který představuje dno zásobníku

Popis překladového automatu

Překladový automat obsahuje zásobník, vstupní pásku, výstupní pásku a rozkladovou tabulku. Rozkladová tabulka nahrazuje přechodovou funkci. +more Překladový automat postupně čte symboly ze vstupní pásky, stejným způsobem pak pracuje i se zásobníkem, na výstupní pásku nakonec zapisuje levý rozklad vstupní věty (tj. čísla použitých pravidel).

Rozkladová tabulka

Rozkladová tabulka je zobrazení M: (∑ ∪ N ∪ {#}) ∙ (∑ ∪ {$}) ∪ {expand i, pop, accept, error}

Jednotlivé funkční hodnoty mají tento význam:

expand i: Je-li A::= α i-té pravidlo gramatiky, pak na vrcholu zásobníku je neterminál A, na vstupu je symbol x, M[A,x] = expand i. Automat provede změnu konfigurace (xm, Aβ, π) |- (xm, αβ, πi) - tzn. +more že do zásobníku umístí pravou stranu pravidla A::= α (řetězec α od konce). Vstupní pásky si automat nevšímá a na výstupní pásku zapíše číslo i.

pop: Jestliže je na vrcholu zásobníku a též na vstupní pásce tentýž terminál symbol x, pak automat provede změnu konfigurace (xm, xβ, π) |- (m, β, π), tzn. že automat odstraní symbol x z vrcholu zásobníku a na vstupní pásku se posune na další znak.

accept: K této hodnotě dojde automat v koncové konfiguraci, ale jen pokud přečte celou vstupní pásku a zároveň při tom vyprázdní zásobník. Na výstupní pásce se objeví úplný levý rozklad vstupní věty.

error: Znamená, že automat vstup nepřijal, vstupní řetězec tedy není větou jazyka.

Pravidla

# je-li A::= α i-té pravidlo gramatiky a α ≠ ε, pak pro všechny a ∈ FIRST(α) platí M[A,a] = expand i # jestliže ε ∈ FIRST(α), pak pro všechna b ∈ FOLLOW(A) M[A,b] = expand i # M[a,a] = pop, m[#,$] = accept, jinak M[X,a] = error

Příklad rozkladu tabulky

Zadaná pravidla:

:

1Předpisčíslo pravidlamnožina FOLLOW
S ::= aAd | εcenter | 1,2FOLLOW(S) = {$}
A ::= bBcenter | 3FOLLOW(A) = {d}
B ::= cbB | εcenter | 4,5FOLLOW(B) = {d}

Rozkladová tabulka:

:

1Vstupní symbol
Zásobníkabcd$
Sexpand1expand2
Aexpand3
Bexpand4expand5
apop
bpop
cpop
dpop
#accept

Související články

Překladač

Kategorie:Informatika

5 min read
Share this post:
Like it 8

Leave a Comment

Please, enter your name.
Please, provide a valid email address.
Please, enter your comment.
Enjoy this post? Join Cesko.wiki
Don’t forget to share it
Top