K Map
K Map
K Map
The minimum sum of products (MSOP) of a function, f, is a SOP representation of f that contains the fewest number of product terms and fewest number of literals of any SOP representation of f.
Is called sum of products. The + is sum operator which is an OR gate. The product such as xy is an AND gate for the two inputs x and y.
Example
Example
f(a,b,c,d) = m(3,7,11,12,13,14,15)
=a`b`cd + a`bcd + ab`cd + abc`d`+ abc`d + abcd` + abcd =cd(a`b` + a`b + ab`) + ab(c`d` + c`d + cd` + cd ) =cd(a`[b` + b] + ab`) + ab(c`[d` + d] + c[d` + d]) =cd(a`[1] + ab`) + ab(c`[1] + c[1]) =ab+ab`cd + a`cd =ab+cd(ab` + a`) =ab+ cd(a + a`)(a`+b`) = ab + a`cd + b`cd = ab +cd(a` + b`)
The minimum product of sums (MPOS) of a function, f, is a POS representation of f that contains the fewest number of sum terms and the fewest number of literals of any POS representation of f. The zeros are considered exactly the same as ones in the case of sum of product (SOP)
Example
f(a,b,c,d) = M(0,1,2,4,5,6,8,9,10) =m(3,7,11,12,13,14,15)
=[(a+b+c+d)(a+b+c+d`)(a+b`+c`+d`) (a`+b+c`+d`)(a`+b`+c+ d)(a`+b`+c+ d`) (a`+b`+c`+d)(a`+b`+c`+d`)]
Karnaugh maps -- A tool for representing Boolean functions of up to six variables. K-maps are tables of rows and columns with entries represent 1`s or 0`s of SOP and POS representations.
An n-variable K-map has 2n cells with each cell corresponding to an n-variable truth table value. K-map cells are labeled with the corresponding truth-table row. K-map cells are arranged such that adjacent cells correspond to truth rows that differ in only one bit position (logical adjacency).
If mi is a minterm of f, then place a 1 in cell i of the K-map. If Mi is a maxterm of f, then place a 0 in cell i.
Examples
A 0
B 0 1
1 1
0 1
f(A,B,C) = m(0,3,5)=
A`B`C`+A`BC+AB` C
C` 0 C 1
A`B` A`B 0 0 0 1
A B 1 1
A B` 1 0
1
A`B`C`
1
A`BC
1
AB`C
Maxterm example
(A+B) (A+B`) (A`+B`) (A`+B) A`B` A`B AB AB`
C
C` 0
0 0
C` C
f(A,B,C) = M(1,2,4,6,7)
=(A+B+C`)(A+B`+C)(A`+B+C) )(A`+B`+C) (A`+B`+C`) Note that the complements are (0,3,5) which are the minterms of the previous example
K-map cells that are physically adjacent are also logically adjacent. Also, cells on an edge of a K-map are logically adjacent to cells on the opposite edge of the map. If two logically adjacent cells both contain logical 1s, the two cells can be combined to eliminate the variable that has value 1 in one cells label and value 0 in the other.
This is equivalent to the algebraic operation, aP + a P =P where P is a product term not containing a or a. A group of cells can be combined only if all cells in the group have the same value for some set of variables.
Always combine as many cells in a group as possible. This will result in the fewest number of literals in the term that represents the group. Make as few groupings as possible to cover all minterms. This will result in the fewest product terms. Always begin with the largest group, which means if you can find eight members group is better than two four groups and one four group is better than pair of two-group.
Example Simplify f= A`BC`+ A B C`+ A B C Using: (a) Sum of minterms. (b) Maxterms.
Universal set A BC
BC 00
2
A 11
6 4
AB 10 C
0
A 00
2
01 1
01
6
11
4
10 0
0
1 3
1
7 5
0
1
0
3 7 5
C 1 B (b)
1 AB
C 1
B (c)
Example
AB CD
0
Simplify
f(A,B,C,D) = m(2,3,4,5,7,8,10,13,15)
A 00
4
AB 10 CD
0
A 00
4
01
12
11
8
01
12
11
8
10 1
00
1 5
1
13 9
1 1
15 11
00
1 5
1
13 9
01
3 7
1 1
2 6
01 D 11
10 3 7
1
15
1
11
11 C 10
1
14
1 C 1
1
2 6
1
14
1
10
10
B (a) AB CD
0
B (b) A AB 10
8
A 00
0 4
00
4
01
12
11
CD 00
1
01
12
11
8
10 1
00
1 5
1
13 9
1 1
15 11
1
5 13 9
01
3 7
1 1
2 6
01 D 11
10 3 7
1
15
1
11
11 C 10
1
14
1 C 1
1
2 6
1
14
1
10
10
B (c)
B (d)
A 00
4
AB 10 CD
0
A 00
4
AB 10 CD
0
A 00
4
01
12
11
8
01
12
11
8
01
12
11
8
10 1
00
1 5
1
13 9
1 1
15 11
00
1 5
1
13 9
1 1
15 11
00
1 5
1
13 9
01
3 7
1 1
2 6
01 D 11
10 3 7
1 1
2 6
01 D 11
10 3 7
1
15
1
11
11 C 10
1
14
1 C 1
1
14
1 C 1
1
2 6
1
14
1
10
10
10
B (a)
B (b)
B (c)
Note:-1. (c ) produces less terms than (a), therefore (c ) is correct 2. (b) is an intermediate step, only (c) is correct and complete grouping is done
f(A,B,C,D) = m(0,5,7,8,10,12,14,15)
AB CD
0
A 00
4
AB 10 CD
0
A 00
4
01
12
11
8
01
12
11
8
10 1
9
00
1
1
5 13
1
9
00
1
1
5 13
1 1
01
3 7
1
15 11
01 D 11
10 3 7
15
11
11 C 10
2 6
1
14
1 C 1 1
1
2 6 14
1
10
10
B (a) AB CD
0
B (b) A AB 10
8
A 00
0 4
00
4
01
12
11 1
CD 00
1
01
12
11
8
10 1
9
00
1
1
5 13
1
9
1
5 13
1 1
01
3 7
1
15 11
01 D 11
10 3 7
15
11
11 C 10
2 6
1
14
1 C 1 1
1
2 6 14
1
10
10
B (c)
B (d)
Example
Example
Example
f(A,B,C,D) = m(1,2,4,6,9)
Step 2 AB CD
0
A 00
4
01
12
11
8
10 Step 1
00
1 5
1
13 9
01
3
1
7 15 11
1 D
11 C 10
2 6 14 10
Step 3
AB C 0
1 3
BC
10
01
6
11
4
A 0
00
01 1
11 1
10 1 1
1
7
1
5
1 B
C 0 AB 00 01 11 10 1
1 1
1 1
Dont-care condition
Minterms that may produce either 0 or 1 for the function. They are marked with an in the K-map. This happens, for example, when we dont input certain minterms to the Boolean function. These dont-care conditions can be used to provide further simplification of the algebraic expression. (Example) F = A`B`C`+A`BC` + ABC` d=A`B`C +A`BC + AB`C F = A` + BC`
Example
F a , b , c , d m 0, 2, 6,8,12,13,15 d 3, 9,10
D=Dont care (i.e. either 1 or 0)
Four-variable K-Map
ab 00 cd 00 01 11 10 01 11 10
1 d
1 1 1
F a, b, c, d
Four-variable K-Map
ab 00 cd 00 01 11 10 01 11 10
1 d
1 1 1
F ac a d abd