Abstract
We present a generic formalization of the refocusing trans- formation for functional languages in the Coq proof assistant. The refo- cusing technique, due to Danvy and Nielsen, allows for mechanical trans- formation of an evaluator implementing a reduction semantics into an equivalent abstract machine via a succession of simple program transfor- mations. So far, refocusing has been used only as an informal procedure: the conditions required of a reduction semantics have not been formally captured, and the transformation has not been formally proved correct. The aim of this work is to formalize and prove correct the refocusing technique. To this end, we first propose an axiomatization of reduction semantics that is sufficient to automatically apply the refocusing method. Next, we prove that any reduction semantics conforming to this axiom- atization can be automatically transformed into an abstract machine equivalent to it. The article is accompanied by a Coq development that contains the formalization of the refocusing method and a number of case studies that serve both as an illustration of the method and as a sanity check on the axiomatization.
Originalsprog | Engelsk |
---|---|
Titel | IFL'10 Proceedings of the 22nd international conference on Implementation and application of functional languages |
Antal sider | 16 |
Forlag | Springer |
Publikationsdato | 2011 |
Sider | 72-88 |
ISBN (Trykt) | 978-3-642-24275-5 |
DOI | |
Status | Udgivet - 2011 |
Emneord
- Refocusing Transformation
- Functional Languages
- Coq Proof Assistant
- Reduction Semantics
- Abstract Machine
- Program Transformations
- Formal Verification
- Axiomatization
- Mechanical Transformation
- Danvy and Nielsen