#rust #reversible-computing #havent-read-yet #computer-science
haven't read this yet, but it seems worth sharing.
https://blog.erk.dev/posts/rrust/
Introduction
Reversible computing is the idea that you can for a given function
f(x) := yyou can generate the inverse function that takes the output and generates the inputf^-1(y) := x. This of course could be done by hand, but we want to make a machine, here donoted by I, that can make the transformation of the code. That is thatI(f) := f^-1. To generalize this a bit we can look atxandyas states andfas a function that goes from statexto statey, this is how we will look at it in the following chapters since we are going to model our functions as mutations to variables. So we want to generate the inverse functionf^-1that takes state y and mutates it to state x.