a context-free grammar for the language terminals
TRANSCRIPT
![Page 1: A context-free grammar for the language Terminals](https://reader031.vdocuments.site/reader031/viewer/2022012513/618c49faca79685cda569e73/html5/thumbnails/1.jpg)
![Page 2: A context-free grammar for the language Terminals](https://reader031.vdocuments.site/reader031/viewer/2022012513/618c49faca79685cda569e73/html5/thumbnails/2.jpg)
![Page 3: A context-free grammar for the language Terminals](https://reader031.vdocuments.site/reader031/viewer/2022012513/618c49faca79685cda569e73/html5/thumbnails/3.jpg)
A context-free grammar for the language
{anbn | n ≥ 0}
Terminals:
a b
Non-terminal:
I
Start symbol:
I
Productions:
I ::= ε | aIb
38
![Page 4: A context-free grammar for the language Terminals](https://reader031.vdocuments.site/reader031/viewer/2022012513/618c49faca79685cda569e73/html5/thumbnails/4.jpg)
A context-free grammar for the language
{anbn | n ≥ 0}
Terminals:
a b
Non-terminal:
I
Start symbol:
I
Productions:
I ::= ε | aIb
38
![Page 5: A context-free grammar for the language Terminals](https://reader031.vdocuments.site/reader031/viewer/2022012513/618c49faca79685cda569e73/html5/thumbnails/5.jpg)
Some production rules for ‘English’ sentences
SENTENCE → SUBJECT VERB OBJECT
SUBJECT → ARTICLE NOUNPHRASE
OBJECT → ARTICLE NOUNPHRASE
ARTICLE → a
ARTICLE → the
NOUNPHRASE → NOUN
NOUNPHRASE → ADJECTIVE NOUN
ADJECTIVE → big
ADJECTIVE → small
NOUN → cat
NOUN → dog
VERB → eats
35
![Page 6: A context-free grammar for the language Terminals](https://reader031.vdocuments.site/reader031/viewer/2022012513/618c49faca79685cda569e73/html5/thumbnails/6.jpg)
Every regular language is context-free
Given a DFA M , the set L(M) of strings accepted by M can be
generated by the following context-free grammar:
set of terminals = ΣM
set of non-terminals = StatesM
start symbol = start state of M
productions of two kinds:
q → aq′ whenever qa−→ q′ in M
q → ε whenever q ∈ AcceptM
39
![Page 7: A context-free grammar for the language Terminals](https://reader031.vdocuments.site/reader031/viewer/2022012513/618c49faca79685cda569e73/html5/thumbnails/7.jpg)
Example of a finite automaton
!!!"#$%&'(q0a
!!
b
""
!"#$%&'(q1
b
##a
!!!"#$%&'(q2
b
$$
a!!!"#$%&'()*+,-./0q3
a
%%
b
""
States: q0, q1, q2, q3.
Input symbols: a, b.
Transitions: as indicated above.
Start state: q0.
Accepting state(s): q3.
10
![Page 8: A context-free grammar for the language Terminals](https://reader031.vdocuments.site/reader031/viewer/2022012513/618c49faca79685cda569e73/html5/thumbnails/8.jpg)
Definition A context-free grammar is regular iff all its productions are of
the form
X → uY
or
X → u
where u is a string of terminals and X and Y are non-terminals.
Theorem
(a) Every language generated by a regular grammar is a regular
language (i.e. is the set of strings accepted by some DFA).
(b) Every regular language can be generated by a regular grammar.
40
![Page 9: A context-free grammar for the language Terminals](https://reader031.vdocuments.site/reader031/viewer/2022012513/618c49faca79685cda569e73/html5/thumbnails/9.jpg)
Definition A context-free grammar is regular iff all its productions are of
the form
X → uY
or
X → u
where u is a string of terminals and X and Y are non-terminals.
Theorem
(a) Every language generated by a regular grammar is a regular
language (i.e. is the set of strings accepted by some DFA).
(b) Every regular language can be generated by a regular grammar.
40
![Page 10: A context-free grammar for the language Terminals](https://reader031.vdocuments.site/reader031/viewer/2022012513/618c49faca79685cda569e73/html5/thumbnails/10.jpg)
Example of the construction used
in the proof of the Theorem on Slide 40
regular grammar:
S→abX
X→bbY
Y →X
X→a
Y →ε
(start symbol = S)
NFAε:
��?>=<89:;S
a
��
GFED@ABC?>=<89:;Y
ε
��GFED@ABCq1b // GFED@ABCX
b //
a
��
GFED@ABCq2
b
`❇̀❇❇❇❇❇❇❇❇
GFED@ABC?>=<89:;q3
41
![Page 11: A context-free grammar for the language Terminals](https://reader031.vdocuments.site/reader031/viewer/2022012513/618c49faca79685cda569e73/html5/thumbnails/11.jpg)
Chomsky Normal Form (CNF)
Theorem
Any context-free language can be generated by a grammar whose
productions are of one of the following three types:
X → Y Z X → a I → ε
where X,Y, Z are non-terminals, a is a terminal, and I is the start
symbol.
The last type of production occurs if and only if the language contains ε(which is why the use of CNFs is usually restricted to languages that do
not contain ε.)
42
![Page 12: A context-free grammar for the language Terminals](https://reader031.vdocuments.site/reader031/viewer/2022012513/618c49faca79685cda569e73/html5/thumbnails/12.jpg)
![Page 13: A context-free grammar for the language Terminals](https://reader031.vdocuments.site/reader031/viewer/2022012513/618c49faca79685cda569e73/html5/thumbnails/13.jpg)
Greibach Normal Form (GNF)
Theorem
Any context-free language can be generated by a grammar whose
productions are of one of the following two types:
X → aU I → ε
where a is a terminal, U is a (possibly empty) string of non-terminals,
and I is the start symbol.
The last type of production occurs if and only if the language contains ε(which is why the use of GNFs is usually restricted to languages that do
not contain ε.)
43