The Fredkin gate (also CSWAP gate and conservative logic gate) is a computational circuit suitable for reversible computing, invented by Edward Fredkin. It is universal, which means that any logical or arithmetic operation can be constructed entirely of Fredkin gates. The Fredkin gate is a circuit or device with three inputs and three outputs that transmits the first bit unchanged and swaps the last two bits if, and only if, the first bit is 1. The basic Fredkin gate is a controlled swap gate that maps three inputs (C, I1, I2) onto three outputs (C, O1, O2). The C input is mapped directly to the C output. If C = 0, no swap is performed; I1 maps to O1, and I2 maps to O2. Otherwise, the two outputs are swapped so that I1 maps to O2, and I2 maps to O1. It is easy to see that this circuit is reversible, i.e., "undoes" itself when run backwards. A generalized n×n Fredkin gate passes its first n−2 inputs unchanged to the corresponding outputs, and swaps its last two outputs if and only if the first n−2 inputs are all 1. The Fredkin gate is the reversible three-bit gate that swaps the last two bits if, and only if, the first bit is 1. It has the useful property that the numbers of 0s and 1s are conserved throughout, which in the billiard ball model means the same number of balls are output as input. This corresponds nicely to the conservation of mass in physics, and helps to show that the model is not wasteful. The Fredkin gate can be defined using truth functions with AND, OR, XOR, and NOT, as follows: O1 = I1 XOR S O2 = I2 XOR S Cout= Cin where S = (I1 XOR I2) AND C Alternatively: O1 = (NOT C AND I1) OR (C AND I2) O2 = (C AND I1) OR (NOT C AND I2) Cout= Cin One way to see that the Fredkin gate is universal is to observe that it can be used to implement AND, NOT and OR: If I2 = 0, then O2 = C AND I1. If I2 = 1, then O1 = C OR I1. If I1 = 0 and I2 = 1, then O2 = NOT C. Three-bit full adder (add with carry) using five Fredkin gates. The "g" garbage output bit is (p NOR q) if r=0, and (p NAND q) if r=1.