### EECS150 - Digital Design

# <u>Lecture 19 - Combinational Logic</u> <u>Circuits : A Deep Dive</u>

March 28, 2011 John Wawrzynek

Spring 2011 EECS150 - Lec19-cl Page 1

#### **Outline**

- Review of three representations for combinational logic:
  - truth tables,
  - graphical (logic gates), and
  - algebraic equations
- · Relationship among the three
- Adder example
- · Laws of Boolean Algebra
- · Canonical Forms
- · Boolean Simplification

# Combinational Logic (CL) Defined



 $y_i = f_i(x0, ..., xn-1)$ , where x, y are {0,1}. Y is a function of only X.

- If we change X, Y will change immediately (well almost!).
- There is an implementation dependent delay from X to Y.

Spring 2011 EECS150 - Lec19-cl Page 3

# CL Block Example #1



#### **Boolean Equation:**

$$y_0 = [x_0 \text{ AND not}(x_1)]$$

$$OR \text{ (not}(x_0) \text{ AND } x_1]$$

$$y_0 = x_0 x_1' + x_0' x_1$$

#### **Truth Table Description:**



#### **Gate Representation:**



How would we prove that all three representations are equivalent?

### **Boolean Algebra/Logic Circuits**

- Why are they called "logic circuits"?
- · Logic: The study of the principles of reasoning.
- The 19th Century Mathematician, George Boole, developed a math. system (algebra) involving logic, Boolean Algebra.
- · His variables took on TRUE, FALSE
- Later Claude Shannon (father of information theory) showed (in his Master's thesis!) how to map Boolean Algebra to digital circuits:



# Relationship Among Representations

\* Theorem: Any Boolean function that can be expressed as a truth table can be written as an expression in Boolean Algebra using AND, OR, NOT.



How do we convert from one to the other?

Spring 2011 EECS150 - Lec19-cl Page 6

# **CL Block Example #2**

· 4-bit adder:

Truth Table Representation:
 a3 a2 a1 a0 b3 b2 b1 b0 r3 r2 r1 r0 c



In general:  $2^n$  rows for n inputs.

256 rows!

0 0 0 0 1

Is there a more efficient (compact) way to specify this function?

0 0 0 1 1 1 1 1

 Spring 2011
 EECS150 - Lec19-cl
 Page 7

# 4-bit Adder Example

 Motivate the adder circuit design by hand addition:

a3 a2 a1 a0 + b3 b2 b1 b0 c r3 r2 r1 r0

Add a0 and b0 as follows:

| а | b                | r | С | • | carry to   |
|---|------------------|---|---|---|------------|
| 0 | 0<br>1<br>0<br>1 | 0 | 0 |   | next stage |
| U | 1                | 1 | U |   | •          |
| 1 | 0                | 1 | 0 |   |            |
| 1 | 1                | 0 | 1 |   |            |
|   |                  |   |   |   |            |

$$r = a XOR b = a \oplus b$$
  
 $c = a AND b = ab$ 

• Add a1 and b1 as follows:

| ci | а | b | r | CO |
|----|---|---|---|----|
| 0  | 0 | 0 | 0 | 0  |
| 0  | 0 | 1 | 1 | 0  |
| 0  | 1 | 0 | 1 | 0  |
| 0  | 1 | 1 | 0 | 1  |
| 1  | 0 | 0 | 1 | 0  |
| 1  | 0 | 1 | 0 | 1  |
| 1  | 1 | 0 | 0 | 1  |
| 1  | 1 | 1 | 1 | 1  |

$$r = a \oplus b \oplus c_i$$
  
 $co = ab + ac_i + bc_i$ 

# 4-bit Adder Example

· In general:

$$\begin{aligned} & r_i = a_i \oplus b_i \oplus c_{in} \\ & c_{out} = a_i c_{in} + a_i b_i + b_i c_{in} = c_{in} (a_i + b_i) + a_i b_i \end{aligned}$$



"Full adder cell"

· Now, the 4-bit adder:



"ripple" adder

Spring 2011 EECS150 - Lec19-cl Page 9

# 4-bit Adder Example

 Graphical Representation of FAcell

$$\textbf{r}_{i} = \textbf{a}_{i} \oplus \textbf{b}_{i} \oplus \textbf{c}_{in}$$

$$c_{out} = a_i c_{in} + a_i b_i + b_i c_{in}$$



 Alternative Implementation (with 2-input gates):

$$r_{i} = (a_{i} \oplus b_{i}) \oplus c_{in}$$
$$c_{out} = c_{in}(a_{i} + b_{i}) + a_{i}b_{i}$$



Page 10



Spring 2011 EECS150 - Lec19-cl

# **Boolean Algebra**

#### Defined as:

Set of elements B, binary operators  $\{+, \bullet\}$  unary operation  $\{'\}$ , such that the following axioms hold:

- 1. B contains at least two elements a, b such that  $a \neq b$ .
- 2. Closure: a,b in B, a+b in B,  $a \cdot b$  in B, a' in B.
- 3. Communitive laws:

$$a+b=b+a$$
,  $a \bullet b=b \bullet a$ .

4. Identities: 0, 1 in *B* 

$$a + 0 = a$$
,  $a \cdot 1 = a$ .

5. Distributive laws:

$$a + (b \bullet c) = (a + b) \bullet (a + c), \ a \bullet (b + c) = a \bullet b + a \bullet c.$$

6. Complement:

$$a + a' = 1$$
,  $a \cdot a' = 0$ .

Spring 2011

EECS150 - Lec19-cl

Page 11

### **Logic Functions**

$$B = \{0,1\}, + = OR, \bullet = AND, ' = NOT$$

is a valid Boolean Algebra.

#### Do the axioms hold?

- Ex: communitive law: 0+1 = 1+0?

Spring 2011

#### Other logic functions of 2 variables (x,y)



Look at NOR and NAND:



 Theorem: Any Boolean function that can be expressed as a truth table can be expressed using NAND and NOR.

- Proof sketch:  $\longrightarrow$  = NOT  $\longrightarrow$  = AND  $\longrightarrow$  = OR

- How would you show that either NAND or NOR is sufficient?

 Spring 2011
 EECS150 - Lec19-cl
 Page 13

#### Laws of Boolean Algebra

Duality: A dual of a Boolean expression is derived by interchanging OR and AND operations, and 0s and 1s (literals are left unchanged).

$$\{F(x_1, x_2, ..., x_n, 0, 1, +, \bullet)\}^D = \{F(x_1, x_2, ..., x_n, 1, 0, \bullet, +)\}$$

Any law that is true for an expression is also true for its dual.

Operations with 0 and 1:

$$1. x + 0 = x x * 1 = x$$

$$2. x + 1 = 1 x * 0 = 0$$

Idempotent Law:

$$3. x + x = x \qquad x x = x$$

Involution Law:

4. 
$$[x']' = x$$

Laws of Complementarity:

$$5. x + x' = 1 x x' = 0$$

Commutative Law:

6. 
$$x + y = y + x \quad x \quad y = y \quad x$$

Spring 2011

# Laws of Boolean Algebra (cont.)

Associative Laws:

$$(x + y) + z = x + (y + z)$$

$$x y z = x (y z)$$

Distributive Laws:

$$x (y + z) = (x y) + (x z)$$

$$x + (y z) = (x + y)(x + z)$$

"Simplification" Theorems:

$$(x + y) (x + y') = x$$
$$x (x + y) = x$$

DeMorgan's Law:

$$(x + y + z + ...)' = x'y'z'$$
  $(x y z ...)' = x' + y' + z'$ 

$$(x y z ...)' = x' + y' + z'$$

Theorem for Multiplying and Factoring:

$$(x + y)(x' + z) = xz + x'y$$

Consensus Theorem:

$$x y + y z + x' z = (x + y) (y + z) (x' + z)$$
  
 $x y + x' z = (x + y) (x' + z)$ 

Spring 2011

EECS150 - Lec19-cl

Page 15

# **Proving Theorems via axioms of Boolean Algebra**

Ex: prove the theorem: X y + X y' = X

$$xy + xy' = x(y + y')$$
 distributive law

$$x(y + y') = x(1)$$
 complementary law

$$x(1) = x$$
 identity

Ex: prove the theorem: X + X y = X

$$x + xy = x1 + xy$$
 identity

$$x 1 + x y = x (1 + y)$$
 distributive law

$$x(1+y) = x(1)$$
 identity

$$x(1) = x$$
 identity

Spring 2011 EECS150 - Lec19-cl Page 16

# **DeMorgan's Law**

 Spring 2011
 EECS150 - Lec19-cl
 Page 17

### Relationship Among Representations

\* Theorem: Any Boolean function that can be expressed as a truth table can be written as an expression in Boolean Algebra using AND, OR, NOT.



How do we convert from one to the other?

#### **Canonical Forms**

- Standard form for a Boolean expression unique algebraic expression directly from a true table (TT) description.
- Two Types:
  - \* Sum of Products (SOP)
  - \* Product of Sums (POS)
- Sum of Products (disjunctive normal form, minterm expansion).

#### Example:

| minterms | abc   f f' |                                         |
|----------|------------|-----------------------------------------|
| a'b'c'   | 00001      |                                         |
| a'b'c    | 00101      |                                         |
| a'bc'    | 01001      |                                         |
| a'bc     | 01110      | One product (and) term for each 1 in f: |
| ab'c'    | 100 10     | f = a'bc + ab'c' + ab'c +abc' +abc      |
| ab'c     | 10110      | f' = a'b'c' + a'b'c + a'bc'             |
| abc'     | 110 10     |                                         |
| abc      | 11110      |                                         |

 Spring 2011
 EECS150 - Lec19-cl
 Page 19

# Sum of Products (cont.)

#### Canonical Forms are usually not minimal:

#### Our Example:

Page 20

ing 2011 EECS150 - Lec19-cl

#### **Canonical Forms**

• Product of Sums (conjunctive normal form, maxterm expansion). Example:

```
maxterms a b c f f'

a+b+c 0 0 0 0 1

a+b+c' 0 0 1 0 1

a+b'+c 0 1 0 0 1

a+b'+c' 0 1 1 1 0

a'+b+c' 1 0 1 1 0

a'+b+c' 1 1 0 1 0

a'+b'+c 1 1 0 1 0

a'+b'+c' 1 1 1 1 0

a'+b'+c' 1 1 1 0 1 0
```

Mapping from SOP to POS (or POS to SOP): Derive truth table then proceed.

 Spring 2011
 EECS150 - Lec19-cl
 Page 21

### Algebraic Simplification Example

Ex: full adder (FA) carry out function (in canonical form):

$$Cout = a'bc + ab'c + abc' + abc$$

## **Algebraic Simplification**

```
Cout = a'bc + ab'c + abc' + abc

= a'bc + ab'c + abc' + abc + abc

= a'bc + abc + ab'c + abc' + abc

= (a' + a)bc + ab'c + abc' + abc

= (1)bc + ab'c + abc' + abc

= bc + ab'c + abc' + abc

= bc + ab'c + abc + abc' + abc

= bc + a(b' + b)c + abc' + abc

= bc + a(1)c + abc' + abc

= bc + ac + ab(c' + c)

= bc + ac + ab(1)

= bc + ac + ab
```

 Spring 2011
 EECS150 - Lec19-cl
 Page 23

### **Outline for remaining CL Topics**

- K-map method of two-level logic simplification
- Multi-level Logic
- NAND/NOR networks
- EXOR revisited

#### Algorithmic Two-level Logic Simplication

Key tool: The Uniting Theorem:

 Spring 2011
 EECS150 - Lec19-cl
 Page 25

### Karnaugh Map Method

 K-map is an alternative method of representing the TT and to help visual the adjacencies.



# Karnaugh Map Method

· Adjacent groups of 1's represent product terms



 Spring 2011
 EECS150 - Lec19-cl
 Page 27

# **K-map Simplification**

- 1. Draw K-map of the appropriate number of variables (between 2 and 6)
- 2. Fill in map with function values from truth table.
- 3. Form groups of 1's.
  - ✓ Dimensions of groups must be even powers of two (1x1, 1x2, 1x4, ..., 2x2, 2x4, ...)
  - ✓ Form as large as possible groups and as few groups as possible.
  - ✓ Groups can overlap (this helps make larger groups)
  - Remember K-map is periodical in all dimensions (groups can cross over edges of map and continue on other side)
- 4. For each group write a product term.
  - the term includes the "constant" variables (use the uncomplemented variable for a constant 1 and complemented variable for constant 0)
- 5. Form Boolean expression as sum-of-products.

## K-maps (cont.)



$$f = b'c' + ac$$



 Spring 2011
 EECS150 - Lec19-cl
 Page 29

#### **Product-of-Sums Version**

- 1. Form groups of 0's instead of 1's.
- 2. For each group write a sum term.
  - the term includes the "constant" variables (use the uncomplemented variable for a constant 0 and complemented variable for constant 1)
- 3. Form Boolean expression as product-of-sums.



$$f = (b' + c + d)(a' + c + d')(b + c + d')$$

#### **BCD** incrementer example

#### Binary Coded Decimal



 Spring 2011
 EECS150 - Lec19-cl
 Page 31

#### **BCD Incrementer Example**

- · Note one map for each output variable.
- Function includes "don't cares" (shown as "-" in the table).
  - These correspond to places in the function where we don't care about its value, because we don't expect some particular input patterns.
  - We are free to assign either 0 or 1 to each don't care in the function, as a means to increase group sizes.
- In general, you might choose to write product-ofsums or sum-of-products according to which one leads to a simpler expression.

# **BCD** incrementer example



 Spring 2011
 EECS150 - Lec19-cl
 Page 33

#### **BCD** incrementer example



Spring 2011 EECS150 - Lec19-cl

# **Higher Dimensional K-maps**





Spring 2011 EECS150 - Lec19-cl Page 35

### Multi-level Combinational Logic

- Example: reduced sum-of-products form x = adf + aef + bdf + bef + cdf + cef + q
- Implementation in 2-levels with gates:

cost: 17-input OR, 6 3-input AND

=> 50 transistors

delay: 3-input OR gate delay + 7-input AND gate delay



$$x = (a + b + c)(d + e)f + g$$

cost: 1 3-input OR, 2 2-input OR, 1 3-input AND

=> 20 transistors

delay: 3-input OR + 3-input AND + 2-input OR





Footnote: NAND would be used in place of all ANDs and ORs.

Page 36

#### Which is faster?

In general: Using multiple levels (more than 2) will reduce the cost. Sometimes also delay. Sometimes a tradeoff between cost and delay.

Spring 2011 EECS150 - Lec19-cl

# Multi-level Combinational Logic

Another Example: F = abc + abd + a'c'd' + b'c'd'



let 
$$x = ab y = c+d$$

$$f = xy + x'y'$$



Incorporates fanout.

No convenient hand methods exist for multi-level logic simplification:

- a) CAD Tools use sophisticated algorithms and heuristics
- b) Humans and tools often exploit some special structure (example adder)

Are these optimizations still relevant for LUT implementations?

 Spring 2011
 EECS150 - Lec19-cl
 Page 37

#### NAND-NAND & NOR-NOR Networks

DeMorgan's Law Review:

$$(a + b)' = a' b'$$

$$(a b)' = a' + b'$$

$$a + b = (a' b')'$$

$$(a b) = (a' + b')'$$

push bubbles or introduce in pairs or remove pairs: (x')' = x.

# NAND-NAND & NOR-NOR Networks

Mapping from AND/OR to NAND/NAND



 Spring 2011
 EECS150 - Lec19-cl
 Page 39

### NAND-NAND & NOR-NOR Networks

Mapping AND/OR to NOR/NOR

Mapping OR/AND to NOR/NOR



 OR/AND to NAND/NAND (by symmetry with above)



# Multi-level Networks

#### Convert to NANDs:

F = a(b + cd) + bc'



#### (note fanout)



Spring 2011 EECS150 - Lec19-cl

Page 41

Page 42

#### **EXOR Function**

Parity, addition mod 2

$$x \oplus y = x'y + xy'$$









Another approach:



if x=0 then y else y'

Spring 2011 EECS150 - Lec19-cl