Syntaktický diagram

Syntaktické diagramy jsou grafickou reprezentací bezkontextových gramatik. Lze je považovat za grafický protějšek metajazyků jako Backusova–Naurova forma (BNF) nebo rozvinutá Backusova–Naurova forma (EBNF). Zatímco pro zpracování počítačem, např. při konstrukci překladačů, jsou vhodnější textové reprezentace gramatik jako BNF nebo EBNF, pro člověka je zpravidla srozumitelnější grafická reprezentace například syntaktickými diagramy. K prvním použitím syntaktických diagramů patří kniha „Pascal User Manual“ od Niklause Wirtha[1] (diagramy začínají na stránce 47) a manuál interpretu příkazů CANDE firmy Burroughs.[2] K novějším příkladům použití syntaktických diagramů patří kanonické definice JSON formátů pro výměnu dat.

Princip syntaktických diagramů editovat

Pro reprezentaci bezkontextové gramatiky se používá sada syntaktických diagramů. Každý diagram reprezentuje všechna pravidla, jejichž levá strana je tvořena stejným neterminálem. Hlavní diagram odpovídá pravidlům, která mají na levé straně počáteční symbol gramatiky, a reprezentuje jazyk tak, že slovo patří do jazyka právě tehdy, když jej lze vyjádřit nějakou cestou v hlavním diagramu.

Každý diagram má vstupní bod a koncový bod. Diagram popisuje možné cesty mezi těmito dvěma body průchodem neterminály a terminály. Terminály jsou reprezentovány ovály a neterminály obdélníky.

Příklad editovat

BNF reprezentace gramatiky pro aritmetický výraz může vypadat takto:

<expression> ::= <term> | <expression> "+" <term>
<term>       ::= <factor> | <term> "*" <factor>
<factor>     ::= <constant> | <variable> | "(" <expression> ")"
<variable>   ::= "x" | "y" | "z" 
<constant>   ::= <digit> | <digit> <constant>
<digit>      ::= "0" | "1" | "2" | "3" | "4" | "5" | "6" | "7" | "8" | "9"

Tuto gramatiku lze vyjádřit také v EBNF:

expression = term | expression, "+" , term;
term       = factor | term, "*" , factor;
factor     = constant | variable | "(" , expression , ")";
variable   = "x" | "y" | "z"; 
constant   = digit , {digit};
digit      = "0" | "1" | "2" | "3" | "4" | "5" | "6" | "7" | "8" | "9";

Reprezentace této gramatiky pomocí syntaktických diagramů je následující:

 

Odkazy editovat

Související články editovat

Reference editovat

V tomto článku byl použit překlad textu z článku Syntax diagram na anglické Wikipedii.

  1. Niklaus Wirth: Programming Language Pascal. (červenec 1973)
  2. Archivovaná kopie. bitsavers.org [online]. [cit. 2017-02-12]. Dostupné v archivu pořízeném z originálu dne 2011-06-29. 

První odkaz neumožňuje přístup z cizích domén. Soubor je však dostupný na [1] Archivováno 22. 2. 2017 na Wayback Machine..

Externí odkazy editovat