Frázová gramatika

Zo stránky testwiki
Verzia z 13:08, 10. október 2023, ktorú vytvoril imported>Teslaton (pridaná Kategória:Alan Turing pomocou použitia HotCat)
(rozdiel) ← Staršia verzia | Aktuálna úprava (rozdiel) | Novšia verzia → (rozdiel)
Prejsť na navigáciu Prejsť na vyhľadávanie

Frázová gramatika je jeden z najdôležitejších modelov na opis formálnych jazykov.

Jednotlivé slová gramatika generuje pomocou svojich pravidiel zo štartovacieho symbolu. V každom kroku je možné podľa pravidiel prepísať istú časť už vytvoreného slova na iné. Do jazyka, ktorý táto gramatika generuje, potom vyberieme tie odvodené slová, ktoré sa skladajú len zo špeciálnych symbolov -- terminálov.

Definícia

Frázová gramatika G je usporiadaná štvorica G=(N,T,P,σ), kde

  • N je abeceda neterminálnych symbolov (neterminálov),
  • T je abeceda terminálnych symbolov (terminálov), pričom NT=,
  • Pkon(NT)*N(NT)*×(NT)* je množina prepisovacích pravidiel (konečná!),
  • σN je počiatočný neterminál.

Prvky (u,v) relácie P (prepisovacie pravidlá) sa zvyknú označovať zápisom uv, ktorý názornejšie vyjadruje, že časť u vo vetnej forme sa má prepísať na v.

Prepisovanie, odvodenie a jazyk generovaný frázovou gramatikou zavedieme teraz formálne:

Krok odvodenia v gramatike G je binárna relácia na množine vetných foriem (t. j. (NT)*) označovaná symbolicky a definovaná takto:

x1ux2y1vy2 práve vtedy, keď uvP pre nejaké x1,x2,y1,y2,v(NT)*,u(NT)*N(NT)*

Symbol * označuje reflexívno-tranzitívny uzáver relácie .

Jazyk generovaný gramatikou G je množina terminálnych slov L(G):={wT*|σ*w}.

Sila

Trieda jazykov, ktoré dokážu vygenerovať frázové gramatiky, je presne tá istá trieda, ktorú dokážu akceptovať Turingove stroje. Táto trieda jazykov sa nazýva ako trieda rekurzívne vyčísliteľných jazykov a označuje sa RE.

Postupným pridávaním rôznych obmedzení na pravidlá frázových gramatík získame (väčšinou) slabšie gramatiky (t. j. generujúce ostrú podmnožinu rekurzívne vyčísliteľných jazykov), napr. kontextové gramatiky, bezkontextové gramatiky či regulárne gramatiky. Rekurzívne vyčísliteľné jazyky stoja na vrchu Chomského hierarchie jazykov.

Keďže frázová gramatika ako taká má konečný zápis (hoci reprezentuje potenciálne nekonečný objekt -- jazyk), všetkých frázových gramatík je spočítateľne veľa, z čoho vyplýva, že k veľkej väčšine jazykov sa nedá nájsť príslušná frázová gramatika, ktorá ich generuje. Tieto jazyky sú však veľmi komplikované a vykazujú istú „nepredstaviteľnosť“. Príkladom jazykov, ktoré nie sú rekurzívne vyčísliteľné, sú komplement diagonálneho jazyka či komplement univerzálneho jazyka.

Šablóna:Formálne jazyky a gramatiky