compiler construction - lecture : [1ex] summer …...compiler construction lecture 8: syntax...

110
Compiler Construction Lecture 8: Syntax Analysis IV (LR (k ) Grammars) Summer Semester 2017 Thomas Noll Software Modeling and Verification Group RWTH Aachen University https://moves.rwth-aachen.de/teaching/ss-17/cc/

Upload: others

Post on 01-Aug-2020

11 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Compiler ConstructionLecture 8: Syntax Analysis IV (LR(k) Grammars)

Summer Semester 2017

Thomas NollSoftware Modeling and Verification GroupRWTH Aachen University

https://moves.rwth-aachen.de/teaching/ss-17/cc/

Page 2: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Bottom-Up Parsing

Outline of Lecture 8

Bottom-Up Parsing

Nondeterministic Bottom-Up Parsing

Resolving Termination Nondeterminism

LR(k) Grammars

LR(0) Grammars

Examples of LR(0) Conflicts

2 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 3: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Bottom-Up Parsing

Recap: Top-Down Parsing

Example 8.1

Grammar forarithmetic expressions:

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Leftmost analysis of (a)*b:

( a ) * b

3 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 4: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Bottom-Up Parsing

Recap: Top-Down Parsing

Example 8.1

Grammar forarithmetic expressions:

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Leftmost analysis of (a)*b:

( a ) * b

E

3 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 5: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Bottom-Up Parsing

Recap: Top-Down Parsing

Example 8.1

Grammar forarithmetic expressions:

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Leftmost analysis of (a)*b:2

( a ) * b

T

E

3 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 6: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Bottom-Up Parsing

Recap: Top-Down Parsing

Example 8.1

Grammar forarithmetic expressions:

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Leftmost analysis of (a)*b:2 3

( a ) * b

T F

T

E

3 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 7: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Bottom-Up Parsing

Recap: Top-Down Parsing

Example 8.1

Grammar forarithmetic expressions:

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Leftmost analysis of (a)*b:2 3 4

( a ) * b

F

T F

T

E

3 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 8: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Bottom-Up Parsing

Recap: Top-Down Parsing

Example 8.1

Grammar forarithmetic expressions:

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Leftmost analysis of (a)*b:2 3 4 5

( a ) * b

E

F

T F

T

E

3 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 9: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Bottom-Up Parsing

Recap: Top-Down Parsing

Example 8.1

Grammar forarithmetic expressions:

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Leftmost analysis of (a)*b:2 3 4 5 2

( a ) * b

T

E

F

T F

T

E

3 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 10: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Bottom-Up Parsing

Recap: Top-Down Parsing

Example 8.1

Grammar forarithmetic expressions:

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Leftmost analysis of (a)*b:2 3 4 5 2 4

( a ) * b

F

T

E

F

T F

T

E

3 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 11: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Bottom-Up Parsing

Recap: Top-Down Parsing

Example 8.1

Grammar forarithmetic expressions:

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Leftmost analysis of (a)*b:2 3 4 5 2 4 6

( a ) * b

F

T

E

F

T F

T

E

3 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 12: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Bottom-Up Parsing

Recap: Top-Down Parsing

Example 8.1

Grammar forarithmetic expressions:

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Leftmost analysis of (a)*b:2 3 4 5 2 4 6 7

( a ) * b

F

T

E

F

T F

T

E

3 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 13: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Bottom-Up Parsing

Bottom-Up Parsing I

Example 8.2

Grammar forarithmetic expressions:

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Reversed rightmost analysisof (a)*b:

( a ) * b

4 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 14: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Bottom-Up Parsing

Bottom-Up Parsing I

Example 8.2

Grammar forarithmetic expressions:

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Reversed rightmost analysisof (a)*b:

( a ) * b

4 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 15: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Bottom-Up Parsing

Bottom-Up Parsing I

Example 8.2

Grammar forarithmetic expressions:

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Reversed rightmost analysisof (a)*b:6

( a ) * b

F

4 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 16: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Bottom-Up Parsing

Bottom-Up Parsing I

Example 8.2

Grammar forarithmetic expressions:

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Reversed rightmost analysisof (a)*b:6 4

( a ) * b

F

T

4 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 17: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Bottom-Up Parsing

Bottom-Up Parsing I

Example 8.2

Grammar forarithmetic expressions:

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Reversed rightmost analysisof (a)*b:6 4 2

( a ) * b

F

T

E

4 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 18: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Bottom-Up Parsing

Bottom-Up Parsing I

Example 8.2

Grammar forarithmetic expressions:

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Reversed rightmost analysisof (a)*b:6 4 2 5

( a ) * b

F

T

E

F

4 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 19: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Bottom-Up Parsing

Bottom-Up Parsing I

Example 8.2

Grammar forarithmetic expressions:

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Reversed rightmost analysisof (a)*b:6 4 2 5 4

( a ) * b

F

T

E

F

T

4 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 20: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Bottom-Up Parsing

Bottom-Up Parsing I

Example 8.2

Grammar forarithmetic expressions:

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Reversed rightmost analysisof (a)*b:6 4 2 5 4 7

( a ) * b

F

T

E

F

T F

4 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 21: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Bottom-Up Parsing

Bottom-Up Parsing I

Example 8.2

Grammar forarithmetic expressions:

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Reversed rightmost analysisof (a)*b:6 4 2 5 4 7 3

( a ) * b

F

T

E

F

T F

T

4 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 22: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Bottom-Up Parsing

Bottom-Up Parsing I

Example 8.2

Grammar forarithmetic expressions:

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Reversed rightmost analysisof (a)*b:6 4 2 5 4 7 3 2

( a ) * b

F

T

E

F

T F

T

E

4 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 23: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Bottom-Up Parsing

Bottom-Up Parsing II

Approach:1. Given G ∈ CFGΣ, construct a nondeterministic bottom-up parsing automaton (NBA) which

accepts L(G) and which additionally computes corresponding (reversed) rightmostanalyses– input alphabet: Σ– pushdown alphabet: X– output alphabet: [p] (where p := |P|)– state set: omitted– transitions:

shift: shifting input symbols onto the pushdownreduce: replacing the right-hand side of a production by its left-hand side (= inverse expansion

step)

2. Remove nondeterminism by allowing lookahead on the input:G ∈ LR(k) iff L(G) recognisable by deterministic bottom-up parsing automaton withlookahead of k symbols

5 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 24: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Bottom-Up Parsing

Bottom-Up Parsing II

Approach:1. Given G ∈ CFGΣ, construct a nondeterministic bottom-up parsing automaton (NBA) which

accepts L(G) and which additionally computes corresponding (reversed) rightmostanalyses– input alphabet: Σ– pushdown alphabet: X– output alphabet: [p] (where p := |P|)– state set: omitted– transitions:

shift: shifting input symbols onto the pushdownreduce: replacing the right-hand side of a production by its left-hand side (= inverse expansion

step)

2. Remove nondeterminism by allowing lookahead on the input:G ∈ LR(k) iff L(G) recognisable by deterministic bottom-up parsing automaton withlookahead of k symbols

5 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 25: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Nondeterministic Bottom-Up Parsing

Outline of Lecture 8

Bottom-Up Parsing

Nondeterministic Bottom-Up Parsing

Resolving Termination Nondeterminism

LR(k) Grammars

LR(0) Grammars

Examples of LR(0) Conflicts

6 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 26: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Nondeterministic Bottom-Up Parsing

Nondeterministic Bottom-Up Automaton I

Definition 8.3 (Nondeterministic bottom-up parsing automaton)

Let G = 〈N,Σ,P,S〉 ∈ CFGΣ. The nondeterministic bottom-up parsing automatonof G, NBA(G), is defined by the following components.• Input alphabet: Σ

• Pushdown alphabet: X• Output alphabet: [p]

• Configurations: Σ∗ × X ∗ × [p]∗ (top of pushdown to the right)• Transitions for w ∈ Σ∗, α ∈ X ∗, and z ∈ [p]∗:

shifting steps: (aw , α, z) ` (w , αa, z) if a ∈ Σreduction steps: (w , αβ, z) ` (w , αA, zi) if πi = A→ β

• Initial configuration for w ∈ Σ∗: (w , ε, ε)

• Final configurations: {ε} × {S} × [p]∗

7 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 27: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Nondeterministic Bottom-Up Parsing

Nondeterministic Bottom-Up Automaton II

Example 8.4

Grammar forarithmetic expressions(cf. Example 8.2):

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Bottom-up parsing of (a)*b:((a)*b, ε , ε)` ( a)*b, ( , ε)` ( )*b, (a, ε)

` ()*b, (F , 6 )` ()*b, (T , 64 )` ()*b, (E , 642 )` ( *b, (E) , 642 )` ( *b, F , 6425 )` ( *b, T , 64254 )` ( b, T* , 64254 )` ( ε, T*b , 64254 )` ( ε, T*F , 642547 )` ( ε, T , 6425473 )` ( ε, E , 64254732)

8 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 28: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Nondeterministic Bottom-Up Parsing

Nondeterministic Bottom-Up Automaton II

Example 8.4

Grammar forarithmetic expressions(cf. Example 8.2):

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Bottom-up parsing of (a)*b:((a)*b, ε , ε)

` ( a)*b, ( , ε)` ( )*b, (a, ε)

` ()*b, (F , 6 )` ()*b, (T , 64 )` ()*b, (E , 642 )` ( *b, (E) , 642 )` ( *b, F , 6425 )` ( *b, T , 64254 )` ( b, T* , 64254 )` ( ε, T*b , 64254 )` ( ε, T*F , 642547 )` ( ε, T , 6425473 )` ( ε, E , 64254732)

8 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 29: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Nondeterministic Bottom-Up Parsing

Nondeterministic Bottom-Up Automaton II

Example 8.4

Grammar forarithmetic expressions(cf. Example 8.2):

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Bottom-up parsing of (a)*b:((a)*b, ε , ε)` ( a)*b, ( , ε)

` ( )*b, (a, ε)

` ()*b, (F , 6 )` ()*b, (T , 64 )` ()*b, (E , 642 )` ( *b, (E) , 642 )` ( *b, F , 6425 )` ( *b, T , 64254 )` ( b, T* , 64254 )` ( ε, T*b , 64254 )` ( ε, T*F , 642547 )` ( ε, T , 6425473 )` ( ε, E , 64254732)

8 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 30: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Nondeterministic Bottom-Up Parsing

Nondeterministic Bottom-Up Automaton II

Example 8.4

Grammar forarithmetic expressions(cf. Example 8.2):

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Bottom-up parsing of (a)*b:((a)*b, ε , ε)` ( a)*b, ( , ε)` ( )*b, (a, ε)

` ()*b, (F , 6 )` ()*b, (T , 64 )` ()*b, (E , 642 )` ( *b, (E) , 642 )` ( *b, F , 6425 )` ( *b, T , 64254 )` ( b, T* , 64254 )` ( ε, T*b , 64254 )` ( ε, T*F , 642547 )` ( ε, T , 6425473 )` ( ε, E , 64254732)

8 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 31: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Nondeterministic Bottom-Up Parsing

Nondeterministic Bottom-Up Automaton II

Example 8.4

Grammar forarithmetic expressions(cf. Example 8.2):

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Bottom-up parsing of (a)*b:((a)*b, ε , ε)` ( a)*b, ( , ε)` ( )*b, (a, ε)

` ()*b, (F , 6 )

` ()*b, (T , 64 )` ()*b, (E , 642 )` ( *b, (E) , 642 )` ( *b, F , 6425 )` ( *b, T , 64254 )` ( b, T* , 64254 )` ( ε, T*b , 64254 )` ( ε, T*F , 642547 )` ( ε, T , 6425473 )` ( ε, E , 64254732)

8 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 32: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Nondeterministic Bottom-Up Parsing

Nondeterministic Bottom-Up Automaton II

Example 8.4

Grammar forarithmetic expressions(cf. Example 8.2):

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Bottom-up parsing of (a)*b:((a)*b, ε , ε)` ( a)*b, ( , ε)` ( )*b, (a, ε)

` ()*b, (F , 6 )` ()*b, (T , 64 )

` ()*b, (E , 642 )` ( *b, (E) , 642 )` ( *b, F , 6425 )` ( *b, T , 64254 )` ( b, T* , 64254 )` ( ε, T*b , 64254 )` ( ε, T*F , 642547 )` ( ε, T , 6425473 )` ( ε, E , 64254732)

8 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 33: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Nondeterministic Bottom-Up Parsing

Nondeterministic Bottom-Up Automaton II

Example 8.4

Grammar forarithmetic expressions(cf. Example 8.2):

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Bottom-up parsing of (a)*b:((a)*b, ε , ε)` ( a)*b, ( , ε)` ( )*b, (a, ε)

` ()*b, (F , 6 )` ()*b, (T , 64 )` ()*b, (E , 642 )

` ( *b, (E) , 642 )` ( *b, F , 6425 )` ( *b, T , 64254 )` ( b, T* , 64254 )` ( ε, T*b , 64254 )` ( ε, T*F , 642547 )` ( ε, T , 6425473 )` ( ε, E , 64254732)

8 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 34: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Nondeterministic Bottom-Up Parsing

Nondeterministic Bottom-Up Automaton II

Example 8.4

Grammar forarithmetic expressions(cf. Example 8.2):

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Bottom-up parsing of (a)*b:((a)*b, ε , ε)` ( a)*b, ( , ε)` ( )*b, (a, ε)

` ()*b, (F , 6 )` ()*b, (T , 64 )` ()*b, (E , 642 )` ( *b, (E) , 642 )

` ( *b, F , 6425 )` ( *b, T , 64254 )` ( b, T* , 64254 )` ( ε, T*b , 64254 )` ( ε, T*F , 642547 )` ( ε, T , 6425473 )` ( ε, E , 64254732)

8 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 35: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Nondeterministic Bottom-Up Parsing

Nondeterministic Bottom-Up Automaton II

Example 8.4

Grammar forarithmetic expressions(cf. Example 8.2):

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Bottom-up parsing of (a)*b:((a)*b, ε , ε)` ( a)*b, ( , ε)` ( )*b, (a, ε)

` ()*b, (F , 6 )` ()*b, (T , 64 )` ()*b, (E , 642 )` ( *b, (E) , 642 )` ( *b, F , 6425 )

` ( *b, T , 64254 )` ( b, T* , 64254 )` ( ε, T*b , 64254 )` ( ε, T*F , 642547 )` ( ε, T , 6425473 )` ( ε, E , 64254732)

8 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 36: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Nondeterministic Bottom-Up Parsing

Nondeterministic Bottom-Up Automaton II

Example 8.4

Grammar forarithmetic expressions(cf. Example 8.2):

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Bottom-up parsing of (a)*b:((a)*b, ε , ε)` ( a)*b, ( , ε)` ( )*b, (a, ε)

` ()*b, (F , 6 )` ()*b, (T , 64 )` ()*b, (E , 642 )` ( *b, (E) , 642 )` ( *b, F , 6425 )` ( *b, T , 64254 )

` ( b, T* , 64254 )` ( ε, T*b , 64254 )` ( ε, T*F , 642547 )` ( ε, T , 6425473 )` ( ε, E , 64254732)

8 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 37: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Nondeterministic Bottom-Up Parsing

Nondeterministic Bottom-Up Automaton II

Example 8.4

Grammar forarithmetic expressions(cf. Example 8.2):

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Bottom-up parsing of (a)*b:((a)*b, ε , ε)` ( a)*b, ( , ε)` ( )*b, (a, ε)

` ()*b, (F , 6 )` ()*b, (T , 64 )` ()*b, (E , 642 )` ( *b, (E) , 642 )` ( *b, F , 6425 )` ( *b, T , 64254 )` ( b, T* , 64254 )

` ( ε, T*b , 64254 )` ( ε, T*F , 642547 )` ( ε, T , 6425473 )` ( ε, E , 64254732)

8 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 38: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Nondeterministic Bottom-Up Parsing

Nondeterministic Bottom-Up Automaton II

Example 8.4

Grammar forarithmetic expressions(cf. Example 8.2):

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Bottom-up parsing of (a)*b:((a)*b, ε , ε)` ( a)*b, ( , ε)` ( )*b, (a, ε)

` ()*b, (F , 6 )` ()*b, (T , 64 )` ()*b, (E , 642 )` ( *b, (E) , 642 )` ( *b, F , 6425 )` ( *b, T , 64254 )` ( b, T* , 64254 )` ( ε, T*b , 64254 )

` ( ε, T*F , 642547 )` ( ε, T , 6425473 )` ( ε, E , 64254732)

8 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 39: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Nondeterministic Bottom-Up Parsing

Nondeterministic Bottom-Up Automaton II

Example 8.4

Grammar forarithmetic expressions(cf. Example 8.2):

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Bottom-up parsing of (a)*b:((a)*b, ε , ε)` ( a)*b, ( , ε)` ( )*b, (a, ε)

` ()*b, (F , 6 )` ()*b, (T , 64 )` ()*b, (E , 642 )` ( *b, (E) , 642 )` ( *b, F , 6425 )` ( *b, T , 64254 )` ( b, T* , 64254 )` ( ε, T*b , 64254 )` ( ε, T*F , 642547 )

` ( ε, T , 6425473 )` ( ε, E , 64254732)

8 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 40: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Nondeterministic Bottom-Up Parsing

Nondeterministic Bottom-Up Automaton II

Example 8.4

Grammar forarithmetic expressions(cf. Example 8.2):

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Bottom-up parsing of (a)*b:((a)*b, ε , ε)` ( a)*b, ( , ε)` ( )*b, (a, ε)

` ()*b, (F , 6 )` ()*b, (T , 64 )` ()*b, (E , 642 )` ( *b, (E) , 642 )` ( *b, F , 6425 )` ( *b, T , 64254 )` ( b, T* , 64254 )` ( ε, T*b , 64254 )` ( ε, T*F , 642547 )` ( ε, T , 6425473 )

` ( ε, E , 64254732)

8 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 41: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Nondeterministic Bottom-Up Parsing

Nondeterministic Bottom-Up Automaton II

Example 8.4

Grammar forarithmetic expressions(cf. Example 8.2):

GAE : E → E+T | T (1, 2)T → T*F | F (3, 4)F → (E) | a | b (5, 6, 7)

Bottom-up parsing of (a)*b:((a)*b, ε , ε)` ( a)*b, ( , ε)` ( )*b, (a, ε)

` ()*b, (F , 6 )` ()*b, (T , 64 )` ()*b, (E , 642 )` ( *b, (E) , 642 )` ( *b, F , 6425 )` ( *b, T , 64254 )` ( b, T* , 64254 )` ( ε, T*b , 64254 )` ( ε, T*F , 642547 )` ( ε, T , 6425473 )` ( ε, E , 64254732)

8 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 42: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Nondeterministic Bottom-Up Parsing

Correctness of NBA(G)

Theorem 8.5 (Correctness of NBA(G))

Let G = 〈N,Σ,P,S〉 ∈ CFGΣ and NBA(G) as before. Then, for every w ∈ Σ∗ andz ∈ [p]∗,

(w , ε, ε) `∗ (ε,S, z) iff ←−z is a rightmost analysis of w

Proof.

similar to the top-down case (Theorem 6.1)

9 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 43: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Nondeterministic Bottom-Up Parsing

Correctness of NBA(G)

Theorem 8.5 (Correctness of NBA(G))

Let G = 〈N,Σ,P,S〉 ∈ CFGΣ and NBA(G) as before. Then, for every w ∈ Σ∗ andz ∈ [p]∗,

(w , ε, ε) `∗ (ε,S, z) iff ←−z is a rightmost analysis of w

Proof.

similar to the top-down case (Theorem 6.1)

9 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 44: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Nondeterministic Bottom-Up Parsing

Nondeterminisn in NBA(G)

Observation: NBA(G) is generally nondeterministic• Shift or reduce? Example:

(bw , αa, z) `{

(w , αab, z)(bw , αA, zi)

if πi = A→ a

• If reduce: which “handle” β? Example:

(w , αab, z) `{

(w , αA, zi)(w , αaB, zj)

if πi = A→ ab and πj = B → b

• If reduce β: which left-hand side A? Example:

(w , αa, z) `{

(w , αA, zi)(w , αB, zj)

if πi = A→ a and πj = B → a

• When to terminate parsing? Example:

(ε,S, z)︸ ︷︷ ︸final

` (ε,A, zi) if πi = A→ S

10 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 45: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Nondeterministic Bottom-Up Parsing

Nondeterminisn in NBA(G)

Observation: NBA(G) is generally nondeterministic• Shift or reduce? Example:

(bw , αa, z) `{

(w , αab, z)(bw , αA, zi)

if πi = A→ a

• If reduce: which “handle” β? Example:

(w , αab, z) `{

(w , αA, zi)(w , αaB, zj)

if πi = A→ ab and πj = B → b

• If reduce β: which left-hand side A? Example:

(w , αa, z) `{

(w , αA, zi)(w , αB, zj)

if πi = A→ a and πj = B → a

• When to terminate parsing? Example:

(ε,S, z)︸ ︷︷ ︸final

` (ε,A, zi) if πi = A→ S

10 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 46: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Nondeterministic Bottom-Up Parsing

Nondeterminisn in NBA(G)

Observation: NBA(G) is generally nondeterministic• Shift or reduce? Example:

(bw , αa, z) `{

(w , αab, z)(bw , αA, zi)

if πi = A→ a

• If reduce: which “handle” β? Example:

(w , αab, z) `{

(w , αA, zi)(w , αaB, zj)

if πi = A→ ab and πj = B → b

• If reduce β: which left-hand side A? Example:

(w , αa, z) `{

(w , αA, zi)(w , αB, zj)

if πi = A→ a and πj = B → a

• When to terminate parsing? Example:

(ε,S, z)︸ ︷︷ ︸final

` (ε,A, zi) if πi = A→ S

10 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 47: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Nondeterministic Bottom-Up Parsing

Nondeterminisn in NBA(G)

Observation: NBA(G) is generally nondeterministic• Shift or reduce? Example:

(bw , αa, z) `{

(w , αab, z)(bw , αA, zi)

if πi = A→ a

• If reduce: which “handle” β? Example:

(w , αab, z) `{

(w , αA, zi)(w , αaB, zj)

if πi = A→ ab and πj = B → b

• If reduce β: which left-hand side A? Example:

(w , αa, z) `{

(w , αA, zi)(w , αB, zj)

if πi = A→ a and πj = B → a

• When to terminate parsing? Example:

(ε,S, z)︸ ︷︷ ︸final

` (ε,A, zi) if πi = A→ S

10 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 48: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Resolving Termination Nondeterminism

Outline of Lecture 8

Bottom-Up Parsing

Nondeterministic Bottom-Up Parsing

Resolving Termination Nondeterminism

LR(k) Grammars

LR(0) Grammars

Examples of LR(0) Conflicts

11 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 49: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Resolving Termination Nondeterminism

Resolving Termination Nondeterminism I

General assumption to avoid nondeterminism of last type:every grammar is start separated

Definition 8.6 (Start separation)

A grammar G = 〈N,Σ,P,S〉 ∈ CFGΣ is called start separated if S only occurs inproductions of the form S → A where A 6= S.

Remarks:• Start separation always possible by adding S′ → S with new start symbol S′

• From now on consider only reduced grammars of this form (and let π0 := S′ → S)

12 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 50: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Resolving Termination Nondeterminism

Resolving Termination Nondeterminism I

General assumption to avoid nondeterminism of last type:every grammar is start separated

Definition 8.6 (Start separation)

A grammar G = 〈N,Σ,P,S〉 ∈ CFGΣ is called start separated if S only occurs inproductions of the form S → A where A 6= S.

Remarks:• Start separation always possible by adding S′ → S with new start symbol S′

• From now on consider only reduced grammars of this form (and let π0 := S′ → S)

12 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 51: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Resolving Termination Nondeterminism

Resolving Termination Nondeterminism II

Start separation removes “When to terminate parsing?” nondeterminism:

Lemma 8.7

If G ∈ CFGΣ is start separated, then no successor of a final configuration (ε,S′, z) inNBA(G) is again a final configuration.(Thus parsing should be stopped in the first final configuration.)

Proof.

• To (ε,S′, z), only reductions by ε-productions can be applied:

(ε,S′, z) ` (ε,S′A, zi) if πi = A→ ε

• Thereafter, only reductions by productions of the form A0 → A1 . . .An (n ≥ 0) applicable• Every resulting configuration is of the (non-final) form

(ε,S′B1 . . .Bk , z) where k ≥ 1

13 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 52: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Resolving Termination Nondeterminism

Resolving Termination Nondeterminism II

Start separation removes “When to terminate parsing?” nondeterminism:

Lemma 8.7

If G ∈ CFGΣ is start separated, then no successor of a final configuration (ε,S′, z) inNBA(G) is again a final configuration.(Thus parsing should be stopped in the first final configuration.)

Proof.

• To (ε,S′, z), only reductions by ε-productions can be applied:

(ε,S′, z) ` (ε,S′A, zi) if πi = A→ ε

• Thereafter, only reductions by productions of the form A0 → A1 . . .An (n ≥ 0) applicable• Every resulting configuration is of the (non-final) form

(ε,S′B1 . . .Bk , z) where k ≥ 1

13 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 53: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Resolving Termination Nondeterminism

Resolving Termination Nondeterminism II

Start separation removes “When to terminate parsing?” nondeterminism:

Lemma 8.7

If G ∈ CFGΣ is start separated, then no successor of a final configuration (ε,S′, z) inNBA(G) is again a final configuration.(Thus parsing should be stopped in the first final configuration.)

Proof.

• To (ε,S′, z), only reductions by ε-productions can be applied:

(ε,S′, z) ` (ε,S′A, zi) if πi = A→ ε

• Thereafter, only reductions by productions of the form A0 → A1 . . .An (n ≥ 0) applicable

• Every resulting configuration is of the (non-final) form

(ε,S′B1 . . .Bk , z) where k ≥ 1

13 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 54: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Resolving Termination Nondeterminism

Resolving Termination Nondeterminism II

Start separation removes “When to terminate parsing?” nondeterminism:

Lemma 8.7

If G ∈ CFGΣ is start separated, then no successor of a final configuration (ε,S′, z) inNBA(G) is again a final configuration.(Thus parsing should be stopped in the first final configuration.)

Proof.

• To (ε,S′, z), only reductions by ε-productions can be applied:

(ε,S′, z) ` (ε,S′A, zi) if πi = A→ ε

• Thereafter, only reductions by productions of the form A0 → A1 . . .An (n ≥ 0) applicable• Every resulting configuration is of the (non-final) form

(ε,S′B1 . . .Bk , z) where k ≥ 1

13 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 55: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(k) Grammars

Outline of Lecture 8

Bottom-Up Parsing

Nondeterministic Bottom-Up Parsing

Resolving Termination Nondeterminism

LR(k) Grammars

LR(0) Grammars

Examples of LR(0) Conflicts

14 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 56: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(k) Grammars

LR(k) Grammars I

Goal: resolve remaining nondeterminism of NBA(G) by supporting lookahead ofk ∈ N symbols on the input=⇒ LR(k): reading of input from left to right with k -lookahead,

computing a rightmost analysis

Definition 8.8 (LR(k) grammar)

Let G = 〈N,Σ,P,S〉 ∈ CFGΣ be start separated and k ∈ N. Then G has the LR(k)property (notation: G ∈ LR(k)) if for all rightmost derivations of the form

S

{⇒∗r αAw ⇒r αβw⇒∗r γBx ⇒r αβy

such that firstk(w) = firstk(y), it follows that α = γ, A = B, and x = y .

15 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 57: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(k) Grammars

LR(k) Grammars I

Goal: resolve remaining nondeterminism of NBA(G) by supporting lookahead ofk ∈ N symbols on the input=⇒ LR(k): reading of input from left to right with k -lookahead,

computing a rightmost analysis

Definition 8.8 (LR(k) grammar)

Let G = 〈N,Σ,P,S〉 ∈ CFGΣ be start separated and k ∈ N. Then G has the LR(k)property (notation: G ∈ LR(k)) if for all rightmost derivations of the form

S

{⇒∗r αAw ⇒r αβw⇒∗r γBx ⇒r αβy

such that firstk(w) = firstk(y), it follows that α = γ, A = B, and x = y .

15 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 58: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(k) Grammars

LR(k) Grammars II

Remarks:• If G ∈ LR(k), then the reduction of αβw to αAw is already determined by firstk(w).• Therefore NBA(G) in configuration (w , αβ, z) can decide to reduce and how to reduce.

• Computation of NBA(G) for S ⇒∗r αAw ⇒r αβw :

(w ′w , ε, ε) `∗ (w , αβ, z)red i` (w , αA, zi) ` . . .

where πi = A→ β• Computation of NBA(G) for S ⇒∗r γBx ⇒r αβy :

– with direct reduction (y = x , αβ = γδ, πj = B → δ):

(y ′y , ε, ε) `∗ (y , αβ, z ′) = (x, γδ, z ′)red j

` (x, γB, z ′j) ` . . .

– with previous shifts (y = x ′x , αβx ′ = γδ, πj = B → δ):

(y ′y , ε, ε) `∗ (y , αβ, z ′) = (x ′x, αβ, z ′)shift`∗

(x, αβx ′, z ′) = (x, γδ, z ′)red j

` (x, γB, z ′j) ` . . .

16 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 59: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(k) Grammars

LR(k) Grammars II

Remarks:• If G ∈ LR(k), then the reduction of αβw to αAw is already determined by firstk(w).• Therefore NBA(G) in configuration (w , αβ, z) can decide to reduce and how to reduce.• Computation of NBA(G) for S ⇒∗r αAw ⇒r αβw :

(w ′w , ε, ε) `∗ (w , αβ, z)red i` (w , αA, zi) ` . . .

where πi = A→ β

• Computation of NBA(G) for S ⇒∗r γBx ⇒r αβy :– with direct reduction (y = x , αβ = γδ, πj = B → δ):

(y ′y , ε, ε) `∗ (y , αβ, z ′) = (x, γδ, z ′)red j

` (x, γB, z ′j) ` . . .

– with previous shifts (y = x ′x , αβx ′ = γδ, πj = B → δ):

(y ′y , ε, ε) `∗ (y , αβ, z ′) = (x ′x, αβ, z ′)shift`∗

(x, αβx ′, z ′) = (x, γδ, z ′)red j

` (x, γB, z ′j) ` . . .

16 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 60: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(k) Grammars

LR(k) Grammars II

Remarks:• If G ∈ LR(k), then the reduction of αβw to αAw is already determined by firstk(w).• Therefore NBA(G) in configuration (w , αβ, z) can decide to reduce and how to reduce.• Computation of NBA(G) for S ⇒∗r αAw ⇒r αβw :

(w ′w , ε, ε) `∗ (w , αβ, z)red i` (w , αA, zi) ` . . .

where πi = A→ β• Computation of NBA(G) for S ⇒∗r γBx ⇒r αβy :

– with direct reduction (y = x , αβ = γδ, πj = B → δ):

(y ′y , ε, ε) `∗ (y , αβ, z ′) = (x, γδ, z ′)red j

` (x, γB, z ′j) ` . . .

– with previous shifts (y = x ′x , αβx ′ = γδ, πj = B → δ):

(y ′y , ε, ε) `∗ (y , αβ, z ′) = (x ′x, αβ, z ′)shift`∗

(x, αβx ′, z ′) = (x, γδ, z ′)red j

` (x, γB, z ′j) ` . . .

16 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 61: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(k) Grammars

LR(k) Grammars II

Remarks:• If G ∈ LR(k), then the reduction of αβw to αAw is already determined by firstk(w).• Therefore NBA(G) in configuration (w , αβ, z) can decide to reduce and how to reduce.• Computation of NBA(G) for S ⇒∗r αAw ⇒r αβw :

(w ′w , ε, ε) `∗ (w , αβ, z)red i` (w , αA, zi) ` . . .

where πi = A→ β• Computation of NBA(G) for S ⇒∗r γBx ⇒r αβy :

– with direct reduction (y = x , αβ = γδ, πj = B → δ):

(y ′y , ε, ε) `∗ (y , αβ, z ′) = (x, γδ, z ′)red j

` (x, γB, z ′j) ` . . .

– with previous shifts (y = x ′x , αβx ′ = γδ, πj = B → δ):

(y ′y , ε, ε) `∗ (y , αβ, z ′) = (x ′x, αβ, z ′)shift`∗

(x, αβx ′, z ′) = (x, γδ, z ′)red j

` (x, γB, z ′j) ` . . .

16 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 62: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

Outline of Lecture 8

Bottom-Up Parsing

Nondeterministic Bottom-Up Parsing

Resolving Termination Nondeterminism

LR(k) Grammars

LR(0) Grammars

Examples of LR(0) Conflicts

17 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 63: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

LR(0) Grammars

The case k = 0 is relevant (in contrast to LL(0)): here the decision is just based onthe contents of the pushdown, without any lookahead.

Corollary 8.9 (LR(0) grammar)

G ∈ CFGΣ has the LR(0) property if for all rightmost derivations of the form

S

{⇒∗r αAw ⇒r αβw⇒∗r γBx ⇒r αβy

it follows that α = γ, A = B, and x = y.

Goal: derive a finite information from the pushdown which suffices to resolve thenondeterminism (similar to abstraction of right context in LL parsing by fo-sets)

18 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 64: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

LR(0) Grammars

The case k = 0 is relevant (in contrast to LL(0)): here the decision is just based onthe contents of the pushdown, without any lookahead.

Corollary 8.9 (LR(0) grammar)

G ∈ CFGΣ has the LR(0) property if for all rightmost derivations of the form

S

{⇒∗r αAw ⇒r αβw⇒∗r γBx ⇒r αβy

it follows that α = γ, A = B, and x = y.

Goal: derive a finite information from the pushdown which suffices to resolve thenondeterminism (similar to abstraction of right context in LL parsing by fo-sets)

18 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 65: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

LR(0) Grammars

The case k = 0 is relevant (in contrast to LL(0)): here the decision is just based onthe contents of the pushdown, without any lookahead.

Corollary 8.9 (LR(0) grammar)

G ∈ CFGΣ has the LR(0) property if for all rightmost derivations of the form

S

{⇒∗r αAw ⇒r αβw⇒∗r γBx ⇒r αβy

it follows that α = γ, A = B, and x = y.

Goal: derive a finite information from the pushdown which suffices to resolve thenondeterminism (similar to abstraction of right context in LL parsing by fo-sets)

18 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 66: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

LR(0) Items and Sets I

Example 8.10

G : S′→ S (0)S → B | C (1, 2)B → aB | b (3, 4)C → aC | c (5, 6)

NBA(G):(ab, ε, ε)

` (b, a, ε)` (ε, ab, ε)` (ε, aB, 4)` (ε,B, 43)` (ε,S, 431)` (ε,S′, 4310)

S′

S

B

a B

b

19 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 67: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

LR(0) Items and Sets I

Example 8.10

G : S′→ S (0)S → B | C (1, 2)B → aB | b (3, 4)C → aC | c (5, 6)

NBA(G):(ab, ε, ε)

` (b, a, ε)` (ε, ab, ε)` (ε, aB, 4)` (ε,B, 43)` (ε,S, 431)` (ε,S′, 4310)

[S′ → .S]

[S → .B]

[B → .aB]

a [B → .b]

b

19 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 68: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

LR(0) Items and Sets I

Example 8.10

G : S′→ S (0)S → B | C (1, 2)B → aB | b (3, 4)C → aC | c (5, 6)

NBA(G):(ab, ε, ε)

` (b, a, ε)

` (ε, ab, ε)` (ε, aB, 4)` (ε,B, 43)` (ε,S, 431)` (ε,S′, 4310)

[S′ → .S]

[S → .B]

[B → a.B]

a [B → .b]

b

19 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 69: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

LR(0) Items and Sets I

Example 8.10

G : S′→ S (0)S → B | C (1, 2)B → aB | b (3, 4)C → aC | c (5, 6)

NBA(G):(ab, ε, ε)

` (b, a, ε)` (ε, ab, ε)

` (ε, aB, 4)` (ε,B, 43)` (ε,S, 431)` (ε,S′, 4310)

[S′ → .S]

[S → .B]

[B → a.B]

a [B → b.]

b

19 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 70: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

LR(0) Items and Sets I

Example 8.10

G : S′→ S (0)S → B | C (1, 2)B → aB | b (3, 4)C → aC | c (5, 6)

NBA(G):(ab, ε, ε)

` (b, a, ε)` (ε, ab, ε)` (ε, aB, 4)

` (ε,B, 43)` (ε,S, 431)` (ε,S′, 4310)

[S′ → .S]

[S → .B]

[B → aB.]

a [B → b.]

b

19 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 71: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

LR(0) Items and Sets I

Example 8.10

G : S′→ S (0)S → B | C (1, 2)B → aB | b (3, 4)C → aC | c (5, 6)

NBA(G):(ab, ε, ε)

` (b, a, ε)` (ε, ab, ε)` (ε, aB, 4)` (ε,B, 43)

` (ε,S, 431)` (ε,S′, 4310)

[S′ → .S]

[S → B.]

[B → aB.]

a [B → b.]

b

19 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 72: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

LR(0) Items and Sets I

Example 8.10

G : S′→ S (0)S → B | C (1, 2)B → aB | b (3, 4)C → aC | c (5, 6)

NBA(G):(ab, ε, ε)

` (b, a, ε)` (ε, ab, ε)` (ε, aB, 4)` (ε,B, 43)` (ε,S, 431)

` (ε,S′, 4310)

[S′ → S.]

[S → B.]

[B → aB.]

a [B → b.]

b

19 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 73: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

LR(0) Items and Sets I

Example 8.10

G : S′→ S (0)S → B | C (1, 2)B → aB | b (3, 4)C → aC | c (5, 6)

NBA(G):(ab, ε, ε)

` (b, a, ε)` (ε, ab, ε)` (ε, aB, 4)` (ε,B, 43)` (ε,S, 431)` (ε,S′, 4310)

[S′ → S.]

[S → B.]

[B → aB.]

a [B → b.]

b

19 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 74: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

LR(0) Items and Sets II

Definition 8.11 (LR(0) items and sets)

Let G = 〈N,Σ,P,S〉 ∈ CFGΣ be start separated by S′ → S andS′ ⇒∗r αAw ⇒r αβ1β2w (i.e., A→ β1β2 ∈ P).• [A→ β1 · β2] is called an LR(0) item for αβ1.

• Given γ ∈ X ∗, LR(0)(γ) denotes the set of all LR(0) items for γ, called the LR(0) set (or:LR(0) information) of γ.• LR(0)(G) := {LR(0)(γ) | γ ∈ X ∗}.

Corollary 8.12

1. For every γ ∈ X ∗, LR(0)(γ) is finite.2. LR(0)(G) is finite.3. The item [A→ β·] ∈ LR(0)(γ) indicates the possible reduction (w , αβ, z) ` (w , αA, zi)

where πi = A→ β and γ = αβ.4. The item [A→ β1 · Yβ2] ∈ LR(0)(γ) indicates an incomplete handle β1 (to be completed by

shift operations or ε-reductions).

20 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 75: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

LR(0) Items and Sets II

Definition 8.11 (LR(0) items and sets)

Let G = 〈N,Σ,P,S〉 ∈ CFGΣ be start separated by S′ → S andS′ ⇒∗r αAw ⇒r αβ1β2w (i.e., A→ β1β2 ∈ P).• [A→ β1 · β2] is called an LR(0) item for αβ1.• Given γ ∈ X ∗, LR(0)(γ) denotes the set of all LR(0) items for γ, called the LR(0) set (or:

LR(0) information) of γ.

• LR(0)(G) := {LR(0)(γ) | γ ∈ X ∗}.

Corollary 8.12

1. For every γ ∈ X ∗, LR(0)(γ) is finite.2. LR(0)(G) is finite.3. The item [A→ β·] ∈ LR(0)(γ) indicates the possible reduction (w , αβ, z) ` (w , αA, zi)

where πi = A→ β and γ = αβ.4. The item [A→ β1 · Yβ2] ∈ LR(0)(γ) indicates an incomplete handle β1 (to be completed by

shift operations or ε-reductions).

20 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 76: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

LR(0) Items and Sets II

Definition 8.11 (LR(0) items and sets)

Let G = 〈N,Σ,P,S〉 ∈ CFGΣ be start separated by S′ → S andS′ ⇒∗r αAw ⇒r αβ1β2w (i.e., A→ β1β2 ∈ P).• [A→ β1 · β2] is called an LR(0) item for αβ1.• Given γ ∈ X ∗, LR(0)(γ) denotes the set of all LR(0) items for γ, called the LR(0) set (or:

LR(0) information) of γ.• LR(0)(G) := {LR(0)(γ) | γ ∈ X ∗}.

Corollary 8.12

1. For every γ ∈ X ∗, LR(0)(γ) is finite.2. LR(0)(G) is finite.3. The item [A→ β·] ∈ LR(0)(γ) indicates the possible reduction (w , αβ, z) ` (w , αA, zi)

where πi = A→ β and γ = αβ.4. The item [A→ β1 · Yβ2] ∈ LR(0)(γ) indicates an incomplete handle β1 (to be completed by

shift operations or ε-reductions).

20 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 77: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

LR(0) Items and Sets II

Definition 8.11 (LR(0) items and sets)

Let G = 〈N,Σ,P,S〉 ∈ CFGΣ be start separated by S′ → S andS′ ⇒∗r αAw ⇒r αβ1β2w (i.e., A→ β1β2 ∈ P).• [A→ β1 · β2] is called an LR(0) item for αβ1.• Given γ ∈ X ∗, LR(0)(γ) denotes the set of all LR(0) items for γ, called the LR(0) set (or:

LR(0) information) of γ.• LR(0)(G) := {LR(0)(γ) | γ ∈ X ∗}.

Corollary 8.12

1. For every γ ∈ X ∗, LR(0)(γ) is finite.

2. LR(0)(G) is finite.3. The item [A→ β·] ∈ LR(0)(γ) indicates the possible reduction (w , αβ, z) ` (w , αA, zi)

where πi = A→ β and γ = αβ.4. The item [A→ β1 · Yβ2] ∈ LR(0)(γ) indicates an incomplete handle β1 (to be completed by

shift operations or ε-reductions).

20 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 78: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

LR(0) Items and Sets II

Definition 8.11 (LR(0) items and sets)

Let G = 〈N,Σ,P,S〉 ∈ CFGΣ be start separated by S′ → S andS′ ⇒∗r αAw ⇒r αβ1β2w (i.e., A→ β1β2 ∈ P).• [A→ β1 · β2] is called an LR(0) item for αβ1.• Given γ ∈ X ∗, LR(0)(γ) denotes the set of all LR(0) items for γ, called the LR(0) set (or:

LR(0) information) of γ.• LR(0)(G) := {LR(0)(γ) | γ ∈ X ∗}.

Corollary 8.12

1. For every γ ∈ X ∗, LR(0)(γ) is finite.2. LR(0)(G) is finite.

3. The item [A→ β·] ∈ LR(0)(γ) indicates the possible reduction (w , αβ, z) ` (w , αA, zi)where πi = A→ β and γ = αβ.

4. The item [A→ β1 · Yβ2] ∈ LR(0)(γ) indicates an incomplete handle β1 (to be completed byshift operations or ε-reductions).

20 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 79: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

LR(0) Items and Sets II

Definition 8.11 (LR(0) items and sets)

Let G = 〈N,Σ,P,S〉 ∈ CFGΣ be start separated by S′ → S andS′ ⇒∗r αAw ⇒r αβ1β2w (i.e., A→ β1β2 ∈ P).• [A→ β1 · β2] is called an LR(0) item for αβ1.• Given γ ∈ X ∗, LR(0)(γ) denotes the set of all LR(0) items for γ, called the LR(0) set (or:

LR(0) information) of γ.• LR(0)(G) := {LR(0)(γ) | γ ∈ X ∗}.

Corollary 8.12

1. For every γ ∈ X ∗, LR(0)(γ) is finite.2. LR(0)(G) is finite.3. The item [A→ β·] ∈ LR(0)(γ) indicates the possible reduction (w , αβ, z) ` (w , αA, zi)

where πi = A→ β and γ = αβ.

4. The item [A→ β1 · Yβ2] ∈ LR(0)(γ) indicates an incomplete handle β1 (to be completed byshift operations or ε-reductions).

20 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 80: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

LR(0) Items and Sets II

Definition 8.11 (LR(0) items and sets)

Let G = 〈N,Σ,P,S〉 ∈ CFGΣ be start separated by S′ → S andS′ ⇒∗r αAw ⇒r αβ1β2w (i.e., A→ β1β2 ∈ P).• [A→ β1 · β2] is called an LR(0) item for αβ1.• Given γ ∈ X ∗, LR(0)(γ) denotes the set of all LR(0) items for γ, called the LR(0) set (or:

LR(0) information) of γ.• LR(0)(G) := {LR(0)(γ) | γ ∈ X ∗}.

Corollary 8.12

1. For every γ ∈ X ∗, LR(0)(γ) is finite.2. LR(0)(G) is finite.3. The item [A→ β·] ∈ LR(0)(γ) indicates the possible reduction (w , αβ, z) ` (w , αA, zi)

where πi = A→ β and γ = αβ.4. The item [A→ β1 · Yβ2] ∈ LR(0)(γ) indicates an incomplete handle β1 (to be completed by

shift operations or ε-reductions).

20 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 81: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

LR(0) Conflicts

Definition 8.13 (LR(0) conflicts)

Let G = 〈N,Σ,P,S〉 ∈ CFGΣ and I ∈ LR(0)(G).• I has a shift/reduce conflict if there exist A→ α1aα2,B → β ∈ P such that

[A→ α1 · aα2], [B → β·] ∈ I.

• I has a reduce/reduce conflict if there exist A→ α,B → β ∈ P with A 6= B or α 6= β suchthat

[A→ α·], [B → β·] ∈ I.

Lemma 8.14

G ∈ LR(0) iff no I ∈ LR(0)(G) contains conflicting items.

Proof.

omitted

21 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 82: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

LR(0) Conflicts

Definition 8.13 (LR(0) conflicts)

Let G = 〈N,Σ,P,S〉 ∈ CFGΣ and I ∈ LR(0)(G).• I has a shift/reduce conflict if there exist A→ α1aα2,B → β ∈ P such that

[A→ α1 · aα2], [B → β·] ∈ I.

• I has a reduce/reduce conflict if there exist A→ α,B → β ∈ P with A 6= B or α 6= β suchthat

[A→ α·], [B → β·] ∈ I.

Lemma 8.14

G ∈ LR(0) iff no I ∈ LR(0)(G) contains conflicting items.

Proof.

omitted

21 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 83: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

LR(0) Conflicts

Definition 8.13 (LR(0) conflicts)

Let G = 〈N,Σ,P,S〉 ∈ CFGΣ and I ∈ LR(0)(G).• I has a shift/reduce conflict if there exist A→ α1aα2,B → β ∈ P such that

[A→ α1 · aα2], [B → β·] ∈ I.

• I has a reduce/reduce conflict if there exist A→ α,B → β ∈ P with A 6= B or α 6= β suchthat

[A→ α·], [B → β·] ∈ I.

Lemma 8.14

G ∈ LR(0) iff no I ∈ LR(0)(G) contains conflicting items.

Proof.

omitted

21 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 84: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

Computing LR(0) Sets I

Theorem 8.15 (Computing LR(0) sets)

Let G = 〈N,Σ,P,S〉 ∈ CFGΣ be start separated by S′ → S and reduced.1. LR(0)(ε) is the least set such that

– [S′ → ·S] ∈ LR(0)(ε) and– if [A→ ·Bγ] ∈ LR(0)(ε) and B → β ∈ P,

then [B → ·β] ∈ LR(0)(ε).

2. LR(0)(αY ) (α ∈ X ∗,Y ∈ X) is the least set such that– if [A→ γ1 · Yγ2] ∈ LR(0)(α),

then [A→ γ1Y · γ2] ∈ LR(0)(αY ) and– if [A→ γ1 · Bγ2] ∈ LR(0)(αY ) and B → β ∈ P,

then [B → ·β] ∈ LR(0)(αY ).

22 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 85: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

Computing LR(0) Sets I

Theorem 8.15 (Computing LR(0) sets)

Let G = 〈N,Σ,P,S〉 ∈ CFGΣ be start separated by S′ → S and reduced.1. LR(0)(ε) is the least set such that

– [S′ → ·S] ∈ LR(0)(ε) and– if [A→ ·Bγ] ∈ LR(0)(ε) and B → β ∈ P,

then [B → ·β] ∈ LR(0)(ε).2. LR(0)(αY ) (α ∈ X ∗,Y ∈ X) is the least set such that

– if [A→ γ1 · Yγ2] ∈ LR(0)(α),then [A→ γ1Y · γ2] ∈ LR(0)(αY ) and

– if [A→ γ1 · Bγ2] ∈ LR(0)(αY ) and B → β ∈ P,then [B → ·β] ∈ LR(0)(αY ).

22 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 86: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

Computing LR(0) Sets II

Example 8.16 (cf. Example 8.10)G : S′→ S S → B | C

B → aB | b C → aC | c

I0 := LR(0)(ε) : [S′ → ·S] [S → ·B] [S → ·C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I1 := LR(0)(S) : [S′ → S·]I2 := LR(0)(B) : [S → B·]I3 := LR(0)(C) : [S → C·]I4 := LR(0)(a) : [B → a · B] [C → a · C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I5 := LR(0)(b) : [B → b·]I6 := LR(0)(c) : [C → c·]I7 := LR(0)(aB) : [B → aB·]I8 := LR(0)(aC) : [C → aC·]

(LR(0)(aa) = LR(0)(a) = I4, LR(0)(ab) = LR(0)(b) = I5, LR(0)(ac) = LR(0)(c) = I6, ...,I9 := LR(0)(γ) = ∅ in all remaining cases, e.g., for γ = bB)

No conflicts =⇒ G ∈ LR(0) (but G /∈ LL(1))

23 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 87: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

Computing LR(0) Sets II

Example 8.16 (cf. Example 8.10)G : S′→ S S → B | C

B → aB | b C → aC | c [S′ → ·S] ∈ LR(0)(ε)

I0 := LR(0)(ε) : [S′ → ·S]

[S → ·B] [S → ·C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I1 := LR(0)(S) : [S′ → S·]I2 := LR(0)(B) : [S → B·]I3 := LR(0)(C) : [S → C·]I4 := LR(0)(a) : [B → a · B] [C → a · C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I5 := LR(0)(b) : [B → b·]I6 := LR(0)(c) : [C → c·]I7 := LR(0)(aB) : [B → aB·]I8 := LR(0)(aC) : [C → aC·]

(LR(0)(aa) = LR(0)(a) = I4, LR(0)(ab) = LR(0)(b) = I5, LR(0)(ac) = LR(0)(c) = I6, ...,I9 := LR(0)(γ) = ∅ in all remaining cases, e.g., for γ = bB)

No conflicts =⇒ G ∈ LR(0) (but G /∈ LL(1))

23 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 88: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

Computing LR(0) Sets II

Example 8.16 (cf. Example 8.10)G : S′→ S S → B | C

B → aB | b C → aC | c[A→ ·Bγ] ∈ LR(0)(ε),B → β ∈ P=⇒ [B → ·β] ∈ LR(0)(ε)

I0 := LR(0)(ε) : [S′ → ·S] [S → ·B]

[S → ·C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I1 := LR(0)(S) : [S′ → S·]I2 := LR(0)(B) : [S → B·]I3 := LR(0)(C) : [S → C·]I4 := LR(0)(a) : [B → a · B] [C → a · C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I5 := LR(0)(b) : [B → b·]I6 := LR(0)(c) : [C → c·]I7 := LR(0)(aB) : [B → aB·]I8 := LR(0)(aC) : [C → aC·]

(LR(0)(aa) = LR(0)(a) = I4, LR(0)(ab) = LR(0)(b) = I5, LR(0)(ac) = LR(0)(c) = I6, ...,I9 := LR(0)(γ) = ∅ in all remaining cases, e.g., for γ = bB)

No conflicts =⇒ G ∈ LR(0) (but G /∈ LL(1))

23 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 89: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

Computing LR(0) Sets II

Example 8.16 (cf. Example 8.10)G : S′→ S S → B | C

B → aB | b C → aC | c[A→ ·Bγ] ∈ LR(0)(ε),B → β ∈ P=⇒ [B → ·β] ∈ LR(0)(ε)

I0 := LR(0)(ε) : [S′ → ·S] [S → ·B] [S → ·C]

[B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I1 := LR(0)(S) : [S′ → S·]I2 := LR(0)(B) : [S → B·]I3 := LR(0)(C) : [S → C·]I4 := LR(0)(a) : [B → a · B] [C → a · C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I5 := LR(0)(b) : [B → b·]I6 := LR(0)(c) : [C → c·]I7 := LR(0)(aB) : [B → aB·]I8 := LR(0)(aC) : [C → aC·]

(LR(0)(aa) = LR(0)(a) = I4, LR(0)(ab) = LR(0)(b) = I5, LR(0)(ac) = LR(0)(c) = I6, ...,I9 := LR(0)(γ) = ∅ in all remaining cases, e.g., for γ = bB)

No conflicts =⇒ G ∈ LR(0) (but G /∈ LL(1))

23 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 90: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

Computing LR(0) Sets II

Example 8.16 (cf. Example 8.10)G : S′→ S S → B | C

B → aB | b C → aC | c[A→ ·Bγ] ∈ LR(0)(ε),B → β ∈ P=⇒ [B → ·β] ∈ LR(0)(ε)

I0 := LR(0)(ε) : [S′ → ·S] [S → ·B] [S → ·C] [B → ·aB] [B → ·b]

[C → ·aC] [C → ·c]

I1 := LR(0)(S) : [S′ → S·]I2 := LR(0)(B) : [S → B·]I3 := LR(0)(C) : [S → C·]I4 := LR(0)(a) : [B → a · B] [C → a · C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I5 := LR(0)(b) : [B → b·]I6 := LR(0)(c) : [C → c·]I7 := LR(0)(aB) : [B → aB·]I8 := LR(0)(aC) : [C → aC·]

(LR(0)(aa) = LR(0)(a) = I4, LR(0)(ab) = LR(0)(b) = I5, LR(0)(ac) = LR(0)(c) = I6, ...,I9 := LR(0)(γ) = ∅ in all remaining cases, e.g., for γ = bB)

No conflicts =⇒ G ∈ LR(0) (but G /∈ LL(1))

23 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 91: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

Computing LR(0) Sets II

Example 8.16 (cf. Example 8.10)G : S′→ S S → B | C

B → aB | b C → aC | c[A→ ·Bγ] ∈ LR(0)(ε),B → β ∈ P=⇒ [B → ·β] ∈ LR(0)(ε)

I0 := LR(0)(ε) : [S′ → ·S] [S → ·B] [S → ·C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I1 := LR(0)(S) : [S′ → S·]I2 := LR(0)(B) : [S → B·]I3 := LR(0)(C) : [S → C·]I4 := LR(0)(a) : [B → a · B] [C → a · C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I5 := LR(0)(b) : [B → b·]I6 := LR(0)(c) : [C → c·]I7 := LR(0)(aB) : [B → aB·]I8 := LR(0)(aC) : [C → aC·]

(LR(0)(aa) = LR(0)(a) = I4, LR(0)(ab) = LR(0)(b) = I5, LR(0)(ac) = LR(0)(c) = I6, ...,I9 := LR(0)(γ) = ∅ in all remaining cases, e.g., for γ = bB)

No conflicts =⇒ G ∈ LR(0) (but G /∈ LL(1))

23 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 92: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

Computing LR(0) Sets II

Example 8.16 (cf. Example 8.10)G : S′→ S S → B | C

B → aB | b C → aC | c[A→ γ1 · Yγ2] ∈ LR(0)(α)

=⇒ [A→ γ1Y · γ2] ∈ LR(0)(αY )

I0 := LR(0)(ε) : [S′ → ·S] [S → ·B] [S → ·C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I1 := LR(0)(S) : [S′ → S·]

I2 := LR(0)(B) : [S → B·]I3 := LR(0)(C) : [S → C·]I4 := LR(0)(a) : [B → a · B] [C → a · C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I5 := LR(0)(b) : [B → b·]I6 := LR(0)(c) : [C → c·]I7 := LR(0)(aB) : [B → aB·]I8 := LR(0)(aC) : [C → aC·]

(LR(0)(aa) = LR(0)(a) = I4, LR(0)(ab) = LR(0)(b) = I5, LR(0)(ac) = LR(0)(c) = I6, ...,I9 := LR(0)(γ) = ∅ in all remaining cases, e.g., for γ = bB)

No conflicts =⇒ G ∈ LR(0) (but G /∈ LL(1))

23 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 93: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

Computing LR(0) Sets II

Example 8.16 (cf. Example 8.10)G : S′→ S S → B | C

B → aB | b C → aC | c[A→ γ1 · Yγ2] ∈ LR(0)(α)

=⇒ [A→ γ1Y · γ2] ∈ LR(0)(αY )

I0 := LR(0)(ε) : [S′ → ·S] [S → ·B] [S → ·C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I1 := LR(0)(S) : [S′ → S·]I2 := LR(0)(B) : [S → B·]

I3 := LR(0)(C) : [S → C·]I4 := LR(0)(a) : [B → a · B] [C → a · C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I5 := LR(0)(b) : [B → b·]I6 := LR(0)(c) : [C → c·]I7 := LR(0)(aB) : [B → aB·]I8 := LR(0)(aC) : [C → aC·]

(LR(0)(aa) = LR(0)(a) = I4, LR(0)(ab) = LR(0)(b) = I5, LR(0)(ac) = LR(0)(c) = I6, ...,I9 := LR(0)(γ) = ∅ in all remaining cases, e.g., for γ = bB)

No conflicts =⇒ G ∈ LR(0) (but G /∈ LL(1))

23 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 94: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

Computing LR(0) Sets II

Example 8.16 (cf. Example 8.10)G : S′→ S S → B | C

B → aB | b C → aC | c[A→ γ1 · Yγ2] ∈ LR(0)(α)

=⇒ [A→ γ1Y · γ2] ∈ LR(0)(αY )

I0 := LR(0)(ε) : [S′ → ·S] [S → ·B] [S → ·C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I1 := LR(0)(S) : [S′ → S·]I2 := LR(0)(B) : [S → B·]I3 := LR(0)(C) : [S → C·]

I4 := LR(0)(a) : [B → a · B] [C → a · C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I5 := LR(0)(b) : [B → b·]I6 := LR(0)(c) : [C → c·]I7 := LR(0)(aB) : [B → aB·]I8 := LR(0)(aC) : [C → aC·]

(LR(0)(aa) = LR(0)(a) = I4, LR(0)(ab) = LR(0)(b) = I5, LR(0)(ac) = LR(0)(c) = I6, ...,I9 := LR(0)(γ) = ∅ in all remaining cases, e.g., for γ = bB)

No conflicts =⇒ G ∈ LR(0) (but G /∈ LL(1))

23 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 95: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

Computing LR(0) Sets II

Example 8.16 (cf. Example 8.10)G : S′→ S S → B | C

B → aB | b C → aC | c[A→ γ1 · Yγ2] ∈ LR(0)(α)

=⇒ [A→ γ1Y · γ2] ∈ LR(0)(αY )

I0 := LR(0)(ε) : [S′ → ·S] [S → ·B] [S → ·C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I1 := LR(0)(S) : [S′ → S·]I2 := LR(0)(B) : [S → B·]I3 := LR(0)(C) : [S → C·]I4 := LR(0)(a) : [B → a · B] [C → a · C]

[B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I5 := LR(0)(b) : [B → b·]I6 := LR(0)(c) : [C → c·]I7 := LR(0)(aB) : [B → aB·]I8 := LR(0)(aC) : [C → aC·]

(LR(0)(aa) = LR(0)(a) = I4, LR(0)(ab) = LR(0)(b) = I5, LR(0)(ac) = LR(0)(c) = I6, ...,I9 := LR(0)(γ) = ∅ in all remaining cases, e.g., for γ = bB)

No conflicts =⇒ G ∈ LR(0) (but G /∈ LL(1))

23 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 96: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

Computing LR(0) Sets II

Example 8.16 (cf. Example 8.10)G : S′→ S S → B | C

B → aB | b C → aC | c[A→ γ1 · Bγ2] ∈ LR(0)(αY ),B → β ∈ P=⇒ [B → ·β] ∈ LR(0)(αY )

I0 := LR(0)(ε) : [S′ → ·S] [S → ·B] [S → ·C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I1 := LR(0)(S) : [S′ → S·]I2 := LR(0)(B) : [S → B·]I3 := LR(0)(C) : [S → C·]I4 := LR(0)(a) : [B → a · B] [C → a · C] [B → ·aB] [B → ·b]

[C → ·aC] [C → ·c]

I5 := LR(0)(b) : [B → b·]I6 := LR(0)(c) : [C → c·]I7 := LR(0)(aB) : [B → aB·]I8 := LR(0)(aC) : [C → aC·]

(LR(0)(aa) = LR(0)(a) = I4, LR(0)(ab) = LR(0)(b) = I5, LR(0)(ac) = LR(0)(c) = I6, ...,I9 := LR(0)(γ) = ∅ in all remaining cases, e.g., for γ = bB)

No conflicts =⇒ G ∈ LR(0) (but G /∈ LL(1))

23 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 97: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

Computing LR(0) Sets II

Example 8.16 (cf. Example 8.10)G : S′→ S S → B | C

B → aB | b C → aC | c[A→ γ1 · Bγ2] ∈ LR(0)(αY ),B → β ∈ P=⇒ [B → ·β] ∈ LR(0)(αY )

I0 := LR(0)(ε) : [S′ → ·S] [S → ·B] [S → ·C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I1 := LR(0)(S) : [S′ → S·]I2 := LR(0)(B) : [S → B·]I3 := LR(0)(C) : [S → C·]I4 := LR(0)(a) : [B → a · B] [C → a · C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I5 := LR(0)(b) : [B → b·]I6 := LR(0)(c) : [C → c·]I7 := LR(0)(aB) : [B → aB·]I8 := LR(0)(aC) : [C → aC·]

(LR(0)(aa) = LR(0)(a) = I4, LR(0)(ab) = LR(0)(b) = I5, LR(0)(ac) = LR(0)(c) = I6, ...,I9 := LR(0)(γ) = ∅ in all remaining cases, e.g., for γ = bB)

No conflicts =⇒ G ∈ LR(0) (but G /∈ LL(1))

23 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 98: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

Computing LR(0) Sets II

Example 8.16 (cf. Example 8.10)G : S′→ S S → B | C

B → aB | b C → aC | c[A→ γ1 · Yγ2] ∈ LR(0)(α)

=⇒ [A→ γ1Y · γ2] ∈ LR(0)(αY )

I0 := LR(0)(ε) : [S′ → ·S] [S → ·B] [S → ·C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I1 := LR(0)(S) : [S′ → S·]I2 := LR(0)(B) : [S → B·]I3 := LR(0)(C) : [S → C·]I4 := LR(0)(a) : [B → a · B] [C → a · C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I5 := LR(0)(b) : [B → b·]

I6 := LR(0)(c) : [C → c·]I7 := LR(0)(aB) : [B → aB·]I8 := LR(0)(aC) : [C → aC·]

(LR(0)(aa) = LR(0)(a) = I4, LR(0)(ab) = LR(0)(b) = I5, LR(0)(ac) = LR(0)(c) = I6, ...,I9 := LR(0)(γ) = ∅ in all remaining cases, e.g., for γ = bB)

No conflicts =⇒ G ∈ LR(0) (but G /∈ LL(1))

23 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 99: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

Computing LR(0) Sets II

Example 8.16 (cf. Example 8.10)G : S′→ S S → B | C

B → aB | b C → aC | c[A→ γ1 · Yγ2] ∈ LR(0)(α)

=⇒ [A→ γ1Y · γ2] ∈ LR(0)(αY )

I0 := LR(0)(ε) : [S′ → ·S] [S → ·B] [S → ·C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I1 := LR(0)(S) : [S′ → S·]I2 := LR(0)(B) : [S → B·]I3 := LR(0)(C) : [S → C·]I4 := LR(0)(a) : [B → a · B] [C → a · C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I5 := LR(0)(b) : [B → b·]I6 := LR(0)(c) : [C → c·]

I7 := LR(0)(aB) : [B → aB·]I8 := LR(0)(aC) : [C → aC·]

(LR(0)(aa) = LR(0)(a) = I4, LR(0)(ab) = LR(0)(b) = I5, LR(0)(ac) = LR(0)(c) = I6, ...,I9 := LR(0)(γ) = ∅ in all remaining cases, e.g., for γ = bB)

No conflicts =⇒ G ∈ LR(0) (but G /∈ LL(1))

23 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 100: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

Computing LR(0) Sets II

Example 8.16 (cf. Example 8.10)G : S′→ S S → B | C

B → aB | b C → aC | c[A→ γ1 · Yγ2] ∈ LR(0)(α)

=⇒ [A→ γ1Y · γ2] ∈ LR(0)(αY )

I0 := LR(0)(ε) : [S′ → ·S] [S → ·B] [S → ·C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I1 := LR(0)(S) : [S′ → S·]I2 := LR(0)(B) : [S → B·]I3 := LR(0)(C) : [S → C·]I4 := LR(0)(a) : [B → a · B] [C → a · C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I5 := LR(0)(b) : [B → b·]I6 := LR(0)(c) : [C → c·]I7 := LR(0)(aB) : [B → aB·]

I8 := LR(0)(aC) : [C → aC·](LR(0)(aa) = LR(0)(a) = I4, LR(0)(ab) = LR(0)(b) = I5, LR(0)(ac) = LR(0)(c) = I6, ...,I9 := LR(0)(γ) = ∅ in all remaining cases, e.g., for γ = bB)

No conflicts =⇒ G ∈ LR(0) (but G /∈ LL(1))

23 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 101: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

Computing LR(0) Sets II

Example 8.16 (cf. Example 8.10)G : S′→ S S → B | C

B → aB | b C → aC | c[A→ γ1 · Yγ2] ∈ LR(0)(α)

=⇒ [A→ γ1Y · γ2] ∈ LR(0)(αY )

I0 := LR(0)(ε) : [S′ → ·S] [S → ·B] [S → ·C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I1 := LR(0)(S) : [S′ → S·]I2 := LR(0)(B) : [S → B·]I3 := LR(0)(C) : [S → C·]I4 := LR(0)(a) : [B → a · B] [C → a · C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I5 := LR(0)(b) : [B → b·]I6 := LR(0)(c) : [C → c·]I7 := LR(0)(aB) : [B → aB·]I8 := LR(0)(aC) : [C → aC·]

(LR(0)(aa) = LR(0)(a) = I4, LR(0)(ab) = LR(0)(b) = I5, LR(0)(ac) = LR(0)(c) = I6, ...,I9 := LR(0)(γ) = ∅ in all remaining cases, e.g., for γ = bB)

No conflicts =⇒ G ∈ LR(0) (but G /∈ LL(1))

23 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 102: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

Computing LR(0) Sets II

Example 8.16 (cf. Example 8.10)G : S′→ S S → B | C

B → aB | b C → aC | cI0 := LR(0)(ε) : [S′ → ·S] [S → ·B] [S → ·C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I1 := LR(0)(S) : [S′ → S·]I2 := LR(0)(B) : [S → B·]I3 := LR(0)(C) : [S → C·]I4 := LR(0)(a) : [B → a · B] [C → a · C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I5 := LR(0)(b) : [B → b·]I6 := LR(0)(c) : [C → c·]I7 := LR(0)(aB) : [B → aB·]I8 := LR(0)(aC) : [C → aC·]

(LR(0)(aa) = LR(0)(a) = I4, LR(0)(ab) = LR(0)(b) = I5, LR(0)(ac) = LR(0)(c) = I6, ...,I9 := LR(0)(γ) = ∅ in all remaining cases, e.g., for γ = bB)

No conflicts =⇒ G ∈ LR(0) (but G /∈ LL(1))

23 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 103: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

LR(0) Grammars

Computing LR(0) Sets II

Example 8.16 (cf. Example 8.10)G : S′→ S S → B | C

B → aB | b C → aC | cI0 := LR(0)(ε) : [S′ → ·S] [S → ·B] [S → ·C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I1 := LR(0)(S) : [S′ → S·]I2 := LR(0)(B) : [S → B·]I3 := LR(0)(C) : [S → C·]I4 := LR(0)(a) : [B → a · B] [C → a · C] [B → ·aB] [B → ·b] [C → ·aC] [C → ·c]

I5 := LR(0)(b) : [B → b·]I6 := LR(0)(c) : [C → c·]I7 := LR(0)(aB) : [B → aB·]I8 := LR(0)(aC) : [C → aC·]

(LR(0)(aa) = LR(0)(a) = I4, LR(0)(ab) = LR(0)(b) = I5, LR(0)(ac) = LR(0)(c) = I6, ...,I9 := LR(0)(γ) = ∅ in all remaining cases, e.g., for γ = bB)

No conflicts =⇒ G ∈ LR(0) (but G /∈ LL(1))

23 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 104: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Examples of LR(0) Conflicts

Outline of Lecture 8

Bottom-Up Parsing

Nondeterministic Bottom-Up Parsing

Resolving Termination Nondeterminism

LR(k) Grammars

LR(0) Grammars

Examples of LR(0) Conflicts

24 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 105: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Examples of LR(0) Conflicts

Shift/Reduce Conflicts

Example 8.17

G : S′→ SS → aS | a

LR(0)(ε) : [S′ → ·S] [S → ·aS] [S → ·a]LR(0)(S) : [S′ → S·]LR(0)(a) : [S → a · S] [S → ·aS] [S → ·a] [S → a·]LR(0)(aS) : [S → aS·]Note: G is unambiguous

25 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 106: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Examples of LR(0) Conflicts

Shift/Reduce Conflicts

Example 8.17

G : S′→ SS → aS | a

LR(0)(ε) : [S′ → ·S] [S → ·aS] [S → ·a]LR(0)(S) : [S′ → S·]LR(0)(a) : [S → a · S] [S → ·aS] [S → ·a] [S → a·]LR(0)(aS) : [S → aS·]

Note: G is unambiguous

25 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 107: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Examples of LR(0) Conflicts

Shift/Reduce Conflicts

Example 8.17

G : S′→ SS → aS | a

LR(0)(ε) : [S′ → ·S] [S → ·aS] [S → ·a]LR(0)(S) : [S′ → S·]LR(0)(a) : [S → a · S] [S → ·aS] [S → ·a] [S → a·]LR(0)(aS) : [S → aS·]Note: G is unambiguous

25 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 108: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Examples of LR(0) Conflicts

Reduce/Reduce Conflicts

Example 8.18

G : S′→ SS → Aa | BbA → aB → a

LR(0)(ε) : [S′ → ·S] [S → ·Aa] [S → ·Bb] [A→ ·a] [B → ·a]LR(0)(S) : [S′ → S·]LR(0)(A) : [S → A · a]LR(0)(B) : [S → B · b]LR(0)(a) : [A→ a·] [B → a·]LR(0)(Aa) : [S → Aa·]LR(0)(Bb) : [S → Bb·]Note: G is unambiguous

26 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 109: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Examples of LR(0) Conflicts

Reduce/Reduce Conflicts

Example 8.18

G : S′→ SS → Aa | BbA → aB → a

LR(0)(ε) : [S′ → ·S] [S → ·Aa] [S → ·Bb] [A→ ·a] [B → ·a]LR(0)(S) : [S′ → S·]LR(0)(A) : [S → A · a]LR(0)(B) : [S → B · b]LR(0)(a) : [A→ a·] [B → a·]LR(0)(Aa) : [S → Aa·]LR(0)(Bb) : [S → Bb·]

Note: G is unambiguous

26 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)

Page 110: Compiler Construction - Lecture : [1ex] Summer …...Compiler Construction Lecture 8: Syntax Analysis IV (LR(k) Grammars)Summer Semester 2017 Thomas Noll Software Modeling and Verification

Examples of LR(0) Conflicts

Reduce/Reduce Conflicts

Example 8.18

G : S′→ SS → Aa | BbA → aB → a

LR(0)(ε) : [S′ → ·S] [S → ·Aa] [S → ·Bb] [A→ ·a] [B → ·a]LR(0)(S) : [S′ → S·]LR(0)(A) : [S → A · a]LR(0)(B) : [S → B · b]LR(0)(a) : [A→ a·] [B → a·]LR(0)(Aa) : [S → Aa·]LR(0)(Bb) : [S → Bb·]Note: G is unambiguous

26 of 26 Compiler Construction

Summer Semester 2017Lecture 8: Syntax Analysis IV (LR(k) Grammars)