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.
Original language | English |
---|---|
Title of host publication | Conference on Computing Frontiers, CF 2008 : Proceedings of the 2008 Conference on Computing Frontiers, Ischia, Italy May 5-7, 2008 |
Publisher | Association for Computing Machinery |
Publication date | 2008 |
Pages | 43-54 |
ISBN (Print) | 9781605580777 |
DOIs | |
Publication status | Published - 2008 |
Event | Conference on Computing Frontiers - Ischia, Italy Duration: 5 May 2008 → 7 May 2008 |
Conference
Conference | Conference on Computing Frontiers |
---|---|
Country/Territory | Italy |
City | Ischia |
Period | 05/05/2008 → 07/05/2008 |