Monadic Compiler Calculation (Functional Pearl)

Patrick Bahr, Graham Hutton

Publikation: Konference artikel i Proceeding eller bog/rapport kapitelKonferencebidrag i proceedingsForskningpeer review

Abstract

Bahr and Hutton recently developed a new approach to calculating correct compilers directly from specifications of their correctness. However, the methodology only considers converging behaviour of the source language, which means that the compiler could potentially produce arbitrary, erroneous code for source programs that diverge. In this article, we show how the methodology can naturally be extended to support the calculation of compilers that address both convergent and divergent behaviour simultaneously, without the need for separate reasoning for each aspect. Our approach is based on the use of the partiality monad to make divergence explicit, together with the use of strong bisimilarity to support equational-style calculations, but also generalises to other forms of effect by changing the underlying monad.
OriginalsprogEngelsk
Titel Proceedings of the ACM on Programming Languages
Vol/bind6
ForlagAssociation for Computing Machinery
Publikationsdatoaug. 2022
DOI
StatusUdgivet - aug. 2022

Fingeraftryk

Dyk ned i forskningsemnerne om 'Monadic Compiler Calculation (Functional Pearl)'. Sammen danner de et unikt fingeraftryk.

Citationsformater