|Unitards: another consequence |
of quantum computing.
Now, just for the record, quantum computing is not a bad thing; in fact, it's one of the most exciting discoveries of our time. At minimum QCs will help us efficiently solve challenging problems that take forever on today's computers. It's entirely possible, though not guaranteed, that they'll totally revolutionalize the way we compute (see this breathless article). Whichever it is, quantum computers will be a general good.
But not necessarily for cryptographers.
This is because cryptographers don't always want faster algorithms for solving hard problems. It isn't that we thrive on people's frustration; it's that many of our best cryptosystems simply depend on the hardness of problems like integer factorization. By making these problems easy, QCs throw a huge wrench into the works. And this isn't a hypothetical concern: thanks to Shor's algorithm, many of our most beloved cryptosystems are already living on borrowed time.
But all is not lost. We have two very important things working in our favor. The first is time. For all the excitement around quantum computing, nobody's managed to actually build a useful one. And (no matter what D-Wave says) it doesn't look like they will anytime soon.
The second is that quantum computers are not magic. QCs are very good at quickly solving certain problems, but their usefulness is more limited than most people realize. Moreover, we only know of a handful of useful quantum algorithms today. This could change: think how many classical algorithms were discovered after classical computers were built. But it gives us hope.
In the rest of this post I'm going to try to give a flavor of the problem, and point out some of the bright spots -- areas where we feel pretty good. I want to be clear that this isn't my research area, and many of the best ideas in this post come from the excellent book Post-Quantum Cryptography, edited by Bernstein, Buchmann and Dahmen. (A dead-tree copy of the book will run you $90, but you can check out Dan Berstein's fantastic intro right here.)
Quantum vs. Classical
|Quantum computers are only human. (Well, technically,|
they're complicated machines full of super-cooled liquid
nitrogen and helium.)
To bring this back to cryptography, let's say you're trying to brute-force your way through the keyspace of a cryptosystem. In a classical computer this means trying one key at a time, for as many keys as it takes to get a useful result. Parallelization can speed this up, but ultimately just moves the problem sideways -- trading resources for time.
Quantum computers use an entirely different model of computing. The fundamental component of a quantum computer is a quantum bit ('qubit'), a value that can be in two states (1 and 0) at the same time. By entangling n qubits, it's possible to construct a computer that exists in a 'superposition' of 2^n states simultaneously. And this is when things get interesting.
And complicated. Entrangling qubits is one thing (and not necessarily an easy thing). The real trick is finding a way to do computation with a computer that's in more than one state, and -- even more importantly -- to pull a single 'right' answer back into our classical world once the computation is done.
These words obscure a lot of detail; an entire field's worth of detail. What matters for our purposes is that in some cases it seems like quantum algorithms can harness this power to accomplish things much faster than classical algorithms. When this happens, it makes certain problems much easier (i.e., less time-consuming) to solve. But not every problem.
Quantum computers are not magic!
The important thing to know is that quantum computers can't do everything. They can't see the future. They can't even (we believe) solve NP-complete problems in polynomial time. In fact, the general belief among researchers is that the class BQP -- roughly, things that quantum computers can do efficiently -- does not include all of NP (though in fairness, nobody knows for sure).
|Proposed hierarchy of complexity classes|
with a guess for where BQP may fit. (Wikipedia)
Given these facts, you might not all that impressed with quantum computers right now. You'd be wrong.
The man himself
|Dr. Peter Shor|
I can only imagine how he explains this to his neighbors.
Shor's algorithm actually has two components: (1) a classical portion that converts the factoring problem into an order-finding problem. And (2) a quantum portion that solves the latter in polynomial time (with some reasonable error probability). Shor's algorithm can also be used to solve the Discrete Logarithm Problem (DLP) in fields and (with tweaks) elliptic curve groups.
The problem? Almost every practical public-key cryptosystem in use today depends on the hardness of the above problems. That includes RSA and Diffie-Hellman (both used in TLS), Elgamal (used in PGP), DSA and ECDSA (used to sign X.509 certificates, among other things), and even the Rabin cryptosystem (used primarily by Bram Cohen).
These are important algorithms, used today not just to protect short-term data, but also to encrypt data that may be still be important several decades from now. If anyone manages to build a reasonable quantum computer in that time, some people are going to be pretty unhappy.
I should quickly mention that Shor's algorithm is not the only quantum algorithm that cryptographers care about -- it just happens to be the most interesting one. There's also Grover's algorithm, which can be used to improve brute-force attacks on symmetric encryption schemes like AES. But the speedup from Grover's algorithm is 'only' quadratic (it essentially halves the key length), not exponential like Shor's algorithm. We can live with quadratic.
So what can we do about it?
With all the background out of the way, we can finally get to the point of this post. What can cryptographers do to deal with the looming potential of quantum computers? And when should we start doing it? There are a few answers to this question.
Solution #1: Business as usual
This is probably my favorite solution. Don't do anything. Quantum computing is a long way off, and it may never happen at all. Let's just keep doing what we're doing, until we're old enough that someone gives us a pension and we can dump the problem in someone else's lap. Besides, isn't there an asteroid heading towards the Earth?
No, this isn't really a solution at all, but it seems to be the default mentality right now. It probably isn't hurting us -- for the moment.
Solution #2: Don't overreact
While Shor's algorithm is a pretty serious threat to RSA, (EC)DSA and most of the public-key algorithms we use in practice, these aren't the only algorithms that we use. And the good news is that quantum computers probably won't have the same effect on those.
AES, for example, would be affected by Grover's algorithm, but only (in the absolute absurdly worst case), by reducing the effective key size by half. So a 256-bit key would still provide at least the same security margin as today's 128-bit keys. We can probably live with that -- and if not, we can always get bigger keys.
The only hole in this argument is that we have absolutely no idea what specific attacks people will develop against ciphers like AES in the future . Even now -- using only classical algorithms -- researchers have managed to shave a couple of bits off of the AES security margin. Quantum computers may substantially expand our toolbox.
Solution #3: Lattices, lattices, lattices!
In a more abstract setting, lattice 'problems' -- can be used to build a wide variety of cryptosystems. The best known examples include the NTRU scheme (used for encryption and signature) and Craig Gentry's fully-homomorphic encryption scheme. But there are plenty more.
Lattices get a lot of attention these days, in part because you can do neat things with them (fully-homomorphic encryption is a great example). But a more general argument for lattice-based crypto is its resistance to quantum attacks. In contrast to factoring and DLP, there are no quantum algorithms known to run (substantially) faster than classical algorithms against the lattice problems we use to construct modern cryptosystems.
As with all of these claims, the keyword is 'known'. Will we someday find such algorithms? Who knows. But deploying schemes that aren't quantum-broken (yet) certainly feels a lot better than deploying schemes that are.
Solution #4: Fight fire with fire
This type of cryptography is known Quantum Key Distribution. QKD uses quantum-mechanical effects, rather than hard computational problems, to protect messages transmitted over a long distance.
The basic idea is quite simple: anyone who measures the quantum state of a particle must by definition change it (physics students: you're welcome to correct me here!). The exception is entangled particles, which will both measure identically, even if the measurement is conducted at distant points. QKD rigs entangle particles, then transmit one set to a remote party via a long fiber-optic cable. If an attacker taps the cable and measures the particle, his tampering will be detected. If not, both parties can derive a random one-time pad, which they can then use to communicate. Quantum computers can't do anything about this.
Unfortunately the more 'perfect' something sounds, the less you should trust it, especially if it's a research system. This is what QKD researchers discovered last summer, when a team showed how to override the photon detectors in a QKD system with adversarially-generated signals of their own. The result: they were able to completely intercept the key without detection. This can all be fixed, but it goes to show that this is a harder problem than it looks.
More to the point, QKD requires a massive change in the way we distribute data. Today we send our ciphertexts through packet-switched networks, but QKD systems require dedicated fiber-optic connections between each participant. Thus, QKD isn't likely to give us a good replacement for TLS anytime soon.
This has been yet another long post. Before I wrap up I just want to preemptively apologize to all of the physicists and quantum complexity theorists whose work I've mangled along the way.
No matter how terribly I've done this, the basic story is sound: quantum computers are at least theoretically possible, they're quite likely to be practical, and they really will change a lot of things when they arrive. Mostly for the better. But not for the cryptosystems we use today.
If we don't find a way to do something about this, the next few decades are going to be a very interesting time for crypto. For this reason alone, I'm hoping that asteroid isn't coming; I'd really like to see how it all turns out.