Skip to content

Programs of Compiler Design Lab as per KTU S7 syllabus of 2015-19 batch

Notifications You must be signed in to change notification settings

detheROUGE/compiler_design

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

CS431 - Compiler Design Lab

Programs of Compiler Design Lab as per KTU S7 syllabus of 2015-19 batch

Excercises / Experiments

  1. Design and implement a lexical analyzer for given language using C and the lexical analyzer should ignore redundant spaces, tabs and new lines.
  2. Implementation of Lexical Analyzer using Lex Tool.
  3. Generate YACC specification for a few syntactic categories.
    1. Program to recognize a valid arithmetic expression that uses operator +, – , * and /.
    2. Program to recognize a valid variable which starts with a letter followed by any number of letters or digits.
    3. Implementation of Calculator using LEX and YACC.
    4. Convert the BNF rules into YACC form and write code to generate abstract syntax tree
  4. Write program to find ε – closure of all states of any given NFA with ε transition.
  5. Write program to convert NFA with ε transition to NFA without ε transition.
  6. Write program to convert NFA to DFA.
  7. Write program to minimize any given DFA.
  8. Develop an operator precedence parser for a given language.
  9. Write program to find Simulate First and Follow of any given grammar.
  10. Construct a recursive descent parser for an expression.
  11. Construct a Shift Reduce Parser for a given language.
  12. Write a program to perform loop unrolling.
  13. Write a program to perform constant propagation.
  14. Implement Intermediate code generation for simple expressions.
  15. Implement the back end of the compiler which takes the three address code and produces the 8086 assembly language instructions that can be assembled and run using an 8086 assembler. The target assembly instructions can be simple move, add, sub, jump etc.

Prerequisites

  • gcc
  • lex

Installing

sudo apt update
sudo apt install build-essential    # For gcc
sudo apt install flex               # For lex

About

Programs of Compiler Design Lab as per KTU S7 syllabus of 2015-19 batch

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C 82.1%
  • Lex 10.5%
  • Yacc 7.4%