Hauptinhalt
CS 551 — Compilerbau
(engl. Compiler Construction)
Niveaustufe, Verpflichtungsgrad | Vertiefungsmodul, abhängig vom importierenden Studiengang |
Lehr- und Lernformen, Arbeitsaufwand |
Vorlesung (4 SWS), Übung (2 SWS), 270 Stunden (90 Std. Präsenzzeit, 180 Std. Selbststudium) |
Leistungspunkte, Voraussetzungen zum Erwerb |
9 LP Studienleistung(en): Erreichen von mindestens 50 Prozent der Punkte aus den wöchentlich zu bearbeitenden Übungsaufgaben und mündliche Präsentation der Lösung von mindestens zwei der Übungsaufgaben. Prüfungsleistung: Klausur oder mündliche Prüfung (Einzelprüfung) |
Sprache, Benotung |
Englisch,Die Benotung erfolgt mit 0 bis 15 Punkten gemäß der Prüfungsordnung für den Studiengang M.Sc. Informatik. |
Ursprung | M.Sc. Informatik |
Dauer des Moduls, Häufigkeit |
Ein Semester, Regelmäßig alle 3 bis 4 Semester |
Modulverantwortliche(r) | Prof. Dr. Christoph Bockisch |
Inhalt
Compiler übersetzen Programme aus höheren Programmiersprachen in ausführbaren Maschinencode. In der Vorlesung werden Konzepte und Methoden, die für die verschiedenen Phasen von Compilern entwickelt wurden, vor- und gegenübergestellt:
- Lexikalische Analyse: reguläre Ausdrücke, endliche Automaten, flm-Prinzip, Scannergeneratoren
- Syntaktische Analyse: Kontextfreie Grammatiken, RD-Parsing mit LL(k)- Grammatiken, SR-Parsing mit LR(k)-Grammatiken, Präzedenz-gesteuerte Parser, Parsergeneratoren;
- Semantische Analyse mit Attributgrammatiken
- Zwischencode-Erzeugung
- Code-Optimierung
Qualifikationsziele
Die Studierenden
- kennen die Unterscheidung verschiedener Aspekte von Programmiersprachen (Lexik, Syntax, Semantik, Pragmatik),
- haben Kenntnisse über den Aufbau von Compilern und Compilerphasen,
- verstehen Werkzeuge zur Compilererzeugung und können diese anwenden,
- kennen Grundprinzipien der Codeerzeugung, der denotationellen Semantik und abstrakter Maschinen,
- können einzelner Teile eines Compilers programmieren,
- sind in der Lage, wissenschaftliche Arbeitsweisen beim eigenständigen Erkennen, Formulieren und Lösen von Problemen anzuwenden,
- sind in der Lage über wissenschaftliche Inhalte frei zu sprechen, sowohl vor einem Publikum als auch in einer Diskussion.
Voraussetzungen
Keine. Empfohlen werden die Kompetenzen, die in dem Modul Theoretische Informatik vermittelt werden.
Verwendbarkeit
Das Modul kann im FB12 verwendet werden im Studiengang bzw. in den Studiengängen
- B.Sc. Informatik
- M.Sc. Informatik
- M.Sc. Mathematik
- LAaG Informatik
Im Studiengang M.Sc. Informatik kann das Modul im Studienbereich Informatik Wahlpflichtmodule absolviert werden.
Das Modul kann auch in anderen Studiengängen absolviert werden (Exportmodul).
Das Modul ist der Theoretischen Informatik zugeordnet. Weitere Informationen zur Wählbarkeit sind der Bereichsbeschreibung zu entnehmen.
Literatur
- Drachenbuch: Aho/Sethi/Ullman: Compilers — Principles, Techniques, and Tools, Addison-Wesley 1986
- Waite/Goos: Compiler Construction, Springer Verlag 1994
- Wilhelm/Maurer: Übersetzerbau: Theorie, Konstruktion, Generierung, Springer Verlag 1992
- Appel: Modern Compiler Implementation in ML/Java/C++, Addison-Wesley 1998
Bitte beachten Sie:
Diese Seite beschreibt ein Modul gemäß dem im Wintersemester 2023/24 aktuellsten gültigen Modulhandbuch. Die meisten für ein Modul gültigen Regeln werden nicht durch die Prüfungsordnung festgelegt, und können daher von Semester zu Semester aktualisiert werden. Folgende Versionen liegen im Online-Modulhandbuch vor:
- WiSe 2016/17
- SoSe 2018
- WiSe 2018/19
- WiSe 2019/20
- WiSe 2020/21
- SoSe 2021
- WiSe 2021/22
- WiSe 2022/23
- WiSe 2023/24
Das Modulhandbuch enthält alle Module, unabhängig vom aktuellen Veranstaltungsangebot, vergleichen Sie dazu bitte das aktuelle Vorlesungsverzeichnis in Marvin.
Die Angaben im Online-Modulhandbuch wurden automatisch erstellt. Rechtsverbindlich sind die Angaben der Prüfungsordnung. Wenn Ihnen Unstimmigkeiten oder Fehler auffallen, sind wir für Hinweise dankbar.