Zurück
Semester | Herbstsemester 2024 |
Angebotsmuster | unregelmässig |
Dozierende |
Ali Ajorian (ali.ajorian@unibas.ch)
Erick Lavoie (erick.lavoie@unibas.ch, BeurteilerIn) |
Inhalt | This seminar will provide fundamentals of interpretation and compilation of programming languages with a strong emphasis on practical projects. It will include a selection of topics among the followings: program representations and transformations, the difference between compilation and interpretation, a taxonomy of programming languages, Turing-completeness and the tower of interpreters, computation models, execution semantics, programming language concepts, meta-programming. We will look at applications of the concepts with a special emphasis on secure execution of programs with and without the use of Trusted Execution Environments, which will be relevant for doing Bachelor and Master projects related to the ongoing Survivable Computing project of the Computer Networks Group. |
Lernziele | The main objective of the course is to successfully implement an interpreter and compiler for a simplified but representative subset of the Python programming language. This subset will support variables, conditionals, loops, functions, and other functionalities according to student interests. Students that succeed will obtain a concrete understanding of how high-level programming languages are executed on lower-level hardware. The techniques covered are also fundamental for more advanced automated program analysis and transformations, such as finding bugs and vulnerabilities in source code, increasing performance with optimizing compilers, and increasing the security of executables. |
Literatur | The first 9 lectures will cover Chapters 1,2,5,6 and 8 of the following textbook: https://github.com/IUCompilerCourse/Essentials-of-Compilation The rest of the lectures will cover advanced topics according to students interests, among other chapters of the book and papers. |
Bemerkungen | Implementation and presentations will be done in teams of 2-3 students. Due to time limitations for presentations, a maximum of 24 students may register for the seminar, first-come first-served. |
Teilnahmebedingungen | Completed the equivalent of 2 years of Bachelor in Computer Science |
Anmeldung zur Lehrveranstaltung | Access for synchronized courses on ADAM only by course registration in online services. |
Unterrichtssprache | Englisch |
Einsatz digitaler Medien | kein spezifischer Einsatz |
Intervall | Wochentag | Zeit | Raum |
---|---|---|---|
wöchentlich | Montag | 12.15-14.00 | Spiegelgasse 1, Seminarraum 00.003 |
Datum | Zeit | Raum |
---|---|---|
Montag 23.09.2024 | 12.15-14.00 Uhr | Spiegelgasse 1, Seminarraum 00.003 |
Montag 30.09.2024 | 12.15-14.00 Uhr | Spiegelgasse 1, Seminarraum 00.003 |
Montag 07.10.2024 | 12.15-14.00 Uhr | Spiegelgasse 1, Seminarraum 00.003 |
Montag 14.10.2024 | 12.15-14.00 Uhr | Spiegelgasse 1, Seminarraum 00.003 |
Montag 21.10.2024 | 12.15-14.00 Uhr | Spiegelgasse 1, Seminarraum 00.003 |
Montag 28.10.2024 | 12.15-14.00 Uhr | Spiegelgasse 1, Seminarraum 00.003 |
Montag 04.11.2024 | 12.15-14.00 Uhr | Spiegelgasse 1, Seminarraum 00.003 |
Montag 11.11.2024 | 12.15-14.00 Uhr | Spiegelgasse 1, Seminarraum 00.003 |
Montag 18.11.2024 | 12.15-14.00 Uhr | Spiegelgasse 1, Seminarraum 00.003 |
Montag 25.11.2024 | 12.15-14.00 Uhr | Spiegelgasse 1, Seminarraum 00.003 |
Montag 02.12.2024 | 12.15-14.00 Uhr | Spiegelgasse 1, Seminarraum 00.003 |
Montag 09.12.2024 | 12.15-14.00 Uhr | Spiegelgasse 1, Seminarraum 00.003 |
Montag 16.12.2024 | 12.15-14.00 Uhr | Spiegelgasse 1, Seminarraum 00.003 |
Module |
Modul: Applications and Related Topics (Bachelorstudium: Computer Science) Modul: Applications and Related Topics (Bachelor Studienfach: Computer Science) |
Leistungsüberprüfung | Lehrveranst.-begleitend |
Hinweise zur Leistungsüberprüfung | Evaluation will cover the followings: 1. Active participation in class (10%) 2. Quality and number of unit tests (15%) 2.1 Contributed in common pool 2.2 Passed by implementation 3. Presentation on advanced topic (20%) 4. Final report on custom extension to base implementation (25%) 5. Final oral interview (30%) 5.1 Theory covered in class 5.2 Understanding of implementation |
An-/Abmeldung zur Leistungsüberprüfung | Anm.: Belegen Lehrveranstaltung; Abm.: stornieren |
Wiederholungsprüfung | keine Wiederholungsprüfung |
Skala | 1-6 0,5 |
Wiederholtes Belegen | beliebig wiederholbar |
Zuständige Fakultät | Philosophisch-Naturwissenschaftliche Fakultät, studiendekanat-philnat@unibas.ch |
Anbietende Organisationseinheit | Fachbereich Informatik |