# Reversible Evolution

In quantum mechanics, every change except measurement (and noise that
damages the state, known as *decoherence*, which we will discuss in
the third week) must be *reversible*. (In mathematical terms, this
means that it can be represented by a *unitary* matrix.)

This means
that it must be possible for us to recreate the initial state using
only the output state, without additional information. Here, we will
introduce some of those changes as discrete operations which we call
*gates*.

## Basic Classical Logic Gates

You may already be familiar with the most basic logic gates we use in creating a classical computer, but just in case you’re not, let’s review them. Some of the gates have one input bit and one output bit, others have two input bits and only one output bit.

### NOT

The NOT gate, as you might expect, flips a single bit.

input | output |
---|---|

0 | 1 |

1 | 0 |

The NOT gate is reversible: if you apply a NOT gate twice to the same signal, you get out the same value you started with: NOT(NOT(X)) = X.

### AND

The AND gate takes two input bits, and its output is one *only* if
both input bits are one:

input | input | output |
---|---|---|

0 | 0 | 0 |

0 | 1 | 0 |

1 | 0 | 0 |

1 | 1 | 1 |

The AND gate is not reversible: there are four different possible input states (00, 01, 10, 11) and only two possible output states (0 and 1), so there isn’t enough information in the output to know for sure what the inputs were. In the case that the output C is 1, you know that both inputs were 1, but in all three of the other cases, you can’t tell.

### OR

The OR gate takes two input bits, and its output is zero *only* if
both input bits are zero:

input | input | output C |
---|---|---|

0 | 0 | 0 |

0 | 1 | 1 |

1 | 0 | 1 |

1 | 1 | 1 |

Its behavior in a lot of ways is similar to that of the AND gate. The OR gate is not reversible: there are four different possible input states (00, 01, 10, 11) and only two possible output states (0 and 1), so there isn’t enough information in the output to know for sure what the inputs were. In the case that the output C is 0, you know that both inputs were 0, but in all three of the other cases, you can’t tell.

In fact, with the AND or OR gate, even if I gave you the output and
*one* of the inputs, you wouldn’t be able to tell unambiguously what
the other input value was in all cases.

### XOR

The XOR, or exclusive OR, gate takes two input bits, and its output is
one *only* if exactly one input bit is one:

input | input | output |
---|---|---|

0 | 0 | 0 |

0 | 1 | 1 |

1 | 0 | 1 |

1 | 1 | 0 |

The OR gate is close to reversible: with two input bits and one output
bit, there still isn’t enough information in the output to know for
sure what the inputs were. But, if I give you *one* of the inputs,
you can now tell unambiguously what the other input was! We will see
below that one of the important reversible two-qubit gates is related
to XOR.

## Reversible Classical Gates

### Entropy and Information

In the early 1970s, Charles Bennett of IBM, later joined by Richard Feynman of Caltech, and Tommaso Toffoli and Ed Fredkin of MIT, laid the groundwork for discrete reversible logic operations. Bennett was an acolyte of Rolf Landauer, who recognized that the destruction of information adds to the entropy of the Universe, and must generate waste heat.

*Entropy* is the amount of disorder in something. If you take a
physics class, or possibly chemistry, you will learn about entropy
when you learn about thermodynamics. If you have a lot of energy
confined in one place, you can use it to do work, such as turning a
motor. This spreads energy around. Once the energy is spread out
evenly, the entropy is maximized and it is no longer possible to do
useful work with it.

In computer science we also talk about the *entropy of information*.
If you have a certain amount of data, it might be all zeroes or all
ones, in which case it’s very easy to tell a friend how to recreate
the same state: just say, “I have seven hundred ones.” If your data
is more complex, though, it gets harder to describe; it has *high
entropy*.

I (Van Meter) can recall taking Feynman’s class at Caltech, in which he explained the relationship between information and entropy in terms of thermodynamics. For quite a while, I believed that he was speaking allegorically, and couldn’t understand why he was bringing in physical constants. When I finally understood that he meant it quite literally, I could feel the hair on the back of my neck stand up. It remains one of the most startling ideas I have ever encountered.

### Reversible Computing

Generally, entropy increases when we lose information, or when information is erased. The AND and OR gates we discussed above necessarily lose information: they start with two input bits, and end with only one, so there is no way to carry all of the information through.

If, instead, we require all of our gates to have the same number of
input and output bits, it’s possible that we might be able to *undo*
our computation. A second additional criteria is necessary to make it
*reversible*: every possible output state comes from exactly one input
state. Then we say that the function is “one to one”, or *bijective*.

Any logic function can be computed using one, two, and three-bit reversible gates, so we will look at a few of them.

### Identity

The *identity* gate does nothing to the state: its output is the same
as its input. It is obviously reversible; since it does nothing, in
order to get back to where we started, we only have to do nothing one
more time!

input | output |
---|---|

0 | 0 |

1 | 1 |

### NOT

We have already seen the NOT gate above. Executing NOT twice in a row brings us back to where we started: NOT(NOT(X)) = X.

### CNOT

The controlled NOT gate, or CNOT, takes two input bits and produces two output bits. If one of the bits (called the control bit) is one, the other bit (called the target bit) is flipped. If the control bit is zero, the target bit is passed through unchanged.

input | input | output | output |
---|---|---|---|

0 | 0 | 0 | 0 |

0 | 1 | 0 | 1 |

1 | 0 | 1 | 1 |

1 | 1 | 1 | 0 |

A quick examination of the table shows that is the same as , and is the XOR of and , . If we apply the same gate twice, obviously stays the same, and the new , and we are back where we started.

### CCNOT (Toffoli Gate)

The control-control-NOT gate, or CCNOT gate, is also called the Toffoli gate, named for Tommaso Toffoli. It uses two control bits instead of one.

input | input | input | output | output | output |
---|---|---|---|---|---|

0 | 0 | 0 | 0 | 0 | 0 |

0 | 0 | 1 | 0 | 0 | 1 |

0 | 1 | 0 | 0 | 1 | 0 |

0 | 1 | 1 | 0 | 1 | 1 |

1 | 0 | 0 | 1 | 0 | 0 |

1 | 0 | 1 | 1 | 0 | 1 |

1 | 1 | 0 | 1 | 1 | 1 |

1 | 1 | 1 | 1 | 1 | 0 |

### CSWAP (Fredkin Gate)

The control-SWAP gate, or CSWAP gate, is also called the Fredkin gate, named for Ed Fredkin. If the control bit is zero, the other two bits are left alone. If the control bit is one, the other two bits are swapped.

input | input | input | output | output | output |
---|---|---|---|---|---|

0 | 0 | 0 | 0 | 0 | 0 |

0 | 0 | 1 | 0 | 0 | 1 |

0 | 1 | 0 | 0 | 1 | 0 |

0 | 1 | 1 | 0 | 1 | 1 |

1 | 0 | 0 | 1 | 0 | 0 |

1 | 0 | 1 | 1 | 1 | 0 |

1 | 1 | 0 | 1 | 0 | 1 |

1 | 1 | 1 | 1 | 1 | 1 |

Either the CCNOT or the CSWAP gate is powerful enough to be able to
create *any* classical logic circuit.

## Single-Qubit Gates

The reversible gates above all have quantum equivalents, and we will use them in constructing quantum algorithms. But qubits are more complex objects than simple classical bits, allowing a broader range of operations that all qualify as unitary. Here, we will look at some single-qubit gates that go beyond just the Identity and NOT gates above.

### Rotations on the Bloch Sphere

When we introduced qubits, we introduced the notion of the Bloch sphere, and the idea of the state of a single qubit as a point on the sphere. The one-qubit gates can be understood as rotations about the X, Y, or Z axis of the Bloch sphere.

### The NOT Gate and Other *X* Gates

A simple reversible gate, like the classical NOT gate, the gate takes 0 to 1 and 1 to 0. Since our state can be a superposition, it does a little more than this, it swaps our 0 and 1 values, or the contents of our 0 and 1 dials. It is a rotation of 180 degrees, or , about the axis. It’s also possible to rotate by any angle, which swaps the 0 and 1 values less completely.

### The Phase Gates

Although rotating around the axis is somewhat like the classical
NOT gate, rotating around the axis has no classical equivalent.
rotation modifies the phase of the state. We call a 180
degree rotation simply the *Z* gate. For other angles, we call it a Z
rotation or a phase gate, and specify the angle.

### The Hadamard Gate

The Hadamard gate is our most basic means of creating superposition. It takes our state to a 50/50 superposition of and :

If it also took the state to the same 50/50 superposition, it wouldn’t be reversible. Instead, it takes it to a superposition with a phase twist on the state:

Applying the Hadamard twice to the same qubit returns it to its original state. In fact, this is our first use of interference! If we began with the state, we get constructive interference that builds us a new state, and destructive interference that eliminates the state:

Here we can see that the phase of the state has a critical impact on the interference; reversing the other state results in constructive interference on the state, and destructive interference on the state:

© Keio University