Open In App

LALR Parser (with Examples)

LALR Parser :
LALR Parser is lookahead LR parser. It is  the most powerful parser which can handle large classes of grammar. The size of CLR parsing table is quite large as compared to other parsing table. LALR reduces the size of this table.LALR works similar to CLR. The only difference is , it combines the similar states of CLR parsing table  into one single state. 
The general syntax becomes  [A->∝.B, a ]
where A->∝.B is production and a is a terminal or right end marker $
LR(1) items=LR(0) items + look ahead

How to add lookahead with the production?



CASE 1 –

A->∝.BC, a

Suppose this is the 0th production.Now, since ‘ . ‘ precedes B,so we have to write B’s productions as well.



B->.D [1st production]

Suppose this is B’s production. The look ahead of this production is given as- we look at previous production i.e. – 0th production. Whatever is after B, we find FIRST(of that value) , that is the lookahead of 1st production. So, here in 0th production, after B, C is there. Assume FIRST(C)=d, then 1st production become.

B->.D, d

CASE 2  –
Now if the 0th production was like this,

A->∝.B, a

Here,we can see there’s nothing after B. So the lookahead of 0th production will be the lookahead of 1st production. ie-

B->.D, a

CASE 3 –
Assume a production A->a|b

A->a,$ [0th production]
A->b,$ [1st production]

Here, the 1st production is a part of the previous production, so the lookahead will be the same as that of its previous production.

Steps for constructing the LALR parsing table :

  1. Writing augmented grammar
  2. LR(1) collection of items to be found
  3. Defining 2 functions: goto[list of terminals] and action[list of non-terminals] in the LALR parsing table

EXAMPLE
Construct CLR parsing table for the given context free grammar

S-->AA    
A-->aA|b

Solution:

STEP1- Find augmented grammar
The augmented grammar of the given grammar is:-

S'-->.S ,$   [0th production]    
S-->.AA ,$ [1st production]    
A-->.aA ,a|b [2nd production]      
A-->.b ,a|b [3rd production]

Let’s apply the rule of lookahead to the above productions.

STEP2 – Find LR(0) collection of items
Below is the figure showing the LR(0) collection of items. We will understand everything one by one.

The terminals of this grammar are {a,b}
The non-terminals of this grammar are {S,A}

RULES –

  1. If any non-terminal has ‘ . ‘ preceding it, we have to write all its production and add ‘ . ‘ preceding each of its production.
  2. from each state to the next state, the ‘ . ‘ shifts to one place to the right.

STEP 3 –
Defining 2 functions: goto[list of terminals] and action[list of non-terminals] in the parsing table.Below is the CLR parsing table

Once we make a CLR parsing table, we can easily make a LALR parsing table from it.

In the step2 diagram, we can see that 

In LALR parsing table construction , we merge these similar states. 

Below is the LALR parsing table. 

Now we have to remove the unwanted rows

The final LALR table looks like the below.

Article Tags :