Section outline
-
-
Dear Students,
Welcome to the course CSE331 !! Myself K. M. Shahriar Islam. I am looking forward to the opportunity so we will have to learn and grow together in this course. I always believe that your success is most important to me as a teacher. Please don’t hesitate to contact me in case of having difficulties with the course materials and any other academic problems. To smooth this operation, general questions related to the courses should be posted on the Discussion Forum. If you have any question for which you are not interested to post in Forum, then you can send your query via email for a quick response. My contact information is mentioned below. Success in an online class requires just as much work and effort as success in a traditional classroom. Lastly, I am expecting much cooperation from all of you. Hope we will enjoy this journey joyfully.
Stay safe and healthy. Thanks all of you for joining with this course.
Best Regards,
K. M. Shahriar Islam
-
Text Book:
1. Compiler Principles, Techniques and Tools By Aho, Ullman, Sethi [Download]
Reference Books:
1. Implementations of Compiler, A new approach to Compilers including the algebraic methods By Yunlin su, Song Y. Yan. [Download]
2. Compiler construction, Principles and Practice, By Kenneth C Louden. [Download]
3. Basics of Compiler Design by Torben. [Download]
-
-
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.
-
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:
Lecture Slide (Phase of a Compiler)
-
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:
- Lecture Slide (Context Free Grammar)
- Lecture Slide (LMD & RMD)
-
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:
- Lecture Slide (Regular Expression)
- Lecture Video
- Test Question
-
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:
- Lecture Slide (NFA and DFA)
- Lecture Video
- Test Question
-
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:
- Lecture Slide (NFA to DFA Conversion)
- Lecture Video
-
-
-
Topics Covered for Midterm Examination
- Language Processing System
- Phase of a Compiler
- Context Free Grammar, LMD, RMD, Ambiguity
- Regular Expression
- NFA and DFA
- NFA to DFA Conversion
-
-
-
Discussion Topics:
- Discuss about 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:
- Lecture Slide (Elimination of LR & LF)
-
-
-
-
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:
- Lecture Slide (FIRST and FOLLOW Function)
- Additional Files: FIRST FUNCTION FOLLOW FUNCTION
-
-
-
-
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.
- Lecture Slide (Intermediate Code Generation)
-
-
-
-
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:
- Lecture Slide (Basic Block)
-
-
-
-
Those who missed quiz 1 or quiz 2 feel please participate in this quiz.
N:B: NOT MANDATORY FOR ALL
-