Introduction To Effective BC
Introduction To Effective BC
of
Context-Free Grammars
Equivalent
grammar
S aB
S aB | ab
A aaA
Substitute A aaA
A abBc B b A abBc | abbc
B aA
B aA
Bb
Costas Busch - LSU 2
S aB | ab
A aaA
A abBc | abbc
B aA
Substitute
B aA
S aB | ab | aaA
Equivalent
A aaA
A abBc | abbc | abaAc
grammar
Costas Busch - LSU 3
In general: A xBz
B y1
Substitute
B y1
equivalent
A xBz | xy1z grammar
Costas Busch - LSU 4
Nullable Variables
production : X
Nullable Variable: Y
Example: S aMb
M aMb
M
Example: S aA
Aa
A B
Unit Productions
BA
B bb
Costas Busch - LSU 7
Removal of unit productions:
S aA
S aA | aB
Aa
Substitute Aa
A B A B B A| B
BA
B bb
B bb
S aA | aB S aA | aB
Aa Remove Aa
B A| B BB BA
B bb B bb
Final grammar
S aA | aB | aA S aA | aB
Aa Aa
B bb B bb
S aSb
S
SA
A aA Useless Production
S A aA aaA aaaA
Costas Busch - LSU 12
Another grammar:
SA
A aA
A
B bA Useless Production
Not reachable from S
If there is a derivation
S xAy w L(G)
consists of
terminals
Then variable A is useful
S aSb
S Productions
Variables S A useless
useless A aA useless
useless B C useless
useless C D useless
Costas Busch - LSU 15
Removing Useless Variables and Productions
Example Grammar: S aS | A | C
Aa
B aa
C aCb
S aS | A | C Round 1: { A, B}
Aa (the right hand side of production
that has only terminals)
B aa
Round 2: { A, B, S}
C aCb (the right hand side of a production
has terminals and
variables of previous round)
S aS | A | C
Aa S aS | A
B aa Aa
C aCb B aa
S aS | A
Aa S A B
B aa unreachable
Final Grammar
S aS | A
S aS | A
Aa
Aa
B aa
Contains only
useful variables