Principles of a reversible programming language

Tetsuo Yokoyama, Holger Bock Axelsen, Robert Glück

79 Citations (Scopus)

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 languageEnglish
Title of host publicationConference on Computing Frontiers, CF 2008 : Proceedings of the 2008 Conference on Computing Frontiers, Ischia, Italy May 5-7, 2008
PublisherAssociation for Computing Machinery
Publication date2008
Pages43-54
ISBN (Print)9781605580777
DOIs
Publication statusPublished - 2008
EventConference on Computing Frontiers - Ischia, Italy
Duration: 5 May 20087 May 2008

Conference

ConferenceConference on Computing Frontiers
Country/TerritoryItaly
CityIschia
Period05/05/200807/05/2008

Fingerprint

Dive into the research topics of 'Principles of a reversible programming language'. Together they form a unique fingerprint.

Cite this