How Does A Computer Think?

Computers are, in simple terms, clever ways of manipulating electricity to do maths. At the core of every computer is the processor or CPU (central processing unit), the part that does the actual 'thinking'. Modern processors are incredibly sophisticated and elegant constructions, but the basic principle upon which they are built is relatively straightforward.

Electricity

Computers, like so many other things in the modern world, rely on electricity to do their job. Electricity itself is based on tiny particles called electrons, which flow through wires and carry energy to wherever it is needed. You can imagine that these electrons moving through the wire are like water flowing along a river. When the river branches into different streams, it is analogous to electricity being carried off to different parts of a circuit. If you were to place water mills on each of those streams, the water would drive their wheels and produce work (grinding corn and so forth), just as electricity is used to power electronic components.

Your browser does not support this animation, please try a recent version of Firefox, Safari or Chrome.

Figure 1 - Electrons flowing round a circuit, delivering power to a lightbulb.

For some electronic components, lightbulbs, motors and so on, the most important property of electricity is its ability to do work. A lightbulb, for example, will take the electricity passed to it and use it to produce light (and some waste heat), while a motor will use it to produce motion. A computer processor, however, is more interested in the ability to move electricity around than it is in getting it to do work. By splitting the flow of electricity up into a number of different input channels, and then combining these channels in different ways to produce an output, the processor is able to perform calculations.

Making Things Simple for Computers

The method by which these channels of information are combined is based upon a branch of mathematics called Boolean algebra, which can be used to perform calculations using something called the binary number system. Although this may sound a little complicated, it is actually one of the simpler topics in mathematics. However, we will not get into it here for the sake of keeping things brief. Instead we will simply say that humans think and communicate using complex constructs, such as words and images, whereas computers are very basic, and only understand how to think using electricity. In order for computers to be useful to us, we need a way of representing things like words in a simple format that computers can work with. This format is the binary number system, and everything that a computer does is represented as a series of 1s and 0s.

Human Level Computer Level 01001000101010101 The true delight is in the finding out rather than in the knowing. - Isaac Asimov 01010100 01101000 01100101 00100000...
Figure 2 - Images and words are concepts that humans understand, but they have to be translated into streams of 1s and 0s to allow computers to work with them.

Let's now go back to thinking about electricity in the context of streams and rivers. Whenever you have a stream with water flowing through it, it is said to represent the value 1 in binary. If a stream is blocked, so that no water is able to flow through it, it represents the value 0 in binary. Swap out the idea of a stream for a wire, and the water for electricity, and that is how a computer works. Complicated concepts such as words and images are represented as 1s and 0s, which then directly translate into streams (and sometimes stationary pools) of electricity, which the computer can work with directly.

Thinking with the Transistor

Now, the question that remains is what we mean by "working with" this electricity. How does the computer, specifically the processor, manipulate this information once it has been converted into electronic form? The answer to this lies with one of the most important and transformative inventions of the 20th century: the transistor. This simple electronic component is what makes the modern computer possible, as it allows the processor to control the flow of electricity. Returning once again to our streams analogy, the transistor can be thought of as a sluice gate, called upon to facilitate or prevent the passage of water as needed.

The process by which a computer performs calculations follows from this idea. A series of streams are set up to represent information in binary form, some containing water, some empty. The processor is told what sort of calculation it needs to perform on these input streams, and sets up the sluice gates (transistors) accordingly. The water is then allowed to flow through the system, combining and splitting according to the rules of Boolean algebra. The result is a series of output streams, some of which are full of water (1s), some of which are empty (0s). These contain the result of the calculation in binary form, which can in turn be passed back to the user in human-readable form.

A simple example of this can be given by considering a simple processor set up to perform the job of a calculator. We will use it to add together the numbers 2 and 3. First we will set up the processor, manipulating the transistors (sluice gates) to perform an addition. Then we convert the numbers 2 and 3 to binary form (10 and 11), and place them on the input wires. We allow the processor to run (also known as clocking), and the result is a combination of the inputs to produce a binary 5 (101) on the output wires.

The End

And that's it, the basic principles that form the core of every modern computer. Since the invention of the transistor the pace of development of computer hardware has been astonishing. At this point modern smartphones manage to pack billions of transistors into chips approximately the size of a fingernail, and are capable of performing billions of calculations per second with them. But at their heart, they are simply converting information into 1s and 0s, and manipulating it with electricity.