Qubits
A standard computer processor is binary meaning that each transistor can only exist in two states either 1 or 0, on or off.
While a Quantum Computer uses Quantum Bits or Qubits. A qubit can theoretically exist in an infinite number of states due to the 3 dimensional nature of the states.
This means that you can store and process a huge amount of information with only a couple of bits. This is the basic fact about Quantum computers that makes them so efficient.
The highest number you can count to in binary with only 5 digits is 11111-base 2, which when written in decimal is 31. The first 5 powers of 2 starting at 0 are 2⁰=1; 2¹=2; 2²=4; 2³=8; and 2⁴=16. 1+2+4+8+16=31)
In decimal, the highest number you can count to with 5 digits is 99,999. So you see that every digit becomes more powerful the more possible values it can hold.
Now consider that in an electric computer, to perform a digit operation, electricity must flow from a power source, through the circuitry, back to ground. If all your operations can be run in parallel, then it doesn’t make a ton of difference, but if the result of one digit relies on the result of the previous digit (remember how you have to carry a digit in addition if you overflow?) Then the total number of digits has an effect on the total length of time it takes for electricity to flow through the entire circuit and perform the operation. If we can find a way to store the same data in fewer digits, then we can shorten the amount of time it takes to perform these tiered operations.
Since typical electric computers can only distinguish between electricity and no electricity, then binary is the only options. We actually used to have analog computers in the past that could distinguish between 0V, 1V, 2V… And any number of different voltage levels. These computers are orders of magnitude faster than the typical digital computers we’re used to that only do on and off. They’re even making a huge comeback in things like machine learning that are super time-consuming.
The main reason analog computers fell out of fashion once digital came along is because digital computers can be programmed over and over again to do nearly limitless tasks. Analog computers are programmed solely by what components they are made from and how they are wired. Which makes them insanely fast, but for one and only one task. Additionally, the more precision you want with digital computers you can add more digits. Each digit costs the same as the last. And overall, we’re getting cheaper and smaller at an alarming rate. Analog computers either need more sensitive components or higher voltages, both of which can be more expensive, and are more susceptible to damage. And also sensitive components are less resilient to ambient noise, muddying the data.
Quantum computers are the best of both worlds. They are endlessly programmable like digital computers. The number of states is still discrete which helps with noise cancelling and repeatability like digital, but the digits can hold more than one value like analog. They can do more operations in parallel. And primarily, as discussed earlier, they can store more data per digit. Than a binary computer, meaning fewer operations have to be done to get to the same result. By the way, if you want more precision or more data, you can either add more digits, or you can more precisely control the states in the existing digits. Both of the analog and digital options can be used at will.
They aren’t, or they are, but not to all things.
If you took a normal computer and a quantum computer and run normal programs on it, would the normal computer properly be at least as fast.
Quantum computers are only faster for tasks that uses the q-bit functionality.
If you take a labyrinth and asked a normal computer to solve it, would the computer have to test each and every path one at a time. A quantum com computer could test several paths at once, all dependent on the numbers of q-bits.
There are some types of problems where it’s hard to *find* the answer but easy to *check* a possible guess. The classic example is factoring large numbers. If I ask you “find a four-digit number that divides 47,086,973”, the only way to do that is trial and error, guessing and checking four-digit numbers one at a time until you eventually find one that works. However, each individual check–e.g. “check whether 47,086,973 is divisible by 6203”–is easy; the hard part is just that there are a lot of possible four-digit numbers to try.
A quantum computer is designed to work simultaneously in multiple parallel universes. We tell the computer “*randomly* pick a four-digit number and then check whether it divides 47,086,973”. It picks a different random number in different timelines. In most of those timelines the answer is “no”, but in a few the answer is “yes”. If we can arrange to inspect a version of the computer that got a “yes” answer, then from our perspective it will have had a lucky guess on its first try. That’s what makes it faster than a classical computer: a classical computer won’t normally guess right on its first try, but will instead have to take many guesses before it finds one that works.
The tricky part of this–well, one of several tricky parts–is that there can only ever be one version of the computer in our timeline. So it’s very important not to interact with the computer in any way that would be possible if it *hadn’t* found the correct answer. Do not look at the computer, do not touch the computer, do not receive heat from the computer, etc.; do not do anything except receive an “I guessed right!” message from the computer. Non-interaction is hard; currently we can only do it with very small objects for very brief periods of time in very cold rooms, which makes quantum computing impractical; quantum computers are still something we’re *studying* rather than something we’re *using*.
Latest Answers