Shor's algorithm is a quantum algorithm for finding the prime factors of an integer. It was developed in 1994 by the American mathematician Peter Shor.[1][2] It is one of the few known quantum algorithms with compelling potential applications and strong evidence of superpolynomial speedup compared to best known classical (non-quantum) algorithms.[3] However, beating classical computers will require quantum computers with millions of qubits due to the overhead caused by quantum error correction.[4]
Shor proposed multiple similar algorithms for solving the factoring problem, the discrete logarithm problem, and the period-finding problem. "Shor's algorithm" usually refers to the factoring algorithm, but may refer to any of the three algorithms. The discrete logarithm algorithm and the factoring algorithm are instances of the period-finding algorithm, and all three are instances of the hidden subgroup problem.
On a quantum computer, to factor an integer , Shor's algorithm runs in polynomial time, meaning the time taken is polynomial in
.[5] It takes quantum gates of order
using fast multiplication,[6] or even
using the asymptotically fastest multiplication algorithm currently known due to Harvey and van der Hoeven,[7] thus demonstrating that the integer factorization problem is in complexity class BQP. Shor's algorithm is asymptotically faster than the most scalable classical factoring algorithm, the general number field sieve, which works in sub-exponential time:
.[8]
Feasibility and impact
Assuming a quantum computer with a sufficient number of qubits could operate without succumbing to quantum noise and other quantum-decoherence phenomena, then Shor's algorithm could be used to break public-key cryptography schemes, such as
- The RSA scheme
- The finite-field Diffie–Hellman key exchange
- The elliptic-curve Diffie–Hellman key exchange[9]
RSA can be broken if factoring large integers is computationally feasible. As far as is known, this is not possible using classical (non-quantum) computers; no classical algorithm is known that can factor integers in polynomial time. However, Shor's algorithm shows that factoring integers can be done with a polynomial complexity circuit on an ideal quantum computer. Thus, it might be feasible to defeat RSA by constructing a large enough quantum computer. This was a powerful motivator for the design and construction of quantum computers, and for the study of new quantum-computer algorithms. It has also facilitated research on new cryptosystems that are secure from quantum computers, collectively called post-quantum cryptography (PQC).
Physical implementation
As of 2026, the high error rates of quantum computers and limited number of physical qubits available for quantum error correction, laboratory demonstrations of Shor's algorithm obtain correct results in only in a fraction of attempts, and have only succeeded with small semiprimes.
In 2001, Shor's algorithm was demonstrated by a group at IBM, who factored into
, using an NMR implementation of a quantum computer with seven qubits.[10] After IBM's implementation, two independent groups implemented Shor's algorithm using photonic qubits, emphasizing that multi-qubit entanglement was observed when running Shor's algorithm circuits.[11][12] In 2012, the factorization of
was performed with solid-state qubits.[13] Later, in 2012, the factorization of
was achieved.[14] In 2016, the factorization of
was performed again using trapped-ion qubits.[15] However, none of these demonstrations fulfill the requirements of Shor’s algorithm: they compile the circuit using prior knowledge of the solution, and some have even oversimplified the algorithm in a way that makes it equivalent to coin flipping.[16]
Algorithm
The problem that we are trying to solve is: given an odd composite number , find its integer factors.
To achieve this, Shor's algorithm consists of two parts:
- A classical reduction of the factoring problem to the problem of order-finding. This reduction is similar to that used for other factoring algorithms, such as the quadratic sieve.
- A quantum algorithm to solve the order-finding problem.
Classical reduction
A complete factoring algorithm is possible if we're able to efficiently factor arbitrary into just two integers
and
greater than 1, since if either
or
are not prime, then the factoring algorithm can in turn be run on those until only primes remain.
A basic observation is that, using Euclid's algorithm, we can always compute the GCD between two integers efficiently. In particular, this means we can check efficiently whether is even, in which case 2 is trivially a factor. Let us thus assume that
is odd for the remainder of this discussion. Afterwards, we can use efficient classical algorithms to check whether
is a prime power.[17] For prime powers, efficient classical factorization algorithms exist,[18] hence the rest of the quantum algorithm may assume that
is not a prime power.
If those easy cases do not produce a nontrivial factor of , the algorithm proceeds to handle the remaining case. We pick a random integer
A possible nontrivial divisor of
can be found by computing
, which can be done classically and efficiently using the Euclidean algorithm. If this produces a nontrivial factor (meaning
), the algorithm is finished, and the other nontrivial factor is
. If a nontrivial factor was not identified, then this means that
and the choice of
are coprime, so
is contained in the multiplicative group of integers modulo
, having a multiplicative inverse modulo
. Thus,
has a multiplicative order
modulo
, meaning
and is the smallest positive integer satisfying this congruence.
The quantum subroutine finds . It can be seen from the congruence that
divides
, written
. This can be factored using difference of squares:Since we have factored the expression in this way, the algorithm doesn't work for odd
(because
must be an integer), meaning that the algorithm would have to restart with a new
. Hereafter we can therefore assume that
is even. It cannot be the case that
, since this would imply
, which would contradictorily imply that
would be the order of
, which was already
. At this point, it may or may not be the case that
. If
does not divide
, then this means that we are able to find a nontrivial factor of
. We computeIf
, then
was true, and a nontrivial factor of
cannot be achieved from
, and the algorithm must restart with a new
. Otherwise, we have found a nontrivial factor of
, with the other being
, and the algorithm is finished. For this step, it is also equivalent to compute
; it will produce a nontrivial factor if
is nontrivial, and will not if it's trivial (where
).
The algorithm restated shortly follows: let be odd, and not a prime power. We want to output two nontrivial factors of
.
- Pick a random number
.
- Compute
, the greatest common divisor of
and
.
- If
, then
is a nontrivial factor of
, with the other factor being
, and we are done.
- Otherwise, use the quantum subroutine to find the order
of
.
- If
is odd, then go back to step 1.
- Compute
. If
is nontrivial, the other factor is
, and we're done. Otherwise, go back to step 1.
It has been shown that this will be likely to succeed after a few runs.[2] In practice, a single call to the quantum order-finding subroutine is enough to completely factor with very high probability of success if one uses a more advanced reduction.[19]
Quantum order-finding subroutine
The goal of the quantum subroutine of Shor's algorithm is, given coprime integers and
, to find the order
of
modulo
, the smallest positive integer
such that
. To achieve this, Shor's algorithm uses a quantum circuit involving two registers. The second register uses
qubits, where
is the smallest integer such that
, i.e.,
. The size of the first register determines how accurate of an approximation the circuit produces. It can be shown that using
qubits gives sufficient accuracy to find
. The exact quantum circuit depends on the parameters
and
, which define the problem. The following description of the algorithm uses bra–ket notation to denote quantum states, and
to denote the tensor product.
The algorithm consists of two main steps:
- Use quantum phase estimation with unitary matrix
representing the operation of multiplying by
(modulo
), and input state
(where the second register is
made from
qubits). The eigenvalues of this
encode information about the period, and
can be seen to be writable as a sum of its eigenvectors. Thanks to these properties, the quantum phase estimation stage gives as output a random integer of the form
for random
.
- Use the continued fractions algorithm to extract the period
from the measurement outcomes obtained in the previous stage. This is a procedure to post-process (with a classical computer) the measurement data obtained from measuring the output quantum states, and retrieve the period.
The connection with quantum phase estimation was not discussed in the original formulation of Shor's algorithm,[2] but was later proposed by Alexei Kitaev.[20]
Quantum phase estimation
In general the quantum phase estimation algorithm, for any unitary and eigenstate
such that
, sends input states
to output states close to
, where
is a superposition of integers close to
. In other words, it sends each eigenstate
of
to a state containing information close to the associated eigenvalue. For the purposes of quantum order-finding, we employ this strategy using the unitary defined by the actionThe action of
on states
with
is not crucial to the functioning of the algorithm, but needs to be included to ensure that the overall transformation is a well-defined quantum gate. Implementing the circuit for quantum phase estimation with
requires being able to efficiently implement the gates
. This can be accomplished via modular exponentiation, which is the slowest part of the algorithm.
The gate thus defined satisfies , which immediately implies that its eigenvalues are the
-th roots of unity
. Furthermore, each eigenvalue
has an eigenvector of the form
, and these eigenvectors are such that
where the last identity follows from the geometric series formula, which implies
.
Using quantum phase estimation on an input state would then return the integer
with high probability. More precisely, the quantum phase estimation circuit sends
to
such that the resulting probability distribution
is peaked around
, with
. This probability can be made arbitrarily close to 1 using extra qubits.
Applying the above reasoning to the input , quantum phase estimation thus results in the evolutionMeasuring the first register, we now have a balanced probability
to find each
, each one giving an integer approximation to
, which can be divided by
to get a decimal approximation for
.
Continued-fraction algorithm to retrieve the period
Then, we apply the continued-fraction algorithm to find integers and
, where
gives the best fraction approximation for the approximation measured from the circuit, for
and coprime
and
. The number of qubits in the first register,
, which determines the accuracy of the approximation, guarantees that
given the best approximation from the superposition of
was measured[2] (which can be made arbitrarily likely by using extra bits and truncating the output). However, while
and
are coprime, it may be the case that
and
are not coprime. Because of that,
and
may have lost some factors that were in
and
. This can be remedied by rerunning the quantum order-finding subroutine an arbitrary number of times, to produce a list of fraction approximationswhere
is the number of times the subroutine was run. Each
will have different factors taken out of it because the circuit will (likely) have measured multiple different possible values of
. To recover the actual
value, we can take the least common multiple of each
:The least common multiple will be the order
of the original integer
with high probability. In practice, a single run of the quantum order-finding subroutine is in general enough if more advanced post-processing is used.[21]
Choosing the size of the first register
Phase estimation requires choosing the size of the first register to determine the accuracy of the algorithm, and for the quantum subroutine of Shor's algorithm, qubits is sufficient to guarantee that the optimal bitstring measured from phase estimation (meaning the
where
is the most accurate approximation of the phase from phase estimation) will allow the actual value of
to be recovered.
Each before measurement in Shor's algorithm represents a superposition of integers approximating
. Let
represent the most optimal integer in
. The following theorem guarantees that the continued fractions algorithm will recover
from
:
Theorem—If and
are
bit integers, and
then the continued fractions algorithm run on
will recover both
and
.
[3] As is the optimal bitstring from phase estimation,
is accurate to
by
bits. Thus,which implies that the continued fractions algorithm will recover
and
(or with their greatest common divisor taken out).
The bottleneck
The runtime bottleneck of Shor's algorithm is quantum modular exponentiation, which is by far slower than the quantum Fourier transform and classical pre-/post-processing. There are several approaches to constructing and optimizing circuits for modular exponentiation. The simplest and (currently) most practical approach is to mimic conventional arithmetic circuits with reversible gates, starting with ripple-carry adders. Knowing the base and the modulus of exponentiation facilitates further optimizations.[22][23] Reversible circuits typically use on the order of gates for
qubits. Alternative techniques asymptotically improve gate counts by using quantum Fourier transforms, but are not competitive with fewer than 600 qubits owing to high constants.
Period finding and discrete logarithms
Shor's algorithms for the discrete log and the order finding problems are instances of an algorithm solving the period finding problem. All three are instances of the hidden subgroup problem.
Shor's algorithm for discrete logarithms
Given a group with order
and generator
, suppose we know that
, for some
, and we wish to compute
, which is the discrete logarithm:
. Consider the abelian group
, where each factor corresponds to modular addition of values. Now, consider the function
This gives us an abelian hidden subgroup problem, where corresponds to a group homomorphism. The kernel corresponds to the multiples of
. So, if we can find the kernel, we can find
. A quantum algorithm for solving this problem exists. This algorithm is, like the factor-finding algorithm, due to Peter Shor and both are implemented by creating a superposition through using Hadamard gates, followed by implementing
as a quantum transform, followed finally by a quantum Fourier transform.[3] Due to this, the quantum algorithm for computing the discrete logarithm is also occasionally referred to as "Shor's Algorithm."
The order-finding problem can also be viewed as a hidden subgroup problem.[3] To see this, consider the group of integers under addition, and for a given such that:
, the function
For any finite abelian group , a quantum algorithm exists for solving the hidden subgroup for
in polynomial time.[3]
See also
- GEECM, a factorization algorithm said to be "often much faster than Shor's"[24]
- Grover's algorithm
References
- Shor, P.W. (1994). "Algorithms for quantum computation: Discrete logarithms and factoring". Proceedings 35th Annual Symposium on Foundations of Computer Science. pp. 124–134. doi:10.1109/sfcs.1994.365700. ISBN 978-0-8186-6580-6.
- Shor, Peter W. (October 1997). "Polynomial-Time Algorithms for Prime Factorization and Discrete Logarithms on a Quantum Computer". SIAM Journal on Computing. 26 (5): 1484–1509. arXiv:quant-ph/9508027. doi:10.1137/S0097539795293172. S2CID 2337707.
- Nielsen, Michael A.; Chuang, Isaac L. (9 December 2010). Quantum Computation and Quantum Information (PDF) (7th ed.). Cambridge University Press. ISBN 978-1-107-00217-3. Archived (PDF) from the original on 2019-07-11.
- Gidney, Craig; Ekerå, Martin (2021). "How to factor 2048 bit RSA integers in 8 hours using 20 million noisy qubits". Quantum. 5 433. arXiv:1905.09749. Bibcode:2021Quant...5..433G. doi:10.22331/q-2021-04-15-433. S2CID 162183806.
- See also pseudo-polynomial time.
- Beckman, David; Chari, Amalavoyal N.; Devabhaktuni, Srikrishna; Preskill, John (August 1996). "Efficient networks for quantum factoring". Physical Review A. 54 (2): 1034–1063. arXiv:quant-ph/9602016. Bibcode:1996PhRvA..54.1034B. doi:10.1103/physreva.54.1034. PMID 9913575.
- Harvey, David; van der Hoeven, Joris (March 2021). "Integer multiplication in time O (n log n)" (PDF). Annals of Mathematics. 193 (2). doi:10.4007/annals.2021.193.2.4.
- "Number Field Sieve". wolfram.com.
- Roetteler, Martin; Naehrig, Michael; Svore, Krysta M.; Lauter, Kristin E. (2017). "Quantum resource estimates for computing elliptic curve discrete logarithms". In Takagi, Tsuyoshi; Peyrin, Thomas (eds.). Advances in Cryptology – ASIACRYPT 2017 – 23rd International Conference on the Theory and Applications of Cryptology and Information Security, Hong Kong, China, December 3–7, 2017, Proceedings, Part II. Lecture Notes in Computer Science. Vol. 10625. Springer. pp. 241–270. arXiv:1706.06752. doi:10.1007/978-3-319-70697-9_9. ISBN 978-3-319-70696-2.
- Vandersypen, Lieven M. K.; Steffen, Matthias; Breyta, Gregory; Yannoni, Costantino S.; Sherwood, Mark H.; Chuang, Isaac L. (December 2001). "Experimental realization of Shor's quantum factoring algorithm using nuclear magnetic resonance". Nature. 414 (6866): 883–887. arXiv:quant-ph/0112176. Bibcode:2001Natur.414..883V. doi:10.1038/414883a. PMID 11780055.
- Lu, Chao-Yang; Browne, Daniel E.; Yang, Tao; Pan, Jian-Wei (19 December 2007). "Demonstration of a Compiled Version of Shor's Quantum Factoring Algorithm Using Photonic Qubits". Physical Review Letters. 99 (25) 250504. arXiv:0705.1684. Bibcode:2007PhRvL..99y0504L. doi:10.1103/PhysRevLett.99.250504. PMID 18233508.
- Lanyon, B. P.; Weinhold, T. J.; Langford, N. K.; Barbieri, M.; James, D. F. V.; Gilchrist, A.; White, A. G. (19 December 2007). "Experimental Demonstration of a Compiled Version of Shor's Algorithm with Quantum Entanglement". Physical Review Letters. 99 (25) 250505. arXiv:0705.1398. Bibcode:2007PhRvL..99y0505L. doi:10.1103/PhysRevLett.99.250505. PMID 18233509.
- Lucero, Erik; Barends, Rami; Chen, Yu; Kelly, Julian; Mariantoni, Matteo; Megrant, Anthony; O'Malley, Peter; Sank, Daniel; Vainsencher, Amit; Wenner, James; White, Ted; Yin, Yi; Cleland, Andrew N.; Martinis, John M. (2012). "Computing prime factors with a Josephson phase qubit quantum processor". Nature Physics. 8 (10): 719. arXiv:1202.5707. Bibcode:2012NatPh...8..719L. doi:10.1038/nphys2385. S2CID 44055700.
- Martín-López, Enrique; Laing, Anthony; Lawson, Thomas; Alvarez, Roberto; Zhou, Xiao-Qi; O'Brien, Jeremy L. (12 October 2012). "Experimental realization of Shor's quantum factoring algorithm using qubit recycling". Nature Photonics. 6 (11): 773–776. arXiv:1111.4147. Bibcode:2012NaPho...6..773M. doi:10.1038/nphoton.2012.259. S2CID 46546101.
- Monz, Thomas; Nigg, Daniel; Martinez, Esteban A.; Brandl, Matthias F.; Schindler, Philipp; Rines, Richard; Wang, Shannon X.; Chuang, Isaac L.; Blatt, Rainer (4 March 2016). "Realization of a scalable Shor algorithm". Science. 351 (6277): 1068–1070. arXiv:1507.08852. Bibcode:2016Sci...351.1068M. doi:10.1126/science.aad9480. PMID 26941315. S2CID 17426142.
- Smolin, John A.; Smith, Graeme; Vargo, Alexander (July 2013). "Oversimplifying quantum factoring". Nature. 499 (7457): 163–165. arXiv:1301.7007. Bibcode:2013Natur.499..163S. doi:10.1038/nature12290. PMID 23846653.
- Bernstein, Daniel (1998). "Detecting perfect powers in essentially linear time". Mathematics of Computation. 67 (223): 1253–1283. doi:10.1090/S0025-5718-98-00952-1.
- For example, computing the first
roots of
, e.g., with the Newton method and checking each integer result for primality (AKS primality test).
- Ekerå, Martin (June 2021). "On completely factoring any integer efficiently in a single run of an order-finding algorithm". Quantum Information Processing. 20 (6) 205. arXiv:2007.10044. Bibcode:2021QuIP...20..205E. doi:10.1007/s11128-021-03069-1.
- Kitaev, A. Yu (1995). "Quantum measurements and the Abelian Stabilizer Problem". arXiv:quant-ph/9511026.
- Ekerå, Martin (May 2024). "On the Success Probability of Quantum Order Finding". ACM Transactions on Quantum Computing. 5 (2): 1–40. arXiv:2201.07791. doi:10.1145/3655026.
- Markov, Igor L.; Saeedi, Mehdi (2012). "Constant-Optimized Quantum Circuits for Modular Multiplication and Exponentiation". Quantum Information and Computation. 12 (5–6): 361–394. arXiv:1202.6614. Bibcode:2012arXiv1202.6614M. doi:10.26421/QIC12.5-6-1. S2CID 16595181.
- Markov, Igor L.; Saeedi, Mehdi (2013). "Faster Quantum Number Factoring via Circuit Synthesis". Phys. Rev. A. 87 (1) 012310. arXiv:1301.3210. Bibcode:2013PhRvA..87a2310M. doi:10.1103/PhysRevA.87.012310. S2CID 2246117.
- Bernstein, Daniel J.; Heninger, Nadia; Lou, Paul; Valenta, Luke (2017). "Post-quantum RSA". Post-Quantum Cryptography. Lecture Notes in Computer Science. Vol. 10346. pp. 311–329. doi:10.1007/978-3-319-59879-6_18. ISBN 978-3-319-59878-9.
Further reading
- Nielsen, Michael A.; Chuang, Isaac L. (2010). Quantum Computation and Quantum Information: 10th Anniversary Edition. Cambridge University Press. ISBN 978-1-107-00217-3.
- Kaye, Phillip; Laflamme, Raymond; Mosca, Michele (2006). An Introduction to Quantum Computing. doi:10.1093/oso/9780198570004.001.0001. ISBN 978-0-19-857000-4.
- "Explanation for the man in the street" by Scott Aaronson, "approved" by Peter Shor. (Shor wrote "Great article, Scott! That's the best job of explaining quantum computing to the man on the street that I've seen."). An alternate metaphor for the QFT was presented in one of the comments. Scott Aaronson suggests the following 12 references as further reading (out of "the 10105000 quantum algorithm tutorials that are already on the web."):
- Shor, Peter W. (1997), "Polynomial-Time Algorithms for Prime Factorization and Discrete Logarithms on a Quantum Computer", SIAM J. Comput., 26 (5): 1484–1509, arXiv:quant-ph/9508027v2, Bibcode:1999SIAMR..41..303S, doi:10.1137/S0036144598347011. Revised version of the original paper by Peter Shor ("28 pages, LaTeX. This is an expanded version of a paper that appeared in the Proceedings of the 35th Annual Symposium on Foundations of Computer Science, Santa Fe, New Mexico, November 20--22, 1994. Minor revisions made January, 1996").
- Quantum Computing and Shor's Algorithm, Matthew Hayward's Quantum Algorithms Page, 2005-02-17, imsa.edu, LaTeX2HTML version of the original LaTeX document, also available as PDF or postscript document.
- Quantum Computation and Shor's Factoring Algorithm, Ronald de Wolf, CWI and University of Amsterdam, January 12, 1999, 9 page postscript document.
- Shor's Factoring Algorithm, Notes from Lecture 9 of Berkeley CS 294–2, dated 4 Oct 2004, 7 page postscript document.
- Chapter 6 Quantum Computation Archived 2020-04-30 at the Wayback Machine, 91 page postscript document, Caltech, Preskill, PH229.
- Quantum computation: a tutorial by Samuel L. Braunstein.
- The Quantum States of Shor's Algorithm, by Neal Young, Last modified: Tue May 21 11:47:38 1996.
- III. Breaking RSA Encryption with a Quantum Computer: Shor's Factoring Algorithm, Lecture notes on Quantum computation, Cornell University, Physics 481–681, CS 483; Spring, 2006 by N. David Mermin. Last revised 2006-03-28, 30 page PDF document.
- Lavor, C.; Manssur, L. R. U.; Portugal, R. (2003). "Shor's Algorithm for Factoring Large Integers". arXiv:quant-ph/0303175.
- Lomonaco, Jr (2000). "Shor's Quantum Factoring Algorithm". arXiv:quant-ph/0010034. This paper is a written version of a one-hour lecture given on Peter Shor's quantum factoring algorithm. 22 pages.
- Chapter 20 Quantum Computation, from Computational Complexity: A Modern Approach, Draft of a book: Dated January 2007, Sanjeev Arora and Boaz Barak, Princeton University. Published as Chapter 10 Quantum Computation of Sanjeev Arora, Boaz Barak, "Computational Complexity: A Modern Approach", Cambridge University Press, 2009, ISBN 978-0-521-42426-4
- A Step Toward Quantum Computing: Entangling 10 Billion Particles. Archived 2011-01-20 at the Wayback Machine, from "Discover Magazine", Dated January 19, 2011.
- Josef Gruska - Quantum Computing Challenges also in Mathematics unlimited: 2001 and beyond, Editors Björn Engquist, Wilfried Schmid, Springer, 2001, ISBN 978-3-540-66913-5
External links
- Version 1.0.0 of libquantum: contains a C language implementation of Shor's algorithm with their simulated quantum computer library, but the width variable in shor.c should be set to 1 to improve the runtime complexity.
- PBS Infinite Series created two videos explaining the math behind Shor's algorithm, "How to Break Cryptography" and "Hacking at Quantum Speed with Shor's Algorithm".
- Complete implementation of Shor's algorithm with Classiq