UNIT1- DIGITAL PRINCIPLES
Digital Data
• Data can be of different kinds
• All data is represented using 0’s and 1’s in computer
• Each symbol is represented as a unique combination
of 0’s and 1’s , e.g. 10011011
2
Number System
• the number system is used for representing the
information.
• The number system has different bases and the most
common of them are the decimal, binary, octal, and
hexadecimal.
• The base or radix of the number system is the total
number of the digit used in the number system.
• Suppose if the number system representing the digit
from 0 – 9 then the base of the system is the 10.
3
Number System
• A Number system in base r or radix r uses unique
symbols for r digits
• One or more digits are combined to get a number
– Base: Valid digits used to make number
– Position: Starts from right side of number. Rightmost
digit - position 0, next on left - position 1, so on
• Digits of number have two kinds of values
– Face value: Digit located at that position. E.g. in 52,
face value at position 0 is 2, at position 1 is 5
– Position value: (baseposition). E.g. in 52, position value
of 2 is 100, 5 is 101
• Number: Sum of face value * baseposition of each digit. E.g.
for 52, 5*101 + 2*100 = 50 + 2 = 52 4
Number System
• Computers normally use four number systems
• Computer understands only Binary number system
• Binary data is represented internally as octal and
hexadecimal numbers for to ease of use
• Number in a base is written as (number)base of number
– E.g. (23)10 means 23 is decimal number, (345)8 shows
345 is octal number
5
6
Decimal Number System
• Consists of 10 digits – 0, 1, 2, 3, 4, 5, 6, 7,
8, 9
• All numbers represented as combination
of digits 0-9. E.g. 34, 5965, 867321
7
Binary Number System
• Consists of two digits – 0 and 1
• All numbers formed using combination of 0
and 1. E.g.1001, 11000011, 10110101
8
Octal Number System
• Consists of eight digits – 0 to 7
• All numbers represented using these eight
digits. E.g. 273, 103, 2375
9
Hexadecimal Number System
• Consists of sixteen digits – 0 to 9, A, B, C, D, E,
F, where (A -10, B - 11, C -12, D-13, E-14, F-15)
• All numbers represented using these sixteen
digits. E.g. 3FA, 87B, 113
10
Conversion of Decimal Integer
• Decimal integer can be converted to any other
base, using division operation
• To convert decimal integer to
Binary: divide by 2
Octal: divide by 8
Hexadecimal: divide by 16
11
Convert 23 from Base 10 to Base 2, 8, 16
12
Conversion of Binary to Octal &
Hexadecimal
• Uses shortcut method.
– Octal - combination of 3 bits (23 = 8).
– Hexadecimal - combination of 4 bits (24=16)
• Steps for Binary to Octal conversion
– Partition binary number in groups of 3 bits, starting from right
side
– For each group of three bits, find octal number
– Result: Combination of octal numbers
• Steps for Binary to Hexadecimal conversion
– Partition binary number in groups of 4 bits, starting from right
side
– For each group of four bits, find hexadecimal number
– Result: Combination of hexadecimal numbers
13
Example: Conversion of Binary to Octal
• Given binary number 1110101100110
• Partition binary number in groups of 3 bits, starting from right
side
• For each group find its octal number
• Octal number is 16546
14
Conversion from Octal, Hexadecimal to Binary
• Uses inverse of steps for conversion of binary
to octal and hexadecimal
• Octal to Binary conversion
Convert octal number into 3 digit binary number
Result: Combination of all bits
• Hexadecimal to Binary conversion
Convert hexadecimal number into 4 digit binary
number
Result: Combination of all bits
15
Example: Conversion from Hexadecimal to
Binary
• Given number is 2BA3
• Convert each hexadecimal digit into 4 digit
binary number
• Combine all bits to get result
0010101110100011
16
How to convert octal to hexadecimal ?
• 1. Convert the octal number into binary and then convert the
binary into hexadecimal.
• 2. Convert the octal number into decimal and then convert the
decimal into hexadecimal.
• Octal Binary Hexadecimal
Let's convert (56)8 into hexadecimal
17
Step 1 : Convert (56)8 into Binary
• In order to convert the octal number into binary, we need to
express every octal value using 3 binary bits.
– Binary equivalent of 5 is (101)2.
= (56)8
– Binary equivalent of 6 is (110)2. = (101)(110)
= (101110)2
Step 2 : Convert (101110)2 into Hexadecimal
In order to convert the binary number into hexadecimal, we need
to group every 4 binary bits and calculate the value[From left to
right].
(101110)2 in hexadecimal = (101110)2
= (10)(1110)
= (2)(14)
= (2e)16
18
Octal Decimal Hexadecimal
• Step 1 : Convert (56)8 into Decimal
= 5*81+6*80
= 40+6
= (46)10
Step 2 : Convert (46)10 into hexadecimal
16|46 ---- 16|2 - 14
= (2e)16
19
20
21
1’s complement and 2’s
complement
• Complements are used in digital
computers in order to simply the
subtraction operation and for the logical
manipulations.
• For the Binary number (base-2) system,
there are two types of complements: 1’s
complement and 2’s complement.
22
1’s Complement of a Binary Number
• There is a simple algorithm to convert a binary
number into 1’s complement. To get 1’s complement
of a binary number, simply invert the given number.
2’s Complement of a Binary Number
• There is a simple algorithm to convert a binary
number into 2’s complement. To get 2’s complement
of a binary number, simply invert the given number
and add 1 to the least significant bit (LSB) of given
result.
23
• Examples:
1's complement of "0111" is "1000"
1's complement of "1100" is "0011"
2’s complement of a binary number is 1, added to the 1’s complement of the binary
number.
Examples:
2's complement of "0111" is "1001" 2's complement of "1100" is
"0100"
24
Use of 1's complement
• 1's complement plays an important role in representing the signed
binary numbers.
• The main use of 1's complement is to represent a signed binary
number.
• Apart from this, it is also used to perform various arithmetic
operations such as addition and subtraction.
• In signed binary number representation, we can represent both
positive and negative numbers.
• For representing the positive numbers, there is nothing to do. But
for representing negative numbers, we have to use 1's complement
technique.
• For representing the negative number, we first have to represent it
with a positive sign, and then we find the 1's complement of it.
25
Example 1
26
Addition and Subtraction using 1's
complement
• To perform the arithmetic operations such as addition and
subtraction using 1's complement.
• There are three different cases possible when we add two
binary numbers which are as follows:
❖ Addition of the positive number with a negative number when the
positive number has a greater magnitude.
❖ Adding a positive value with a negative value in case the negative
number has a higher magnitude.
❖ Addition of two negative numbers
27
Addition of the positive number with a negative number
when the positive number has a greater magnitude
• Initially, calculate the 1's complement of the given negative number.
Sum up with the given positive number. If we get the end-around
carry 1, it gets added to the LSB.
28
Adding a positive value with a negative value in case the
negative number has a higher magnitude.
• Initially, calculate the 1's complement of the negative value. Sum it
with a positive number. In this case, we did not get the end-around
carry.
• So, take the 1's complement of the result to get the final result.
29
Addition of two negative numbers
• In this case, first find the 1's complement of both the negative numbers, and then
we add both these complement numbers.
• In this case, we always get the end-around carry, which get added to the LSB,
and for getting the final result, we take the 1's complement of the result.
30
Subtraction using 1's complement
• These are the following steps to subtract two binary numbers using 1's
complement
• Step-1: find the 1's complement of the subtrahend
• Step-2: add the complement number with the minuend
• Step-3: If got a carry, add the carry to its LSB. Else take 1's complement of the
result which will be negative
31
Example 2: 10101 - 10111
• We take 1's complement of subtrahend
10111, which comes out 01000. Now, add
both of the numbers. So,
• 10101+01000 =11101.
• In the above result, we didn't get the carry bit.
So calculate the 1's complement of the result,
i.e., 00010, which is the negative number and
the final answer.
32
Addition and Subtraction using 2's
complement
• There are three different cases possible when we add two
binary numbers using 2's complement, which is as
follows:
❖ Addition of the positive number with a negative number when the
positive number has a greater magnitude.
❖ Adding of the positive value with a negative value when the
negative number has a higher magnitude.
❖ Addition of two negative numbers
33
Addition of the positive number with a negative number
when the positive number has a greater magnitude
• Initially find the 2's complement of the given negative number. Sum
up with the given positive number. If we get the end-around carry 1
then the number will be a positive number and the carry bit will be
discarded and remaining bits are the final result.
34
Adding of the positive value with a negative value when the
negative number has a higher magnitude.
• Initially, add a positive value with the 2's complement value of the
negative number. Here, no end-around carry is found.
• So, we take the 2's complement of the result to get the final result.
35
Addition of two negative numbers
• first, find the 2's complement of both the negative numbers, and then we will add
both these complement numbers. In this case, we will always get the end-around
carry, which will be added to the LSB, and forgetting the final result, we will take
the2's complement of the result.
36
Subtraction using 2's complement
• These are the following steps to subtract two binary numbers using 1's
complement
• Step-1: find the 2's complement of the subtrahend
• Step-2: add the complement number with the minuend
• Step-3: f we get the carry by adding both the numbers, then we discard this carry
and the result is positive else take 2's complement of the result which will be
negative.
Example 1: 10101 - 00111
We take 2's complement of subtrahend 00111, which is 11001. Now, sum them. So,
10101+11001 =1 01110.
In the above result, we get the carry bit 1. So we discard this carry bit and remaining
is the final result and a positive number.
Example 2: 10101 – 10111
We take 2's complement of subtrahend 10111, which comes out 01001. Now, we add
both of the numbers. So,
10101+01001 =11110.
In the above result, we didn't get the carry bit. So calculate the 2's complement of the
result, i.e., 00010. It is the negative number and the final answer.
37
Differences between 1’s complement and 2’s complement
38
9's Complement
• The 9's complement is used to find the subtraction of the
decimal numbers.
• The 9's complement of a number is calculated by subtracting
each digit of the number by 9.
• For example, suppose we have a number 1423, and we want to
find the 9's complement of the number.
• For this, we subtract each digit of the number
1423 by 9.
• So, the 9's complement of the number 1423 is
– 9999-1423= 8576.
39
40
10's Complement
• The 10's complement is also used to find the subtraction of the
decimal numbers.
• The 10's complement of a number is calculated by subtracting
each digit by 9 and then adding 1 to the result.
• Simply, by adding 1 to its 9's complement we can get its 10's
complement value.
• For example, suppose we have a number 1423, and we want to
find the 10's complement of the number.
• For this, we find the 9's complement of the number 1423 that is
9999-1423= 8576,
• and now we will add 1 to the result. So the 10's complement of
the number 1423 is 8576+1=8577.
41
42
43
BINARY CODED DECIMAL (BCD)
• The binary coded decimal (BCD) is a type of binary code used
to represent a given decimal number in an equivalent binary
form.
• Its main advantage is that it allows easy conversion to decimal
digits for printing or display and faster calculations.
• The most common BCD code is the 8421 BCD code.
• In this, the BCD equivalent of a decimal number is written by
replacing each decimal digit in integer and fractional parts
with its four-bit binary equivalent ‘(or nibble).
• Here 8, 4, 2 and 1 represent the weights of different bits in the
four-bit groups, starting from the (MSB) most significant bit
(to extreme left) and proceeding towards the least significant
(LSB) bit.
44
The 4221 BCD and 5421 BCD are other weighted BCD codes shown in
table. The numbers 4, 2, 2, 1 in 4221 BCD and 5, 4, 2 and 1 in 5421 BCD
represent weights of the relevant bits.
45
convert the given decimal numbers
to BCD.
46
47
Exercise-1
48
Exercise-1
49
50
EBCDIC
(Extended Binary Coded Decimal Inter change code)
• EBCDIC(pronounced “ebb see dick”)
• This is a coding system used to represent characters-letters,
numerals, punctuation marks, and other symbols in computerized
text.
• A character is represented in EBCDIC by eight bit.
• EBCDIC mainly used on IBM mainframe and IBM mid-
range computer operating systems.
• Each byte consists of two nibbles, each four bits wide.
• The first four bits define the class of character, while the second
nibble defines the specific character inside that class.
51
52
Character Codes
• Many applications of digital computers require the
handling of data not only of numbers, but also of letters.
• The most commonly used character code is ASCII (the
American Standard Code for Information Interchange).
• ASCII represents each character with a 7-bit string,
yielding a total of 128 characters.
• The code contains the uppercase and lower case
alphabet, numeral, punctuation, and various nonprinting
control characters.
54
ASCII Code
56
Gray Code
• Gray Code system is a binary number system in which every
successive pair of numbers differs in only one bit.
• It is used in applications in which the normal sequence of binary
numbers generated by the hardware may produce an error or
ambiguity during the transition from one number to the next.
• For example, the states of a system may change from 3(011) to
4(100) as- 011 — 001 — 101 — 100.
• Therefore there is a high chance of a wrong state being read
while the system changes from the initial state to the final state.
• This could have serious consequences for the machine using the
information. The Gray code eliminates this problem since only
one bit changes its value during any transition between two
numbers.
57
Decimal
Decimal Binary Gray
of Gray
0 0000 0000 0
1 0001 0001 1
2 0010 0011 3
3 0011 0010 2
4 0100 0110 6
5 0101 0111 7
6 0110 0101 5
7 0111 0100 4
8 1000 1100 12
9 1001 1101 13
10 1010 1111 15
11 1011 1110 14
12 1100 1010 10
13 1101 1011 11
14 1110 1001 9
15 1111 1000 8 58
Converting Binary to Gray Code
59
Converting Gray Code to Binary
60
61
PRACTICAL APPLICATION
• Mathematical puzzles- The binary-reflected
Gray code represents the underlying scheme of
the classical Chinese rings puzzle
Telegraphy codes
Analog-to-digital signal conversion
Position encoders
Genetic algorithms
Boolean circuit minimization
62
Excess-3 Code
• The excess-3 code is also treated as XS-3 code.
• The excess-3 code is a non-weighted and self-
complementary BCD code used to represent the decimal
numbers.
• This code has a biased representation. This code plays
an important role in arithmetic operations because it
resolves deficiencies encountered when we use the 8421
BCD code for adding two decimal digits whose sum is
greater than 9.
• The Excess-3 code uses a special type of algorithm,
which differs from the binary positional number system
or normal non-biased BCD.
63
Excess-3 Code
• We can easily get an excess-3 code of a decimal number
by simply adding 3 to each decimal digit.
• And then we write the 4-bit binary number for each digit
of the decimal number.
• We can find the excess-3 code of the given binary
number by using the following steps:
– We find the decimal number of the given binary number.
– Then we add 3 in each digit of the decimal number.
– Now, we find the binary code of each digit of the newly
generated decimal number.
• We can also add 0011 in each 4-bit BCD code of the
decimal number for getting excess-3 code.
64
The Excess-3 code for the decimal
number is as follows:
Decimal Digit BCD Code Excess-3 Code
0 0000 0011
1 0001 0100
2 0010 0101
3 0011 0110
4 0100 0111
5 0101 1000
6 0110 1001
7 0111 1010
8 1000 1011
9 1001 1100 65
Example 1: Decimal number 31
1. We find the BCD code of each digit of the
decimal number.
2. Then, we add 0011 in both of the BCD code.
Decimal BCD Excess-3
3 0011+0011 0110
1 0001+0011 0100
66
Example 2: Decimal number 81.61
• We find the BCD code of each digit of the decimal
number.
• Then, we add 0011 in both of the BCD code.
Decimal BCD Excess-3
8 1000+0011 1011
1 0001+0011 0100
6 0110+0011 1001
So, the excess-3 code of the decimal number 81.61 is 1011 0100.1001 0100
67
Why use Excess-3 code?
• These codes are self-complementary.
• These codes use biased representation.
• The excess-3 code has no limitation, so that it considerably simplifies
arithmetic operations.
• The codes 0000 and 1111 can cause a fault in the transmission line.
The excess-3 code doesn't use these codes and gives an advantage for
memory organization.
• These codes are usually unweighted binary decimal codes.
• This code has a vital role in arithmetic operations. It is because it
resolves deficiencies which are encountered when we use the 8421
BCD code for adding two decimal digits whose sum is greater than 9.
68