Greibach normal form: Difference between revisions
m Open access bot: doi updated in citation with #oabot. |
Removed "not including the start symbol" from the definition of Greibach normal form, as this is not mentioned in the original paper or anywhere else to my knowledge |
||
Line 5: | Line 5: | ||
where <math>A</math> is a [[nonterminal symbol]], <math>a</math> is a terminal symbol, |
where <math>A</math> is a [[nonterminal symbol]], <math>a</math> is a terminal symbol, |
||
<math>A_1 A_2 \ldots A_n</math> is a (possibly empty) sequence of nonterminal symbols |
<math>A_1 A_2 \ldots A_n</math> is a (possibly empty) sequence of nonterminal symbols and <math>S</math> is the start symbol. |
||
Observe that the grammar does not have [[left recursion]]s. |
Observe that the grammar does not have [[left recursion]]s. |
Revision as of 11:49, 17 April 2024
In formal language theory, a context-free grammar is in Greibach normal form (GNF) if the right-hand sides of all production rules start with a terminal symbol, optionally followed by some variables. A non-strict form allows one exception to this format restriction for allowing the empty word (epsilon, ε) to be a member of the described language. The normal form was established by Sheila Greibach and it bears her name.
More precisely, a context-free grammar is in Greibach normal form, if all production rules are of the form:
where is a nonterminal symbol, is a terminal symbol, is a (possibly empty) sequence of nonterminal symbols and is the start symbol.
Observe that the grammar does not have left recursions.
Every context-free grammar can be transformed into an equivalent grammar in Greibach normal form.[1] Various constructions exist. Some do not permit the second form of rule and cannot transform context-free grammars that can generate the empty word. For one such construction the size of the constructed grammar is O(n4) in the general case and O(n3) if no derivation of the original grammar consists of a single nonterminal symbol, where n is the size of the original grammar.[2] This conversion can be used to prove that every context-free language can be accepted by a real-time (non-deterministic) pushdown automaton, i.e., the automaton reads a letter from its input every step.
Given a grammar in GNF and a derivable string in the grammar with length n, any top-down parser will halt at depth n.
See also
References
- ^ Greibach, Sheila (January 1965). "A New Normal-Form Theorem for Context-Free Phrase Structure Grammars". Journal of the ACM. 12 (1): 42–52. doi:10.1145/321250.321254. S2CID 12991430.
- ^ Blum, Norbert; Koch, Robert (1999). "Greibach Normal Form Transformation Revisited". Information and Computation. 150 (1): 112–118. CiteSeerX 10.1.1.47.460. doi:10.1006/inco.1998.2772. S2CID 10302796.
- Alexander Meduna (6 December 2012). Automata and Languages: Theory and Applications. Springer Science & Business Media. ISBN 978-1-4471-0501-5.
- György E. Révész (17 March 2015). Introduction to Formal Languages. Courier Corporation. ISBN 978-0-486-16937-8.