Generating reversible circuits from higher-order functional programs

From MaRDI portal




Abstract: Boolean reversible circuits are boolean circuits made of reversible elementary gates. Despite their constrained form, they can simulate any boolean function. The synthesis and validation of a reversible circuit simulating a given function is a difficult problem. In 1973, Bennett proposed to generate reversible circuits from traces of execution of Turing machines. In this paper, we propose a novel presentation of this approach, adapted to higher-order programs. Starting with a PCF-like language, we use a monadic representation of the trace of execution to turn a regular boolean program into a circuit-generating code. We show that a circuit traced out of a program computes the same boolean function as the original program. This technique has been successfully applied to generate large oracles with the quantum programming language Quipper.





Describes a project that uses

Uses Software





This page was built for publication: Generating reversible circuits from higher-order functional programs

Report a bug (only for logged in users!)Click here to report a bug for this page (MaRDI item Q3186607)