 |
How Computers Add - A Logical Approach |
 |
|
We looked at Number Systems and counting (see It's a Binary
World - How Computers Count) last time. As a quick refresher,
we saw that computers are made up of many units of 0 and 1,
the binary system. 1 is the highest digit possible so numbers
in the computer are stored as for example 1010 or 10 in decimal.
We also saw that these binary numbers can be seen as octal
(8) or hexadecimal (16) numbers - in this case 1010 becomes
15 octal, or A hex.
You probably realise that the 'standard' PC code is in 8
bit bytes taking the hex system a stage further. You may also
know that processors, and Windows software that runs on them,
have progressed from 8 bits to 16 bits to 32 bits to 64 bits.
Basically this means the computer can work on 1,2, 4 or 8
bytes at once. Don't worry if this is all Gobbledegook, you
don't need it to understand how computers add!
OK now to the Math - cringe time! It's a little more complicated
than last time, but if you think logically, like a computer,
realising they are really dumb, you will sail through it!
We take a break here to look at a bit of math you may not
have heard of - Boolean Algebra. Once again it's really simple,
but it shows you how a computer works, and why it is so pedantic!
Boolean Algebra is named after George Boole, an English Mathematician
in the 19th Century. He devised the logic system used in digital
computers more than a century before there was a computer
to use it!
In Boolean Algebra, instead of + and - etc. we use AND and
OR to form our logic steps.
For example:-
x OR y = z means if x or y is present, we get z.
However,
x AND y = z means that both x and y need to be present to
get z.
We can also consider an XOR (eXclusive OR).
x XOR y=z means that x or y BUT NOT BOTH must be present to
get z.
That's it! That's all the math you need to understand how
a computer counts. Told you it was simple!
How do we use this logic in the computer? We make up a little
electronic circuit called a Gate with transistors and things,
so we can work on our binary numbers stored in a register
- just a bit of memory. (And that's the last electronics you'll
hear about!). We make an AND gate, an OR gate, and an XOR
gate
When we add in decimal, for example 9+3 we get 2 'units'
and carry one to the 10s, giving 10+2=12
Remember the binary bit values in Decimal 1,2,4,8 etc? We
start at 0 then 1 in the first bit position, the 1 bit. If
we add 1 + 1 binary we have to end up with 10, which has a
1 bit in the second bit position, and a 0 in the first, giving
Decimal 2+0=2. This second bit position is formed by a CARRY
from the first bit.
To make an adder we must duplicate with a logic circuit the
way we add in binary. To add 1+1 we need 3 inputs, one for
each bit, and a carry in, and 2 outputs, one for the result
(1 or 0), and a carry out, (1 or 0). In this case the carry
input is not used. We use 2 XOR gates, 2 AND gates and an
OR gate to make up the adder for 1 bit.
Now we go another step, and forget about gates, because now
we have a Logic Block, an ADDER. Our computer is designed
by using various combinations of logic blocks. As well as
the adder we might have a multiplier (a series of adders)
and other components.
Our ADDER block takes one bit (0 or 1) from each number to
be added, plus the Carry bit (0 or 1) and produces an output
of 0 or 1, and a carry of 0 or 1. A table of the input A,
B and Carry, and output O and Carry, looks like this:-
With no Carry in:
A B c O C
0 0 0 0 0
1 0 0 1 0
0 1 0 1 0
1 1 0 0 1
With Carry in:
A B c O C
0 0 1 1 0
1 0 1 0 1
0 1 1 0 1
1 1 1 1 1
This is known as a Truth Table, it shows output state for
any given input state.
Let's add 2+3 decimal. That is 010 plus 011 binary. We will
need 3 ADDER blocks for decimal bit values of 1, 2 and 4)
The first ADDER takes the Least Significant Bit (decimal
bit value 1) from each number. Input A will be 0, input B
will be 1 with no carry - 0.
From the truth table this gives an output of 1 and a carry
of 0 (3rd row). BIT 1 RESULT = 1
At the same time the next ADDER (decimal bit value 2) has
inputs of 1, 1 and a carry of 0, giving an output of 0 with
a carry bit of 1 (4th row). BIT 2 RESULT = 0
The next ADDER (decimal bit value 4) has inputs of 0, 0 and
a carry of 1, giving an output of 1 with no carry - 0 (5th
row). BIT 4 RESULT = 1.
So we have bits 4,2,1 as 101 or 4+1=5.
It seems like a laborious way to do it, but our computer
can have 64 adders or more, adding simultaneously two large
numbers billions of times a second. This is where the computer
scores.
Next time we will get to how a computer performs more complcated
operations, and it's simple!
About the Author:
Tony is Webmaster of and a contributer to www.what-why-wisdom.com/
. For diagrams to go with this series of articles check out
"historyofthecomputer.html" on that site.
|
|
|
 |
Relevant Resources |
 |
|
|
|
 |
Need Cisco Hardware for your Cert? |
 |
|
| Call 813.852.6400 now for more information to find the best router or switch to best help you with your certification exam. Having "real" hands-on experience is extremely beneficial not just for testing, but also ensures you are actually familiar with the device you are working on.
|
|
|
|
 |
Cisco Routers |
 |
|
|
|
 |
Cisco Switches |
 |
|
|
|
|