@inproceedings{f46eefd8c7884d1e92af5a7e4fdd717a,
title = "A design-based model of reversible computation ",
abstract = "We investigate, within the UTP framework of Hoare He Designs, the effect of seeing computation as an essentially reversible process. We describe the theoretical link between reversibility and the minimum power requirements of a computation, and we review Zuliani{\textquoteright}s work on Reversible Probabilistic Guarded Command Language. We propose an alternative formalisation of reversible computing which accommodates backtracking. To obtain a basic backtracking language able to search for a single result we exploit the already recognised properties of non-deterministic choice, using it as provisional choice rather than implementor{\textquoteright}s choice. We add a “prospective values” formalism which can describe programs that return all the possible results of a search, and we show how to formally describe the premature termination of such a search, a mechanism analogous to the “cut” of Prolog. An appendix describes some aspects of the wp calculus in terms of Designs, as needed for our proofs. Support for the programming structures described has been incorporated in a reversible virtual machine for i386 platforms with Posix compatibility.",
author = "Stoddart, {W. J. (Bill)} and Zeyda, {F. (Frank)} and Lynas, {R. (Robert)}",
year = "2006",
doi = "10.1007/11768173_4",
language = "English",
isbn = "9783540347507",
volume = "4010",
series = "Lecture Notes in Computer Science",
publisher = "Springer Verlag",
pages = "63--83",
editor = "Dunne and {Stoddart }",
booktitle = "Unifying Theories of Programming",
address = "Germany",
}