Course Name Code Semester T+U Hours Credit ECTS
Compiler Design BSM 438 8 3 + 0 3 5
Precondition Courses
Recommended Optional Courses
Course Language Turkish
Course Level Bachelor's Degree
Course Type Optional
Course Coordinator Prof.Dr. NEJAT YUMUŞAK
Course Lecturers Prof.Dr. NEJAT YUMUŞAK,
Course Assistants
Course Category
Course Objective İt is aimed to examine compiler design and present automatic generators
Course Content Compiler phases, Lexical analysis, Syntax analysis, Semantic analysis, Intermediate code generation, Code optimization, Code generation
# Course Learning Outcomes Teaching Methods Assessment Methods
1 Realization of language designs Lecture, Question-Answer, Testing, Homework, Project / Design,
2 Recognize Compiler design Lecture, Question-Answer, Testing,
3 Determination of compiler tools Lecture, Question-Answer, Testing, Project / Design, Performance Task,
Week Course Topics Preliminary Preparation
1 Compilation process
2 Optimization of DFA and regular expression
3 Lexical analysis
4 Grammars
5 Syntax analysis
6 Abstract syntax trees
7 Semantic analysis
8 Intermediate code generation
9 Parsing (Shift Reduce)
10 Parsing (Recursive descent), First and Follow sets
11 Code optimization
12 Dynamic memory management
13 Register allocation
14 Code generation
Course Notes Lecture Notes
Course Resources 1. Alfred V. Aho Compilers: "Principles, Techniques, and Tools" (2nd Edition).
Order Program Outcomes Level of Contribution
1 2 3 4 5
1 To have sufficient foundations on engineering subjects such as science and discrete mathematics, probability/statistics; an ability to use theoretical and applied knowledge of these subjects together for engineering solutions, X
2 An ability to determine, describe, formulate and solve engineering problems; for this purpose, an ability to select and apply proper analytic and modeling methods,al background in describing, formulating, modeling and analyzing the engineering problem, with a consideration for appropriate analytical solutions in all necessary situations X
3 An ability to select and use modern techniques and tools for engineering applications; an ability to use information technologies efficiently, X
4 An ability to analyze a system, a component or a process and design a system under real limits to meet desired needs; in this direction, an ability to apply modern design methods, X
5 An ability to design, conduct experiment, collect data, analyze and comment on the results and consciousness of becoming a volunteer on research,
6 Understanding, awareness of administration, control, development and security/reliability issues about information technologies,
7 An ability to work efficiently in multidisciplinary teams, self confidence to take responsibility,
8 An ability to present himself/herself or a problem with oral/written techniques and have efficient communication skills; know at least one extra language,
9 An awareness about importance of lifelong learning; an ability to update his/her knowledge continuously by means of following advances in science and technology,
10 Understanding, practicing of professional and ethical responsibilities, an ability to disseminate this responsibility on society,
11 An understanding of project management, workplace applications, health issues of laborers, environment and job safety; an awareness about legal consequences of engineering applications,
12 An understanding universal and local effects of engineering solutions; awareness of entrepreneurial and innovation and to have knowledge about contemporary problems.
Evaluation System
Semester Studies Contribution Rate
1. Kısa Sınav 15
1. Ödev 15
1. Ara Sınav 55
2. Kısa Sınav 15
Total 100
1. Yıl İçinin Başarıya 40
1. Final 60
Total 100
ECTS - Workload Activity Quantity Time (Hours) Total Workload (Hours)
Course Duration (Including the exam week: 16x Total course hours) 16 3 48
Hours for off-the-classroom study (Pre-study, practice) 16 3 48
Mid-terms 1 8 8
Assignment 1 8 8
Final examination 1 15 15
Total Workload 127
Total Workload / 25 (Hours) 5.08
dersAKTSKredisi 5