Topic outline

  • Welcome to Compiler Design Course


  • Week 1: Preparing Background and Learn about Language Processing System

    Week1

    Discussion Topics: 

    • Overview of language processing
    • Discuss about pre-processors – compiler – assembler – interpreters.
    • Discuss about linkers & loaders
    • Distinguish in between Interpreter vs. Compiler.

    Expected Learning Outcomes:

    • Differentiate compiler with interpreter.
    • Recognize the language processing system
    • Conceptually understand the application of compiler.

    Resources of Learning:



  • Week - 2: Phase of a Compiler

    Week2

    Discussion Topics: 

    • Learn about the structure of a compiler.
    • Learn about the phases of a compiler.

    Expected Learning Outcomes:

    • Design the basic structure.
    • Recognize various phases of compiler

    Resources of Learning:



  • Week - 3: Context Free Grammar: LMD, RMD

    Week3

    Discussion Topics: 

    • Learn about Lexical Analysis –Role of Lexical Analysis
    • Discuss about Lexical Analysis Vs. Parsing
    • Discuss about Token, patterns and Lexemes
    • Discuss about Quiz Test.

    Expected Learning Outcomes:

    • Distinguish Token, patterns and Lexemes
    • Recognize Lexical errors.  

    Resources of Learning:


  • Week - 4: Regular Expression

    Week4

    Discussion Topics: 

    • Discuss about Regular definitions for the language constructs
    • Discuss about Transition diagram for recognition of tokens.

    Expected Learning Outcomes:

    • Capable to Design Transition Diagram.
    • Create Regular expression from sentence.

    Resources of Learning:


  • Week - 5: NFA and DFA

    Week5

    Discussion Topics: 

    • Discuss about Automata Theory.
    • Discuss and Illustrate NFA and DFA.

    Expected Learning Outcomes:

    • Understand Tuples.
    • Design and Construct NFA and DFA

    Resources of Learning:


  • Week - 6: NFA to DFA Conversion

    Week6

    Discussion Topics: 

    • Discuss about subset construction method.
    • Discuss and Illustrate the techniques to construct DFA
    • Discuss about Class Test.

    Expected Learning Outcomes:

    • Design DFA from NFA.
    • Distinguish NFA and DFA.
    • Recognize the benefit to construct DFA.

    Resources of Learning:


  • Preparation for Midterm Examination

    Week7

    Topics Covered for Midterm Examination

    • Language Processing System
    • Phase of a Compiler
    • Context Free Grammar
    • Regular Expression
    • NFA and DFA
    • NFA to DFA Conversion

    • Week - 8: Left Recursion and Left Factoring Elimination

      Week8

      Discussion Topics: 

      • Discuss LMD and RMD
      • Discuss and Illustrate the elimination techniques

      Expected Learning Outcomes:

      • Recognize the elimination techniques
      • Understand the importance of Left Elimination

      Resources of Learning:


    • Week - 9: Determination of FIRST and FOLLOW Function

      Week9

      Discussion Topics: 

      • Discuss and illustrate the rules for FIRST and FOLLOW Function.
      • Discuss the techniques to find FIRST and FOLLOW function.

      Expected Learning Outcomes:

      • Recognize specific tokens
      • Identify FIRST and FOLLOW
      • Construct LL1 Table

      Resources of Learning:


    • Week - 10: LR0 Parser and Canonical Table

      Week10

      Discussion Topics: 

      • Discuss and illustrate Kernel item, Non Kernel Item.
      • Discuss about Augmented grammar.
      • Discuss about Canonical Table.

      Expected Learning Outcomes:

      • Recognize kernel and non-kernel item.
      • Construct LR 0 Parser.
      • Design and construct canonical table.
      Resources of Learning:


      • Opened: Thursday, 14 July 2022, 12:00 AM
        Due: Thursday, 21 July 2022, 12:00 AM
    • Week - 11: Intermediate Code Generation

      Week11

      Discussion Topics: 

      • Discuss abstract syntax trees and Directed acyclic graph
      • Discuss and illustrate three address code, quadruples, and triples.
      • Discuss about Class Text.

      Expected Learning Outcomes:

      • Recognize techniques to eliminate common sub tree.
      • Design triples.
      Resources of Learning:


    • Week - 12: Code Generation and Basic Block

      Week12

      Discussion Topics: 

      • Discuss about the rules for leader selection.
      • Discuss and illustrate the techniques to create basic block.
      • Discuss the techniques to design flow graph.

      Expected Learning Outcomes:

      • Recognize three address codes.
      • Design basic blocks for high level languages.
      • Understand the necessity of flow graph.

      Resources of Learning:


    • Week - 13: Code Optimization

      Week13

      Discussion Topics: 

      • Discuss about Machine independent code optimization.
      • Discuss and illustrate the techniques of code optimization.

      Expected Learning Outcomes:

      • Recognize machine independent code.
      • Able to apply techniques to optimize codes.

      Resources of Learning:


      • Week - 14: Preparation for Final Examination

        Week14

        Topics Covered for Final Examination

        • Left Recursion and Left Factoring Elimination
        • Determination of FIRST and FOLLOW Function
        • LR0 Parser and Canonical Table
        • Intermediate Code Generation
        • Code Generation and Basic Block
        • Code Optimization

      • Presentation


        • Presentation group list [55-A] URL
          Restricted Not available unless: You belong to 55-A
        • Presentation group list [55-B] URL
          Restricted Not available unless: You belong to 55-B
        • Presentation group list [55-C] URL
          Restricted Not available unless: You belong to 55-C
      • Assignment


        • [CSE331] Assignment Submission
          Opened: Sunday, 11 December 2022, 12:00 AM
          Due: Sunday, 25 December 2022, 11:59 PM
          Restricted Not available unless any of:
          • You belong to 55-A
          • You belong to 55-B
          • You belong to 55-C
      • Lab Reports


        • Opened: Wednesday, 7 December 2022, 12:00 AM
          Due: Sunday, 11 December 2022, 11:59 PM
          View Make a submission
      • Lab Project