Controlled NOT gate

From Wikipedia, the free encyclopedia
Jump to: navigation, search
The classical analog of the CNOT gate is a reversible XOR gate.
How the CNOT gate can be used (with Hadamard gates) in a computation
Representation of the CNOT gate
Answer on output depending on input and CNOT function
The first qubit flips only if the second qubit is 1.

In computing science, the controlled NOT gate (also C-NOT or CNOT) is a quantum gate that is an essential component in the construction of a quantum computer. It can be used to entangle and disentangle EPR states. Specifically, any quantum circuit can be simulated to an arbitrary degree of accuracy using a combination of CNOT gates and single qubit rotations.


The CNOT gate flips the second qubit (the target qubit) if and only if the first qubit (the control qubit) is |1\rangle.

Before After
Control Target Control Target
|0\rangle |0\rangle |0\rangle |0\rangle
|0\rangle |1\rangle |0\rangle |1\rangle
|1\rangle |0\rangle |1\rangle |1\rangle
|1\rangle |1\rangle |1\rangle |0\rangle

Allowing only \{|0\rangle,|1\rangle\} as input values for both qubits, the output of the CNOT gate corresponds to the result of a classical XOR gate.

More generally, the inputs are allowed to be a linear superposition of \{|0\rangle,|1\rangle\}. The CNOT gate transforms the quantum state:

a|00\rangle + b|01\rangle + c|10\rangle + d|11\rangle


a|00\rangle + b|01\rangle + c|11\rangle + d|10\rangle

The CNOT gate can be represented by the matrix (permutation matrix form):

 \operatorname{CNOT} =  \begin{bmatrix} 1 & 0 & 0 & 0 \\ 0 & 1 & 0 & 0 \\ 0 & 0 & 0 & 1 \\  0 & 0 & 1 & 0 \end{bmatrix}.

The first experimental realization of a CNOT gate was accomplished in 1995. Here, a single Beryllium ion in a trap was used. The two qubits were encoded into an optical state and into the vibrational state of the ion within the trap. At the time of the experiment, the reliability of the CNOT-operation was measured to be on the order of 90%.

In addition to a regular controlled NOT gate, one could construct a function-controlled NOT gate, which accepts an arbitrary number n+1 of qubits as input, where n+1 is greater than or equal to 2 (a quantum register). This gate flips the last qubit of the register if and only if a built-in function, with the first n qubits as input, returns a 1. The function-controlled NOT gate is an essential element of the Deutsch-Jozsa algorithm. CNOT is also a kind of universal gate(in the classical sense of the word). It is easy to see that if the CONTROL is set to '1' the TARGET output is always NOT. So, a NOT GATE can be constructed using CNOT.

Behaviour of CNOT when viewed in the Hadamard basis[edit]

When viewed only in the computational basis \{|0\rangle,|1\rangle\}, the behaviour of the CNOT appears to be like the equivalent classical gate. However, the simplicity of labelling one qubit the control and the other the target does not reflect what happens for most input values of both qubits.

CNOT gate in Hadamard Basis

"consider the Cnot gate in the Hadamard basis \{|+\rangle,|-\rangle\}... it is the state of the second qubit that remains unchanged, and the state of the first qubit that is flipped depending on the state of the second bit. Thus, in this basis the sense of which bit is the control bit and which the target bit has reversed. But we have not changed the transformation at all, only the way we are thinking about it."[1]

"the key is to notice the symmetric behavior of the CNOT gate. If we switch X and Z and qubits 1 and 2, we get back the original transformation."[2] The observation that both qubits are affected in a CNOT interaction is of importance when considering information flow in entangled quantum systems.[3]

Working through each of the Hadamard basis states,[a] the first qubit flips between |+\rangle and |-\rangle when the second qubit is |-\rangle:

Initial state in Hadamard basis Equivalent state in computational basis Apply operator State in computational basis after CNOT Equivalent state in Hadamard basis
|++\rangle \frac{1}{2}(|00\rangle + |01\rangle + |10\rangle + |11\rangle) CNOT \frac{1}{2}(|00\rangle + |01\rangle + |11\rangle + |10\rangle) |++\rangle
|+-\rangle \frac{1}{2}(|00\rangle - |01\rangle + |10\rangle - |11\rangle) CNOT \frac{1}{2}(|00\rangle - |01\rangle + |11\rangle - |10\rangle) |--\rangle
|-+\rangle \frac{1}{2}(|00\rangle + |01\rangle - |10\rangle - |11\rangle) CNOT \frac{1}{2}(|00\rangle + |01\rangle - |11\rangle - |10\rangle) |-+\rangle
|--\rangle \frac{1}{2}(|00\rangle - |01\rangle - |10\rangle + |11\rangle) CNOT \frac{1}{2}(|00\rangle - |01\rangle - |11\rangle + |10\rangle) |+-\rangle

A quantum circuit that performs a Hadamard transform followed by CNOT then another Hadamard transform can be described in terms of matrix operators:

(H1 ⊗ H1)−1 . CNOT . (H1 ⊗ H1)

The single-qubit Hadamard transform, H1, is its own inverse. The tensor product of two Hadamard transforms operating (independently) on two qubits is labelled H2. We can therefore write the matrices as:

H2 . CNOT . H2

When multiplied out, this yields a matrix that swaps the |01\rangle and |11\rangle terms over, while leaving the |00\rangle and |10\rangle terms alone. This is equivalent to a CNOT gate where qubit 2 is the control qubit and qubit 1 is the target qubit:

    1 &  1 &  1 &  1\\
    1 & -1 &  1 & -1\\
    1 &  1 & -1 & -1\\
    1 & -1 & -1 &  1
    1 & 0 & 0 & 0\\
    0 & 1 & 0 & 0\\
    0 & 0 & 0 & 1\\
    0 & 0 & 1 & 0
    1 &  1 &  1 &  1\\
    1 & -1 &  1 & -1\\
    1 &  1 & -1 & -1\\
    1 & -1 & -1 &  1
    1 & 0 & 0 & 0\\
    0 & 0 & 0 & 1\\
    0 & 0 & 1 & 0\\
    0 & 1 & 0 & 0


Constructing the Bell State |\Phi^+\rangle[edit]

A common application of the CNOT gate is to maximally entangle two qubits into the |\Phi^+\rangle Bell state; this forms part of the setup of the superdense coding, quantum teleportation, and entangled quantum cryptography algorithms.

To construct |\Phi^+\rangle, the inputs A (control) and B (target) to the CNOT gate are:[b]

\frac{1}{\sqrt{2}}(|0\rangle + |1\rangle)_A and |0\rangle_B

After applying CNOT, the resulting Bell State \frac{1}{\sqrt{2}}(|00\rangle + |11\rangle) has the property that the individual qubits can be measured using any basis and will always present a 50/50 chance of resolving to each state. In effect, the individual qubits are in an undefined state. The correlation between the two qubits is the complete description of the state of the two qubits; if we choose the same basis to measure both qubits and compares notes, the measurements will perfectly correlate.

When viewed in the computational basis, it appears that qubit A is affecting qubit B. Changing our viewpoint to the Hadamard basis demonstrates that, in a symmetrical way, qubit B is affecting qubit A.

The input state can be viewed as:

|+\rangle_A and \frac{1}{\sqrt{2}}(|+\rangle + |-\rangle)_B

In the Hadamard view, the control and target qubits have conceptually swapped and qubit A is inverted when qubit B is |-\rangle_B. The output state after applying the CNOT gate is \frac{1}{\sqrt{2}}(|++\rangle + |--\rangle) which can be shown[c] to be exactly the same state as \frac{1}{\sqrt{2}}(|00\rangle + |11\rangle).

See also[edit]


  1. ^ Eleanor G. Rieffel; Wolfgang H. Polak (4 March 2011). Quantum Computing: A Gentle Introduction. MIT Press. p. 80. ISBN 978-0-262-01506-6. 
  2. ^ Gottesman, Daniel (1998). "The Heisenberg Representation of Quantum Computers". Group: Proceedings of the XXII International Colloquium on Group Theoretical Methods in Physics, eds. S. P. Corney, R. Delbourgo, and P. D. Jarvis, pp. (Cambridge, MA, International Press, ) 22 (1999): 32–43. arXiv:quant-ph/9807006. 
  3. ^ Deutsch, David; Hayden, Patrick (1999). "Information Flow in Entangled Quantum Systems". Proceedings of the Royal Society A: Mathematical, Physical and Engineering Sciences 456 (1999): 1759–1774. arXiv:quant-ph/9906007. doi:10.1098/rspa.2000.0585. 

External links[edit]


  1. ^ As an example of converting the description of a state from one basis to another, state |++\rangle, which is described in terms of Hadamard basis states, can be converted to a computational basis description by noting that: |+\rangle = \frac{1}{\sqrt{2}}(|0\rangle + |1\rangle) and therefore: |++\rangle = |+\rangle|+\rangle = \frac{1}{2}(|0\rangle + |1\rangle)(|0\rangle + |1\rangle) = \frac{1}{2}(|00\rangle + |01\rangle + |10\rangle + |11\rangle)
  2. ^ \frac{1}{\sqrt{2}}(|0\rangle + |1\rangle), also known as |+\rangle, can be constructed by applying a Hadamard gate to a qubit set to |0\rangle
  3. ^ \frac{1}{\sqrt{2}}(|++\rangle + |--\rangle) = \frac{1}{\sqrt{2}}(|+\rangle_A|+\rangle_B + |-\rangle_A|-\rangle_B) = \frac{1}{2\sqrt{2}}((|0\rangle_A + |1\rangle_A)(|0\rangle_B + |1\rangle_B) + (|0\rangle_A - |1\rangle_A)(|0\rangle_B - |1\rangle_B)) = \frac{1}{2\sqrt{2}}((|00\rangle + |01\rangle + |10\rangle + |11\rangle) + (|00\rangle - |01\rangle - |10\rangle + |11\rangle)) = \frac{1}{\sqrt{2}}(|00\rangle + |11\rangle)