|
|
Module code: KI675 |
2V+2P (4 hours per week) |
5 |
Semester: 5 |
Mandatory course: no |
Language of instruction:
German |
Assessment:
Oral examination, project, presentation
[updated 30.07.2021]
|
KI675 Computer Science and Communication Systems, Bachelor, ASPO 01.10.2014
, semester 5, optional course, technical
KIB-CBAU (P221-0067) Computer Science and Communication Systems, Bachelor, ASPO 01.10.2021
, semester 5, optional course, technical
KIB-CBAU (P221-0067) Computer Science and Communication Systems, Bachelor, ASPO 01.10.2022
, semester 5, optional course, technical
PIBWI55 Applied Informatics, Bachelor, ASPO 01.10.2011
, semester 5, optional course, informatics specific
PIB-CBAU Applied Informatics, Bachelor, ASPO 01.10.2022
, semester 5, optional course, informatics specific
|
60 class hours (= 45 clock hours) over a 15-week period. The total student study time is 150 hours (equivalent to 5 ECTS credits). There are therefore 105 hours available for class preparation and follow-up work and exam preparation.
|
Recommended prerequisites (modules):
KI100 Programming 1 KI200 Programming 2 KI210 Informatics 2 KI586
[updated 22.01.2018]
|
Recommended as prerequisite for:
|
Module coordinator:
Prof. Dr. Markus Esch |
Lecturer: Thorsten Jakobs, M.Sc.
[updated 26.09.2007]
|
Learning outcomes:
Learning outcomes: Importing and, if necessary, translating custom file formats are basic tasks that computer scientists and programmers are regularly confronted with. Based on the typical structure of a compiler, students will learn about the individual steps of importing, analyzing and translating a (formal) language (source language) into another (formal) language (target language), understand those steps and be able to apply them in their own project. After successfully completing this module, students will: be familiar with the the individual modules of a compiler/translator. - understand how lexers and parsers work and can be automatically generated from specifications, - understand how the steps in generating code map high-level language to assembly language using C-to-CMa as an example, - be familiar with the most important program analyses and optimizations that compilers usually perform (available expressions, interval analysis, constant propagation, dead variables, etc.). In their project, students will develop their own compiler for a programming language they designed themselves.
[updated 04.09.2023]
|
Module content:
1. Introduction (high-level programming languages, implementation of programming languages) 2. Lexing 3. Parsing 4. Generating code 5. Code optimization 6. Project work
[updated 04.09.2023]
|
Recommended or required reading:
A. AHO, R. SETHI, J. ULLMAN: Compilers R. WILHELM, D. Maurer: Übersetzerbau: Theorie, Konstruktion, Generierung R. WILHELM, H. SEIDL: Übersetzerbau. Virtuelle Maschinen H. SEIDL, R. WILHELM, S. HACK: Compiler Design: Syntactic and Semantic Analysis H. SEIDL, R. WILHELM, S. HACK: Übersetzerbau. Analyse und Transformation
[updated 04.09.2023]
|
Module offered in:
SS 2019,
WS 2018/19,
SS 2018,
WS 2015/16,
WS 2014/15,
...
|