One Complexity Theorist's View of Quantum Computing
One Complexity Theorist's View of Quantum Computing
One Complexity Theorist's View of Quantum Computing
Lance Fortnow
NEC Research Institute
4 Independence Way
Princeton, NJ 08540
Abstract
The complexity of quantum computation remains poorly understood. While physicists attempt to find ways to create quantum computers, we still do not have much evidence one way
or the other as to how useful these machines will be. The tools of computational complexity
theory should come to bear on these important questions.
Quantum computing often scares away many potential researchers in computer science because of the apparent background need in quantum mechanics and the alien looking notation
used in papers on the topic.
This paper will give an overview of quantum computation from the point of view of a
complexity theorist. We will see that one can think of BQP as yet another complexity class
and study its power without focusing on the physical aspects behind it.
Introduction
When one starts looking at quantum computation an obvious question comes to mind: Can quantum
computers be built? By this I mean can one create a large reliable quantum computerperhaps to
factor numbers using Shors algorithm [Sho97] faster than any classical computer can factor. There
has been some success in creating quantum machines with a tiny number of bits; but we have many
physical and engineering issues to overcome before a large scale quantum machine can be realized.
As a computational complexity theorist, I would like to consider a different and perhaps more
important question: Are quantum computers useful? In other words, even if we can build reasonable quantum machines, will they actually help us solve important computational problems not
attainable by traditional machines? Realize that the jury is still out on this issue. Grovers algorithm [Gro96] gives only a quadratic speed-up, which means that a quantum machine will have to
approach speeds of a traditional computer (on the order of a trillion operations per second) before
Grover overtakes brute-force searching.
Shors quantum algorithms for factoring and discrete logarithm [Sho97] give us better examples.
Here we achieve an exponential speed-up from the best known probabilistic algorithms. Factoring
alone does not make quantum computing useful. Consider the following paragraph from Shors
famous paper [Sho97, p. 1506]:
Based on a talk first presented at the Second Workshop on Algorithms in Quantum Information Processing at
DePaul University, Chicago, January 21, 1999. A preliminary version appeared in Proceedings of Computing: The
Australasian Theory Symposium 2000.
Discrete logarithms and factoring are not in themselves widely useful problems. They
have become useful only because they have been found to be crucial for public-key cryptography, and this application is in turn possible only because they have been presumed
to be difficult. This is also true of the generalizations of Boneh and Lipton [BL95] of
these algorithms. If the only uses of quantum computation remain discrete logarithms
and factoring, it will likely become a special-purpose technique whose only raison detre
is to thwart public key cryptosystems.
How useful can quantum computing be? What is the computational complexity of BQP, the
class of efficiently quantum computable problems. Does BQP contain NP-complete problems like
graph 3-colorability? What is the relationship between BQP and other more traditional complexity
classes like the polynomial-time hierarchy?
These questions are well-suited for computational complexity theorists. Many researchers,
though, shy away from quantum complexity because it appears that a deep knowledge of physics
is necessary to understand BQP. Also most papers use a strange form of notation that make their
results appear more difficult than they really are.
This paper argues that one can think about BQP as just a regular complexity class, conceptually
not much different than its probabilistic cousin BPP. We develop a way of looking at computation
as matrix multiplications and exhibit some immediate consequences of this formulation. We show
that BQP is a rather robust complexity class that has much in common with other classes. We
argue that BQP and BPP exhibit much of the same behavior particularly in their ability to do
searching and hiding of information.
While this paper does not assume any knowledge of physics, we do recommend a familiarity
with basic notions of complexity theory as described in Balcazar, Daz and Gabarr
o [BDG88].
Consider a multitape deterministic Turing machine M that uses t(n) time and s(n) space. Let
us also fix some input x in {0, 1}n and let t = t(n) and s = s(n). We will assume t(n) n and
s(n) log n are fully time and space constructible respectively. We will always have s(n) t(n)
2O(s(n)) .
Recall that a configuration c of machine M on input x consists of the contents of the work
tapes, tape pointers and current state. We will let C be the number of all configurations of M on
input x. Note that a read-only input tape is not considered as part of the configuration and thus
we have C = 2O(s) .
For most of the paper, we will refer to the polynomial-time case, where t(n) = s(n) = nO(1) .
Let cI be the initial configuration of M (x). We can assume without loss of generality that M
has exactly one accepting configuration cA .
Define a C C transition matrix T from the description of the transition function of M . Let
T (ca , cb ) = 1 if one can get from ca to cb in one step and T (ca , cb ) = 0 otherwise.
Observation 2.1 For any two configurations ca and cb , T r (ca , cb ) = 1 if and only if M on input
x in configuration ca when run for r steps will be in configuration cb .
In particular we have that M (x) accepts if and only if T t (cI , cA ) = 1.
Now what happens if we allow M to be a nondeterministic machine. Let us formally describe
how the transition function works for a k-tape machine (along the lines of Hopcroft and Ullman [HU79]).
: Q k Q k {L, R}k+1 {0, 1}
2
Here Q is the set of states, is the input alphabet and the tape alphabet. The transition
function (q, a, b1 , . . . , bk , p, c1 , . . . , ck , d0 , d1 , . . . , dk ) takes the value 1 if the transition from state q
looking at input bit a and work tape bits b1 , b2 , . . ., bk moving to state p, writing c1 , . . ., ck on the
work tapes, moving the input head in the direction d0 and the tape heads in directions d1 , . . ., dk
respectively is legal.
This function yields again a transition matrix T in the obvious way: If it is possible to reach
cb from ca in one step then T (ca , cb ) = 1. If it is not possible to go from ca to cb in one transition
then T (ca , cb ) = 0.
A few notes about the matrix T : Most entries are zero. For polynomial-time computation,
given ca , cb and x one can in polynomial-time compute T (ca , cb ), even though the whole transition
matrix is too big to write down in polynomial-time. Since ca and cb are polynomial in the input
length, the matrix T has finite dimension exponential in the input length.
Observation 2.1 has a simple generalization:
Observation 2.2 For any two configurations ca and cb , T r (ca , cb ) is the number of computation
paths from ca to cb of length r.
We now have that M on input x accepts if and only if T t (cI , cA ) > 0.
We can define #M (x) = T t (cI , cA ) as the number of accepting paths of machine M on input
x. For polynomial-time machines this yields the #P functions first defined by Valiant [Val79].
Now interesting events happen when we allow our function to take on nonbinary values. First
let us consider taking on nonnegative integers. We get a further generalization of Observations 2.1
and 2.2:
Observation 2.3 The value of T r (ca , cb ) is the sum over all computation paths from ca to cb of
the product of the values of over each transition on the path.
What kind of functions do we get from T t (cI , cA ) for polynomial-time machines? We still get
exactly the #P functions. Suppose that we have T (ca , cb ) = k for some ca and cb . We simply
create a new nondeterministic Turing machine that will have k computation paths, of length about
log k, from ca to cb . This will only increase the running time by a constant factor.
Now suppose we allow our function to take on nonnegative rational values. Remember that
the function is a finite object independent of the input. Let v be the least common multiple of
the denominators of all the possible values of the function. Define = v. Let T and T be the
corresponding matrices for and respective. Note T = vT .
The values Tt still capture the #P functions. We also have T t = Tt /v t . Since v t is easily
computable this does not give us much more power than before.
We can use a restricted version of this model to capture probabilistic machines. Probabilistic
machines have
: Q k Q k {L, R}k+1 [0, 1]
with the added restriction that for any fixed values of q, a and b1 , . . . , bk ,
X
(q, a, b1 , . . . , bk , p, c1 , . . . , ck , d0 , d1 , . . . , dk ) = 1.
What does this do to the matrices T ? Every row of T sums up to exactly one and its entries
all range between zero and one, i.e., the matrices are stochastic. Note also that stochastic matrices
preserve the L1 norm, i.e., for every vector u, L1 (u T ) = L1 (u). These observations will be useful
to us as we try to understand quantum computation.
3
Now T t (cI , cA ) computes exactly the probability of acceptance of our probabilistic machine.
Keep in mind that T still is mostly zero and although the matrix T is exponential size, the entries
are easily computable given the indices.
We can define the class BPP: A language L is in BPP if there is a probabilistic matrix T as
described above and a polynomial t such that
For x in L, we have T t (cI , cA ) 2/3.
For x not in L, we have T t (cI , cA ) 1/3.
Using standard repetition tricks to reduce the error we can replace 2/3 and 1/3 above with 12p(|x|)
and 2p(|x|) for any polynomial p.
Let us make some variations to the probabilistic model. First let us allow to take on arbitrary rational values including negative values. Since the value T t may be negative we will use
(T t (cI , cA ))2 as our probability of acceptance. Finally instead of preserving the L1 norm, we
preserve the L2 norm instead. That is for every vector u, we have
L2 (T (u)) = L2 (u) =
s
X
u2a .
Unlike the L1 norm, preserving the L2 norm is a global condition, we cannot just require that the
squares of the values of the function add up to one. Matrices that preserve the L2 norm are called
unitary.
This model looks strange but still rather simple. Yet this model captures exactly the power of
quantum computing!
We can define the class BQP: A language L is in BQP if there is a quantum matrix T and a
polynomial t such that
For x in L, we have (T t (cI , cA ))2 2/3.
For x not in L, we have (T t (cI , cA ))2 1/3.
where a quantum matrix is a unitary matrix of finite dimension exponential in the input length
that arises from a function taking on arbitrary rational values. Bernstein and Vazirani [BV97]
show that this model captures the class BQP.
Questions
For those who have seen quantum computing talks in the past, many questions may come up.
3.1
The presentation of quantum computing above is based mostly on the computation model developed
by Bernstein and Vazirani [BV97]. We have presented the model here as another complexity model.
It does however capture all of the physical power and rules of quantum computation.
Can one study quantum computation without a deep background in quantum mechanics? I say
yes. I drive a car without much of a clue as to what a carburetor does. I can program a classical
computer and do research on the computational complexity of these computers even though I
do not have a real understanding of how a transistor works. I often do research on theoretical
computation models such as nondeterminism that have no physical counterpart at all. Given a
good model of a quantum computer, computer scientists can study its computational abilities
without much knowledge of the physical properties of that model.
4
3.2
When researchers in two disciplines try to work they usually find that language forms a major wall
between them. Not the base spoken language, but the notation and definitions each one assumes
that every first-year graduate student in the field knows and follows. In quantum computing,
generally physics notation has prevailed, leading to one of the major barriers to entering the area.
Physicists generally use the Dirac bra-ket notation to represent base quantum states. When
computer scientists see this notation, it looks quite foreign and many assume that the complexity
of the notation reflects some deep principles in quantum mechanics. Nothing could be further from
the truth as the bra-ket notation represents nothing more than vectors.
The notation |010i is called a ket and represents the string 010. In general |xi with x {0, 1}k
represents the string x. Concatenation is concatenation: |xi|yi = |xyi. The strings of length k
form the basis of a vector space of dimension 2k . These basis vectors roughly correspond to the
configurations described in Section 2.
Now, there is also a bra and various rules that apply when putting bras and kets together
but these rarely come into play in quantum computing. For the interested reader there are many
sources one can read on the subject such as Preskills lecture notes [Pre98].
Why does the simple looking notation cause such confusion for computer scientists? This
notation does not conform to computer science conventions, in particular to that of symmetry.
When we consider vectors or other groupings of objects, computer scientists always use symmetric
brackets such at h8, 3, 4i, [0 . . . 1], (a + b) and |x|. When typical computer scientists look at
a character like i or | that does not have a counterpart, they consider these as relational
operators, making equations like
2
1 X
(1)x,y |xi = |0 i n |yi
|1 (y)i = n
2 x
2
[BBBV97, p. 1514]
(1)
3.3
In short: no. The physics definition allows arbitrary real and complex entries as long as the matrices
are unitary. This by itself limits the values to have absolute value at most one. But one can do
much better.
If we allow all possible reals, BQP can accept arbitrarily complicated languages [ADH97].
However this result feels like cheatingbasically you encode hard languages directly into the entries
5
of the matrix. Thus one requires knowing the language ahead of time to create the machine. A
similar trick can also be played with probabilistic machines using noncomputable probabilities.
For fairness we should only allow efficiently computable matrix entries, where we can compute
the ith bit in time polynomial in i. Independently Adleman, DeMarrais and Huang [ADH97] and
Solovay and Yao [SY96] show that we can simulate a BQP machine using efficiently computable
entries from the set {1, 45 , 35 , 0, 35 , 45 , 1}. Or you can get away with fewer numbers if you dont
mind an irrational: {1, 12 , 0, 12 , 1} (see [Kit97]).
3.4
The matrix T as well as any power of T is unitary, i.e. it preserves the L2 norm. For real valued
matrices, T is unitary if and only if the transpose of T is the inverse of T . The reader should try
the proof himself or it can be found in Bernstein and Vazirani [BV97, p. 1463].
In particular this means that T is invertible. Even more so the inverse of T is itself unitary. If
you have a vector v over the configurations that gives the value for each configuration, let w = T (v).
We then have T 1 (w) = v. Given the current entire state of the system we can reverse it to get
the previous state.
Dont think of reversibility as a requirement of quantum computing, but rather as a consequence.
Nevertheless keep in mind that in creating a quantum algorithm at a minimum you will need to
create a reversible procedure.
3.5
For traditional models of computation we can usually assume that there is only one accepting
configuration. We do this by a cleanup operationafter the machine decides to accept we erase
the work tapes, move the head to the left and enter a specified final accepting state.
This procedure will not work for quantum computation since it is not reversible. Bennett,
Bernstein, Brassard and Vazirani [BBBV97] show an interesting way to get around this problem:
Compute whether the quantum machine accepts. Copy the answer to an extra quantum bit. Then
reverse the whole process. The unique accepting state is now the initial state with this extra bit
turned on.
3.6
Our formulation of BQP does not appear to contain any measurements. In fact we are simulating
a measurement at the end. A BQP machine will output accept with probability equal to the
sum of the squares of the values of the accepting configurations. We have only one accepting
configuration so we need just consider (T t (cI , cA ))2 .
One could consider a process that allows measurements during the computation. Bernstein and
Vazirani [BV97] show that we can push all of the measurements to the end. Basically measurements
are linear projections and we can simulate a measurement by doing a rotation and taking one big
projection at the end.
Full Robustness
Section 3 points to the fact that BQP is quite a robust complexity class. Bernstein and Vazirani [BV97] show that BQP can simulate any deterministic or probabilistic polynomial-time algorithm and Bennett, Brassard, Bernstein and Vazirani [BBBV97] show BQPBQP = BQP. In other
6
words we can do quantum subroutines and build that directly into the quantum computation. The
proofs of these facts are technically quite complicated but here are a few points to think about.
Note that a deterministic computation might not be reversible but Bennett [Ben73] showed how
to simulate any deterministic computation by a reversible computation with only a small increase
in the computation time.
Flipping a truly random coin seems inherently nonreversible: Once flipped how does one recover the previous state? Quantum computing does have one nonreversible operation known as
measurements. One can simulate truly random coin tosses using measurements, or as described in
Section 3.6 simulating a measurement and doing it at the end.
From these results we can use standard error reduction techniques to reduce the error in a
quantum algorithm to 2p(n) where p is a polynomial and n is in the length of the input.
Other complexity classes such as the exact version of BQP (denoted EQP or QP) may not
have some of the nice robust properties of Section 3 since approximating the matrix entries would
no longer keep us in the class.
Space-bounded classes also lack some of the robustness of BQP. For example if we do not allow
a measurement until the end even simulating coin flips becomes difficult: we cannot reuse the coins
and keep reversibility. See Watrous [Wat01] for a discussion.
Once you have the formulation of quantum machines described in Section 2, one immediately gets
interesting results on quantum complexity.
5.1
AWPP
Suppose we remove the unitary restriction in the definition of BQP in Section 2. This yields the
class AWPP. Li [Li93] and Fenner, Fortnow, Kurtz and Li [FFKL93] defined and studied the class
AWPP (stands for Almost-Wide Probabilistic Polynomial-time) extensively. They showed many
interesting results for this class.
1. AWPP PP PSPACE, where PP is the set of languages accepted by a probabilistic
polynomial-time Turing machine where we only require the error probability to be smaller
than one-half.
2. The class AWPP is low for PP, i.e., for any language L in AWPP, PPL = PP.
3. If P = PSPACE then relative to any generic oracle G, PG = AWPPG . This implies that
without any assumption there is a relativized world A such that PA = AWPPA and the
polynomial-time hierarchy is infinite.
4. There exists a relativized world where AWPP does not have complete sets, in fact where
AWPP has no sets hard for all of BPP.
Relativization results show us important limitations on how certain techniques will solve problems
in complexity theory. For a background on relativization see the survey paper by Fortnow [For94].
Fortnow and Rogers [FR99] observed that BQP AWPP basically falls out of the characterization given in Section 2. From this we have several corollaries.
1. BQP PP PSPACE [ADH97]
7
5.2
Decision Trees
The oracle results mentioned in Section 5.1 follow from results on decision tree complexity that
have interest in their own right. Consider the situation where we wish to compute a function from
{0, 1}N to {0, 1} where we can only access an input bit by making a explicit random-access query
to that bit. Here the complexity measure is the number of queries needed to compute the function,
not the running time.
To define this model properly for quantum computation, we need these queries to be made
in a unitary way. Beals, Buhrman, Cleve, Mosca and de Wolf [BBC+ 98] show how to vary the
matrix model of Section 2 to create special linear transformations that describe a unitary query.
One can interleave matrices describing these transformations with the unitary matrices given by
the computation of the Turing machine.
Grover [Gro96] shows how to get a nontrivial
advantage with quantum computers: He shows
that computing the OR function needs only O( N ) queries although classically (N ) input bits
are needed in the worst case.
Bernstein and Vazirani [BV97] exhibit a problem solvable with O(log N ) quantum queries but
requiring (log N log log N ) queries by a probabilistic decision tree. Later Simon [Sim97] gives an
example needing only polylogarithmically many quantum queries but requiring linearly many probabilistic queries. Both of these gaps require that there are particular subsets of the inputs to which
f is restricted.
Beals, Buhrman, Cleve, Mosca and de Wolf [BBC+ 98] notice that the characterization given in
Section 2 shows that any quantum decision tree algorithm making t queries can be expressed as a
polynomial in the queries of degree at most 2t.
Nisan and Szegedy [NS94] show that if a polynomial of degree d on {0, 1}N approximates
the characteristic function of some language L {0, 1}N then L has deterministic decision tree
complexity polynomial in d.
Combining these ideas, if there is a quantum algorithm computing a function f defined on
all of {0, 1}N and using t queries then there exists a deterministic algorithm computing f using
polynomial in t queries.
Often one hears of the various ways that quantum machines have advantages over classical computation, for example, the ability to go into many parallel states and that states can be entangled with
each other. In fact often these properties occur in probabilistic computation as well. The strength
of quantum computing lies in the ability to have bad computation paths eliminate each other thus
causing some good paths to occur with larger probability. The ability for quantum machines to
take advantage of this interference is tempered by their restriction to unitary operations.
Suppose you videotape a football game from the television. Let us say the teams are evenly
matched so that either team has an equal probability of winning. Now make a copy of the tape
8
without watching it. Now these videotapes are in some sense entangled. We dont know who won
the game until we watch it but both outcomes will be the same. I can take a videotape to Mars
and watch it there and at the end I will instantaneously know the outcome of the game on the
other tape.
Entanglement works quite differently for quantum computing. In particular the videotape model
fails to capture quantum entanglementno hidden variable theory can capture the effects of
quantum entanglement (see a discussion in Preskill [Pre98]). Usually entanglement makes it harder
for our quantum algorithms to succeed. We often have to find a way to remove entanglement to
have states properly interfere with each other. See Meyer [Mey01] for a further discussion of the
role of entanglement in quantum computing.
If entanglement does not play an important role in the power of efficient quantum computation,
how about parallelism, the ability of a quantum computer to simultaneously enter exponentially
many states? Here there is really no difference between probabilistic and quantum computation.
Consider the value T t (cI , cA ) expanded as follows:
T t (cI , cA ) =
c1 ,...,ct1
One can think of the vector hc1 , . . . , ct1 i as describing a computation path, the value
T (cI , c1 )T (c1 , c2 ) T (ct2 , ct1 )T (ct1 , cA )
as the value along that path and the final value as the sum of the values over all paths.
Did this view of parallelism depend on whether we considered quantum or probabilistic computation? Not a bit.
Where does the power of quantum come from? From interference. For probabilistic computation
the value
T (cI , c1 )T (c1 , c2 ) T (ct2 , ct1 )T (ct1 , cA )
is always nonnegative. Once a computation path has a positive value it is there to stay. For quantum
computation the value could be negative on some path causing cancellation or interference. This
allows other paths to occur with a higher probability. The restriction of quantum computers to
unitary transformations limits the applications of interference but still we can achieve some useful
power from it.
6.1
Randomness plays two important but quite different roles in the theory of computation. Typically
we use randomness for searching. In this scenario, we have a large search space full of mostly good
solutions. Deterministically we can only look in a relatively small number of places and may miss
the vast majority of good solutions. By using randomness we can, with high probability, find the
good solutions. Typical examples include primality testing [SS77] and searching undirected graphs
in a small amount of space [AKL+ 79].
However these randomness techniques appear to apply to only a small number of problems.
Recent results in derandomization indicate we probably can do as well with deterministically chosen
pseudorandom sequences.
We also use randomness to hide information. A computer, no matter how powerful, cannot
predict the value of a truly random bit it cannot see. Hiding forms the basis of virtually all
cryptographic protocols. Hiding also plays an important role in complexity theory. The surprising
9
strength of interactive proof systems [LFKN92, Sha92, BFL91, ALM+ 98] comes from the inability
of the prover to predict the verifiers future coin tosses.
We have the same dichotomy between searching and hiding in quantum bits. The use of quantum
interference allows us to find some things with certain kinds of structure. Shors algorithms for
factoring and discrete logarithm [Sho97] form the obvious example here.
While we do not expect that there exists any notion of quantum pseudorandom generators, at
the moment we still only have a limited collection of problems where quantum search greatly helps
over classical methods.
Quantum hiding, like its probabilistic counterpart, has a much more powerful effect on computation theory. Not only can no computer predict the value of a quantum bit not yet measured but
the quantum bit cannot be copied and any attempt at early measurement will change the state of
the quantum bit.
Quantum bits do have one disadvantage over probabilistic bits. When we flip a probabilistic
coin the original state has been irrevocably destroyed. The reversibility of quantum computation
prevents destroying quantum state. However, we can get around this problem by using classical
probabilistic bits to determine how to prepare the quantum states. We can always get classical
probabilistic bits by measuring an appropriate quantum state.
Quantum hiding in this manner gives powerful tools for quantum cryptography [BBE92] and
quantum interactive proof systems [Wat99] that go beyond what we believe possible with classical
randomness.
Conclusions
Quantum computation is ripe for complexity theorists. While I have focused this article on the
computational complexity of efficient quantum computing, researchers have studied several other
aspects of quantum complexity such as quantum interactive proof systems [Wat99, KW00] and
quantum versions of NP [FGHP98]. A desire to keep this article short and focused prevents me
from discussing these other directions in detail.
There are still many fundamental questions about BQP remaining to be solved.
Is NP in BQP? While we probably cannot answer that problem directly we might be able to
show some unlikely consequences like the polynomial-time hierarchy collapses.
Does BQP sit in the polynomial-time hierarchy? The only evidence against this comes from
Bernstein-Vazirani [BV97]. In their paper they create a relativized world A and a language L that
sits in EQPA BQPA but not BPPA . We cannot prove that L sits in the polynomial-hierarchy
O(1)
n ) time
relative to A. However the language L does sit in deterministic quasipolynomial (2log
and can be recognized by an alternating Turing machine that uses only polylogarithmic alternations
where these machines have access to A. So while we may find it difficult to show BQP is in the
polynomial-time hierarchy, we might be able to show that every language in BQP is accepted by
some alternating quasipolynomial-time Turing machine using polylogarithmic alternations.
For such results we will need more than the fact than BQP sits in AWPP as described in
Section 5.1. Relative to random oracles NP is in AWPP [TO92] and there exist relativized worlds
where an infinite polynomial-time hierarchy sits strictly inside of AWPP [For99]. Somehow we
will need to make better use of the unitary nature of the quantum transformations.
Shors algorithm shows that quantum machines can defeat many commonly used cryptographic
protocols. Can we create one-way functions that no quantum machine can invert better than
random guessing? Perhaps we will need such functions computed by quantum machines as well.
10
Maybe quantum relates to other classes out there? Is BQP equivalent to the problems having
statistical zero-knowledge proof systems? This seems far-fetched but we have no evidence against
this.
For further reading I recommend that the reader get hold of SIAM Journal on Computing
Volume 26 Number 5 (1997). Half of this issue is devoted to quantum computation and as one can
see from the references it has many of the important papers in the area.
Nielsen and Chuang [NC00] give a comprehensive introduction to the area. Preskills course
notes [Pre98] give a detailed description of quantum computation from the physicists point of view.
Acknowledgments
I wish to thank the organizers of the AQIP 99 conference for inviting me to give the presentation
and inviting me to write this paper based on that presentation for the special issue of the conference.
I have had many exciting discussions on these topics with several top researchers in the field
including Harry Buhrman, Peter Shor, Charlie Bennett, Gilles Brassard and Dorit Aharonov. The
opinions expressed in this paper remain solely my own.
Dieter van Melkebeek and the two anonymous referees gave many useful comments on earlier
drafts of this paper.
References
[ADH97]
[AKL+ 79] R. Aleliunas, R. Karp, R. Lipton, L. Lovasz, and C. Rackoff. Random walks, universal
traversal sequences, and the complexity of maze problems. In Proceedings of the 20th
IEEE Symposium on Foundations of Computer Science, pages 218223. IEEE, New
York, 1979.
[ALM+ 98] S. Arora, C. Lund, R. Motwani, M. Sudan, and M. Szegedy. Proof verification and the
hardness of approximation problems. Journal of the ACM, 45(3):501555, May 1998.
[BBBV97] C. Bennett, E. Bernstein, G. Brassard, and U. Vazirani. Strengths and weaknesses of
quantum computing. SIAM Journal on Computing, 26(5):15101523, 1997.
[BBC+ 98] R. Beals, H. Buhrman, R. Cleve, M. Mosca, and R. de Wolf. Quantum lower bounds by
polynomials. In Proceedings of the 39th IEEE Symposium on Foundations of Computer
Science, pages 352361. IEEE, New York, 1998.
[BBE92]
[BDG88]
[Ben73]
C. Bennett. Logical reversibility of computation. IBM Journal of Research and Development, 17(6):525532, November 1973.
[BFL91]
[BL95]
D. Boneh and R. Lipton. Quantum cryptanalysis of hidden linear functions. In Proceedings of the 15th CRYPTO Conference, volume 963 of Lecture Notes in Computer
Science, pages 424437. Springer, Berlin, 1995.
[BV97]
E. Bernstein and U. Vazirani. Quantum complexity theory. SIAM Journal on Computing, 26(5):14111473, 1997.
[FFKL93] S. Fenner, L. Fortnow, S. Kurtz, and L. Li. An oracle builders toolkit. In Proceedings of
the 8th IEEE Structure in Complexity Theory Conference, pages 120131. IEEE, New
York, 1993.
[FGHP98] S. Fenner, F. Green, S. Homer, and R. Pruim. Determining acceptance possibility for
a quantum computation is hard for PH. Technical Report 98-008, Computer Science
Department, Boston University, 1998.
[For94]
[For99]
[FR99]
[Gro96]
[HU79]
J. Hopcroft and J. Ullman. Introduction to Automata Theory, Languages and Computation. Addison-Wesley, Reading, Mass., 1979.
[Kit97]
A. Kitaev. Quantum computations: Algorithms and error correction. Russian Mathematical Surveys, 52(6), 1997.
[KW00]
A. Kitaev and J. Watrous. Parallelization, amplification, and exponential time simulation of quantum interactive proof systems. In Proceedings of the 32nd ACM Symposium
on the Theory of Computing, pages 608617. ACM, New York, 2000.
[LFKN92] C. Lund, L. Fortnow, H. Karloff, and N. Nisan. Algebraic methods for interactive proof
systems. Journal of the ACM, 39(4):859868, 1992.
[Li93]
L. Li. On the counting functions. PhD thesis, University of Chicago, 1993. Department
of Computer Science TR 93-12.
[Mey01]
[NC00]
M. Nielsen and I. Chuang. Quantum Computation and Quantum Information. Cambridge University Press, Cambridge, United Kingdom, 2000.
[NS94]
[Pre98]
J. Preskill.
Lecture notes for advanced mathematical methods of physics.
http://www.theory.caltech.edu/preskill/ph229/index.html#lecture, 1998.
[Sha92]
[Sho97]
[Sim97]
[SS77]
R. Solovay and V. Strassen. A fast Monte-Carlo test for primality. SIAM Journal on
Computing, 6:8485, 1977. See also erratum 7:118, 1978.
[SY96]
[TO92]
S. Toda and M. Ogiwara. Counting classes are at least as hard as the polynomial-time
hierarchy. SIAM Journal on Computing, 21(2):316328, 1992.
[Val79]
[Wat99]
J. Watrous. PSPACE has constant-round quantum interactive proof systems. In Proceedings of the 40th IEEE Symposium on Foundations of Computer Science, pages 112
119. IEEE, New York, 1999.
[Wat01]
13