02247 Oversætterkonstruktion

2016/2017

Kursusinformation
Compiler Construction
Engelsk
5
Kandidat
Kurset udbydes under tompladsordningen
F2B (tors 8-12)
Campus Lyngby
Forelæsninger, teoretiske øvelser og praktiske øvelser.
13-uger
F2B, E2B
Mundtlig eksamen og bedømmelse af rapport(er)
Eksamen er baseret på rapporten om projektet de studerende har arbejdet med i kurset.
7-trins skala , ekstern censur
De studerende forventes at kende til endelige automater og kontekstfrie grammatiker. De studerende skal kunne udtrykke sig i et objektorienteret programmeringssprog.
Christian W. Probst , Lyngby Campus, Bygning 324, Tlf. (+45) 4525 7512 , cwpr@dtu.dk

01 Institut for Matematik og Computer Science
I studieplanlæggeren
Kontakt underviseren for information om hvorvidt dette kursus giver den studerende mulighed for at lave eller forberede et projekt som kan deltage i DTUs studenterkonference om bæredygtighed, klimateknologi og miljø (GRØN DYST). Se mere på http://www.groendyst.dtu.dk
Overordnede kursusmål
Oversættere bidrager til pålideligheden af softwaresystemer med hjælp af analyser og optimeringer af systemets kode, og ved at sikre egenskaber af de genererede programmer. Nogle af de store softwarevirksomheder som Microsoft og Google opfatter oversættere at være så essentielt en del af deres projekter, at de endda oversætter deres oversættere fra kildekode som del af deres build processer.

Kurset underviser i teknikker som bruges til at effektiv implementere moderne funktionelle og objekt-orienterede programmeringssprog, og til at sikre pålideligheden af de genererede programmer. Vi behandler grundlæggende teknikker i moderne oversættere, fra implementering over optimeringer til køretids understøttelse for nye hardwarearkitekturer. I kurset arbejder de studerende i gruppe med at implementere en oversætter for et realistisk programmeringssprog.
Læringsmål
En studerende, der fuldt ud har opfyldt kursets mål, vil kunne:
  • forklare oversætternes bidrag til pålidelighed af softwaresystemer;
  • forklare strukturen af optimerende oversættere og funktionaliteten af de forskellige faser;
  • forklare de behandlede former for intermediate representation, og vælge den passede form baseret på funktionelle krav;
  • forklare relationen mellem højtniveaussprog, intermediate representation, analyser, og optimeringer;
  • forklare processen af code generering for moderne processorer;
  • vælge det rigtige fase for implementering af ny funktionalitet baseret på en kravbeskrivelse;
  • identificere situationer i softwareudvikling, hvor teknikker fra oversættere kan anvendes, og realisere denne anvendelse;
  • anvende moderne værktøjer til implementering af oversættere og forklare deres funktionalitet;
  • implementere en oversætter for et realistisk programmeringssprog;
  • opnå ovennævnte resultater som del af et gruppe arbejde men på en sådan måde at de individuelle bidrag kan identificeres; og
  • kommunikere de opnåede resultater på en klar og præcis måde i en standard form for teknisk rapport.
Kursusindhold
Kurset dækker tre hovedemner:
(1) Oversætter for forskellige sprogparadigmer, såsom funktionelle og objekt-orienterede sprog, og abstrakte maskiner som målarkitektur for oversættere;
(2) Intermediate representationer og deres indflydelse på oversættelsen;
(3) Kodegenerering, kodeselektion, og optimeringer.
Projektet er baseret på oversætterrammeværk LLVM, som bruges i mange kommercielle oversættere.
Sidst opdateret
24. oktober, 2016