dc.rights.license | CC-BY-NC-ND | |
dc.contributor.advisor | Swierstra, W.S. | |
dc.contributor.author | Heinzel, Matthias | |
dc.date.accessioned | 2023-07-20T00:02:06Z | |
dc.date.available | 2023-07-20T00:02:06Z | |
dc.date.issued | 2023 | |
dc.identifier.uri | https://studenttheses.uu.nl/handle/20.500.12932/44219 | |
dc.description.abstract | The 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.sponsorship | Utrecht University | |
dc.language.iso | EN | |
dc.subject | When 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.title | Analysis and Transformation of Intrinsically Typed Syntax | |
dc.type.content | Master Thesis | |
dc.rights.accessrights | Open Access | |
dc.subject.keywords | program 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.courseuu | Computing Science | |
dc.thesis.id | 19511 | |