Show simple item record

dc.rights.licenseCC-BY-NC-ND
dc.contributor.advisorSwierstra, W.S.
dc.contributor.authorHeinzel, Matthias
dc.date.accessioned2023-07-20T00:02:06Z
dc.date.available2023-07-20T00:02:06Z
dc.date.issued2023
dc.identifier.urihttps://studenttheses.uu.nl/handle/20.500.12932/44219
dc.description.abstractThe correctness of variable representations used in compilers usually depends on the compiler writers’ diligence to maintain complex invariants. Program transformations that manipulate the binding structure are therefore tricky to get right. In a dependently typed programming language such as Agda, we can however make use of intrinsically typed syntax trees to enforce type- and scope-safety by construction, ruling out a large class of binding-related bugs. We show how to perform (and prove correct) dead binding elimination and let- sinking using intrinsically typed de Bruijn indices. To avoid repeated traversals of the transformed expression, we include variable liveness information into the syntax tree and later employ a co-de-Bruijn representation. Finally, we perform transformations in this style syntax-generically.
dc.description.sponsorshipUtrecht University
dc.language.isoEN
dc.subjectWhen writing a compiler in a dependently typed programming language, intrinsically typed syntax trees can be used to enforce type- and scope-safety by construction, ruling out a large class of binding-related bugs. We explore dead binding elimination and let-sinking using a de Bruijn representation, then annotate the syntax tree with variable liveness information, and finally employ a co-de-Bruijn representation.
dc.titleAnalysis and Transformation of Intrinsically Typed Syntax
dc.type.contentMaster Thesis
dc.rights.accessrightsOpen Access
dc.subject.keywordsprogram analysis; program transformation; optimisation; live variable analysis; dead binding elimination; let-floating; let-sinking; intrinsically typed syntax; type-safety; scope-safety; correct by construction; variable representation; de Bruijn index; de Bruijn representation; co-de-Bruijn representation; Agda; dependent types; proof assistant; generic programming; syntax-generic programming; program correctness; compiler correctness; lambda calculus; type system; semantics
dc.subject.courseuuComputing Science
dc.thesis.id19511


Files in this item

Thumbnail

This item appears in the following Collection(s)

Show simple item record