Quantum Computing presented by Scott Erholm and Bob Wall z

advertisement
Quantum Computing
presented by
Scott Erholm and Bob Wall
z
θ
x
φ
|ψ>
y
Motivation for Quantum Computing
•Moore's Law: The number of transistors capable of being placed
on a chip doubles every 18 months.
•If the number or transistors doubles, then individual size must
decrease, or we would have gigantic processors which would
require enormous amounts of energy and generate destructive heat.
•Therefore, size must decrease as complexity increases.
•Intel's latest technique uses a 90nm process.
•Each transistor is 50nm wide.
•Some gates are a scant 1.2nm wide.
•1.2nm is the same width as about 5 silicon atoms
z
θ
x
φ
|ψ>
y
Number of Atoms per Bit
The number of atoms needed to represent one bit has been decreasing
nearly linearly. Extrapolation suggests the one-atom-per-bit level would
be reached in in about 2020.
Before then, we will either hit a wall and fail to keep up with Moore's pace,
z
θ
x
φ
|ψ>
y
or we will be forced to use and exploit quantum effects in computers.
Brief History of Quantum Computing
•1982 Richard Feynman proposes quantum computer
•1985 David Deutsch gives a description of a universal quantum computer
•Pre-1994 Quantum computing remains a marginal curiosity
•1994 Peter Shor introduces quantum algorithm for factoring integers and
extracting discrete logarithms in polynomial time
•1995 Shor establishes theory of quantum error-correcting codes
•1997 Ethan Bernstein and Umesh Vazirani construct theoretical quantum
Turing machine
•1998 First working 2-qubit NMR demonstrated at Berkeley.
•1999 First working 3-qubit NMR demonstrated at IBM
•2000 First working 5-qubit NMR demonstrated at IBM
•2001 First working 7-qubit NMR demonstrated at IBM
•2004 “Flying Qubit” is demonstrated by researchers at U. Michigan
z
θ
x
φ
|ψ>
y
Representing quantum information
In normal, or “classical” computing, the basic unit of information is the bit
A bit can be in one of two states, 0 or 1
➢
In quantum computing, the basic unit of information is the “qubit”
After measurement, a qubit will be in one of two states, |0> or |1>
➢
|0>, |1> notation called “ket”, invented by Dirac
➢
States of a qubit can be represented by entities which resolve two
➢
states, such as:
Photon: Vertical or Horizontal polarization
➢
Electron: Spin up or Spin down
➢
Atom: Discrete energy levels
➢
|0> and |1> are called “basis states”
➢
Prior to measurement however, the qubit exists in some linear
➢
combination of states:
|ψ> = α|0> + β|1>
z
θ
x
φ
|ψ>
y
which is called a superposition.
Superposition |ψ> = α|0> + β|1>
Quantum Physics is probabilistic
α and β coefficients are complex numbers, called the amplitudes of
superposition
α = x0 + iy0 and β = x1 + iy1
These coefficients represent the probability of the qubit being in the |0> or
|1> state.
Upon measurement, a qubit will collapse into either the |0> or |1> state, but
before measurement, there is only the probability that the qubit is in a
particular state.
|α|2 is the probability of |0>
|β|2 is the probability of |1>
|α|2 + |β|2 = 1 since the probabilities must sum to one.
z
θ
x
φ
|ψ>
y
Classical 2-state Probabilistic System
If p is the probability of state x, then state y has a probability of (1-p).
The canonical example is that of flipping a fair coin:
Probability of T = ½, so therefore the probability of H = (1-½) = ½.
A classical probabilistic system can be thought of as a probabilistic bit, or
pbit.
Ignoring for the moment that it is incorrect use of the ket notation, a pbit can
be represented the same way as a qubit:
|outcome> = a|0> + b|1> where a = p and b = (1-p)
So in the coin example, the outcome is = ½|T> + ½|H>
z
θ
x
φ
|ψ>
y
Comparisons
•Bit is 1-D point in only one of two states, 0 and 1.
•Pbit is a 2-D line between the two states 0 and 1
•Qubit is a 3-D sphere with 0 and 1 at the poles, and an infinite
number of superpositions as points on the sphere
z
θ
x
φ
|ψ>
y
Sphere representations of a qubit
The reason a qubit is represented as a sphere is because the coefficients are
complex numbers. The probability from 0 to 1 is the similar to classical
probability, but the complex coefficient introduces an additional parameter,
phase angle. The spheres below represent three different qubits with the
same probability proportions of “0-ness” and “1-ness”, but with different
phases.
z
θ
x
φ
|ψ>
y
Bloch Sphere
Because |α|2 + |β|2 = 1, the superposition
equation
|ψ> = α|0> + β|1>
may be re-written in polar coordinate fashion
as:
|ψ> = eiγ(cosθ/2 |0> + eiφsinθ/2 |1>)
Since the factor eiγ has no observable effects,
it can be ignored, so we can effectively write:
|ψ> = cosθ/2 |0> + eiφsinθ/2 |1>
It is important to note that the Bloch sphere is a unit sphere—that is, every
point on the surface of the sphere can be described by a unit vector—a
vector of length 1. It is easy to see then, that every possible state is a unit
vector. Therefore, any state of a qubit can be described by a vector, and
z
θ
x
φ
|ψ>
y
the vectors may be manipulated mathematically.
Why does the phase matter?
Phase becomes important when adding together the effects of a
computational operation on all the terms in a superposition. For example,
consider a pair of qubits A and B:
|ψA> = α|0> + β|1>
and
|ψB> = α|0> - β|1>
Individually, they both have the same probability |α|2 of |0>, and since |β|2 =
|-β|2, they both have the same probability of |1>.
Now however, consider a specific quantum computation for which the output
is defined to be:
[(α+β)/√2]|0> + [(α-β)/√2]|1>
z
θ
x
φ
|ψ>
y
Why does the phase matter? (cont.)
Using qubit A, the output is [(α+β)/√2]|0> + [(α-β)/√2]|1>, but using qubit
B, the output is [(α-β)/√2]|0> + [(α+β)/√2]|1>. The only difference in
the output is the sign of β in the coefficients. As a special illustrative
case, set α = β = 1/√2. In this case, the measured answer of from
qubit A will always be |0>, and the measured answer from qubit B will
always be |1>.
Even though A and B have the same proportions of “0-ness” and “1ness”, because the phase is different, they will produce different
measurements.
z
θ
x
φ
|ψ>
y
Qubit gates
In order to perform any real computation, we need gates to act upon the
qubits! In classical computation, the familiar gates are not, and, or, xor, and
others which take bits as the input(s), and combine them in a logical manner
to produce an output. Since the states and operations are entirely different,
traditional logic gates will not work on qubits, but there do exists some
analogs.
NOT
Since α|0> + β|1> is a unit vector, it can be represented as a matrix
If a NOT function is applied, the vector becomes α|1> + β|0>, or
The NOT itself may be represented as a matrix
z
θ
x
φ
|ψ>
y
In matrix form then,
=
Matrix manipulations
Can any matrix manipulation be performed on a qubit?
No, not just any manipulation
➢
The normalization condition requires that |α|2 + |β|2 = 1 for the state |ψ> =
α|0> + β|1>. This must also be true of the resultant state |ψ'> = α'|0> + β'|1>
after the gate has acted.
The condition the gate must adhere to in order to achieve the constraint is
known as the unitary condition. In order for a unit function matrix U to act,
U†U = I, where U† is the conjugate transpose of U (obtained by transposing
and then complex conjugating U), and I is the 2x2 identity matrix. This is the
only constraint on quantum gates. Any unitary matrix specifies a valid
quantum gate!
z
θ
x
φ
|ψ>
y
Single qubit quantum gates
•In classical computing, the NOT gate is the only non-trivial single-bit gate.
•In quantum computing, there are many non-trivial single-qubit gates.
•Already shown the NOT (X) gate:
•One important gate is the phase shift (Z) gate:
•One most useful is the Hadamard (H) gate:
•The z rotation (Zϕ) gate rotates the vector around the
z axis, :
•In addition to the z rotation, gates exist for x and y rotations also.
z
θ
x
φ
|ψ>
y
Multiple qubit quantum gates
•Prototypical multiple-qubit gate is the controlled-NOT, or CNOT gate.
•Two qubit inputs—one the control and the other the target.
•If the control qubit is set to 0, then the target qubit is not changed.
•If the control qubit is set to 1, then the target qubit is flipped.
|00>⇒|00>;
CNOT =
z
θ
x
φ
|ψ>
y
|01>⇒|01>;
|10>⇒|11>;
|11>⇒|10>;
Multiple qubit quantum gates cont.
Quantum gates cannot be used directly to simulate classical logic gates
because quantum gates are reversible (they have an inverse) while
classical gates do not. However, the Toffoli gate can be used to simulate
any classical using reversible quantum gates, even though the Toffoli
gate is itself reversible.
Toffoli gate truth table
Inputs
z
θ
x
φ
|ψ>
y
Outputs
a
b
c
a'
b'
c'
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
Multiple Qubits and Quantum
Entanglement
●
●
●
●
z
θ
x
φ
|ψ>
y
The state of a register of n qubits has 2n different dimensions
(rather than 2n dimensions with 2n different values).
This exponential growth of the state space is what really gives
quantum computing its “bang for the buck”.
A number of these dimensions cannot be represented as simple
products of the states of individual qubits; these are referred to
as entangled states.
When the state of two qubits is entangled, an operation that
affects one of them (i.e. measuring it) also affects the other qubit
Entanglement (cont.)
●
z
θ
x
φ
|ψ>
y
This entanglement leads to some truly hard-to-explain
quantum effects, such as the Einstein-Podolsky-Rosen
(EPR) Paradox.
–
Suppose you take two entangled qubits, and give one to
Alice and one to Bob. They move far apart.
–
Now Alice measures the state of her qubit – suppose she
measures a |0>.
–
If Bob now measures his qubit, he will measure the same
thing.
–
This seems to imply that it is possible to communicate
instantaneously across any distance (i.e. faster than the speed
of light), violating laws of physics.
Entanglement (cont.)
●
●
z
θ
x
φ
|ψ>
y
In fact, it turns out that even though this action at a
distance seems to happen, it cannot be used to actually
communicate – whew, relativity saved again!
But it can be used for quantum teleportation, dense
coding, and key distribution, some important
applications of quantum theory that have been
experimentally proven.
Quantum Parallelism
●
●
z
θ
x
φ
|ψ>
y
Given some universal function Uf, it is simultaneously
applied to each basis vector in the superposition of its
inputs – this generates the superposition of the results.
This in conjunction with entanglement is the reason for
the excitement about quantum computing – there are a
huge number of possible superpositions of states, and
computations can be done on all of these
superpositions in parallel.
Quantum Circuits
●
●
Quantum circuits or networks are analogous to digital
electronic circuits – a set of quantum gates connected
together to perform a specific operation.
In addition to interconnected gates, the circuit can
include measurement points.
U1
U2
U3
M
z
θ
x
φ
|ψ>
y
Quantum Circuits (cont.)
●
●
●
z
θ
x
φ
|ψ>
y
Because a state cannot be copied or cloned, fan-out
from a gate is not allowed.
Simple example – quantum half-adder.
There are a number of different possible sets of
universal quantum gates.
Quantum Computers
●
z
θ
x
φ
|ψ>
y
Requirements for quantum hardware:
–
Scalable, with well-characterized qubits
–
Initializable to a pure state such as |00…0>
–
Relatively long decoherence time
–
Universal set of quantum gates
–
Qubit-specific measurement capability
–
Ability to faithfully communicate qubits
Quantum Computers (cont.)
●
●
z
θ
x
φ
|ψ>
y
Possible technologies for creating and connecting
qubits:
–
Ion traps
–
Nuclear Magnetic Resonance (NMR)
–
Solid-state (semiconductor quantum dots)
–
Optical lattices
None of these has yet exhibited much scalability.
Quantum Computers (cont.)
●
z
θ
x
φ
|ψ>
y
Ion Traps
–
One of the first implemented mechanisms
–
Small number of ions trapped using electromagnetic fields
–
Ions manipulated using laser pulses
–
Progress is being made on producing lattices of ion traps,
some of which store ions (memory) and some of which allow
interactions (computation units)
–
Ion trap hardware used to implement the Deutsch–Jozsa
algorithm in 2002
Quantum Computers (cont.)
●
z
θ
x
φ
|ψ>
y
NMR
–
Another early mechanism – liquid-based two qubit device
built in 1998.
–
Qubits stored in nuclear spin of hydrogen atoms, constrained
by magnetic fields.
–
Spins manipulated using radio waves.
–
Most advanced computer to date is a seven-qubit device built
using NMR techniques – implemented Shor’s algorithm.
Quantum Computers (cont.)
●
z
θ
x
φ
|ψ>
y
Solid-state devices
–
First proposed in 1998.
–
Early implementation used the spin of a phosphorus nucleus,
qubit controlled and observed via radio waves.
–
Qubits placed within a grid of silicon electrodes
–
Believed by many to be the best chance for long-term viable
hardware implementation.
–
Another possibility – Superconducting Quantum Interference
Devices (SQUIDs)
Error Correction
●
●
●
z
θ
x
φ
|ψ>
y
One big problem with quantum computers is
decoherence – interaction of the particles representing
qubits with the outside environment causes a
deterioration of the state of the qubit.
Since the qubits can’t be completely isolated from the
external world, need a way to correct the deterioration
– quantum error correction
This is difficult, because you cannot copy or clone a
quantum state
Error Correction (cont.)
●
●
z
θ
x
φ
|ψ>
y
Characterization of errors:
–
No errors (I)
–
Bit flip errors (X)
–
Phase errors (Z)
–
Bit flip/phase errors (Y)
Qubit error is a transformation formed by a linear
combination of these components
e1 I + e2 X + e3 Y + e4 Z
Error Correction (cont.)
●
Quantum error correction can be done similarly to
classical error correction – add parity qubits and define
a transform SC (the syndrome extraction operator) such
that for a given set of n data qubits and k parity qubits
C(x) which has been transformed by a correctable
error, applying SC identifies which error occurred.
That is,
i = SC(Ei(C(x)))
z
θ
x
φ
|ψ>
y
Error Correction (cont.)
●
Error correction proceeds as follows:
–
Apply SC to quantum state padded with |0> bits:



c








S  eiEi   0   ei  Ei   i
i
i
–
This will generate a superposition of errors associated with
their respective index.
–
Measure the |i> component of the result – yields a value i0
and projects the state to
Ei 0  , i 0
z
θ
x
φ
|ψ>
y



Error Correction (cont.)
●
z
θ
x
φ
|ψ>
y
–
Now apply the inverse of the error transform Ei0 to the first n
+ k qubits to get the corrected state

–
We only need to do one inverse transform, because the
second step projected multiple error transformations onto a
single error.
The errors that can occur (and their frequency) is
dependent on the quantum hardware implementation.
The correction would need to be built into the software
or the hardware.
Future Direction
●
One researcher, Marshall Stoneham at University
College London, is working on a silicon-based
approach, and he predicts that there could be desktop
quantum computers by 2010.
–
z
θ
x
φ
|ψ>
y
(Is this guy a programmer trapped in a physicist’s body? We
all know how good software people are at time estimates …)
References
http://www.cs.caltech.edu/~westside/quantum-intro.html
Introduction to Quantum Information Processing. A paper by Krill,
et. al., from 2002.
An Introduction to Quantum Computing for Non-Physicists. A
paper by Rieffel and Polak, found in ACM Computing Surveys,
Vol. 32, No. 3, September 2000, pp. 300-335.
Jenny Hogan, “Quantum Bits and Silicon Chips”, Nature, Vol. 24,
31 July 2003, pp. 484-486.
http://videos.dac.com/videos/40th/51/51_1/51_1slides.pdf
z
θ
x
φ
|ψ>
y
Questions?
(... sure, like we'll be able to answer them ... )
z
θ
x
φ
|ψ>
y
Don’t touch that dial…
Stay tuned next time, when we’ll see
how you actually program one of
these things to do something useful.
z
θ
x
φ
|ψ>
y
Download