Upload
lamkhue
View
464
Download
10
Embed Size (px)
Citation preview
CHAPTER – 2
NUMBER SYSTEMS
The Decimal Number System :
We begin our study of the number systems with the familiar decimal
number system. The decimal system contains ten unique symbol 0, 1, 2, 3, 4,
5, 6, 7, 8 and 9. Since counting in decimal involves ten symbols, we say that its
base or radix is ten. There is no symbol for its base, i.e. for ten. It is a
positional weighted system. It means that the value attached to a symbol
depends on its location with respect to the decimal point. In this system, any
number (integer, fraction or mixed) of any magnitude can be represented by
the use of these ten symbols only. Each symbol in the number is called a digit.
The left most digit in any number representation, which has the greatest
positional weight out of all the digits present in the number, is called the most
significant digit (MSD) and the right most digit which has the least positional
weight out of all the digits present in that number, is called the least significant
digit (LSD). The digits on the left side of the decimal point from the integer part
of a decimal number and those on the right side from the fractional part. The
digits to the right of the decimal point have weights which are negative powers
of 10 and the digits to the left of the decimal point have weights which are
positive powers of 10.
The value of a decimal number is the sum of the products of the digits of
that number with their respective column weights. The weight of each column is
10 times greater than the weight of the column to its right.
The first digit to the left of the decimal point has a weight of unity or 100,
the second digit to the left of the decimal point has a weight of 10 or 101, the
third has a weight of 100 or 102, and so on. The first digit to the right of the
decimal point has a weight of 1/1 or 10–1, the second digit to the right has a
weight of 1/100 or 10-2, the third has a weight of 1/1000 or 10-3, and so on.
In general, the value of any mixed decimal number
dn dn-1 dn-2 . . . d1 d0 . d-1 d-2 d-3 . . . d-k
is given by
(dn x 10n) + (dn–1 x 10n–1) + . . . + (d1 x 101) + (d0 x 100) + (d-1 x 10-1) +
(d-2 x 10-2) + . . .
Consider the decimal number 9256.26 using digit 2, 5, 6, 9. This is mixed
number.
Hence,
9256.26 = 9 x 1000 + 2 x 100 + 5 x 10 + 6 x 1 + 2 x (1/10) + 6 x (1/100)
= 9 x 103 + 2 x 102 + 5 x 101 + 6 x 100 + 2 x 10-1 + 6 x 10-2
Consider another number 6592.69, using the same digits 2, 5, 6, 9. Here,
6592.69 = 6 x 103 + 5 x 102 + 9 x 101 + 2 x 100 + 6 x 10-1 + 9 x 10-2
Note the difference in position values of the same digits, when placed in
different positions.
Nine’s and Ten’s Complements
The 9’s complement of a decimal number is obtained by subtracting each
digit of that decimal number from 9. The 10’s complement of a decimal number
is obtained by adding a 1 to its 9’s complement.
To perform decimal subtraction using the 9’s complement method, obtain
the 9’s complement of the subtrahend and add it to the minuend. Call this
number the intermediate result. If there is a carry, it indicates that the answer
is positive. Add the carry to the LSD of this result to get the answer. The carry
is called the end around carry. If there is no carry, it indicates that the answer
is negative and the intermediate result is its 9’s complement. Take the 9’s
complement of this result and place a negative sign in front to get the answer.
Example : 1 Find the 9’s complement of the following decimal numbers.
(a) 3465 (b) 782.54 (c) 4526.075
Solution
(a) 9 9 9 9
- 3 4 6 5
6 5 3 4
(9’s complement of
3465)
(b) 9 9 9 . 9 9
- 7 8 2 . 5 4
2 1 7 . 4 5
(9’s complement
of 782.54)
(c) 9 9 9 9 . 9 9 9
- 4 5 2 6 . 0 7 5
5 4 7 3 . 9 2 4
(9’s complement of 4526.075)
Example : 2 Find 10’s complement of the following decimal numbers.
(a) 4069 (b) 1056.074
Solution
(a) 9 9 9 9
- 4 0 6 9
5 9 3 0 (9’s complement of 4069)
+ 1
5 9 3 1 (10’s complement of 4069)
(b) 9 9 9 9 . 9 9 9
- 1 0 5 6 . 0 7 4
8 9 4 3 . 9 2 5 (9’s complement of 4069)
+ 1
8 9 4 3 . 9 2 5 (10’s complement of 4069)
Example : 3 Subtract the following numbers using the 9’s complement method.
(a) 745.81 – 436.62 (b) 436.62 – 745.81
Solution
(a) 7 4 5 . 8 1
- 4 3 6 . 6 2
3 0 9 . 1 9
7 4 5 . 8 1
+ 5 6 3 . 3 7
3 0 9 . 1 8
+ 1
3 0 9 . 1 9
(9’s complement of 436.62)
(Intermediate result)
(End around carry)
(Answer)
(b) 4 3 6 . 6 2
- 7 4 5 . 8 1
- 3 0 9 . 1 9
4 3 6 . 6 2
+ 2 5 4 . 1 8
6 9 0 . 8 0
(9’s complement of 745.81)
(Intermediate result with no carry)
The 9’s complement of 690.80 is 309.19
Therefore, the answer is – 309.19.
Example 4: Subtract the following numbers using the 10‘s complement method
(a) 2928.54 – 416.73 (b) 416.73 – 2928.54
Solution :
(a) 2 9 2 8 . 5 4
- 0 4 1 6 . 7 3
2 5 1 1 . 8 1
(a) 2 9 2 8 . 5 4
+ 9 5 8 3 . 2 7
2 5 1 1 . 8 1
(10’s complement of 416.73)
(Ignore the carry)
The answer is 2511.81.
The Binary Number System :
The binary number system is a positional weighted system. the base or
radix of this number system is 2. Hence, it has two independent symbols. The
base itself cannot be a symbol. The symbols used are 0 and 1. A binary digit is
called a bit. A binary number consists of a sequence of bits, each of which is
either a 0 or a 1. The binary point separates the integer and fraction parts. Each
digit (bit) carries a weight based on its position relevant to the binary point. The
weight of each bit position is one power of 2 greater than the weight of the
position to its immediate right. The first bit to the left of the binary point has
weight of 20 and the column is called the units column. The second bit to the
left has a weight 21 and it is in the 2’s column. The third bit to the left has a
weight of 22 and it is in the 4’s column, and so on. The first bit to the right of
the binary point has a weight of 2-2 is in the ¼’s column, and so on.
The decimal value of the binary number is the sum of the products of all
its bits multiplied by the weights of their respective positions. In general, a
binary number with an integer part of (n + 1) bits and a fraction part of k bits
can be written as
dn dn-1 dn-2 . . . . d1 d0 . d-1 d-2 d-3 . . . d-k
Its decimal equivalent is
(dn x 2n) + (dn-1 x 2n-1) + . . . + (d1 x 21) + (d0 x 20) + (d-1 x 2-1)
+ (d-2 x 2-2) . . .
In general, the decimal equivalent of the number dndn-1 . . . d1d0.d-1d-2 . . . in
any number system with base b is given by
(dn x bn) + (dn-1 x bn-1) + . . . + (d1 x b1) + (d0 x b0) +
(d-1 x b-1) + (d-2 x b-2) + . . .
The binary number system is used in digital computers because the
switching circuits used in these computers use two-state devices such as
transistors, diodes, etc. A transistor can be OFF or ON, a switch can be OPEN or
CLOSED, a diode can be OFF or ON, etc. These devices have to exist in one of
the two possible states. So, these two states can be represented by the
symbols 0 and 1, respectively.
Counting in Binary :-
Counting in binary is very much similar to decimal counting as shown in
Table. Start counting with 0, the next count is 1. We have now exhausted all
symbols; therefore we put a 1 in the column to left and continue to get 10, 11.
Thus, 11 is the maximum we can count using two bits. So, put a 1 in the next
column to the left and continue counting; we can count 100, 101, 111. The
largest number we can count using three bits is 111. Put a 1 to the left and
continue; we get, 1000, 1001, 1010, 1011, 1100, 1101, 1110, 1111. The
maximum count we can get using four bits is 1111. Continue counting with 5,
6, . . . bi
ts as shown in Table.
Table Counting in binary
Decimal number Binary number Decimal number Binary number
0
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
0
1
10
11
100
101
110
111
1000
1001
1010
1011
1100
1101
1110
1111
10000
10001
10010
10011
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
10100
10101
10110
10111
11000
11001
11010
11011
11100
11101
11110
11111
100000
100001
100010
100011
100100
100101
100110
100111
An easy way to remember to write a binary sequence of n bits is :
The right most column is the binary number begins with a 0 and
alternates between 0 and 1
The second column begins with 2 (=21) zeros and alternates between the
groups of 0 0 and 1 1
The third column begins with 4(= 22) zeros and alternates between the
groups of 0 0 0 0 and 1 1 1 1.
The nth column begins with 2n-1 zeros and alternates between the groups
of 2n-1 zeros and 2n-1 ones.
Binary to Decimal Conversion
Binary numbers may be converted to their decimal equivalents by the
positional weights method. In this method, each binary digit of the number is
multiplied by its position weight and the product terms and added to obtain the
decimal number.
Example – 5 Convert 101012 to decimal
Solution :
(Positional weights) 24 23 22 21 20
(Binary number) 1 0 1 0 1 = (1 x 24) + (0 x 23) + (1 x 22) + (0 x 21) + (1 x 20)
= 16 + 0 + 4 + 0 + 1
= 2110
Example – 6 Convert 11011.1012 to decimal
Solution :
24 23 22 21 20 2-1 2-2 2-3
1 1 0 1 1 1 0 1 = (1 x 24) + (1 x 23) + (0 x 22) + (1 x 21) +
(1 x 2-1) + (1 x 2-2) + (1 x 2-3)
= 16 + 8 + 0 + 2 + 1 + 0.5 + 0 + 0.125
= 27.62510
Example : 7 Convert 10010112 to decimal.
Solution :
An integer binary number can also be converted to an integer decimal
number as follows. Starting with the extreme left bit, i.e. MSB, multiply this bit
by 2 and add the product to the next bit to the right.
Multiply the result obtained in the previous step by 2 and add the product
to the next bit to the right.
Continue this process as shown below till all the bits in the number are
exhausted.
1 0 0 1 0 1 1
1 x 2 + 0 = 2
2 x 2 + 0 = 4
4 x 2 + 1 = 9
9 x 2 + 0 = 18
18 x 2 + 1 = 37
37 x 2 + 1 = 75
The above steps can be written down as follows :
Copy down the extreme left bit, i.e. MSB = 1
Multiply by 2, add the next bit (1 x 2) + 0 = 2
Multiply by 2, add the next bit (2 x 2) + 0 = 4
Multiply by 2, add the next bit (4 x 2) + 1 = 9
Multiply by 2, add the next bit (9 x 2) + 0 = 18
Multiply by 2, add the next bit (18 x 2) + 1 = 37
Multiply by 2, add the next bit (37 x 2) + 1 = 75
Total result is, 1 0 0 1 0 1 12 = 7510
Decimal to Binary Conversion :
There are two methods to convert a decimal number to a binary number.
These are the reverse processes of the two methods used to convert a binary
number to a decimal number.
First method :- In this method is normally used only for small numbers, the
values of various powers of 2 need to be remembered. For conversion of large
numbers, we should have a table of powers of 2. In this method, known as the
sum-of weights method, the set of binary weight values whose sum is equal to
the decimal number is determined. To convert a given decimal integer number
to binary, first obtain the largest decimal number which is a power of 2 not
exceeding the given decimal number and record it. Subtract this number from
the given number and obtain the remainder. Once again obtain the largest
decimal number which is a power of 2 not exceeding this remainder and record
it. Subtract this number from the remainder to obtain the net remainder.
Repeat the above process on the successive remainders till you get a 0
remainder. The sum of these power of 2 expressed in binary is the binary
equivalent of the original decimal number. In a similar manner, this sum of
weights method can also be applied to convert decimal fractions to binary. To
convert a decimal mixed number to binary, convert the integer and fractions to
binary. To convert a decimal mixed number to binary, convert the integer and
fraction parts separately into binary. In general, the sum-of-weights method
can be used to convert a decimal number to a number in any other base
system.
Second method : In this method, the decimal integer number is converted to
binary integer number by successive division by 2, and the decimal fraction is
converted to binary fraction by successive multiplication by 2. This is also
known as double-dabble method. In the successive division by 2 method, the
give decimal integer number is successively divided by 2 till the quotient is
zero. The last remainder is the MSB. The remainders read from bottom to top
give the equivalent binary integer number. In the successive multiplication by-2
method, the given decimal fraction and the subsequent decimal fractions are
successively multiplied by 2, till the fraction part of the product is 0 or till the
desired accuracy is obtained. The first integer obtained is the MSB. Thus, the
integers and read from top to bottom give the equivalent binary fraction. To
convert a mixed number to binary, convert the integer and fraction parts
separately to binary and then combine them.
In general, these methods can be used for converting a decimal number
to an equivalent number in any other base system by just replacing 2 by the
base b of that number system. That is, any decimal number can be converted
to an equivalent number in any other base system by the sum-of-weights
method, or by the double-dabble method – repeated division-by-b for integers
and multiplication – by – b for fractions.
Example 8 : Convert 163.87510 to binary.
Solution :
The given decimal number is a mixed number. We, therefore, convert its
integer and fraction parts separately.
The integer part is 16310
The largest number, which is a power of 2, not exceeding 163 is 128.
128 = 27 = 100000002
The remainder is 163 – 128 = 35
The largest number, which a power of 2, not exceeding 35 is 32.
32 = 27 = 1000002
The remainder is 35 – 32 = 3
The largest number, which a power of 2, not exceeding 3 is 2
2 = 21 = 102
The remainder is 3 – 2 = 1
1 – 20 = 12
Therefore, 16310 = 100000002 + 1000002 + 102 + 12 = 101000112
The fraction part of 0.87510
The largest fraction, which is a power of 2, not exceeding 0.875 is 0.5
0.5 = 2-1 = 0.1002
The remainder is 0.875 – 0.5 = 0.375
The largest fraction, which is a power of 2, not exceeding 0.375 is 0.25
0.25 = 2-2 = 0.012
The remainder is 0.375 – 0.25 = 0.125
The largest fraction, which a power of 2, not exceeding 0.125 is 0.125 itself
Therefore, 087510 = 0.1002 + 0.012 + 0.0012 = 0.1112
The final result is, 163.87510 = 10100011.1112
Example – 9 Convert 5210 to binary using the double-dabble method
We divide the given decimal number successively by 2 and read the remainders
upwards to get the equivalent binary number.
Successive division Remainder
2 52
2 26 0
2 13 0
2 6 1
2 3 1
2 1 1
0 1
Reading the remainder from bottom to top, the result is 5210 = 1101002
Example – 10 Convert 0.7510 to binary using the double-dabble method
Solution
Multiply the given fraction by 2. Keep the integer in the product as it is
and multiply the new fraction in the product by 2. Continue this process and
read the integers in the products from top to bottom.
Given Fraction 0.75
Multiply 0.75 by 2
Multiply 0.50 by 2
1.50
1.00
Reading the integers from top to bottom 0.7510 = 0.112
Example – 11 Covert 105.1510 to binary.
Solution
Conversion of integer 105.
Successive division Remainder
2 105
2 52 1
2 26 0
2 13 0
2 6 1
2 3 0
1 1
0 1
Reading the reminders from bottom to top, 10510 = 11010012
Conversion of fraction 0.1510
Given Fraction 0.15
Multiply 0.15 by 2
Multiply 0.30 by 2
Multiply 0.60 by 2
Multiply 0.20 by 2
Multiply 0.40 by 2
Multiply 0.80 by 2
0.30
| 0.60
| 1.20
0.40
0.80
1.60
This particular fraction can never be expressed exactly in binary. This
process may be terminated after a few steps.
Reading the integers from top to bottom, 0.1510 = 0.0010012
Therefore, the final result is, 105.1510 = 1101001.0010012
Binary Addition :
The rules for binary addition are the following:
0 + 0 = 0; 0 + 1 = 1; 1 + 0 = 1; 1 + 1 = 10 i.e. 0 with a carry of 1
Example – 12 Add the binary numbers 1010 and 1111
Solution
16 8 4 2 1 (Column number)
1 0 1 0
+ 1 1 1
1 0 0 0 1
In the 1’s column 0 + 1 = 1
In the 2’s column 1 + 1 = 0 with a carry of 1 to the 4’s column
In the 4’s column 0 + 1 + 1 = 0 with a carry of 1 to the 8’s column
In the 8’s column 1 + 1 = 0 with a carry of 1 to the 16’s column
Example – 13 Add the binary numbers 1101.101 and 111.011
Solution
8 4 2 1 . 2-1 2-2 2-3 (Column number)
1 1 0 1 . 1 0 1
+ 1 1 1 . 0 1 1
1 0 1 0 1 . 0 0 0
In the 2–3,s column 1 + 1 = 0, with a carry of 1 to the 2-2 column
In the 2–2,s column 0+ 1 + 1 = 0, with a carry of 1 to the 2-1 column
In the 2–1,s column 1+ 0 + 1 = 0, with a carry of 1 to the 1’s column
In the 1’s column 1+ 1 + 1 = 1, with a carry of 1 to the 2’s column
In the 2’s column 0+ 1 + 1 = 0, with a carry of 1 to the 4’s column
In the 4’s column 1+ 1 + 1 = 1, with a carry of 1 to the 8’s column
In the 8’s column 1 + 1 = 0, with a carry of 1 to the 16’s column
Binary Subtraction :
The binary subtraction is performed in a manner similar to that in decimal
subtraction. The rules for binary subtraction are :
0 – 0 = 0; 1 – 1 = 0; 1 – 0 = 1; 0 – 1 = 1, with a borrow of 1.
Example 14 Subtract 102 from 10002
Solution :
In the 1’s column 0 – 0 = 0
In the 2’s column, a 1 cannot be subtracted from 0; so, a 1 must be
borrowed from the 4’s column. But the 4’s column also has a 0; so, a 1 must be
borrowed from the 8’s column, making the 8’s column 0. the 1 borrowed from
the 8’s column becomes 10 in the 4’s column. Keep one 1 in the 4’s column and
bring the remaining 1 to the 2’s column. This becomes 10 in the 2’s column, so
10 – 1 = 1 in the 2’s column.
In the 4’s column 1 – 0 = 1 8 4 2 1 (Column number)
In the 8’s column 0 – 0 = 0 1 0 0 0
- 1 0
Hence, the result is 01102. 0 1 1 0
Example – 15 Subtract 111.1112 from 1010.012
Solution :
8 4 2 1 2-1 2-2 2-3 (Column number)
1 0 1 0 . 0 1 0
1 1 1 . 1 1 1
0 0 1 0 . 0 1 1
In the 2-3 column, a 1 cannot be subtracted from a 0. So, borrow a 1 from
the 2–2 column making the 2-2 column 0. The 1 borrowed from the 2-2 column
becomes 10 in the 2-3 column. Therefore, in the 2-3 column 10 – 1 = 1.
In the 2-2 column, as 1 cannot be subtracted from a 0. So, borrow a 1
from the 2-1 column, but it is also a 0. So, borrow a 1 from the 1’s column. That
is also a 0, so borrow a 1 from the 2’s column making the 2’s column 0. this 1
borrowed from the 2’s column becomes 10 in the 1’s column. Keep one 1 in the
1’s column, bring the other 1 to the 2-1 column, which becomes 10 in this
column, keep one in the 2-1 column and bring the other 1 to 2-2 column, which
becomes 10 in this column. Therefore,
In the 2-2’s, column 10 – 1 = 1
In the 2-1’s, column 1 – 1 = 0
In the 1’s, column 1 – 1 = 0
Now in the 2’s column, a 1 cannot be subtracted from a 0, so, borrow a 1
from the 4’s column. But the 4’s column has a 0. So, borrow a 1 from the 8’s
column, making the 8’s column 0, and bring it to the 4’s column. It becomes 10
in the 4’s column. Keep one 1 in the 4’s column and bring the second 1 to the
2’s column making it 10 in the 2’s column. Therefore,
In the 2’s column 10 – 1 = 1
In the 4’s column 1 – 1 = 0
In the 8’s column 0 – 0 = 0
Hence, the result is 0010.0112.
Binary Multiplication
There are two method of binary multiplication – the paper method and
the computer method. Both the methods obey the following multiplication rules:
0 x 0 = 0; 1 x 1 = 1; 1 x 0 = 0; 0 x 1 = 0
The paper method is similar to the multiplication of decimal numbers on paper.
Multiply the multiplicand with each bit of the multiplier, and add the
partial products. The partial product is the same as the multiplicand if the
multiplier bit is a 1 and is zero if the multiplier bit is a 0.
Example – 16 Multiply 11012 by 1102
Solution
The LSB of the multiplier is a 0. So, the first partial
product is a 0. The next two bits of the multiplier
are 1s. So, the next two partial products are equal
to the multiplicand itself. The sum of the partial
products gives the answer.
1 1 0 1
x 1 1 0
0 0 0 0
1 1 0 1
1 1 0 1
1 0 0 1 1 1 0
Example – 17 Multiply 1011.1012 by 101.012
Solution :
1 0 1 1 . 1 0 1
x 1 0 1 . 0 1 0
1 0 1 1 1 0 1
0 0 0 0 0 0 0
1 0 1 1 1 0 1
0 0 0 0 0 0 0
1 0 1 1 1 0 1
1 1 1 1 0 1 . 0 0 0 0 1
Computer Method of Multiplication
A computer can add only two numbers at a time with a carry. So, the
paper method cannot be used by the digital computer. Besides, the computer
has only a fixed number of bit be positions available. A p-bit number multiplied
by another p-bit number yields a 2p-bit number. To multiply a p-bit number by
another p-bit multiplicand register and a 2p-bit multiplier/result register are
required. The multiplier is placed in the left p-bits of the multiplier/quotient
(MQ) register and the right p-bits are set to zero. This permits the MQ to be
used as a dual register, which holds the multiplier and the partial (then final)
results. the multiplicand is placed in the M register. The MQ register is then
shifted one bit to the left. If a 1 is shifted out, M is added to the MQ register. If
a 0 is shifted out, a 0 is added to the MQ register. The entire process is
repeated p (the number of bits in the multiplier) times. The result appears in
the MQ register.
Example : 18 Multiply 11002 by 10012 using the computer method
Solution
The computer method of multiplication is performed as shown below
MQ register
Shift MQ left
Add M
1 0 0 1 0 0 0 0
1 0 0 1 0 0 0 0 0
1 1 0 0
(A 1 is shift out. So, add M to MQ)
Partial sum in MQ
Shift MQ left
Add 0
0 0 1 0 1 1 0 0
0 0 1 0 1 1 0 0 0
0 0 0 0
(A 0 is shift out. So, add 0 to MQ)
Partial sum in MQ
Shift MQ left
Add 0
0 1 0 1 1 0 0 0
0 1 0 1 1 0 0 0 0
0 0 0 0
(A 0 is shift out. So, add 0 to MQ)
Partial sum in MQ
Shift MQ left
Add M
1 0 1 1 0 0 0 0
1 0 1 1 0 0 0 0 0
1 1 0 0
(A 1 is shift out. So, add M to MQ)
Final sum in MQ 0 1 1 0 1 1 0 0
Binary Division
Like multiplication, division too can be performed by two method – the
paper method and the computer method. In the paper method, long – division
procedures similar to those in decimal are used.
Example 2.19 : Divide 1011012 by 1102
Solution
Divisor 110 cannot go in 101. So, consider the first 4 bits 1011 of the
dividend. 110 can go in 1011, one time with a remainder of 101. Next, 110 can
go in 1010, one time with a remainder of 100. Next 110 can go in 1001, one
time with a remainder of 11. finally, 110 can go in 110 with a remainder of 0.
1 1 0 ) 1 0 1 1 0 1 ( 1 1 1 . 1
1 1 0
1 0 1 0
1 1 0
1 0 0 1
1 1 0
1 1 0
1 1 0
0 0 0
Therefore, 101101 110 = 111.1
Example 20 Divide 110101.112 by 1012.
Solution :
1 0 1 )1 1 0 1 0 1 . 1 1 ( 1 0 1 0 . 1 1
1 0 1
0 1 1 0
1 0 1
1 1 1
1 0 1
1 0 1
1 0 1
0 0 0
Therefore, 110101.11 101 = 1010.11
Computer Method of Division
The computer method of division involves successive subtraction.
Suppose we divide an eight-bit dividend by a four-bit divisor; the quotient will
be formed in the right-half of the MQ register and the remainder in the left-half.
The dividend is first placed in the MQ register, and the divisor in the D register.
The divisor is then subtracted from the dividend. The result is considered
negative if a borrow is required, and positive if no borrow is required. If the
result is negative, then the quotient will be four or less bits, sufficiently small to
be contained in the right-half of the MQ register.
The MQ register is next shifted left one bit. The bit shifted out, a 0 or a 1
is not lost. It is stored in a carry flag, a single flip – flop, and is used for the
subtraction following the left shift. If the result of subtraction is positive, a 1 is
added to the LSB of the MQ register where the quotient is accumulated if it
negative, the divisor is added to the MQ and MQ is shifted left one bit. This
effectively puts a 0 in this bit of the quotient. The process is continued until the
MQ register has been shifted left four bits (the number of bits in the D register).
The remainder is then in the left-half of the MQ register and the quotient in the
right-half.
Example – 21 Divide 32 by 5 in binary using the computer method.
Solution :
Dividend = 32 = 10000 = 00100000
Divisor = 5 = 101 = 0101
Computer division
MQ
Subtract D
0 0 1 0 0 0 0 0
0 1 0 1
MQ 1 1 0 1 0 0 0 0 (Borrow is required; the result is
negative; division is valid)
Add D 0 1 0 1
MQ
Shift MQ left
Subtract D
0 0 1 0 0 0 0 0
0 0 1 0 0 0 0 0 0
0 1 0 1
(Original number)
MQ
Add D
1 1 1 1 0 0 0 0
0 1 0 1
(Result is negative)
MQ
Shift MQ left
0 1 0 0 0 0 0 0
0 1 0 0 0 0 0 0 0
(A 1 is shift out. So, add M to MQ)
Subtract D 0 1 0 1
MQ 0 0 1 1 0 0 0 0 (Result is positive
Add 1 1
MQ
Shift MQ left
Subtract D
0 0 0 1 0 0 1 1
0 0 0 1 0 0 1 1 0
1 1 0 1
MQ
Add D
1 1 0 1 0 1 1 0
0 1 0 1
(Result is negative)
MQ 0 0 1 0 0 1 1 0 (Final answer)
REPRESENTATION OF SIGNED NUMBERS AND BINARY ARITHMETIC
IN COMPUTERS
So far, we have considered only positive numbers. The representation of
negative numbers is also equally important. There are two ways of representing
signed numbers – sign magnitude form and complement form. There are two
complement forms: 1’s complement form and 2’s complement form.
Most digital computers do subtraction by the 2’s complement method, but
some do it by the 1’s complement method. The advantage of perfoming
subtraction by the complement method is reduction in the hardware. Instead of
having separate digital circuits are needed. That is, subtraction is also
performed by adders only. instead of subtracting one number from the other,
the complement of the subtrahend is added to the minuend.
In sign-magnitude form, an additional bit called the sign bit is placed in
front of the number. If the sign bit is 0, the number is positive. If it is a 1, the
number is negative for example,
0 1 0 1 0 0 1 = + 41
Sign bit Magnitude
1 1 0 1 0 0 1 = - 41
Sign bit Magnitude
Under the signed – magnitude system, a great deal of manipulation is
necessary to add a positive number to a negative number. Thus, though the
signed – magnitude number system is possible, it is impractical.
Representation of Signed Numbers using 2’s (or 1’s) Complement
method
The 2’s (or 1’s) complement system for representing signed numbers
work like this:
1. If the number is positive, the magnitude is represented in its true binary
from and a sign bit 0 is placed in from of the MSB
2. If the number is negative the magnitude is represented in its 2’s (or 1’s)
complement form and a sign bit 1 is placed in front of the MSB.
That is, to represent the numbers in sign 2’s (or 1’s) complement form,
determine the 2’s (or 1’s) complement of the magnitude of the number and
then attach the sign bit.
The 2’s (or 1’s) complement operation on a signed number will change a
positive number to a negative number and vice versa. The conversion of
complement to true binary is the same as the process used to convert binary to
complement. The representation of + 51 and – 51 in both 2’s and 1’s
complement forms is shown below:
0 1 1 0 0 1 1 + 51 (In sign magnitude form)
Sign bit Magnitude (In 2’s Complement form)
(In 1’s Complement form)
1 1 1 0 0 1 1 - 51 (In sign magnitude form)
Sign bit Magnitude
1 0 0 1 1 0 1 - 51 (In 2’s sign magnitude form)
Sign bit Magnitude
1 0 0 1 1 0 0 - 51 (In 1’s sign magnitude form)
Sign bit Magnitude
Example 22 : Each of the following number is signed binary number.
Determine the decimal value in each case, if they are in (i) sign magnitude
from, (ii) 2’s complement form, and (iii) 1’s complement form.
Solution :-
Given number Sign magnitude form 2’s complement form 1’s complement form
0 1 1 0 1
0 1 0 1 1 1
1 0 1 1 1
1 1 0 1 0 1 0
+ 13
+ 23
- 7
- 42
+ 13
+ 23
- 9
- 22
+ 13
+ 23
- 8
- 21
To subtract using the 2’s (or 1’s) complement method, represent both the
subtrahend and the minuend by the same number of bits. Take the 2’s (or 1’s)
complement of the subtrahend including the sign bit. Keep the minuend in its
original form and add the 2’s (or 1’s) complement of the subtrahend to it.
The choice of 0 for positive sign, and 1 for negative sing is not arbitrary.
In fact, this choice makes it possible to add the sign bits in binary addition just
as other bits are added. When the sign bit is a 0, the remaining bits represent
magnitude, and when the sign bit is a 1, the remaining bits represent 2’s or 1’s
complement of the number. The polarity of the signed number can be changed
simply by performing the complement on the complete number.
Special case in 2’s complement representation Whenever a signed nmber
has a 1 in the sign bit and all 0s for the magnitude bits, the decimal equivalent
is – 2*, where n is the number of bits in the magnitude. For example, 1000= -8
and 10000 = - 16.
Characteristics of the 2’s complement numbers. The 2’s complement
numbers have the following properties :
1. There is one unique zero.
2. The 2’s complement of 0 is 0.
3. The left most bit cannot be used to express a quantity. It is a sign bit. If it
is a 1, the number is negative and if it is a 0, the number is positive.
4. For an n-bit word which includes the sign bit, there are 2n-1 – 1 positive
integers, 2n-1 negative integers and one 0, for a total of 2n unique states.
5. Significant information is contained in the 1s of the positive numbers and
0s of the negative numbers.
6. A negative number may be converted into a positive number by finding its
2’s complement.
Method of obtaining the 2’s complement of a number : The 2’s
complement of a number can be obtained in three ways as given below.
1. By obtaining the 1’s complement of the given number (by changing all 0s
to 1s and 1s to 0s) and then adding 1.
2. By subtracting the given n-bit number N from 2*
3. Starting at the LSB, copying down each bit up and including the first 1 bit
encountered, and complementing the remaining bits.
Example 23 Express – 45 in 8 – bit 2’s complement form.
Solution
+ 45 in 8 – bit form is 00101101.
First method
Obtain the 1’s complement of 00101101 and then add 1.
Positive expression of the given number 0 0 1 0 1 1 0 1
1’s complement of it 1 1 0 1 0 0 1 0
Add 1 + 1
Thus, the 2’s complement form of – 45 is 1 1 0 1 0 0 1 1
Second method
Subtract the given number N from 2n
2n = 1 0 0 0 0 0 0 0 0
Subtract 45 = 0 0 1 0 1 1 0 1
Thus, the 2’s complement form of –45 is 1 1 0 1 0 0 1 1
Third method
Copy down the bits starting from LSB upto and including the first 1, and then
complement the remaining bits.
Original number 0 0 1 0 1 1 0 1
Copy up to the first 1 bit 1
Complement the remaining bits 1 1 0 1 0 0 1 .
Thus, the 2’s complement form of –45 is 1 1 0 1 0 0 1 1
Example 24 : Express – 73.75 in 12 – bit 2’s complement form.
Solution
+ 73.75 = N = 01001001.1100
First method
Positive expression of the given number 0 1 0 0 1 0 0 1 . 1 1 0 0
1’s complement of it 1 0 1 1 0 1 1 0 . 0 0 1 1
Add 1 1
Thus, the 2’s complement of –73.75 is 1 0 1 1 0 1 1 0 . 0 1 0 0
Second method
28 = 1 0 0 0 0 0 0 0 0 . 0 0 0 0
Substract 73.75 = - 0 1 0 0 1 0 0 1 . 1 1 0 0
Thus, the 2’s complement of –73.75 is = 1 0 1 1 0 1 1 0 . 0 1 0 0
Third method
Original number 0 1 0 0 1 0 0 1 . 1 1 0 0
Copy up to the first 1 bit 1 0 0
Complement the remaining bits 1 0 1 1 0 1 1 0 . 0 .
Thus, - 73.75 in 2’s complement form is 1 0 1 1 0 1 1 0 . 0 1 0 0
Two’s Complement Arithmetic
The 2’s complement system is used to represent negative numbers using
modulus arithmetic. The word length of a computer is fixed. That means, if a 4-
bit number is added to another 4-bit number, the result will be only of 4 bits.
Carry, if any, from the fourth bit will overflow. This is called the modulus
arithmetic. For example : 1100 + 1111 = 1011.
In the 2’s complement subtraction, add the 2’s complement of the
subtrahend to the minuend. If there is a carry out, ignore it. Look at the sign
bit, i.e. MSB of the sum term. If the MSB is a 0, the result is positive and is in
true binary form. If the MSB is a 1 (whether there is a carry or no carry at all)
the result is negative and is in its 2’s complement form. Take its 2’s
complement to find its magnitude in binary.
Example 25 Subtract 14 from 46 using the 8-bit 2’s complement arithmetic.
Solution
+ 1 4 = 0 0 0 0 1 1 1 0
- 1 4 = 1 1 1 1 0 0 1 0 (In 2’s complement from)
+ 4 6 0 0 1 0 1 1 1 0
- 1 4 + 1 1 1 1 0 0 1 0 (2’s complement form of – 14)
+ 3 2 0 0 1 0 0 0 0 0 (Ignore the carry)
There is a carry, ignore it. The MSB is 0; so, result is positive and is in
normal binary form. Therefore, the result is + 00100000 = +32
Example 26 Add – 75 to +26 using the 8 – bit 2’s complement form
Solution
+ 7 5 = 0 1 0 0 1 0 1 1
- 7 5 = 1 0 1 1 0 1 0 1 (In 2’s complement from)
+ 2 6 0 0 0 1 1 0 1 0
- 7 5 + 1 0 1 1 0 1 0 1 (2’s complement form of – 75)
+ 4 9 1 1 0 0 1 1 1 1 (No carry)
There is no carry, the MSB is a 1. So, the result is negative and is in 2’s
complement form. The magnitude is 2’s complement of 11001111, that is,
00110001 = 49. Therefore, the result is –49
Example 27 Add – 45.75 to + 87.5 using the 12-bit 2’s complement
arithmetic.
Solution :
+ 8 7 . 5 0 1 0 1 0 1 1 1 . 1 0 0 0
- 4 5 . 7 5 + 1 1 0 1 0 0 1 0 . 0 1 0 0 (-45.75 in 2’s complement form)
+ 4 5 . 7 5 0 0 1 0 1 0 0 1 . 1 1 0 0 (Ignore the carry)
There is a carry, ignore it. The MSB is 0; so, the result is positive and is in
normal binary form. Therefore, the is + 41.75
Example 28 Add 27.125 to – 79.625 using the 12-bit 2’s complement
arithmetic.
Solution
+ 2 7 . 1 2 5 0 0 0 1 1 0 1 1 . 0 0 1 0
- 7 9 . 6 2 5 + 1 0 1 1 0 0 0 0 . 0 1 1 0 ( - 79.625 in 2’s
- 5 2 . 5 0 0 1 1 0 0 1 0 1 1 . 1 0 0 0 complement form) (No carry)
The is no carry, indicating that the result is negative and is in its 2’s
complement form. The 2’s complement of 11001011.1000 is 00110100.1000.
Therefore, the result is –52.5
Example 29 Add 47.25 to 55.75 using the 2’s complement method.
Solution
- 9 3 . 1 2 5 1 0 1 0 0 0 1 0 . 1 1 1 0 (-93.25 in 2’s complement form)
- 3 1 . 5 0 0 + 1 1 1 0 0 0 0 0 . 1 1 1 0 (-31.5 in 2’s complement form)
- 1 2 4. 6 2 5 1 0 0 0 0 0 1 1 . 0 1 1 0 (Ignore the carry)
There is a carry, ignore it. The MSB is a 1; so, the result is negative and is
in its 2’s complement form. The 2’s complement of 1000 0011.0110 is 0111
1100.1010. Therefore, the result is – 124.625
Example 30 Add 47.25 to 55.75 using the 2’s complement method.
Solution
4 7 . 2 5 0 0 1 0 1 1 1 1 . 0 1 0 0
5 5 . 7 5 + 0 0 1 1 0 1 1 1 . 1 1 0 0
1 0 3 . 0 0 0 1 1 0 0 1 1 1 . 0 0 0 0 (No entry)
There is no carry, and the MSB is 0. Therefore the result is positive and is in its
true binary form. Hence, it is equal to + 103.0
Example 31 Add +47.25 to -40.75 using the 12 –bit 2’s complement
arithmetic.
Solution
+ 4 0 . 7 5 0 0 1 0 1 0 0 0 . 1 1 0 0
- 4 0 . 7 5 + 1 1 0 1 0 1 1 1 . 0 1 0 0 (-47.75 in 2’s complement form)
0 0 . 0 0 0 0 0 0 0 0 0 0 . 0 0 0 0 (No entry)
There is a carry, ignore it. The result is 0
One’s Complement Arithmetic
The 1’s complement of a number is obtained by simply complementing
each bit of the number, that is, by changing all the 0s to 1s and all the 1s to 0s.
we can also say that the 1’s complement of a number is obtained by subtracting
each bit of the number from 1. This complemented value represents the
negative of the original number. This system is very easy to implement in
hardware by simply feeding all bits thought inverters. One of the difficulties of
using 1’s complement is its representation of zero. Both 00000000 and its 1’s
complement 11111111 represent zero. The 00000000 is called positive zero
and the 11111111 is called negative zero.
Example 32 Represent – 99 and – 77.25 in 8-bit 1’s complement form.
Solution :
We first write the positive representation of the given number in binary
form and then complement each of its bits to represent the negative of the
number.
(a) + 9 9 = 0 1 1 0 0 0 1 1
- 9 9 = 1 0 0 1 1 1 0 0 (In 1’s complement form)
(b) + 7 7 . 2 5 = 0 1 0 0 1 1 0 1 . 0 1 0 0
- 7 7 . 2 5 = 1 0 1 1 0 0 1 0 . 1 0 1 1 (In 1’s complement form)
In 1’s complement subtraction, add the 1’s complement of the subtrahend
to the minuend. If there is a carry out, bring the carry around and add it to the
LSB. This is called the end around carry. Look at the sign bit (MSB); if this is a
0, the result is positive and is in true binary. If the MSB is a 1 (whether there is
a carry or no carry at all), the result is negative and is in its 1’s complement
form. Take its 1’s complement to get the magnitude in binary.
Example 33 : Subtract 14 from 25 using the 8-bit 1’s complement arithmetic.
Solution
+ 2 5 0 0 0 1 1 0 0 1
- 1 4 + 1 1 1 1 0 0 0 1 (In 1’s complement form)
1 1 0 0 0 0 1 0 1 0
+ 1 (Add the end around carry)
0 0 0 0 1 0 1 1 = + 1110
Example 34 Add – 25 to +14 using the 8-bit 1’s complement method.
Solution
+ 1 4 0 0 0 0 1 1 1 0
- 2 5 + 1 1 1 0 0 1 1 0 (In 1’s complement form)
- 1 1 1 1 1 1 0 1 0 0 (No carry)
There is no carry and the MSB is a 1. So, the result is negative and is in its 1’s
complement form. The 1’s complement of 111101000 is 00001011. The result
is, therefore, -1110
Example 35 Add – 25 to – 14 using the 8-bit 1’s complement method.
Solution
+ 2 5 0 0 0 1 1 0 0 1
+ 1 4 + 0 0 0 0 1 1 1 0 (In 1’s complement form)
3 9 0 0 1 0 0 1 1 1
There is no carry. The MSB is a 0. So, the result is positive and is in pure
binary. Therefore, the result is, 00100111 = + 39
Example – 37 Add + 25 to – 25 using the 8-bit 1’s complement method
Solution
+ 2 5 0 0 0 1 1 0 0 1
- 2 5 + 1 1 1 0 0 1 1 0 (In 1’s complement form)
0 0 1 1 1 1 1 1 1 1
There is no carry. The MSB is a 1. So, the result is negative and is in its 1’s
complement form. The 1’s complement of 111111111 is 000000000. therefore,
the result is – 0.
Example–38 Subtract 27.50 from 68.75 using the 12 bit 1’s complement
arithmetic
Solution
+ 6 8 . 7 5 0 1 0 0 0 1 0 0 . 1 1 0 0
- 2 7 . 5 0 + 1 1 1 0 0 1 0 0 . 0 1 1 1 (In 1’s complement form)
4 1 . 2 5 0 0 1 0 1 0 0 1 . 0 0 1 1
+ 1 (Add the end around carry)
0 0 1 0 1 0 0 1 . 0 1 0 0
The MSB is a 0. So, the result is positive and is in its normal binary form.
Therefore, the result is +41.25
Example 39 : Add – 89.75 to +43.25 using the 12-bit 1’s complement method.
Solution
+ 4 3 . 2 5 0 0 1 0 1 0 1 1 . 0 1 0 0
- 8 9 . 7 5 + 1 0 1 0 0 1 1 0 . 0 0 1 1 (In 1’s complement form)
- 4 6 . 5 0 1 1 0 1 0 0 0 1 . 0 1 1 1
There is no carry. The MSB is a 1. So, the result is negative and is in its 1’s
complement form. The 1’s complement of 1101001.0111 is 00101110.1000.
Therefore, the result is – 46.50
Double precision Number :
For any computer the word length is fixed. In a 16-bit computer, that is,
in a computer with 16-bit word length, only numbers from +216-1 – 1 (+32,767)
to – 216-1 (- 32,767) can be expressed in each register. If number grater than
this are to be expressed two storing locations need to be used, that is each
such number has to be stored in two register. This is called double precision.
Leaving the MSB which is the sign bit, this allows a 31-bit number length with
two 16-bit registers. If still larger number are to be expressed, three registers
are used to store each number. This is called triple precision.
Floating Point numbers
In decimal system, very large and very small numbers are expressed in
scientific nation, by stating a number (mantissa) and an exponent of 10.
Example are 6.53 x 10-27 and 1.58 x 1021. Binary numbers can also be
expressed in the same notation by stating a number and an exponent of 2.
However, the format for a computer may be as shown below.
Mantissa Exponent
0110000000 100101
In this machine, the 16-bit word consists of two parts, a 10-bit mantissa and a
6-bit exponent. The mantissa is in 2’s complement form. So, the MSB can be
thought of as the sign bit. The binary point is assumed to be to the right of this
sign bit. The 6 bits of the exponent could represent 0 through 63. However, to
express negative exponents, the number 3210 (1000002) has been added to the
desired exponent.
The actual exponent of the number, therefore, is equal to the exponent
given by the 6 bits minus 32. This is a common system used in floating point
formats. It is called the excess – 32 notation. According to these definitions, the
floating point number shown above is
This mantissa portion = + 0 . 1 1 0 0 0 0 0 0 0
The exponent portion = 1 0 0 1 0 1
The actual exponent = 1 0 0 1 0 1 – 1 0 0 0 0 0 = 0 0 0 1 0 1
The entire number = N = + 0.11002 x 25 = 11002 = 2410
There are many formats of floating point numbers, each computer having
its own. Some use two words for the mantissa, and one for the exponent; other
use one and half words for the mantissa, and a half word for the exponent. On
some machines the programmer can select from several formats, depending on
the accuracy desired. Some use excess-n nation for the exponent, some use 2’s
complement, some even use sign-magnitude for both the mantissa and the
exponent.
The Octal Number System
The octal number system was extensively used by early minicomputers. It
is also a positional weighted system. its base or radix is 8. It has 8 independent
symbols 0, 1, 2, 3, 4, 5, 6, and 7. Since its base 8 = 23, every 3-bit group of
binary can be respected by an octal digit. An octal number is, thus, 1/3rd length
of the corresponding binary number.
Usefulness of the Octal System
The ease with which conversions can be made between octal and binary
makes the octal system more attractive as a shorthand means of expressing
large binary numbers. In computer work, binary numbers with up to 64-bits are
not uncommon. These binary numbers do not always represent a numerical
quantity; they often represent some type of code, which conveys non-numerical
information. In computers, binary numbers might represent (a) the actual
numerical data, (b) the numbers corresponding to a location (address) in
memory, (c) an instruction code, (d) a code expressing alphabetic and other
non-numerical characters, or (e) a group of bits representing the status of
devices internal or external to the computer.
When dealing with large binary numbers of many bits, it is convenient and
more efficient for us to write the numbers in octal rather than binary. However,
the digital circuits and systems work strictly in binary; we use octal only for the
convenience of the operators of the system. Table shows octal counting.
Table – Octal counting
Decimal
number
Octal
number
Decimal
number
Octal
number
Decimal
number
Octal
number
Decimal
number
Octal
number
0
1
2
3
4
5
6
7
8
9
0
1
2
3
4
5
6
7
10
11
10
11
12
13
14
15
16
17
18
19
12
13
14
15
16
17
20
21
22
23
20
21
22
23
24
25
26
27
28
29
24
25
26
27
30
31
32
33
34
35
30
31
32
33
34
35
36
37
38
39
36
37
40
41
42
43
44
45
46
47
Octal to Binary Conversion
To convert a given octal number to a binary, just replace each octal digit by tis
3-bit binary equivalent.
Example 40 Convert 367.528 to binary.
Solution
Given octal number is 3 6 7 . 5 2
Convert each octal digit to binary 011 110 111 . 101 010
011110111 . 1010102
Binary to Octal Conversion
To convert a binary number to an octal number, starting from the binary
point make groups of 3 bits each, on either side of the binary point, and replace
each 3-bit binary group by the equivalent octal digit.
Example 41 Convert 110101.1010102 to octal.
Group of three bits are 110 101 . 101 010
Convert each group to octal 6 5 . 5 2
The result is 65 . 528
Example 42 Convert 01101111001.01112 to octal.
Solution
Group of three bits are 10 101 111 011 . 011 1
= 010 101 111 011 . 011 100
Convert each group into octal 2 5 7 1 . 3 4
The result is 2571 . 348
Octal to Decimal Conversion
To convert an octal number to a decimal number, multiply each digit in
the octal number by the weight of its position and add all the product terms.
The decimal value of the octal number dndn-1dn-2 . . . d1d0 . d-1d-2 . . . d-k
is (dn x 8n) + (dn-1 x 8n-1) + . . . + (d1 x 81) + (d0 x 80) + (d-1 x 8-1) + (d-2 x 8-2)
+ . . .
Example 43 : Convert 4057.068 to decimal.
Solution
4057.068 = 4 x 83 + 0 x 82 + 5 x 81 + 7 x 80 + 0 x 8-1 + 6 x 8-2
= 2048 + 0 + 40 + 7 + 0 + 0.0937
= 2095.093710
Decimal to Octal Conversion
To convert a mixed decimal number to a mixed octal number, convert the
integer and fraction parts separately.
To convert the given decimal integer number to octal, successively divide
the given number by 8 till the quotient is 0. The last remainder is the MSD. The
remainders read upwards given the equivalent octal integer number.
To convert the given decimal fraction to octal, successively multiply the
decimal fraction by 8 till the product is 0 or till the required accuracy is
obtained. The first integer from the top is the MSD. The integers to the left of
the octal point read downwards give the octal fraction.
Example 44 : Convert 378.9310 octal
Conversion of 37810 octal
Successive division Remainders
8 378 2
8 47 | 7
8 5 | 5
0 0
Read the remainders from bottom to top. Therefore, 37810 = 5728
Conversion of 0.9310 to octal
0.93 x 8 | 7.44
0.44 x 8 | 3.52
0.52 x 8 4.16
0.16 x 8 1.28
Read the integers to the left of the octal point downwards.
Therefore, 0.9310 = 7.73418. Hence 378.9310 = 572.73418
Conversion of large decimal numbers to binary and large binary numbers
to decimal can be conveniently and quickly performed via octal as shown below.
Example 45 : Convert 549710 to binary.
Solution
Since the given decimal number is large, we first convert this number to
octal and then convert the octal number to binary.
Successive division Remainders
8 5497 8 687 1 8 85 | 7 8 10 | 5 8 1 | 2 0 1
Therefore, 549710 = 125718 = 0010101011110012
Example 46 : Convert 1011110100012 to decimal.
Solution
Since the given binary number is large, we first convert this number to octal
and then convert he octal number to decimal.
1011110100012 = 57218 = 5 x 83 + 7 x 82 + 2 x 81 + 1 x 80
= 2560 + 448 + 16 + 1
= 302510
Octal Addition
The octal addition is performed by the decimal method. Add the digits in
each column in decimal and convert this sum into octal. Record the octal sum
term in that column and carry the term to the next column.
Example 47 : Add 327.548 to 665.378
Solution
83 82 81 80 8-1 8-2 In the 8-2’s column, 4 + 7 = 1110 = 138 (Sum3, Carry 1)
3 2 7 . 5 4 In the 8-1’s column,5 + 3 + 1 = 910 = 118 (Sum3, Carry 1)
+ 6 6 5 . 3 7 In the 80’s column,7 + 5 + 1 = 1310 = 158 (Sum5, Carry 1)
1 2 1 5 . 1 3 In the 81’s column,2 + 6 + 1 = 910 = 118 (Sum1, Carry 1)
In the 8’s column ,3 + 6 + 1 = 1010 = 128 (Sum1, Carry 1)
Octal subtraction
The octal subtraction is similar to decimal subtraction
Example 48 : Subtract 16.478 from 20.148.
Solution
81 80 8-1 8-2
2 0 . 1 4
- 1 6 . 4 7
0 1 . 4 5
In the 8-2’s column, 7 cannot be subtracted from 4. So, borrow a 1 from
the 8-1’s column leaving a 0 there. A 1 borrowed from the 81’s column become 8
in the 8-2’s column. So, in the 8-2’s column 8 + 4 – 7 = 5
In the 8-1’s column, 4 cannot be subtracted from 0. So, borrow a 1 from
the 80’s column has a 0. So, borrow a 1 from the 81’s column leaving a 1 there.
The 1 borrowed from the 81’s column becomes 8 in 80’s column. Leave 7 there
and bring 1 to the 8-1’s column. This becomes 8 in this column.
So, in the column 8–1 8 – 4 = 4
in the column 80 7 – 6 = 1
in the column 81 1 – 1 = 0
The result is 01.458
Subtraction of octal numbers can also be accomplished by the 7’s and 8’s
complement methods similar to 1’s and 2’s complement methods of an octal
number is obtained by subtracting each digit of the number from 7 and its 8’s
complement is obtained by adding a 1 to its 7’s complement.
Example 49 : Find the 7’s and 8’s complement of the following octal numbers.
(a) 4015 (b) 2057.106
Solution
To find the 7’s complement of an octal number, subtract each digit of the
number from 7.
(a) 7 7 7 7
- 4 0 1 5
3 7 6 2 (7’s complement of 4015)
1 (Add 1)
3 7 6 3 (8’s complement of 4015)
(b) 7 7 7 7 . 7 7 7
- 2 0 5 7 . 1 0 6
5 7 2 0 . 6 7 1 (7’s complement of 2057.106)
1 (Add 1)
5 7 2 0 . 6 7 2 (8’s complement of 2057.106)
Example 50 : Subtract 236.438 from 5427.658 using the 7’s complement
arithmetic.
Solution
5 4 2 7 . 6 5 5 4 2 7 . 6 5
- 2 3 6 . 4 3 + 7 5 4 1 . 3 4 (7’s complement of 0236.43)
+ 5 1 7 1 . 2 2 5 1 7 1 . 2 1
+ 1 (End around carry)
5 1 7 1 . 2 2
The carry indicates that the answer is positive and is in octal itself. Hence, the
result is + 5171.228
Example 51 : Subtract 5427.658 from 236.438 using the 8’s complement
method.
Solution
2 3 6 . 4 3 0 2 3 6 . 4 3
5 4 2 7 . 6 5 + 2 3 5 0 . 1 3 (8’s complement of 5427.65)
- 5 1 7 1 . 2 2 2 6 0 6 . 5 6
No carry indicates that the result is negative and is in 8’s complement
form. The 8’s complement of 2606.568 is 5171.228. Hence, the result is –
5171.228.
Octal Multiplication
To perform multiplication in octal, multiply the digits in decimal, convert
the product to octal, record the sum term, and carry the carry term to the next
column. Add all partial products.
Example 52 : Multiply 2763.58 by 68.
Solution
2 7 6 3 . 5 5 x 6 = 3010 = 368 (Sum 6, Carry 3)
x 6 3 x 6 = 1810 = 228; 228 + 38 = 258 (Sum 5, Carry 2)
2 1 6 6 5 . 6 6 x 6 = 3610 = 448; 448 + 28 = 468 (Sum 6, Carry 4)
7 x 6 = 4210 = 528; 528 + 48 = 568 (Sum 6, Carry 5)
2 x 6 = 1210 = 148; 148 + 58 = 218 (Sum 1, Carry 2)
Octal Division
The octal division is accomplished by the decimal method.
Example 53 Divide 4570.328 by 68
Solution
6)4570.32(624.042
44
17 6 cannot go in 4. So, consider 458
14 6 cannot go in 458 (3710) 6 times with a remainder of 1
30 6 cannot go in 178 (1510) 2 times with a remainder of 3
30 6 cannot go in 308 (2410) 4 times with a remainder of 0
032 6 cannot go in 038 (0310) 0 times with a remainder of 3 so, consider 032
30 6 cannot go in 328 (2610) 4 times with a remainder of 2
20 6 cannot go in 208 (1610) 2 times with a remainder of 4
14 The quotient is 624.0428 and the remainder is 48.
4
The Hexadecimal number system
Binary numbers are long. These numbers are fine for machines but are
too lengthy to be handled by human beings. So, there is a need to represent
the binary numbers concisely. One number system developed with this
objective is the hexadecimal number system (or Hex). Although it is somewhat
more difficult to interpret than the octal number system, it has become the
most popular of direct data entry and retrieval in digital systems. The
hexadecimal number system is a positional – weighted system. The base or
radix of this number system is 16, that means, it has 16 independent symbols.
The symbols used are 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, and F. Since its
base is 16 = 24, every 4 binary digit combination can be represented by one
hexadecimal digit. So, a hexadecimal number, yet it provides the same
information as the binary number. A 4-bit group is called a nibble. Since
computer words come in 8 bits, 16 bits, 32 bits and so on, that is, multiples of 4
bits, they can be easily represented in hexadecimal. The hexadecimal system is
particularly useful for human communications will computers. By far, this is the
most commonly used number system in computer literature. It is used both in
large and small computers.
Hexadecimal counting sequence :
0 1 2 3 4 5 6 7 8 9 A B C D E F
10 11 12 13 14 15 16 17 18 19 1A 1B 1C 1D 1E 1F
. . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . .
F0 F1 F2 F3 F4 F5 F6 F7 F8 F9 FA FB FC FD FE FF
100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115
. . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . .
1F0 1F1 1F2 1F3 1F4 1F5 1F6 1F7 1F8 1F9 1FA 1FB 1FC 1FD 1FE 1FF
Binary to Hexadecimal conversion
To convert a binary number to a hexadecimal number, starting from the
binary point, make groups of 4 bits each, on either side of the binary point and
replace each 4-bit group by the equivalent hexadecimal digit as shown in Table.
Table 2.3 Binary to hexadecimal conversion
Hexadecimal Binary Hexadecimal Binary
0
1
2
3
4
5
6
7
0 0 0 0
0 0 0 1
0 0 1 0
0 0 1 1
0 1 0 0
0 1 0 1
0 1 1 0
0 1 1 0
8
9
A
B
C
D
E
F
1 0 0 0
1 0 0 1
1 0 0 1
1 0 1 1
1 1 0 0
1 1 0 1
1 1 1 0
1 1 1 1
Example 54 Convert 10110110112 to hexadecimal.
Solution
Make groups of 4 bits, and replace each 4-bit group by a hex digit.
Given binary number is 1011011011
Groups of four bits are 0010 1101 1011
Convert each group to hex 2 D B
The result 2DB16
Example 55 : Convert 01011111011.0111112 to hexadecimal.
Solution
Given binary number is 01011111011.011111
Groups of four bits are 0010 1111 1011 . 0111 1100
Convert each group to hex 2 F B . 7 C
The result is 2FB.7C16
Hexadecimal to Binary
To convert a hexadecimal number to binary, replace each hex digit by its
4-bit binary group.
Example 56 : Convert 4BAC16 to binary.
Solution
Given hex number is 4 B A C
Convert each hex digit to 4-bit binary 0100 1011 1010 1100
There result is 01001011101011002
Example 57 Convert 3A9E.B0D16 to binary.
Solution
Given hex number is 3 A 9 E B 0 D
Convert each hex digit to 4-bit binary 0011 1010 1001 1100 1011 0000 1101
The result is 0011101010011110.1011000011012
Hexadecimal to Decimal
To convert a hexadecimal number to decimal, multiply each digit in the
hex number by its position weight and add all those product terms.
If the hex number is dndn-1 . . . d1d0 . d-1d-2 . . . d-k, its decimal equivalent
is (dn x 16n) + (dn-1 x 16n-1) + . . . + (D1 x 161) + (d0 x 160) + (d-1 x 16-1) +
(d-2 x 16-2) + . . .
Example 58 : Convert 5C7 by to decimal.
Solution
Multiply each digit of 5C7 by its position weight and add the product terms.
5C716 = (5 X 162) + (12 X 161) + (7 X 160)
= 1280 + 192 + 7
= 147910
Example 59 Convert A0F9.0EB16 to decimal
Solution
A0F9.0EB16 = (10 x 163) + (0 x 162) + (15 x 161) + (9 x 160) + (0 x 16-1) +
(14 x 16-2) + (11 x 16-3)
= 40960 + 0 + 240 + 9 + 0 + 0.0546 + 0.0026
= 41209.057210
Decimal to Hexadecimal
To convert a decimal integer number to hexadecimal, successively divide
the given decimal number by 16 till the quotient is zero. The last remainder is
the MSB. The remainders read from bottom to top give the equivalent
hexadecimal integer.
To convert a decimal fraction to hexadecimal, successively multiply the
given decimal fraction by 16, till the product is zero or till the required accuracy
is obtain, and collect all the integers to the left of decimal point. The first
integer is the MSB and the integers read from top to bottom give the
hexadecimal fraction. This is known as the hex dabble method.
Example 60 : Convert 2598.67510 to hex
Solution
The given decimal number is a mixed number. Convert the integer and
the fraction parts separately to hex.
Conversion of 259810
Successive division
Successive division Remainder
Decimal Hex
16 2598
16 162 6 6
16 10 2 | 2
16 0 10 | A
Reading the remainders upwards, 259810 = A2616
Conversion of 0.67510
Given fraction is 0.675
0.675 x 16
0.800 x 16
0.800 x 16
0.800 x 16
| 10.8
| 12.8
| 12.8
12.8
Reading the integers to the left of hexadecimal point downwards, 0.67510 =
0.ACCC16 Therefore, 2598.67510 = A26.ACCC16
Conversion of very large decimal numbers to binary and very large binary
numbers to decimal is very much simplified if it is done via the hex route.
Example 61 Convert 4905610 to binary
Solution
The given decimal number is very large. It is tedious to convert this
number to binary directly. So, convert this to hex first, and then convert the
hex to binary.
Successive division Remainder Decimal Hex Binary group
16 2598 0 0 0 0 0 0 16 162 10 | A 1 0 1 0 16 10 15 | F 1 1 1 1
0 11 | B 1 0 1 1
Therefore, 4905610 = BFA016 = 10111111101000002.
Example 2.62 : Convert 10110111011011102 to decimal.
Solution
The given binary number is very large. So, perform the binary to decimal
conversion via the hex route.
1011 0111 0110 11102 = B 7 6 E16
B76E16 = (11 X 163)+ (7 X 162) + (6 + 161) + (14 X 160)
= 45056 + 1792 + 96 + 14
= 4695810
Octal To Hexadecimal Conversion
To convert an octal number to hexadecimal, the simplest way is to first
convert to binary and then the binary to hexadecimal.
Example 63 Convert 756.6038 to hex
Solution
Given octal number is
Convert each octal digit to binary
Group of four bits are
7
111
0001
5
101
1110
6
110
1110
. 6
. 110
. 1100
0
000
0001
3
011
1000
Convert each four-bit group to hex 1 E E C 1 8
The result is 1EE . C1816
Hexadecimal to Octal :
To convert a hexadecimal number to octal, the simple way is to first
convert the given hexadecimal number to binary and then the binary number to
octal.
Example 64 Convert B9F.AE16 to octal.
Solution
Given hex number is
Convert each hex digit to binary
Group of four bits are
B
1011
101
9
1001
110 011
F
1111
111
.
.
.
A
1010
101
E
1110
011 100
Convert each three-bit group to octal 5 6 3 7 . 5 3 4
The result is 5637 . 5348
Hexadecimal Addition :
Addition in hexadecimal is performed in a manner similar to that in
decimal. To add in hex, all the digitals in each column along with the carry if
any, are added in decimal and its hex equivalent obtained. The sum term in hex
is recorded in that column, and the carry term is carried to the next column.
Example 65 : Add 2A7C.30D16 and 8D9.E8B16
Solution
163 162 161 160 16-1 16-2 16-3
2 A 7 C . 3 0 D
+ 8 D 9 . E 8 B
3 3 5 6 . 1 9 8
Starting from the LSD
D + B = 1310 + 1110 = 2410 = 1816 (sum 8, carry 1)
0 + 8 + 1 = 910 = 916 (sum 9, carry 0)
3 + E = 310 + 1410 = 1710 = 1116 (sum 1, carry 1)
C + 9 + 1 = 1210 + 910 + 110 = 2210 = 1610 (sum 6, carry 1)
7 + D + 1 = 710 + 1310 + 110 = 2110 = 1516 (sum 5, carry 1)
A + 8 + 1 = 1010 + 810 + 110 = 1910 = 1310 (sum 3, carry 1)
2 + 1 = 310 = 316 (sum 3, carry 0)
The result is 3356.19816
Example 66 Add 3BCA.507816 + 9EBD3.97F316 + 5FB.E2C16
Solution
3 B C A . 5 0 7 8
+ 9 E B D . 9 7 F 3
5 F B . E 2 C
E 0 8 3 . C B 2 B
Starting from the LSD
8 + 3 = 1110 = B16 (sum B, carry 0)
7 + F + C = 710 + 1510 + 1210 = 3410 = 2216 (sum 2, carry 2)
0 + 7 + 2 + 2 = 1110 = B16 (sum B, carry 0)
5 + 9 + E = 510 + 910 + 1410 = 2810 = 1c16 (sum C, carry 1)
A + D + B + 1 = 1010 + 1310 + 1110 + 110 = 3510 = 2316 (sum 3, carry 2)
C + B + F + 2 = 1210 + 1110 + 1510 + 210 = 4010 = 2816 (sum 8, carry 2)
B + E + 5 + 2 = 1110 + 1410 + 510 + 210 = 3210 = 2016 (sum 0, carry 2)
3 + 9 + 2 = 1410 = E16
Hexadecimal Subtraction
Subtraction in hexadecimal is similar to that in decimal.
Example 67 : Subtract 78D6.3B16 from B08E.A116.
Solution :
The hex subtraction is performed as explained below.
163 162 161 160 16-1 16-2
B 0 8 E . A 1
- 7 8 D 6 . 3 B
3 7 B 8 . 6 6
In the 16-2’s column, B cannot be subtracted from 1. So, borrow a 1 from
the 16-1’s column leaving 9 there; the 1 borrowed from the 16-1’s column
becomes 16-2’s column. So,
In the 16-2’s column, 16 + 1 – b = 1610 + 110 – 1110 = 6
In the 16-1’s column, 9 – 3 = 6
In the 160’s column, E – 6 = 1610 – 610 = 8
In the 161’s column D cannot be subtracted from 8. So, borrow a 1 from
the 162’s column. But there is a 0 in the column, so, borrow a 1 from the 163’s
column leaving A there. The 1 borrowed from the 163’s column becomes 16 in
the 162’s column, leave 15 there and bring 1 to the 161’s column. It becomes
16 in that column.
In the 161’s Column, 16 + 8 – D = 2410 – 1310 = 1110 = B
In the 162’s column, 15 – D = 7
In the 163’s column, A – 7 = 1010 – 710 = 3
The result is 37B8.6616.
Subtraction in hexadecimal can also be accomplished by 15’s and 16’s
complement methods, similar to 1’s and 2’s complement methods of binary.
The 15’s complement of a hex number is obtained by subtracting each
digit of the number from 15(F) and its 16’s complement is obtained by adding a
1 to its 15’s complement. The 15’s complement of a hex number is the same as
the 1’s complement of the number expressed in binary and its 16’s complement
is the same as th e2’s complement of the number expressed in binary.
Example 68 : Find the 15’s and 16’s complements of the following hexadecimal
numbers.
(a) 76 (b) 4A9 (c) 7BA (d) F20.3AE
Solution :
(a) F F
- 7 6
8 9 (15’s complement of 76)
1 (add 1)
8 A (16’s complement of 76)
(b) F F F
- 4 A P
B 5 6 (15’s complement of 4A9)
1 (Add 1)
B 5 7 (16’s complement of 4A9)
(c) F F . F
- 7 B . A
8 4 . 5 (15’s complement of 7B.A)
1 (Add 1)
8 4 . 6 (16’s complement of 7B.A)
(d) F F F . F F F
- F 2 0 . 3 A E
0 D F . C 5 1 (15’s complement of F20.3AE)
1 (Add 1)
0 D F . C 5 2 (16’s complement of F20.3AE)
Example 69 : Subtract 4AB.6B10 from 5074.5616 using the 15’s complement
method.
Solution :
5 0 7 4 . 5 6 5 0 7 4 . 5 6
- 0 4 A B . 6 B + F B 5 4 . 9 4 (15’s complement of 04AB.6B)
+ 4 B C 8 . E B 4 B C 8 . E A
+ 1 (End around carry)
4 B C 8 . E B
The carry indicates that the result obtained is positive and is in hex itself.
Example 70 : Subtract 507D.5618 from 4AB.6816 using the 16’s complement
method.
Solution
0 4 A B . 6 8 0 4 A B . 6 8
- 5 0 7 D . 5 6 + A F 8 2 . A A (16’s complement of 507D.56)
+ 4 B D 1 . E E B 4 2 E . 1 2 (No carry)
There is no carry, indicating that the result obtained is negative and
therefore in its 16’s complement from. The 16’s complement of B42E.1216 is
4BD1.EE16. There, the final result is – 4BD1.EE16.
Hexadecimal number can also be subtracted using the 1’s or 2’s
complement method, because the 15’s complement of a hex number is the
same as the 1’s complement of the equivalent binary number and the 16’s
complement of a hex number is the same as the 2’s complement of the
equivalent binary number.
Example 71 : Subtract the following hexadecimal numbers using the 1’s
complement arithmetic
(a) 4816 – 2616 b) 4516 – 7416
Solution :
Find the 1’s complement of the subtrahend numbers using the 1’s
complement arithmetic.
(a) 2616 in binary = 0010 0110
2616 in 1’s complement form = 1101 1001 = D916
4616 4 8
- 2616 + D 9 (1’s complement of 2616)
2216 2 1
+ 1 (End around carry)
2 2
The carry indicates that the result obtained is positive and is in hex itself.
(b) 7416 in binary = 0111 0100
7416 in 1’s complement form = 1000 1011 = 8B16
4516 4 5
- 7416 + 8 B (1’s complement of 2616)
- 2F16 D 0 (no carry)
There is no carry. So, the result obtained is negative and is in the 1’s
complement from. The 1’s complement of D016=2F16. So, the final result is –2F16
Example 72 : Subtract (a) 6916 – 4316 and (b) 2716 – 7316 using the 2’s
complement arithmetic.
Solution :
Find the 2’s complement of the subtrahend and add it to the minuend.
(a) 4316 in binary = 0100 0011
4316 in 2’s complement form = 1011 1101 = BD16
6916 6 9
- 4316 + B D (2’s complement of 4316)
2616 2 6 (Ignore carry)
The carry indicates that the result obtained is positive and is in hex itself.
(b) 7316 in binary = 0111 0011
7316 in 2’s complement form = 1000 1101 = 8D16
2716 2 7
- 7316 + 8 D (2’s complement of 7316)
4C16 B 4 (No carry)
No carry indicates that the answer is negative and is in its 2’s
complement from. The 2’s complement of B4 is 4C. Therefore, the final result is
-4C16.
Hexadecimal Multiplication
The hexadecimal multiplication is similar to decimal multiplication. To
perform multiplication in hexadecimal, multiply the digits in decimal and convert
each product term into hex. Record the sum term in hex, and carry the carry
term to the next column.
Example 73 : Multiply 2A816 BY B616.
2 A 8 8 x 6 = 4810 = 3016
x B 6 A x 6 = 10 x 6 = 6010; 6010 + 310 = 6310 = 3F16
F F 0 2 x 6 = 1210; 1210 + 310 = 1510 = F16
1 D 3 8 8 x B = 8 x 11 = 8810 = 5816
1 E 3 7 0 A x B = 10 x 11=11010; 11010 + 510=11510 = 7316
2 X B = 2 X 11 = 2210; 2210 + 710=2910 = 1D16
Hexadecimal Division :
Hexadecimal division is similar to decimal division.
Example 74 : Divide 2C0BE16 by 2A16.
2A)2C0BE(10C7.924
2A 2A(4210) can go in 2C(4410) 1 time, with a remainder of 2.
20B 2A cannot go in 20. 2A(4210) can go in 20B(52310) 1210(C) times,
1F8 with a remainder of 1910(1316)
13E 2A(4210)can go 7 times in 13E(31810),with a remainder of 2410(1816)
126
180 2A(4210)can go 9 times in 18016(31410),with a remainder of 610(616).
17A
60 2A(4210)can go 2 times in 6016(9610),with a remainder of 1210(C16)
54
C0 2A(4210)can go 4 times inC016(19210),with a remainder of 2410(1816)
A8
18
Miscellaneous examples :
Example 75 : Given the 1610 = 100b, find the value of b.
Solution
Given 1610 = 100b,
Convert 100b, to decimal.
Therefore, 16 = 1 x b2 + 0 x b1 + 0 x b0 = b1, or b = 4
Example 76 : Given that 29210 = 1204 in some system, find the base of that
system.
Solution
Let the base be b. Then
29210 = 1204b = 1 x b3 + 2 x b2 + 0 x b1 + 4 x b0
or 29210 = b3 + 2b2 + 4
Since 4 is the largest digit in the given number, b 5, by trial and error, b = 6.
Example 77 : In the following series, the same integer is expressed in different
number systems. Determine the missing number of the series: 10000, 121,
100, ?, 24, 22, 20.
Solution :
If we take the first number to be in binary, its equivalent is 1610. The next
number is 121; it is equal to 1610 in base 3. Similarly 100 is equal to 1610 in
base 4, 24 is equal to 1610 in base 6. So, the missing number is 31 in base 5.
Example 78 : Each of the following arithmetic operations is correct in at least
one number system. Determine the possible base in each operation.
(a) 1234 + 5432 = 666 (b) 41 133
(c) 33 113 (d) 23 + 44 + 14 + 32 = 223
(e) 302 12.120
(f) 41 5
Solution :
(a) 1 2 3 4 + 5 4 3 2
6 6 6 6 It is valid in any number system with base 7 (Since the largest digit used is 6).
(b) Let the base be b. Express both side in decimal.
4 1 3
3b b
or 4b + 1 = 3b or b = 8
Therefore, the above equation is valid in base 8 system
(c) 33 113
Let the base be b. converting to decimal,
3b + 3 = 3(b+1) = 3b + 3.
It is valid for any value of b. Since the largest digit in the number is 3.
The base can be anything greater than 3.
(d) Let the base be b. Expressing in decimal,
2b + 3 + 4b + 4 + b + 4 + 3b + 2 = 2b2 + 2b + 3 Or
b2 – 4b – 5 = 0 or b = 5
The relation is therefore valid in base 5 system.
(e) Let the base be b. Expressing in decimal,
23 2 132
b bb b
Solving for b, we get b = 4.
(f) Let the base be b. Expressing in decimal, 4 1 5b .
Squaring both sides, 4b + 1 = 25 or b = 6
Therefore, the base is 6.