Unit 1 (DLD&CO) R22
Unit 1 (DLD&CO) R22
Unit 1 (DLD&CO) R22
Number system:
In number system modern method of representing numbers symbolically is based on positional notations.
In this method, each number is represented by a string of symbols where each symbol is associated with a specific weight depending upon its
positions. The total number of different symbols which are used in a particular number system is called the base or radix of the system and the weight
of each position of a particular number is expressed as a power of the base. When a number is formed with the combination of the symbols, each
symbol is then called a digit and the position of each symbol is referred to as the digit position.
Thus if a number system has symbols starting from 0, and the digits of the system are 0, 1, 2, ….. (r - 1) then the base or radix is r. If a number D of
this system be represented by
D = d₀ d₀ ……. d₀…….. d₁ d
The digit at the extreme left has the highest positional value and is generally called the Most Significant Digit, or in short MSD; similarly, the digit
occupying the extreme right position has the least positional value and is referred to as the Least Significant Digit or LSD.
Decimal number system is the most common example of positional notational number system and all the arithmetical calculations undertaken by
human being are carried out on the basis of this number system. In this system, the symbols used are 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 and the base is 10. Thus
the number
dn-1 dn-2…..d 1 d0 means dn-1 10n-1 + dn-2 10n-2 + ……. + d1 101 + d0 100
and this is an n-digit number. If the number be extended to the right of the decimal point, then the powers of the base will be negative starting from -
1.
Here we will discuss about the binary number system we already know binary numbers play a vital role in the design of digital computers.
Hence a detailed discussion of binary number system is given in this section. Binary number system uses two symbols 0 and 1 and its radix is 2. The
symbols 0 and 1 are generally called BITS which is a contraction of the two words Binary digits.
An n-bit binary number of the form an-1 an-2 ….. a1 a0 where each ai (i = 0, 1, …. n - 1) is either 0 or 1 has the magnitude.
For fractional binary numbers, the base has negative integral powers starting with -1 for the bit position just after the binary point.
57
The bit at the extreme left of a binary number has the highest positional value and is usually called the Most Significant Bit or MSB. Similarly, the
bit occupying the extreme right position of a given binary number has the least positional value and is referred to as the Least Significant
Bit or LSB.
To facilitate the distinction between different number systems, we generally use the respective radix as a subscript of the number. However the
subscript will not be used when there is no scope of confusion.
In binary number system a few examples on binary numbers and their decimal equivalents are given below:
1011012 = 1 × 25 + 0 × 24 + 1 × 23 + 1 × 22 + 0 × 21 + 1 × 20
= 32 + 0 + 8 + 4 + 0 + 1
= 4510
The above results can be more clearly expressed in the following manner:
Binary point
111.10112
= 4 + 2 + 1 + .5 + 0 + .125 + .0625
= 7.687510
The above results can be more clearly expressed in the following manner:
57
These are the basic examples shown above.
There are several traditional methods of converting the numbers from binary to decimal conversion. We shall discuss here the two most commonly
used methods, namely; “Expansion method and Value Box method”.
In this method, the given number is expressed as a summation of terms each of which is the product of a bit (0 or 1) and a power of 2. The power of
2 is determined from the bit position.
Thus the decimal equivalent of a binary number has the general form;
= an-1 × 2n-1 + an-2 x 2n-2 + ….. +ai x 2i + …. + a1 x 21 + a0 x 20 + a-1 x 2-1 + a-2 x 2-2 + …. + a-p x 2-p
The value box method of converting numbers from decimal to binary is laborious and time consuming and is suitable for small numbers when it can
be performed mentally. It is advisable not to use it for large numbers. The conversion of large numbers may be conveniently done by multiplication
and division method which is described below.
To effect the conversion of positive integers of the decimal system to binary numbers the decimal number is repeatedly divided by the base of the
binary number system, i.e., by 2. The division is to be carried until the quotient is zero and the remainder of each division is recorded on the right.
The binary equivalent of the decimal number is then obtained by writing down the successive remainders. The first remainder is the least significant
bit and the last one is the most significant bit of the binary number. Thus the binary equivalent is written from the bottom upwards.
Octal number system has a base or radix 8. Eight different symbols, namely 0, 1, 2, 3, 4, 5, 6, 7 are used to represent octal numbers. Conversion of
octal numbers to their decimal equivalents can be accomplished by using the same rule which was followed to convert binary numbers to decimal
numbers, except that we now have a radix 8 instead of 2. Thus the octal number 273 has the decimal equivalent.
57
2738
= 2 × 82 + 7 × 81 + 3 × 80
= 128 + 56 + 3
= 18710
Conversion of decimal I integers to octal can be performed by successively dividing number by 8 and using each remainder as a digit of the desired
octal number. We note that the first remainder is the least significant digit and the last one is the most significant digit. In the case of decimal
fractions, we use the same method which was used in converting decimal fractions to binary fractions.
Few examples on octal number system are explained with this method:
(a) 2980
Solution:
2980
(b) 0.685
Solution:
0.685
57
The hexa-decimal number system has a radix or base 16. It requires 16 symbols to represent a number in this system. The symbols are 0 to 9, A, B,
C, D, E, F where the symbols A, B, C, D, E, F represent the decimal numbers 10, 11, 12, 13, 14, 15 respectively. Let us recall the conversion table for
the decimal numbers 0 to 15 and their binary, octal and hexa-decimal equivalents.
The conversion of hexa-decimal numbers to their decimal equivalents is straight-forward and follows the same rules as that of octal or binary to
decimal. Similarly, conversion of decimal to hexa-decimal may be worked out with the help of division or multiplication, as the case may be, by the
radix 16.
The example on hexa-decimal number system will help us to understand the procedure:
Solution:
B6A16
= 2816 + 96 + 10
= 292210
Solution:
391710
Solution:
57
The conversion of decimal fractions to binary fractions is accomplished by multiplying repeatedly the decimal fraction by the base 2 of the binary
number. The integral part after each multiplication is either 0 or 1. The equivalent binary fraction is obtained by writing the integral parts of each
product to the right of the binary point in the same sequence. If the fractional part of the product becomes exactly zero at a certain stage, then the
binary fraction is finite, otherwise, the fraction is non-terminating and then we find the binary fraction upto the desired degree of accuracy. We
explain the process with the help of the following examples.
(a) 0.375
Solution:
0.75 × 2 = 1.5 1 .5
.5 × 2 = 1.0 1 0
(b) 0.435
Solution:
Fox mixed number, we will have to separate the number into its integral and fractional parts and find the binary equivalent of each part
independently.
Finally, we add the two parts to get the binary equivalent of the given number.
Solution:
57
At first we find the binary equivalent of 56.
0.75 × 2 = 1.5 1 .5
0.5 × 2 = 1.0 1 0
The representation of decimal numbers in everyday business is commonly called the signed-magnitude representation.
In this system, a number consists of a magnitude and a symbol which indicates whether the magnitude is positive or negative.
Thus the decimal numbers + 79, - 82, - 25.2 etc. are interpreted in the usual manner.
This mode of representation can be incorporated to binary numbers quite easily by using an extra bit position to represent the sign. This extra bit is
called the SIGN BIT and is placed before the magnitude of the number to be represented. Generally, the MSB is the sign bit and the convention is
that when the sign bit is 0, the number represented is positive and when the sign bit is 1, the number is negative.
A few examples of 8-bit signed-magnitude binary numbers along with their decimal equivalents are given below to show the point.
57
(vi) (10000000)2 = -(0)10
We note that in signed-magnitude representation two possible representations of zero may be obtained.
In the decimal number system, the radix complement is the 10’s complement. In radix complement representation system, the complement of an n-
digit number is obtained by subtracting the number from 10n.
Let us consider some examples of 3-digit numbers and their radix complement in decimal system.
948 52
607 393
155 845
735 265
br>From the above discussion we find that a subtraction operation is to be preformed to get the 10’s complement of a number, say, N. This
subtraction operation can be avoided by rewriting 10n as (10n - 1) + 1 and 10n - N as {(10n - 1) - N} + 1. The number 10n - 1 is of the form 999...99
consisting of n digits. If the complement of a digit be defined as (9 - the concerned digit), then (10 n - 1) - N is obtained by complementing the digits
of N.
Therefore, the 10’s complement of the number N is obtained by subtracting each digit of the number from 9 and then adding 1 to the LSD of the
number so formed.
For instance, the 10’s complement of 172 is (827 + 1) or 828 and that of 405 is (594 + 1) or 595.
For the binary number system the radix complement is the two’s complement. The 2’s complement of a binary number is obtained by subtracting
each bit of the number from the radix diminished by 1 i.e. from (2 - 1) or 1 and adding an 1 to the LSB. The application of this rule is very simple.
We have to just change 1 to 0 and 0 to 1 in every bit and then add 1 to the LSB of the number so formed. For example, the 2’s complement of the
binary number 11011 is (00100 + 1) or 00101 and that of 10110 is (01001 + 1) or 01010.
If the number be in signed magnitude representation, it is positive if the MSB is 0 and negative if the MSB is 1. The decimal equivalent of a 2’s
complement binary number, in the case of signed-magnitude representation, is computed in the same way as for an unsigned number except that the
weight of the MSB is -2n-1 instead of +2n-1 for an n-bit binary number.
Let us observe some examples of 8-bit binary numbers and their 2’s complement are shown below:
Complement: 10010010
+1
In the decimal number system the diminished radix complement is 9’s complement. This is obtained by subtracting each digit of the number from 9.
57
59 40
894 105
6578 3421
2063 7936
The diminished radix complement of binary numbers is called 1’s complement. The 1’s complement of a binary number is formed by replacing each
1 in the number by a 0 and each 0 by 1.
1011 0100
1101 0010
In the case of signed magnitude representation of binary numbers, the MSB is the sign bit.
Positive number representations are same for both 1’s and 2’s complement. But representation of negative numbers differs by 1. A weight of -(2 n-1 -
1) rather than -2n-1 is given to the MSB while computing the decimal equivalent of 1’s complement of a binary number.
A few examples of 8-bit binary numbers and their 1’s complement are given below;
Binary addition
0+1=1 + 0 1
0 0 1
1+0=1 1 1 10
1 + 1 = 0 with a carry-over of 1
“Carry-overs” of binary addition are performed in the same manner as in decimal addition. With the help of the above rules addition of three or
more binary numbers can be worked out but this has little use in digital computers.
For addition of fractional binary numbers, the binary point of the two numbers are placed one below the other just like the decimal points and the
usual rules are followed.
57
A clear concept on few examples will make the procedure of binary addition:
Solution:
110000
Solution:
Solution:
1 1 1 1 1 1 Carry overs
10101.101
1101.011
100011.000
Solution:
111.0111
10011.001
11010.1001
Binary subtraction
Binary subtraction is also similar to that of decimal subtraction with the difference that when 1 is subtracted from 0, it is necessary to borrow 1 from
the next higher order bit and that bit is reduced by 1 (or 1 is added to the next bit of subtrahend) and the remainder is 1.
0-0=0 - 0 1
0 0 1
1-0=1 1 1 0
1-1=0
57
0 - 1 = 1 with a borrow of 1
For fractional numbers, the rules of subtraction are the same with the binary point properly placed.
A clear concept on few examples will make the procedure of binary subtraction:
Solution:
1 Borrow
1001
101
100
1 Borrow
1000
111
0001
Solution:
1 Borrow
1111011.11
1010101.10
100110.01
Solution:
1 1 1 Borrow
101100.011
11010.101
10001.110
With the help of subtraction by 2’s complement method we can easily subtract two binary numbers.
57
(i) At first, 2’s complement of the subtrahend is found.
(iii) If the final carry over of the sum is 1, it is dropped and the result is positive.
(iv) If there is no carry over, the two’s complement of the sum will be the result and it is negative.
The following examples on subtraction by 2’s complement will make the procedure clear:
Evaluate:
Solution:
The numbers of bits in the subtrahend is 5 while that of minuend is 6. We make the number of bits in the subtrahend equal to that of minuend by
taking a `0’ in the sixth place of the subtrahend.
Now, 2’s complement of 010110 is (101101 + 1) i.e.101010. Adding this with the minuend.
1 10110 Minuend
1 01010 2’s complement of subtrahend
Carry over 1 1 00000 Result of addition
After dropping the carry over we get the result of subtraction to be 100000.
Solution:
Minued - 10110
2’s complement of subtrahend - 00110
Result of addition - 11100
As there is no carry over, the result of subtraction is negative and is obtained by writing the 2’s complement of 11100 i.e.(00011 + 1) or 00100.
Solution:
Minued - 1010.11
2’s complement of subtrahend - 0110.11
Carry over 1 0001.10
After dropping the carry over we get the result of subtraction as 1.10.
Solution:
57
Minued - 10100.01
2’s complement of subtrahend - 01100.10
Result of addition - 11000.11
As there is no carry over the result of subtraction is negative and is obtained by writing the 2’s complement of 11000.11.
In subtraction by 1’s complement we subtract two binary numbers using carried by 1’s complement.
iii) If the result of addition has a carry over then it is dropped and an 1 is added in the last bit.
iv) If there is no carry over, then 1’s complement of the result of addition is obtained to get the final result and it is negative.
Evaluate:
Solution:
Minued - 110101
1’s complement of subtrahend - 011010
Carry over - 1 001111
1
010000
Solution:
Minued - 101011
1’s complement - 000110
110001
Solution:
Minued - 1011.001
1’s complement of subtrahend - 1001.011
Carry over - 1 0100.100
1
0100.101
57
(iv) 10110.01 – 11010.10
Solution:
10110.01
00101.01
11011.10
In this case addition of numbers is performed after taking 1’s complement of the negative number and the end-around carry of the sum is added to the
least significant bit.
The following examples will illustrate this method in binary addition using 1’s complement:
Solution:
+1110 ⇒ 01110
-1101 ⇒ 10010 (taking 1’s complement)
00000
1 carry
00001
Solution:
+1101 ⇒ 01101
-1011 ⇒ 10100 (taking 1’s complement)
00001
1 carry
00010
In this case the addition is carried in the same way as in case 1 but there will be non end-around carry. The sum is obtained by taking 1’s complement
of the magnitude bits of the result and it will be negative.
The following examples will illustrate this method in binary addition using 1’s complement:
Find the sum of the following binary numbers represented in a sign-plus-magnitude 5-bit register:
57
(i) + 1010 and - 1100
Solution:
+1010 ⇒ 01010
-1100 ⇒ 10011 (1’s complement)
11101
Solution:
+0011 ⇒ 00011
-1101 ⇒ 10010 (1’s complement)
10101
For the addition of two negative numbers 1’s complements of both the numbers are to be taken and then added. In this case an end-around carry will
always appear. This along with a carry from the MSB (i.e. the 4th bit in the case of sign-plus-magnitude 5-bit register) will generate a 1 in the sign
bit. 1’s complement of the magnitude bits of the result of addition will give the final sum.
The following examples will illustrate this method in binary addition using 1’s complement:
Find the sum of the following negative numbers represented in a sign-plus-magnitude 5-bit register:
Solution:
1’s complement of the magnitude bits of sum is 1111 and the sign bit is 1.
Solution:
When negative numbers are expressed in binary addition using 2’s complement the addition of binary numbers becomes easier. This operation is
almost similar to that in 1’s complement system and is explained with examples given below:
57
We consider the following cases.
In this case the carry which will be generated is discarded and the final result is the result of addition.
The following examples will illustrate this method in binary addition using 2’s complement:
In a 5-bit register find the sum of the following by using 2’s complement:
Solution:
+1011 ⇒ 01011
-0101 ⇒ 1 1 0 1 1 (2’s complement)
(Carry 1 discarded) 00110
Solution:
+0111 ⇒ 00111
-0011 ⇒ 11101
(Carry 1 discarded) 00100
When the negative numbers is greater no carry will be generated in the sign bit. The result of addition will be negative and the final result is obtained
by taking 2’s complement of the magnitude bits of the result.
The following examples will illustrate this method in binary addition using 2’s complement:
In a 5-bit register find the sum of the following by using 2’s complement:
(i) + 0 0 1 1 and - 0 1 0 1
Solution:
+0011 ⇒ 00011
-0101 ⇒ 11011 (2’s complement)
11110
(ii) + 0 1 0 0 and - 0 1 1 1
Solution:
+0100 ⇒ 00100
-0111 ⇒ 11001 (2’s complement)
11101
57
When two negative numbers are added a carry will be generated from the sign bit which will be discarded. 2’s complement of the magnitude bits of
the operation will be the final sum.
The following examples will illustrate this method in binary addition using 2’s complement:
In a 5-bit register find the sum of the following by using 2’s complement:
Solution:
Solution:
Binary Codes
Binary codes are codes which are represented in binary system with modification from the original ones. Below we will be seeing the following:
Weighted binary codes are those which obey the positional weighting principles, each position of the number represents a specific weight. The
binary counting sequence is an example.
Decimal 8421 2421 5211 Excess-3
0 0000 0000 0000 0011
1 0001 0001 0001 0100
2 0010 0010 0011 0101
3 0011 0011 0101 0110
4 0100 0100 0111 0111
5 0101 1011 1000 1000
6 0110 1100 1010 1001
7 0111 1101 1100 1010
8 1000 1110 1110 1011
9 1001 1111 1111 1100
8421 Code/BCDCode
The BCD (Binary Coded Decimal) is a straight assignment of the binary equivalent. It is possible to assign weights to the binary bits according to
their positions. The weights in the BCD code are8,4,2,1.
57
Example: The bit assignment 1001, can be seen by its weights to represent the decimal 9because:
1x8+0x4+0x2+1x1 =9
2421Code
This is a weighted code, its weights are 2, 4, 2 and 1. A decimal number is represented in 4-bit form and the total four bits weight is 2 + 4 + 2 + 1
= 9. Hence the 2421 code represents the decimal numbers from 0 to9.
5211Code
This is a weighted code, its weights are 5, 2, 1 and 1. A decimal number is represented in 4-bit form and the total four bits weight is 5 + 2 + 1 + 1
= 9. Hence the 5211 code represents the decimal numbers from 0 to9.
Reflective Code
A code is said to be reflective when code for 9 is complement for the code for 0, and so is for 8 and 1 codes, 7 and 2, 6 and 3, 5 and 4. Codes
2421, 5211, and excess-3 are reflective, whereas the 8421 code isnot.
Sequential Codes
A code is said to be sequential when two subsequent codes, seen as numbers in binary representation, differ by one. This greatly aids
mathematical manipulation of data. The 8421 and Excess-3 codes are sequential, whereas the 2421 and 5211 codes are not.
Non weighted codes are codes that are not positional weighted. That is, each position within the binary number is not assigned a fixed value.
Excess-3Code
Excess-3 is a non weighted code used to express decimal numbers. The code derives its name from the fact that each binary code is the
corresponding 8421 code plus0011(3).
Gray Code
The gray code belongs to a class of codes called minimum change codes, in which only one bit in the code changes when moving from one code
to the next. The Gray code is non-weighted code, as the position of bit does not contain any weight. The gray code is a reflective digital code
which has the special property that any two subsequent numbers codes differ by only one bit. This is also called a unit-distance code. In digital
Gray code has got a specialplace.
57
13 1101 1011
14 1110 1001
15 1111 1000
Binary to Gray Conversion
For reliable transmission and storage of digital data, error detection and correction is required. Below are a few examples of codes which permit
error detection and error correction after detection.
Parity
In parity codes, every data byte, or nibble (according to how user wants to use it) is checked if they have even number of ones or even number of
zeros. Based on this information an additional bit is appended to the original data. Thus if we consider 8-bit data, adding the parity bit will make it
9 bit long.At the receiver side, once again parity is calculated and matched with the received parity (bit 9), and if they match, data is ok, otherwise
data is corrupt.
There are two types of parity:
• Even parity: Checks if there is an even number of ones; if so, parity bit is zero. When the number of ones is odd then parity bit is set
to1.
• Odd Parity: Checks if there is an odd number of ones; if so, parity bit is zero. When number of ones is even then parity bit is set to1.
Checksums
The parity method is calculated over byte, word or double word. But when errors need to be checked over 128 bytes or more (basically blocks of
data), then calculating parity is not the right way. So we have checksum, which allows checking for errors on block of data. There are many
variations of checksum.
• Adding all bytes
• CRC
• Fletcher's checksum
• Adler-32
The simplest form of checksum, which simply adds up the asserted bits in the data, cannot detect a number of types of errors. In particular, such a
checksum is not changed by:
• Reordering of the bytes in the message
• Inserting or deleting zero-valued bytes
• Multiple errors which sum to zero
Example of Checksum: Given 4 bytes of data (can be done with any number of bytes): 25h, 62h, 3Fh,52h
• Adding all bytes together gives118h.
• Drop the Carry Nibble to give you18h.
Get the two's complement of the 18h to get E8h. This is the checksum byte
To Test the Checksum byte simply adds it to the original group of bytes. This should give you 200h.
Drop the carry nibble again giving 00h. Since it is 00h this means the checksum means the bytes were probably not changed.
Error-Correcting Codes
Error-correcting codes not only detect errors, but also correct them. This is used normally in Satellite communication, where turn-around delay is
very high as is the probability of data getting corrupt.
57
ECC (Error correcting codes) are used also in memories, networking, Hard disk, CDROM, DVD etc. Normally in networking chips (ASIC), we
have 2 Error detection bits and 1 Error correction bit.
HammingCode
Hamming code adds a minimum number of bits to the data transmitted in a noisy channel, to be able to correct every possible one-bit error. It can
detect (not correct) two-bits errors and cannot distinguish between 1-bit and 2-bits inconsistencies. It can't - in general - detect 3(or more)-bits
errors.
The idea is that the failed bit position in an n-bit string (which we'll call X) can be represented in binary with log2(n) bits, hence we'll try to get it
adding just log2(n)bits.
First, we set m = n + log2(n) to the encoded string length and we number each bit position starting from 1 through m. Then we place these
additional bits at power-of-two positions, that is 1, 2, 4, 8..., while remaining ones (3, 5, 6, 7...) hold the bit string in the originalorder.
Now we set each added bit to the parity of a group of bits. We group bits this way: we form a group for every parity bit, where the following
relationholds:
So bit 1 groups bits 1, 3, 5, 7... while bit 2 groups bits 2, 3, 6, 7, 10... , bit 4 groups bits 4, 5, 6,7,
12, 13... and soon.
Thus, by definition, X (the failed bit position defined above) is the sum of the incorrect parity bits positions (0 for noerrors).
To understand why it is so, let's call Xn the nth bit of X in binary representation. Now consider that each parity bit is tied to a bit of X: parity1 ->
X1, parity2 -> X2, parity4 -> X3, parity8 -> X4 and so on - for programmers: they are the respective AND masks -. By construction, the failed bit
makes fail only the parity bits which correspond to the 1s in X, so each bit of X is 1 if the corresponding parity is wrong and 0 if it iscorrect.
Note that the longer the string, the higher the throughput n/m and the lower the probability that no more than one bit fails. So the string to be sent
should be broken into blocks whose length depends on the transmission channel quality (the cleaner the channel, the bigger the block). Also,
unless it's guaranteed that at most one bit per block fails, a checksum or some other form of data integrity check should beadded.
AlphanumericCodes
The binary codes that can be used to represent all the letters of the alphabet, numbers and mathematical symbols, punctuation marks, are known as
alphanumeric codes or character codes. These codes enable us to interface the input-output devices like the keyboard, printers, video displays with
thecomputer.
ASCIICode
ASCII stands for American Standard Code for Information Interchange. It has become a world standard alphanumeric code for microcomputers
and computers. It is a 7-bit code representing 27 = 128 different characters. These characters represent 26 upper case letters (A to Z), 26
lowercase letters (a to z), 10 numbers (0 to 9), 33 special characters and symbols and 33 controlcharacters.
The 7-bit code is divided into two portions, The leftmost 3 bits portion is called zone bits and the 4-bit portion on the right is called numericbits.
An 8-bit version of ASCII code is known as USACC-II 8 or ASCII-8. The 8-bit version can represent a maximum of 256characters.
EBCDICCode
EBCDIC stands for Extended Binary Coded Decimal Interchange. It is mainly used with large computer systems like mainframes. EBCDIC is an
8-bit code and thus accomodates up to 256 characters. An EBCDIC code is divided into two portions: 4 zone bits (on the left) and 4 numeric bits
(on theright).
Boolean Algebra
Boolean algebra is a type of algebra that is created by operating the binary system. In the year 1854, George Boole, an English mathematician,
proposed this algebra. This is a variant of Aristotle’s propositional logic that uses the symbols 0 and 1, or True and False. Boolen algebra is
concerned with binary variables and logic operations.
57
Boolean Algebra is fundamental in the development of digital electronics systems as they all use the concept of Boolean Algebra to execute
commands. Apart from digital electronics this algebra also finds its application in Set Theory, Statistics, and other branches of mathematics.
In this we learn about, basic Boolean operations, Boolean expressions, Truth Tables, Boolean laws, and others in detail.
OR + (or) ∨ Third
We can easily define these operations using two boolean variables. Let’s take two boolean variables A and B that can have any of the two
values 0 or 1, i.e. they can be either OFF or ON. Then these operations are explained as,
Using the NOT operation reverse the value of the Boolean variable from 0 to 1 or vice-versa. This can be understood as:
Using the AND operation satisfies the condition if both the value of the individual variables are true and if any of the value is false then this
operation gives the negative result. This can be understood as,
Using the OR operation satisfies the condition if any value of the individual variables are true, it only gives a negative result if both the values
are false. This can be understood as,
57
P + Q = R is a Boolean phrase in which P, Q, and R are Boolean variables that can only store two values: 0 and 1. The 0 and 1 are the synonyms
for false and True and are used in Boolen Algebra, sometimes we also use “Yes” in place of True and “No” in place of False.
Thus, we can say that statements using Boolean variables and operating on Boolean operations are Boolean Expressions. Some examples of
Boolean expressions are,
A + B = True
A.B = True
(A)’ = False
Boolean Algebra
Boolean Variables
Boolean Function
Literal
Complement
Truth Table
Now, we will discuss the important terminologies of Boolean algebra in the article below,
Boolean Algebra
The branch of algebra that deals with binary operations or logical operations is called Boolean Algebra.
Boolean Variables
Variables used in Boolean algebra that store the logical value of 0 and 1 are called the boolean variables. They are used to store either true or
false values.
Boolean Function
A function of the Boolean Algebra that is formed by the use of Boolean variables and Boolean operators is called the Boolean function.
Literal
A variable or the complement of the variable in Boolean Algebra is called the Literal.
Complement
The inverse of the boolean variable is called the complement of the variable. The complement of 0 is 1 and the complement of 1 is 0. It is
represented by ‘ over the variable.
Truth Table
Table containing all the possible values of the logical variables and the combination of the variable along with the given operation is called the
truth table. The number of rows in the truth table depends on the total boolean variables used in that function. It is given by using the formula,
57
Number of Rows in Truth Table = 2n
Example: Draw the truth table of the conditions A + B and A.B where A and b are boolean variables.
Solution:
A B X=A+B Y = A.B
T T T T
T F T F
F T T F
F F F F
Identity Law
57
In the Boolean Algebra, we have identity elements for both AND(.) and OR(+) operations. The identity law state that in boolean algebra we have
such variables that on operating with AND and OR operation we get the same result, i.e.
A+0=A
A.1 = A
Commutative Law
Binary variables in Boolean Algebra follow the commutative law. This law states that operating boolean variables A and B is similar to
operating boolean variables B and A. That is,
A. B = B. A
A+B=B+A
Associative Law
Associative law state that the order of performing Boolean operator is illogical as their result is always the same. This can be understood as,
(A.B).C=A.(B.C)
( A + B ) + C = A + ( B + C)
Distributive Law
Boolean Variables also follow the distributive law and the expression for Distributive law is given as:
A . ( B + C) = (A . B) + (A . C)
Inversion Law
Inversion law is the unique law of Boolean algebra this law states that, the complement of the complement of any number is the number itself.
(A’)’ = A
Apart from these other laws are mentioned below:
AND Law
AND law of the Boolean algebra uses AND operator and the AND law is,
A.0=0
A.1=A
A.A=A
OR Law
OR law of the Boolean algebra uses OR operator and the OR law is,
A+0=A
A+1=1
A+A=A
De Morgan’s Laws are also called Demorgan’s Theorem. They are the most important laws in Boolen Algebra and these are added below under
the heading Boolean Algebra Theorem
57
De Morgan’s First laws
Statement: The complement of the product (AND) of two Boolean variables (or expressions) is equal to the sum(OR) of the complement of each
Boolean variable (or expression).
T T F F F F
T F F T T T
F T T F T T
F F T T T T
We can clearly see that truth values for (P.Q)’ are equal to truth values for (P)’ + (Q)’, corresponding to the same input. Thus, De Morgan’s First
Law is true.
Statement: The Complement of the sum (OR) of two Boolean variables (or expressions) is equal to the product(AND) of the complement of
each Boolean variable (or expression).
(P + Q)’ = (P)’.(Q)’
Proof :
T T F F F F
T F F T F F
F T T F F F
F F T T T T
We can clearly see that truth values for (P + Q)’ are equal to truth values for (P)’.(Q)’, corresponding to the same input. Thus, De Morgan’s
Second Law is true.
57
Solution:
P Q P.Q P + P.Q
T T T T
T F F T
F T F F
F F F F
In the truth table, we can see that the truth values for P + P.Q is exactly the same as P.
Solution:
P Q P. P.Q + P + Q
Q
T T T T
T F F T
F T F T
F F F F
Boolean Algebra also called Logical Algebra is a branch of mathematics that deals with Boolean Varaibles such as, 0 and
1.
AND (Conjunction)
OR (Disjunction)
NOT (Negation)
57
Boolean Algebra has various applications. It is used to simplify logical circuits that are the backbone of modern
technology.
The “0” in Boolen Algebra represent a False condition or it represent the Switch Off condition.
The “1” in Boolen Algebra represent a Truecondition or it represent the Switch On condition.
Boolean algebra laws are fundamental rules for working with true/false or binary variables. Key laws include:
– Identity: A AND 1 = A, A OR 0 = A
– Null: A AND 0 = 0, A OR 1 = 1
– Complement: A AND A’ = 0, A OR A’ = 1
These laws are vital for simplifying logical expressions and designing digital circuits.
57
11. Commutative Law for AND: A AND B = B AND A
Boolean algebra is governed by five primary laws, which serve as the foundation for manipulating logical expressions:
1. Identity Law for AND: The AND operation with true (1) leaves a variable unchanged.
– A AND 1 = A
2. Identity Law for OR: The OR operation with false (0) leaves a variable unchanged.
– A OR 0 = A
3. Complement Law for AND: The AND operation with false (0) results in false.
– A AND 0 = 0
4. Complement Law for OR: The OR operation with true (1) results in true.
– A OR 1 = 1
5. Idempotent Law: Repeated operations on a variable with itself do not change its value.
– A AND A = A
– A OR A = A
Boolean logic, also known as Boolean algebra, is governed by three fundamental laws:
Commutative Law: This law states that the order of operands in an operation does not affect the result.
For OR: A OR B = B OR A
Associative Law: This law dictates that the grouping of operands in an operation does not change the result.
For OR: (A OR B) OR C = A OR (B OR C)
Distributive Law: This law describes how one operation (AND or OR) distributes over the other operation.
De Morgan’s theorem is a fundamental principle in Boolean algebra that provides a way to simplify the complement
(negation) of a logical expression involving both AND and OR operations. There are two forms of De Morgan’s theorem,
one for negating an AND operation and another for negating an OR operation. These theorems are named after the British
mathematician and logician Augustus De Morgan.
The theorem states that the complement of the AND operation between two or more variables is equivalent to the OR
operation of their complements.
57
– NOT (A AND B) = (NOT A) OR (NOT B)
This means that if you want to find the complement of the AND operation of two or more variables, you can take the
complement of each variable individually and then use the OR operation between their complements.
The theorem states that the complement of the OR operation between two or more variables is equivalent to the AND
operation of their complements.
This means that if you want to find the complement of the OR operation of two or more variables, you can take the
complement of each variable individually and then use the AND operation between their complements.
Minterms andMaxterms
Any boolean expression may be expressed in terms of either minterms or maxterms. To do this we must first define the concept of a
literal. A literal is a single variable within a term which may or may not be complemented. For an expression with N variables,
minterms and maxterms are defined as follows:
A minterm is the product of N distinct literals where each literal occurs exactly once.
A maxterm is the sum of N distinct literals where each literal occurs exactly once For a two-variable expression, the minterms and maxterms are
asfollows
X Y Z Minterm Maxterm
0 0 0 X'.Y'.Z' X+Y+Z
0 0 1 X'.Y'.Z X+Y+Z'
0 1 0 X'.Y.Z' X+Y'+Z
0 1 1 X'.Y.Z X+Y'+Z'
1 0 0 X.Y'.Z' X'+Y+Z
1 0 1 X.Y'.Z X'+Y+Z'
1 1 0 X.Y.Z' X'+Y'+Z
1 1 1 X.Y.Z X'+Y'+Z'
This allows us to represent expressions in either Sum of Products or Product of Sums forms
Sum Of Products(SOP)
The Sum of Products form represents an expression as a sum ofminterms.
To derive the Sum of Products form from a truth table, OR together all of the minterms which give a value of1.
Example -SOP
X Y F Minterm
0 0 0 X'.Y'
0 1 0 X'Y
57
1 0 1 X.Y'
1 1 1 X.Y
57
Product Of Sum(POS)
The Product of Sums form represents an expression as a product of maxterms. F(X, Y, .......) = Product (b k + Mk), where bk is 0 or
1 and Mk is amaxterm.
To derive the Product of Sums form from a truth table, AND together all of themaxterms
which give a value of0.
Example -POS
X Y F Maxterm
0 0 1 X+Y
0 1 0 X+Y'
1 0 1 X'+Y
1 1 1 X'+Y'
Exercise
Give the expression represented by the following truth table in both Sum of Products and Product of Sumsforms.
X Y Z F(X,Y,X)
0 0 0 1
0 0 1 0
0 1 0 0
0 1 1 1
1 0 0 0
1 0 1 1
1 1 0 1
1 1 1 0
57
Conversion between POS andSOP
Simplification
As with any other form of algebra you have encountered, simplification of expressions can be performed with Booleanalgebra.
Example
= Y.Z' + Y.Z =Y
Example
Digital LogicGates
LogicGates
A logic gate is an electronic circuit/device which makes the logical decisions. To arrive at this decisions, the most common logic gates used are
OR, AND, NOT, NAND, and NOR gates. The NAND and NOR gates are called universal gates. The exclusive-OR gate is another logic gate
which can be constructed using AND, OR and NOTgate.
Logic gates have one or more inputs and only one output. The output is active only for certain input combinations. Logic gates are the building
blocks of any digital circuit. Logic gates arealso
called switches. With the advent of integrated circuits, switches have been replaced by TTL (Transistor Transistor Logic) circuits and CMOS
circuits. Here I give example circuits on how to construct simplesgates.
SymbolicLogic
Boolean algebra derives its name from the mathematician George Boole. Symbolic Logic uses values, variables andoperations.
Inversion
A small circle on an input or an output indicates inversion. See the NOT, NAND and NOR gates given below forexamples.
Multiple InputGates
Given commutative and associative laws, many logic gates can be implemented with more than two inputs, and for reasons of space in
circuits, usually multiple input, complex gates are made. You will encounter such gates in real world (maybe you could analyze an
ASIC lib to findthis).
GatesTypes
AND
OR
NOT
BUF
NAND
NOR
XOR
XNOR
ANDGate
61
The AND gate performs logical multiplication, commonly known as AND function. The AND gate has two or more inputs and single output.
The output of AND gate is HIGH only when all its inputs are HIGH (i.e. even if one input is LOW, Output will beLOW).
If X and Y are two inputs, then output F can be represented mathematically as F = X.Y, Here dot (.) denotes the AND operation. Truth table and
symbol of the AND gate is shown in the figurebelow.
Symbol
TruthTable
X Y F=(X.Y)
0 0 0
0 1 0
1 0 0
1 1 1
Two input AND gate using "diode-resistor" logic is shown in figure below, where X, Y are inputs and F is theoutput.
Circuit
71
If X = 0 and Y = 0, then both diodes D1 and D2 are forward biased and thus both diodes conduct and pull Flow.
If X = 0 and Y = 1, D2 is reverse biased, thus does not conduct. But D1 is forward biased, thus conducts and thus pulls Flow.
If X = 1 and Y = 0, D1 is reverse biased, thus does not conduct. But D2 is forward biased, thus conducts and thus pulls Flow.
If X = 1 and Y = 1, then both diodes D1 and D2 are reverse biased and thus both the diodes are in cut-off and thus there is no drop in voltage at F. Thus F
isHIGH.
In the figure below, X and Y are two switches which have been connected in series (or just cascaded) with the load LED and source battery. When both
switches are closed, current flows toLED.
Circuit
TruthTable
X Y Z F=X.Y.Z
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 1 1
ORGate
The OR gate performs logical addition, commonly known as OR function. The OR gate has two or more inputs and single output. The output of OR gate
is HIGH only when any one of its inputs are HIGH (i.e. even if one input is HIGH, Output will beHIGH).
71
If X and Y are two inputs, then output F can be represented mathematically as F = X+Y. Here plus sign (+) denotes the OR operation. Truth table and
symbol of the OR gate is shown in the figurebelow.
Symbol
TruthTable
X Y F=(X+Y)
0 0 0
0 1 1
1 0 1
1 1 1
Two input OR gate using "diode-resistor" logic is shown in figure below, where X, Y are inputs and F is theoutput.
Circuit
If X = 0 and Y = 0, then both diodes D1 and D2 are reverse biased and thus both the diodes are in cut-off and thus F islow.
If X = 0 and Y = 1, D1 is reverse biased, thus does not conduct. But D2 is forward biased, thus conducts and thus pulling F toHIGH.
If X = 1 and Y = 0, D2 is reverse biased, thus does not conduct. But D1 is forward biased, thus conducts and thus pulling F toHIGH.
If X = 1 and Y = 1, then both diodes D1 and D2 are forward biased and thus both the diodes conduct and thus F isHIGH.
In the figure, X and Y are two switches which have been connected in parallel, and this is connected in series with the load LED and source battery. When
both switches are open, current does not flow to LED, but when any switch is closed then currentflows.
71
Three Input ORgate
Since we have already seen how an OR gate works, I will just list the truth table of a 3-input OR gate. The figure below shows its circuit and truthtable.
TruthTable
X Y Z F=X+Y+Z
0 0 0 0
0 0 1 1
0 1 0 1
0 1 1 1
1 0 0 1
1 0 1 1
1 1 0 1
1 1 1 1
NOTGate
The NOT gate performs the basic logical function called inversion or complementation. NOT gate is also called inverter. The purpose of this gate is to
convert one logic level into the opposite logic level. It has one input and one output. When a HIGH level is applied to an inverter, a LOW level appears on
its output and viceversa.
If X is the input, then output F can be represented mathematically as F = X', Here apostrophe (') denotes the NOT (inversion) operation. There are a couple
of other ways to represent inversion, F= !X, here ! represents inversion. Truth table and NOT gate symbol is shown in the figurebelow.
Symbol
TruthTable
X Y=X'
0 1
1 0
71
NOT gate using "transistor-resistor" logic is shown in the figure below, where X is the input and F is theoutput.
Circuit
When X = 1, The transistor input pin 1 is HIGH, this produces the forward bias across the emitter base junction and so the transistor conducts. As the
collector current flows, the voltage drop across RL increases and hence F isLOW.
When X = 0, the transistor input pin 2 is LOW: this produces no bias voltage across the transistor base emitter junction. Thus Voltage at F isHIGH.
BUFGate
Buffer or BUF is also a gate with the exception that it does not perform any logical operation on its input. Buffers just pass input to output. Buffers are
used to increase the drive strength or sometime just to introduce delay. We will look at this in detaillater.
If X is the input, then output F can be represented mathematically as F = X. Truth table and symbol of the Buffer gate is shown in the figurebelow.
Symbol
TruthTable
X Y=X
0 0
1 1
NANDGate
NAND gate is a cascade of AND gate and NOT gate, as shown in the figure below. It has two or more inputs and only one output. The output of NAND
gate is HIGH when any one of its input is LOW (i.e. even if one input is LOW, Output will beHIGH).
71
If X and Y are two inputs, then output F can be represented mathematically as F = (X.Y)', Here dot (.) denotes the AND operation and (') denotes
inversion. Truth table and symbol of the N AND gate is shown in the figurebelow.
Symbol
TruthTable
X Y F=(X.Y)'
0 0 1
0 1 1
1 0 1
1 1 0
NOR Gate
NOR gate is a cascade of OR gate and NOT gate, as shown in the figure below. It has two or more inputs and only one output. The output of NOR gate is
HIGH when any all its inputs are LOW (i.e. even if one input is HIGH, output will beLOW).
Symbol
If X and Y are two inputs, then output F can be represented mathematically as F = (X+Y)'; here plus (+) denotes the OR operation and (') denotes
inversion. Truth table and symbol of the NOR gate is shown in the figurebelow.
TruthTable
71
X Y F=(X+Y)'
0 0 1
0 1 0
1 0 0
1 1 0
XORGate
An Exclusive-OR (XOR) gate is gate with two or three or more inputs and one output. The output of a two-input XOR gate assumes a HIGH state if one
and only one input assumes a HIGH state. This is equivalent to saying that the output is HIGH if either input X or input Y is HIGH exclusively, and LOW
when both are 1 or 0simultaneously.
If X and Y are two inputs, then output F can be represented mathematically asF= X Y, Here denotes the XOR operation. Y and is equivalent to
X.Y' + X'.Y. Truth table and symbol of the XOR gate is shown in the figurebelow.
Symbol
TruthTable
X Y F=(X Y)
0 0 0
0 1 1
1 0 1
1 1 0
XNOR Gate
An Exclusive-NOR (XNOR) gate is gate with two or three or more inputs and one output. The output of a two-input XNOR gate assumes a HIGH state if
all the inputs assumes same state. This is equivalent to saying that the output is HIGH if both input X and input Y is HIGH exclusively or same as input X
and input Y is LOW exclusively, and LOW when both are notsame.
If X and Y are two inputs, then output F can be represented mathematically asF= X Y, Here denotes the XNOR operation. Y and is equivalent
to X.Y + X'.Y'. Truth table and symbol of the XNOR gate is shown in the figurebelow.
71
Symbol
TruthTable
X Y F=(X Y)'
0 0 1
0 1 0
1 0 0
1 1 1
UniversalGates
Universal gates are the ones which can be used for implementing any gate like AND, OR and NOT, or any combination of these basic gates; NAND and
NOR gates are universal gates. But there are some rules that need to be followed when implementing NAND or NOR basedgates.
To facilitate the conversion to NAND and NOR logic, we have two new graphic symbols for thesegates.
NANDGate
NOR Gate
AnylogicfunctioncanbeimplementedusingNANDgates.Toachievethis,firstthelogic function has to be written in Sum of Product (SOP) form. Once logic
function is converted to SOP, then is very easy to implement using NAND gate. In other words any logic circuit with AND gates in first level and OR
gates in second level can be converted into a NAND-NAND gatecircuit.
71
Consider the following SOPexpression
F = W.X.Y + X.Y.Z +Y.Z.W
The above expression can be implemented with three AND gates in first stage and one OR gate in second stage as shown infigure.
If bubbles are introduced at AND gates output and OR gates inputs (the same for NOR gates), the above circuit becomes as shown infigure.
Now replace OR gate with input bubble with the NAND gate. Now we have circuit which is fully implemented with just NANDgates.
=(XY) Involution
=X''+Y'' DeMorgan
=X+Y Involution
=X''+Y'' DeMorgan
=X+Y Involution
=(X+Y)' Idempotent
71
Realization of logic function using NORgates
Any logic function can be implemented using NOR gates. To achieve this, first the logic function has to be written in Product of Sum (POS) form. Once it
is converted to POS, then it's very easy to implement using NOR gate. In other words any logic circuit with OR gates in first level and AND gates in
second level can be converted into a NOR- NOR gatecircuit.
The above expression can be implemented with three OR gates in first stage and one AND gate in second stage as shown infigure.
If bubble are introduced at the output of the OR gates and the inputs of AND gate, the above circuit becomes as shown infigure.
Now replace AND gate with input bubble with the NOR gate. Now we have circuit which is fully implemented with just NORgates.
71
Implementing an inverter using NORgate
=X''.Y'' DeMorgan
=(X.Y) Involution
=X+Y Involution
=X+Y Involution
=(X+Y)' Idempotent
71
CANONICAL AND STANDARDFORMS
A binary variable may appear either in its normal form (x) or in its complement form(x_).Now consider two binary variables x and y combined with an
AND operation.Sinceeachvariable may appear in either form, there are four possible combinations: x_y_, x_y,xy_,and xy. Each of these four AND terms
is called a minterm, or a standard product.Inasimilar manner, n variables can be combined to form 2n minterms. The 2n different mintermsmay be
determined by a method similar to the one shown in Table 2.3 for three variables.Thebinarynumbersfrom0to2n-1arelistedunderthenvariables.Eachminterm
is obtained from an AND term of the n variables, with each variable being primed if the corresponding bit of the binary number is a 0 and unprimed if a 1.
A symbolfor each minterm is also shown in the table and is of the form mj, where the subscriptjdenotes the decimal equivalent of the binary number of the
mintermdesignated.In a similar fashion, n variables forming an OR term, with each variable being primedor unprimed, provide 2 n possible combinations,
called maxterms, or standard sums.The eight maxterms for three variables, together with their symbolic designations, are listedin Table 2.3 . Any 2 n
maxterms for n variables may be determined similarly. It is importantto note that (1) each maxterm is obtained from an OR term of the n variables, with
each variable being unprimed if the corresponding bit is a 0 and primed if a 1, and (2)each maxterm is the complement of its corresponding minterm and
viceversa.A Boolean function can be expressed algebraically from a given truth table by forminga minterm for each combination of the variables
that produces a 1 in the functionand then taking the OR of all those terms. For example, the function f1 in Tableisdetermined by expressing the
combinations 001, 100, and 111 as x_y_z, xy_z_,andxyz,respectively. Since each one of these minterms results in f1 = 1,
wehavef1=x_y_z+xy_z_+xyz=m1+m4+m7
in memory. Each check bit is a parity over a group of bits in the data word. When the word is read back from memory, the associated parity bits are also
read from memory and compared with a new set of check bits generated from the data
that have been read. If the check bits are correct, no error has occurred. If the check bits do not match the stored parity, they generate a unique pattern,
called a syndrome,that can be used to identify the bit that is in error. A single error occurs when a bit changes in value from 1 to 0 or from 0 to 1 during
the write or read operation. If thespecific bit in error is identified, then the error can be corrected bycomplementing the erroneousbit.
HammingCode
71
One of the most common error‐correcting codes used in RAMs was devised by R. W.Hamming. In the Hamming code, k parity bits are added to an n ‐bit
data word, forminga new word of n + k bits. The bit positions are numbered in sequence from 1 to n+k.Those positions numbered as a power of 2 are
reserved for the parity bits. The remainingbits are the data bits. The code can be used with words of any length. Before giving the general characteristics
of the code, we will illustrate its operation with a data wordof eightbits. Consider, for example:the 8‐bit data word 11000100. We include 4 parity bits
with the 8‐bit word and arrange the 12 bits asfollows:
Bitposition: 1 2 3 4 5 6 7 8 9 10 11 12
P1 P2 1 P4 1 0 0 P8 0 1 0 0
71
KarnaughMaps
Karnaugh maps provide a systematic method to obtain simplified sum-of-products (SOPs) Boolean expressions. This is a compact way of
representing a truth table and is a technique that is used to simplify logic expressions. It is ideally suited for four or less variables, becoming
cumbersome for five or more variables. Each square represents either a minterm or maxterm. A K-map of n variables will have 2 squares. For a
Boolean expression, product terms are denoted by 1's, while sum terms are denoted by 0's - but 0's are often leftblank.
A K-map consists of a grid of squares, each square representing one canonical minterm combination of the variables or their inverse. The map is
arranged so that squares representing minterms which differ by only one variable are adjacent both vertically and horizontally. Therefore XY'Z'
would be adjacent to X'Y'Z' and would also adjacent to XY'Z andXYZ'.
MinimizationTechnique
2-VariableK-Map
In any K-Map, each square represents a minterm. Adjacent squares always differ by just one literal (So that the unifying theorem may apply: X +
X' = 1). For the 2-variable case (e.g.: variables X, Y), the map can be drawn as below. Two variable map is the one which has got only two
variables asinput.
Equivalentlabeling
K- map needs not follow the ordering as shown in the figure above. What this means is that we can change the position of m0, m1, m2, m3
of the above figure as shown in the two figuresbelow.
Position assignment is the same as the default k-maps positions. This is the one which we will be using throughout thistutorial.
This figure is with changed position of m0, m1, m2,m3.
The K-map for a function is specified by putting a '1' in the square corresponding to a minterm, a '0'otherwise.
In this example we have the truth table as input, and we have two output functions. Generally we may have n output functions for m input
variables. Since we have two output functions, we need to draw two k-maps (i.e. one for each function). Truth table of 1 bit adder is shown
below. Draw the k-map for Carry and Sum as shownbelow.
X Y Sum Carry
0 0 0 0
0 1 1 0
1 0 1 0
1 1 0 1
Grouping/CirclingK-maps
The power of K-maps is in minimizing the terms, K-maps can be minimized with the help of grouping the terms to form single terms. When
forming groups of squares, observe/consider thefollowing:
The map is considered to be folded or spherical, therefore squares at the end of a row or column are treated as adjacentsquares.
The simplified logic expression obtained from a K-map is not always unique. Groupings can be made in differentways.
Before drawing a K-map the logic expression must be in canonicalform.
L-
M-
N-
O- In the next few pages we will see some examples ongrouping.
P-
Q- Exa
mple of invalidgroups
R-
S-Example -X'Y+XY
In this example we have the equation as input, and we have one output function. Draw the k-map for function F with marking 1 for X'Y and XY
position. Now combine two 1's as shown in figure to form the single term. As you can see X and X' get canceled and only Yremains.
F =Y
Example -X'Y+XY+XY'
In this example we have the equation as input, and we have one output function. Draw the k-map for function F with marking 1 for X'Y, XY and
XY position. Now combine two 1's as shown in figure to form the two singleterms.
F=X+Y
3- VariableK-Map
There are 8 minterms for 3 variables (X, Y, Z). Therefore, there are 8 cells in a 3- variable K-map. One important thing to note is that K-maps
follow the gray code sequence, not the binaryone.
Using gray code arrangement ensures that minterms of adjacent cells differ by only ONE literal. (Other arrangements which
satisfy this criterion may also beused.)
Each cell in a 3-variable K-map has 3 adjacent neighbours. In general, each cell in an n- variable K-map has n
adjacentneighbours.
Example
F =XYZ'+XYZ+X'YZ
F = XY +YZ
Example
F(X,Y,Z) = (1,3,4,5,6,7)
F = X +Z
3- VariableK-Map
There are 16 cells in a 4-variable (W, X, Y, Z); K-map as shown in the figurebelow.
There are 2 wrap-around: a horizontal wrap-around and a vertical wrap-around. Every cell thus has 4 neighbours. For
example, the cell corresponding to minterm m0 has neighbours m1, m2, m4 andm8.
Example
F(W,X,Y,Z) =(1,5,12,13)
F = WY'Z +W'Y'Z
Example
F = W'XY' +WY
MinimizationTechnique
The expression is represented in the canonical SOP form if not already in that form.
The function is converted into numericnotation.
The numbers are converted into binaryform.
The minterms are arranged in a column divided intogroups.
Begin with the minimizationprocedure.
o Each minterm of one group is compared with each minterm in the group immediatelybelow.
o Each time a number is found in one group which is the same as a number in the group below except for
one digit, the numbers pair is ticked and a new composite iscreated.
o This composite number has the same number of digits as the numbers in the pair except the digit
different which is replaced by an"x".
The above procedure is repeated on the second column to generate a third column.
The next step is to identify the essential prime implicants, which can be done using a prime implicantchart.
o Where a prime implicant covers a minterm, the intersection of the corresponding row and column is
marked with across.
o Those columns with only one cross identify the essential primeimplicants.
-> These prime implicants must be in the finalanswer.
o The single crosses on a column are circled and all the crosses on the same row are also circled,
indicating that these crosses are covered by the prime implicantsselected.
o Once one cross on a column is circled, all the crosses on that column can be circled since the minterm
is nowcovered.
o If any non-essential prime implicant has all its crosses circled, the prime implicant is redundant and
need not be consideredfurther.
Next, a selection must be made from the remaining nonessential prime implicants, by considering how the non-
circled crosses can be coveredbest.
o One generally would take those prime implicants which cover the greatest number of crosses on
theirrow.
o If all the crosses in one row also occur on another row which includes further crosses, then the latter is
said to dominate the former and can be selected.
o The dominated prime implicant can then bedeleted.
Example
Find the minimal sum of products for theBoolean expression, f= (1,2,3,7,8,9,10,11,14,15), using Quine-
McCluskeymethod.
Firstly these minterms are represented in the binary form as shown in the table below. The above binary representations are
grouped into a number of sections in terms of the number of 1's as shown in the tablebelow.
Minterms U V W X
1 0 0 0 1
2 0 0 1 0
3 0 0 1 1
7 0 1 1 1
8 1 0 0 0
9 1 0 0 1
10 1 0 1 0
11 1 0 1 1
14 1 1 1 0
15 1 1 1 1
No of1's Minterms U V W X
1 1 0 0 0 1
1 2 0 0 1 0
1 8 1 0 0 0
2 3 0 0 1 1
2 9 1 0 0 1
2 10 1 0 1 0
3 7 0 1 1 1
3 11 1 0 1 1
3 14 1 1 1 0
4 15 1 1 1 1
Any two numbers in these groups which differ from each other by only one variable can be chosen and combined, to get 2-
cell combination, as shown in the tablebelow.
2-Cellcombinations
Combinations U V W X
(1,3) 0 0 - 1
(1,9) - 0 0 1
(2,3) 0 0 1 -
(2,10) - 0 1 0
(8,9) 1 0 0 -
(8,10) 1 0 - 0
(3,7) 0 - 1 1
(3,11) - 0 1 1
(9,11) 1 0 - 1
(10,11) 1 0 1 -
(10,14) 1 - 1 0
(7,15) - 1 1 1
(11,15) 1 - 1 1
(14,15) 1 1 1 -
From the 2-cell combinations, one variable and dash in the same position can be combined to form 4-cell combinations as
shown in the figurebelow.
4-Cellcombinations
Combinations U V W X
(1,3,9,11) - 0 - 1
(2,3,10,11) - 0 1 -
(8,9,10,11) 1 0 - -
(3,7,11,15) - - 1 1
(10,11,14,15) 1 - 1 -
The cells (1,3) and (9,11) form the same 4-cell combination as the cells (1,9) and (3,11). The order in which the cells are
placed in a combination does not have any effect. Thus the (1,3,9,11) combination could be written as(1,9,3,11).
From above 4-cell combination table, the prime implicants table can be plotted as shown in tablebelow.
Prime ImplicantsTable
Prime Implicants
1 2 3 7 8 9 10 11 14 15
(1,3,9,11) X - X - - X - X - -
(2,3,10,11) - X X - - - X X - -
(8,9,10,11) - - - - X X X X - -
(3,7,11,15) - - - - - - X X X X
- X X - X X - - - X -
The columns having only one cross mark correspond to essential prime implicants. A yellow cross is used against every
essential prime implicant. The prime implicants sum gives the function in its minimal SOPform.
AlgebraicManipulation
Minterms andMaxterms
Any boolean expression may be expressed in terms of either minterms or maxterms. To do this we must first define the
concept of a literal. A literal is a single variable within a term which may or may not be complemented. For an expression
with N variables, minterms and maxterms are defined as follows:
A minterm is the product of N distinct literals where each literal occurs exactly once.
A maxterm is the sum of N distinct literals where each literal occurs exactlyonce
0 0 X'.Y' X+Y
0 1 X'.Y X+Y'
1 0 X.Y' X'+Y
1 1 X.Y X'+Y'
7-
8-
9-For a three-variable expression, the minterms and maxterms are asfollows
10-
X Y Z Minterm Maxterm
0 0 0 X'.Y'.Z' X+Y+Z
0 0 1 X'.Y'.Z X+Y+Z'
0 1 0 X'.Y.Z' X+Y'+Z
0 1 1 X'.Y.Z X+Y'+Z'
1 0 0 X.Y'.Z' X'+Y+Z
1 0 1 X.Y'.Z X'+Y+Z'
1 1 0 X.Y.Z' X'+Y'+Z
1 1 1 X.Y.Z X'+Y'+Z'
11-
12-
13- This allows us to represent expressions in either Sum of Products or Product of Sums forms
14-
15- Sum Of Pr
16- The Sum of Products form represents an expression as a sum ofminterms.
17-
18- F(X, Y, ...) = Sum(ak.mk)
19-
20- where ak is 0 or 1 and mk is aminterm.
21-
22- To derive the Sum of Products form from a truth table, OR together all of the minterms which give a value of1.
23-
24- Example -S
25-
26- Consider the truthtable
27-
X Y F Minterm
0 0 0 X'.Y'
0 1 0 X'Y
1 0 1 X.Y'
1 1 1 X.Y
Product Of Sum(POS)
The Product of Sums form represents an expression as a product ofmaxterms. F(X, Y, .......) = Product (b k + Mk),
To derive the Product of Sums form from a truth table, AND together all of themaxterms
which give a value of0.
Example -POS
X Y F Maxterm
0 0 1 X+Y
0 1 0 X+Y'
1 0 1 X'+Y
1 1 1 X'+Y'
Exercise
Give the expression represented by the following truth table in both Sum of Products and Product of Sumsforms.
X Y Z F(X,Y,X)
0 0 0 1
0 0 1 0
0 1 0 0
0 1 1 1
1 0 0 0
1 0 1 1
1 1 0 1
1 1 1 0
Simplification
As with any other form of algebra you have encountered, simplification of expressions can be performed with
Booleanalgebra.
Example
Example
DON’T-CARECONDITIONS
The logical sum of the minterms associated with a Boolean function specifies the conditions
under which the function is equal to 1. The function is equal to 0 for the restof
the minterms. This pair of conditions assumes that all the combinations of the values
for the variables of the function are valid. In practice, in some applications the function
is not specified for certain combinations of the variables. As an example, the four- bit
binary code for the decimal digits has six combinations that are not used and consequently
are considered to be unspecified. Functions that have unspecified outputsfor
some input combinations are called incompletely specified functions . In most applications,
we simply don‟t care what value is assumed by the function for the unspecified minterms. For this reason, it is customary to
_(0, 2, 5).
The min terms of F are the variable combinations that make the function equal to
1. The Min terms of d are the don‟t-care min terms that may be assigned either 0or
1. The map simplification is shown in Fig. 3.15 . The min terms of F are marked by 1‟s, those of d are marked by X‟s, and
the remainingsquares are filled with 0‟s. To get the simplified expression in sum-of-products form, we must include allfive
1‟s in the map, but we may or may not include any of the X‟s, depending on the way the function is simplified. The term yz
covers the four min terms in the third column. The remaining min term, m1, can becombined.
with min term m3 to give the three-literal term w_x_z. However, by including one or two adjacent X‟s we can combine four
adjacent squares to give a two-literal term. In Fig. 3.15(a), don‟t-care min terms 0 and 2 are included with the 1‟s, resulting in
the simplifiedfunction
F = yz + w_x_ In Fig. 3.15(b), don‟t-care minterm 5 is included with the 1‟s, and the simplified function is now F = yz +w_z
Either one of the preceding two expressions satisfies the conditions stated for this example.
■
The previous example has shown that the don‟t-care minterms in the map are initially
marked with X‟s and are considered as being either 0 or 1. The choice between 0 and 1 is made depending on the way the
incompletely specified function is simplified.
Once the choice is made, the simplified function obtained will consist of a sum of minterms
that includes those minterms which were initially unspecified and have been chosen to be included with the 1‟s. Consider the
two simplified expressions
Both expressions include minterms 1, 3, 7, 11, and 15 that make the function F equal to 1. The don‟t-care minterms 0, 2, and 5
are treated differently in each expression. The first expression includes minterms 0 and 2 with the 1‟s and leaves
minterm5withthe0‟s.Thesecondexpressionincludesminterm5withthe1‟sand leaves minterms 0 and 2 with the 0‟s. The two
expressions represent two functions that are not algebraically equal. Both cover the specified minterms of the function, but each
covers different don‟t-care minterms. As far as the incompletely specified function is concerned, either expression is
acceptable because the only difference is in the value of F for the don‟t-care minterms. It is also possible to obtain a
simplified product-of-sums expression for the function of Fig. 3.15 . In this case, the only way to combine the 0‟s is to include
don‟t-care minterms 0 and 2 with the 0‟s to give a simplified complemented function: F_ = z_ + wy_ Taking the complement
of F_ gives the simplified expression in product-of-sumsform:
F (w, x, y, z) = z(w_ + y) = _(1, 3, 5, 7, 11,15)
Inthiscase,weincludeminterms0and2withthe0‟sandminterm5withthe1‟s.