Abstract
The principles of reversible programming languages are explicated and illustrated with reference to the design of a high-level imperative language, Janus. The fundamental properties for such languages include backward as well as forward determinism and reversible updates of data. The unique design features of the language include explicit post-condition assertions, direct access to an inverse semantics and the possibility of clean (i.e., garbage-free) computation of injective functions. We suggest the clean simulation of reversible Turing machines as a criterion for computing strength of reversible languages, and demonstrate this for Janus. We show the practicality of the language by implementation of a reversible fast Fourier transform. Our results indicate that the reversible programming paradigm has fundamental properties that are relevant to many different areas of computer science.
Originalsprog | Engelsk |
---|---|
Titel | Conference on Computing Frontiers, CF 2008 : Proceedings of the 2008 Conference on Computing Frontiers, Ischia, Italy May 5-7, 2008 |
Forlag | Association for Computing Machinery |
Publikationsdato | 2008 |
Sider | 43-54 |
ISBN (Trykt) | 9781605580777 |
DOI | |
Status | Udgivet - 2008 |
Begivenhed | Conference on Computing Frontiers - Ischia, Italien Varighed: 5 maj 2008 → 7 maj 2008 |
Konference
Konference | Conference on Computing Frontiers |
---|---|
Land/Område | Italien |
By | Ischia |
Periode | 05/05/2008 → 07/05/2008 |