Download presentation
Presentation is loading. Please wait.
1
Discussion #51/18 Discussion #5 LL(1) Grammars &Table-Driven Parsing
2
Discussion #52/18 Topics Approaches to Parsing –Full backtracking –Deterministic Simple LL(1), table-driven parsing Improvements to simple LL(1) grammars
3
Discussion #53/18 Prefix Expression Grammar Consider the following grammar (which yields prefix expressions for binary operators): E N | OEE O + | | * | / N 0 | 1 | 2 | 3 | 4 Here, prefix expressions associate an operator with the next two operands. * + 2 3 4 (* (+ 2 3) 4) (2 + 3) * 4 = 20 * 2 + 3 4 (* 2 (+ 3 4)) 2 * (3 + 4) = 14
4
Discussion #54/18 E NOEE …+ *NOEEN …+NN012 012301234 E N | OEE O + | | * | / N 0 | 1 | 2 | 3 | 4 *+342 Top-Down Parsing with Backtracking
5
Discussion #55/18 What are the obvious problems? We never know what production to try. It appears to be terribly inefficient—and it is. Are there grammars for which we can always know what rule to choose? Yes! Characteristics: –Only single symbol look ahead –Given a non-terminal and a current symbol, we always know which production rule to apply
6
Discussion #56/18 LL(1) Parsers An LL parser parses the input from Left to right, and constructs a Leftmost derivation of the sentence. An LL(k) parser uses k tokens of look-ahead. LL(1) parsers, although fairly restrictive, are attractive because they only need to look at the current non-terminal and the next token to make their parsing decisions. LL(1) parsers require LL(1) grammars.
7
Discussion #57/18 Simple LL(1) Grammars For simple LL(1) grammars all rules have the form A a 1 1 | a 2 2 | … | a n n where a i is a terminal, 1 <= i <= n a i a j for i j and i is a sequence of terminals and non-terminal or is empty, 1 <= i <= n
8
Discussion #58/18 Creating Simple LL(1) Grammars By making all production rules of the form: A a 1 1 | a 2 2 | … | a n n Thus, E 0 | 1 | 2 | 3 | 4 | +EE | EE | *EE | /EE Why is this not a simple LL(1) grammar? E N | OEE O + | | * | / N 0 | 1 | 2 | 3 | 4 How can we change it to simple LL(1)?
9
Discussion #59/18 E (1) 0 | (2) 1 | (3) 2 | (4) 3 | (5) 4 | (6) +EE | (7) EE | (8) *EE | (9) /EE * + 2 3 4 E 2 * 3 E ?*EE 8 EE+ 6 2 3 3 4 4 5 EE 7 2 3 EE* 8 3 4 Success! Fail! Output = 8 6 3 4 5 Example: LL(1) Parsing
10
Discussion #510/18 Simple LL(1) Parse Table A parse table is defined as follows: (V {#}) (V T {#}) {( , i), pop, accept, error } where – is the right side of production number i –# marks the end of the input string (# V) If A (V {#}) is the symbol on top of the stack and a (V T {#}) is the current input symbol, then: ACTION (A, a) = pop if A = a for a V T accept if A = # and a = # (a , i) which means “pop, then push a and output i” (A a is the ith production) error otherwise
11
Discussion #511/18 Parse Table E (1) 0 | (2) 1 | (3) 2 | (4) 3 | (5) +EE | (6) *EE 0123+*# E(0,1)(1,2)(2,3)(3,4)(+EE,5)(*EE,6) 0pop 1 2 3 + * #accept V {#} V T {#} All blank entries are error
12
Discussion #512/18 0123+*# E(0,1)(1,2)(2,3)(3,4)(+EE,5)(*EE,6) 0,1,2,3,+,*pop #accept ActionStackInputOutput InitializeE#E# *+123# ACTION(E,*) = Replace [E,*EE], Out 6*EE# *+123#6 ACTION(*,*) = pop(*,*)EE#* +123#6 ACTION(E,+) = Replace [E,+EE], Out 5+EEE#* +123#65 ACTION(+,+) = pop(+,+)EEE#*+ 123#65 ACTION(E,1) = Replace [E,1], Out 21EE#*+ 123#652 ACTION(1,1) = pop(1,1)EE#*+1 23#652 ACTION(E,2) = Replace [E,2], Out 32E#*+1 23#6523 ACTION(2,2) = pop(2,2)E#E#*+12 3#6523 ACTION(E,3) = Replace [E,3], Out 43#3#*+12 3#65234 ACTION(3,3) = pop(3,3)#*+123 #65234 ACTION(#,#) = acceptDone!
13
Discussion #513/18 Simple LL(1): More Restrictive than Necessary Simple LL(1) grammars are very easy and efficient to parse but also very restrictive. The good news: we can achieve the same desirable results without being so restrictive. How? We only need to retain the restriction that single-symbol look ahead uniquely determines which rule to use.
14
Discussion #514/18 Consider the following grammar, which is not simple LL(1): E (1) N | (2) OEE O (3) + | (4) * N (5) 0 | (6) 1 | (7) 2 | (8) 3 What are the problem rules? (1) & (2) Observe that it is possible distinguish between rules 1 and 2. –N leads to {0, 1, 2, 3} –O leads to {+, *} –{0, 1, 2, 3} {+, *} = –Thus, if we see 0, 1, 2, or 3 we choose (1), and if we see + or *, we choose (2). Relaxing Simple LL(1) Restrictions
15
Discussion #515/18 LL(1) Grammars FIRST( ) = { | * and V T } A grammar is LL(1) if for all rules of the form A 1 | 2 | … | n the sets FIRST( 1 ), FIRST( 2 ), …, and FIRST( n ) are pair-wise disjoint; that is, FIRST( i ) FIRST( j ) = for i j
16
Discussion #516/18 E (1) N | (2) OEE O (3) + | (4) * N (5) 0 | (6) 1 | (7) 2 | (8) 3 +*0123# E(OEE,2) (N,1) O(+,3)(*,4) N(0,5)(1,6)(2,7)(3,8) +pop * 0 1 2 3 #accept V {#} V T {#} For (A, a), we select ( , i) if a FIRST( ) and is the right hand side of rule i.
17
Discussion #517/18 +*0123# E(OEE,2) (N,1) O(+,3)(*,4) N(0,5)(1,6)(2,7)(3,8) +,*,0,1,2,3pop #accept ActionStackInputOutput InitializeE#E# *+123# ACTION(E,*) = Replace [E,OEE], Out 2OEE# *+123#2 ACTION(*,*) = pop(*,*)EE#* +123#24 ACTION(E,+) = Replace [E,OEE], Out 2OEEE#* +123#242 ACTION(+,+) = pop(+,+)EEE#*+ 123#2423 ACTION(N,1) = Replace [N,1], Out 61EE#*+ 123#242316 ACTION(1,1) = pop(1,1)EE#*+1 23#242316 ACTION(E,2) = Replace [E,N], Out 1NE#*+1 23#2423161 ACTION(2,2) = pop(2,2)E#E#*+12 3#24231617 ACTION(E,3) = Replace [E,N], Out 1N#N#*+12 3#242316171 ACTION(3,3) = pop(3,3)#*+123 #2423161718 ACTION(#,#) = acceptDone! ACTION(O,*) = Replace [O,*], Out 4*EE# *+123#24 ACTION(O,+) = Replace [O,+], Out 3+EEE#* +123#2423 ACTION(E,1) = Replace [E,N], Out 1NEE#*+ 123#24231 ACTION(N,2) = Replace [N,2], Out 72E#*+1 23#24231617 ACTION(N,3) = Replace [N,3], Out 83#3#*+12 3#2423161718
18
Discussion #518/18 What does 2 4 2 3 1 6 1 7 1 8 mean? E (1) N | (2) OEE O (3) + | (4) * N (5) 0 | (6) 1 | (7) 2 | (8) 3 E (2) OEE (1) N (6) 1 (7) 2 (8) 3 (4) * (2) OEE (1) N (3) + (1) N 2 4 2 3 1 6 1 7 1 8 defines a parse tree via a preorder traversal.
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.