Compiler Design Articles

Page 5 of 12

What is Postfix Notation?

Ginni
Ginni
Updated on 03-Nov-2021 22K+ Views

In postfix notation, the operator appears after the operands, i.e., the operator between operands is taken out & is attached after operands.Example1 − Translate a ∗ d − (b + c) into Postfix form.Solutionad ∗ bc + −Example2 − Convert a + (b ∗⊝ c) is in Postfix form.SolutionHere ⊝ represents the unary minus operator.a b c ⊝ ∗ +Example3 − Convert Postfix Expression into Infix Expression using Stack Implementationa d ∗ bc + −SolutionString SymbolsStackad ∗ bc + −AADad*(a * d)B(a * d)bC(a * d)b c+(a ∗ d)(b + c)-(a ∗ d)-(b + c)Example4 − Calculate the value for ...

Read More

What is Intermediate Code Generation?

Ginni
Ginni
Updated on 03-Nov-2021 24K+ Views

Intermediate code can translate the source program into the machine program. Intermediate code is generated because the compiler can’t generate machine code directly in one pass. Therefore, first, it converts the source program into intermediate code, which performs efficient generation of machine code further. The intermediate code can be represented in the form of postfix notation, syntax tree, directed acyclic graph, three address codes, Quadruples, and triples.If it can divide the compiler stages into two parts, i.e., Front end & Back end, then this phase comes in between.Example of Intermediate Code Generation −Three Address Code− These are statements of form ...

Read More

What is Implementation of Syntax Directed Translators?

Ginni
Ginni
Updated on 03-Nov-2021 3K+ Views

A syntax-directed translation scheme is a context-free grammar in which attributes are related to the grammar symbol and semantic actions enclosed within braces ({ }). These semantic actions are the subroutines that are known by the parser at the suitable time for translation. The location of the semantic actions on the right side of production denotes the time when it will be known for implementation by the parser.When it can produce a translation scheme, it should provide that an attribute value is available when the action defines it. This needed thatInherited attributes of a symbol on the right side of ...

Read More

What is Types of Syntax Directed Translation Schemes?

Ginni
Ginni
Updated on 03-Nov-2021 6K+ Views

There are two types of Syntax directed translation schemes which are as follows −Synthesized TranslationIn this translation, values of variables on L.H.S of a production rule depend on the value of the variable on R.H.S of production rule.For Example, E → E(1) + E(2)     {E. VAL = E(1). VAL + E(2). VAL}Here, E on L.H.S of production rule can be computed by the sum of values of E(1) and E(2) which are on R.H.S of a production rule, i.e., L.H.S variable is dependent on R.H.S variables.In synthesized translation, the value of the synthesized attribute at the node is evaluated ...

Read More

What is the Syntax Directed Translation?

Ginni
Ginni
Updated on 03-Nov-2021 9K+ Views

In syntax directed translation, along with the grammar it can identify some informal notations and these notations are known as as semantic rules.After implementing the Semantic Analysis, the source program is modified to an intermediate form.There is some information that is required by the Intermediate code generation phase to convert the semantically checked parse tree into intermediate code. But this information or attributes of variables cannot be represented alone by Context- Free Grammar.So, some semantic actions have to be attached with Context-Free grammar which helps the intermediate code generation phase to generate intermediate code.So, Attaching attributes to the variables of ...

Read More

Find FIRST & FOLLOW for the following GrammarnE → E + T|TnT → T ∗ F|FnF → (E)|id

Ginni
Ginni
Updated on 03-Nov-2021 12K+ Views

SolutionComputation of FIRSTE → E + T|TSince FIRST (E) does not contain ε.∴ FIRST (E) = FIRST(E + T) = FIRST(E)As, E → T∴ FIRST (E) = {FIRST(T)}                                       (1)T → T ∗ F|FAs FIRST (T) does not contain ε or T does not derive ε.∴ FIRST (T) = FIRST(T ∗ F) = {FIRST(T)}As, T → F (FIRST(T) = {FIRST(F)}                      (2)F → (E)|id∴ By Rule (3)of FIRSTFIRST (F) = {(, id}    ...

Read More

What is Implementation of LR Parsing Tables?

Ginni
Ginni
Updated on 03-Nov-2021 2K+ Views

LR Parsing Tables are a two-dimensional array in which each entry represents an Action or goto entry. A programming language grammar having a large number of productions has a large number of states or items, i.e., I0, I1 … … In.So, due to more states, more Actions & goto entries will be filled, which requires a lot of memory. So, a two-dimensional array is not sufficient to store so many action entries, because each entry requires at least 8 bits to encode.So, we have to use more efficient encoding than a two-dimensional array for encoding, Action & goto field.For example, ...

Read More

Consider the ambiguous grammar.nE → E + EnE → E * EnE → (E)nE → idn(a) Construct LR (0) items for above grammar.n(b) Construct SLR parsing table for grammar.n(c) Parse the input string id + id * id.

Ginni
Ginni
Updated on 03-Nov-2021 7K+ Views

Problem Statement Consider the ambiguous grammar.E → E + EE → E * EE → (E)E → id(a) Construct LR (0) items for above grammar.(b) Construct SLR parsing table for grammar.(c) Parse the input string id + id * id. SolutionStep1− Construct Augmented Grammar(0) E′ → S(1) E → E + E(2) E → E ∗ E(3) E → (E)(4) E → idStep2− Find closure & goto functions to construct LR (0) items.Closure (E′ → ∙ E) =Applying goto on I9∵ goto cannot be applied on I9, ...

Read More

What is Shift Reduce Parser?

Ginni
Ginni
Updated on 02-Nov-2021 16K+ Views

Shift Reduce Parser is a type of Bottom-Up Parser. It generates the Parse Tree from Leaves to the Root. In Shift Reduce Parser, the input string will be reduced to the starting symbol. This reduction can be produced by handling the rightmost derivation in reverse, i.e., from starting symbol to the input string.Shift Reduce Parser requires two Data StructuresInput BufferStackThere are the various steps of Shift Reduce Parsing which are as follows −There are the various steps of Shift Reduce Parsing which are as follows −It uses a stack and an input buffer.Insert $ at the bottom of the stack ...

Read More

Show that the following grammar is LR (1)nS → A a |b A c |B c | b B anA → dnB → d

Ginni
Ginni
Updated on 02-Nov-2021 9K+ Views

SolutionStep1 − Construct Augment Grammar(0) S′ → S(1) S → A a(2) S → b A c(3) S → B c(4) S → b B a(5) A → d(6) B → dStep2 − Find Closure & goto. Construct a set of LR (1) items. Here all the boxes represent new states.LR (1) Parsing TableSo, the LR (1) Parsing Table has no several entries. Grammar is LR (1).Construction of LR (1) or Canonical LR Parsing TableInput − An Augmented Grammar G’.Output − The Canonical LR (1) Parsing TableMethodFilling the "shift" Entries(s) − Apply Rule (2a) of construction of CLR Parsing Table.Consider ...

Read More
Showing 41–50 of 113 articles
« Prev 1 3 4 5 6 7 12 Next »
Advertisements