# Boolean Algebra and Logic Synthesis

#### Reminders:

- Lab 2 due Thursday
- Bash tutorial in lab on Thursday 7:30pm

#### Reminder: Combinational Devices

A <u>combinational device</u> is a circuit element that has

- one or more digital inputs
- one or more digital outputs
- a functional specification that details the value of each output for every possible combination of valid input values
- a timing specification consisting (at a minimum) of a propagation delay (t<sub>PD</sub>): an upper bound on the required time to produce valid, stable output values from an arbitrary set of valid, stable input values

Static discipline



February 25, 2020 MIT 6.004 Spring 2020 L06-2

## Reminder: Composing Combinational Devices

A set of interconnected elements is a combinational device if

- each circuit element is combinational
- every input is connected to exactly one output or to a constant (0 or 1)
- the circuit contains no directed cycles

Cycles can cause feedback loops that prevent output from reaching a known or stable value! Example:



## **Functional Specifications**

 There are many ways to specify the function of a combinational device



- We will use two systematic approaches:
  - Truth tables enumerate the output values of input values
  - Boolean expressions are equations containing binary (0/1) variables and three operations: AND (⋅), OR (+), and NOT (overbar)

$$Y = \bar{C} \cdot A + C \cdot B$$

Truth Table

| C | В | A | Y |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | 0 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 |

Any combinational function can be specified as a truth table or Boolean expression

## **Timing Specifications**

 Propagation delay (t<sub>PD</sub>): An upper bound on the delay from valid inputs to valid outputs



- Contamination delay (t<sub>CD</sub>): A lower bound on the delay from invalid inputs to invalid outputs
   A Starte to change
  - Used later (for sequential logic), can ignore for now

#### The Combinational Contract





No promises during XXXXX

## Boolean Algebra

How to interpret and manipulate Boolean expressions

## Boolean Algebra

- Boolean algebra comprises
  - Two elements, 0 and 1
  - Two binary operators, AND (·) and OR (+)
     One unary operator, NOT (overbar)

| а | b | a∙b | а | b | a+b | а | ā |
|---|---|-----|---|---|-----|---|---|
| 0 | 0 | 0   | 0 | 0 | 0   | 0 | 1 |
| 0 | 1 | 0   | 0 | 1 | 1   | 1 | 0 |
| 1 | 0 | 0   | 1 | 0 | 1   |   |   |
| 1 | 1 | 1   | 1 | 1 | 1   |   |   |

 All of Boolean algebra can be derived from the definitions of AND, OR, and NOT

## Boolean Algebra Axioms

 Instead of using truth tables to define AND, OR, and NOT, we can derive all of Boolean algebra using a small set of axioms:

| identity | 心性<br>a·1=a        | a+0=a              |
|----------|--------------------|--------------------|
| null     | a·0=0              | a+1=1              |
| negation | $\overline{0} = 1$ | $\overline{1} = 0$ |

对偏原程、

- Duality principle: If a Boolean expression is true, then replacing 0 ↔ 1 and AND ↔ OR yields another expression that is true
  - This principle holds for the axioms → Holds for all expressions
  - Halves the number of expressions you have to learn ©

## Useful Boolean Algebra Properties

 Using the axioms, we can derive several useful properties to manipulate and simplify Boolean expressions:

commutative 
$$a \cdot b = b \cdot a$$
  $a+b=b+a$  associative  $a \cdot (b \cdot c) = (a \cdot b) \cdot c$   $a+(b+c) = (a+b)+c$  distributive  $a \cdot (b+c) = a \cdot b+a \cdot c$   $a+b \cdot c = (a+b) \cdot (a+c)$  complements  $a \cdot \overline{a} = 0$   $a+\overline{a} = 1$  absorption  $a \cdot (a+b) = a$   $a+a \cdot b = a$  reduction  $a \cdot b + a \cdot \overline{b} = a$   $(a+b) \cdot (a+\overline{b}) = a$  DeMorgan's Law  $\overline{a \cdot b} = \overline{a} + \overline{b}$   $\overline{a+b} = \overline{a} \cdot \overline{b}$ 

## Useful Boolean Algebra Properties

- Many of these properties are easy to remember because they match the ones for integer algebra, but be aware of the differences
  - e.g., distributive property for Boolean "+" a+b·c = (a+b)·(a+c) does not hold for integer "+"!
- To familiarize yourself with the properties, we recommend that you simply prove them
  - Example: DeMorgan's Law

| a | b | a⋅b | <u>a</u> + <u>b</u> |
|---|---|-----|---------------------|
| 0 | 0 | 1   | 1                   |
| 0 | 1 | 1   | 1                   |
| 1 | 0 | 1   | 1                   |
| 1 | 1 | 0   | 0                   |

### Equivalence and Normal Form

 Given a truth table, it is easy to derive an equivalent Boolean expression: write a sum of products where each product term covers a single 1 in the truth table



- This representation is called the function's normal form
  - It is unique, but there may be simpler expressions

# Logic Synthesis

Building logic circuits from Boolean expressions

## From Boolean Algebra to Gates

- A logic diagram represents a Boolean expression as a circuit schematic with logic gates and wires
- Basic logic gates:

 We often use AND and OR gates with more than two inputs

$$A = B$$
 $C = D$ 
 $Z = A \cdot B \cdot C \cdot D$ 

AND, OR, and NOT are universal: They can implement any combinational function Why?

## Straightforward Logic Synthesis

- We can implement any sum-of-products (SOP) Boolean expression with three levels of gates:
  - 1. Inverters
  - 2. ANDs
  - 3. OR
- However, we can often implement the same function with fewer gates. This requires simplifying its Boolean expression to use fewer operations.

$$Y = \overline{C}\overline{B}A + \overline{C}BA + CB\overline{A} + CBA$$



## Boolean Simplification of SOPs

- A minimal sum-of-products is a sum-of-products expression that has the smallest possible number of AND and OR operators
  - Unlike the normal form, it is not unique (a function may have multiple minimal SOPs)
  - Minimal SOPs can be implemented with fewer gates
- Simple algebraic manipulation (using the properties we've seen) is sufficient to minimize small expressions (3-4 variables)

$$Y = \overline{CBA} + \overline{CBA} + \overline{CBA} + \overline{CBA}$$
reduction
$$Y = \overline{CBA} + \overline{CBA}$$
reduction
$$Y = \overline{CA} + \overline{CBA}$$

More sophisticated techniques exist (e.g., K-maps),
 but we will not need them in this course

#### Truth Tables with "Don't Cares"

Another way to reveal simplification is to rewrite the truth table using "don't cares" (--, X, or ?) to indicate when the value of a particular input is irrelevant in determining the value of the output.



Note: Some input combinations (e.g., 000) are matched by more than one row in the "don't care" table. It would be a bug if all matching fows didn't specify the same output value!

### 多层级

## Multi-Level Boolean Simplification



- We can often reduce the number of gates by using more logic levels than an SOP
  - Find common subexpressions and factor them out into independent variables
- Example:  $F = A \cdot C + B \cdot C + A \cdot D + B \cdot D$  (minimal SOP)

$$F = (A+B)\cdot C + (A+B)\cdot D \qquad (not SOP)$$

$$X = A + B$$
  
 $F = X \cdot C + X \cdot D$ 



- Multi-level simplification has no well-defined optimum
  - Adding levels may reduce gates but increase delay

## Logic Optimization

In practice, tools use Boolean simplification and other techniques to synthesize a circuit that meets certain area, delay, and power goals:



#### Other Common Gates

XOR (Exclusive-OR)



Inverting logic

**NAND** 

$$A \circ B \circ Z = \overline{A \cdot B} \circ A \circ B \circ B \circ B$$

NOR

$$A \circ B \circ Z = \overline{A + B}$$

## Universal Building Blocks

NANDs and NORs are <u>universal</u>:



Any logic function can be implemented using only NANDs (or, equivalently, NORs)

## Standard Cell Library

- Library of gates and their physical characteristics
- Example:

| Gate     | Delay<br>(ps) | Area<br>(μ²) |
|----------|---------------|--------------|
| Inverter | 20            | 10           |
| Buffer   | 40            | 20           |
| AND2     | 50            | 25           |
| NAND2    | 30            | 15           |
| OR2      | 55            | 26           |
| NOR2     | 35            | 16           |
| AND4     | 90            | 40           |
| NAND4    | 70            | 30           |
| OR4      | 100           | 42           |
| NOR4     | 80            | 32           |

#### **Observations:**

- In current technology (CMOS), inverting gates are faster and smaller
- 2. Delay and area grow with number of inputs

## Design Tradeoffs: Delay vs Size



## Example: Mapping a Circuit to a Standard Cell Library

Find an implementation of a circuit, e.g.,



Using gates from a standard cell library, e.g.,



That optimizes for some goal, e.g., minimum area

## Example: Mapping a Circuit to a Standard Cell Library

#### Possible implementations:



$$7 \text{ NAND2 } (3) = 21$$
  
 $5 \text{ INV } (2) = 10$ 



$$7 \text{ NP}$$
 $2 \text{ INV} = 4$ 
 $1 \text{ NAND3} = 4$ 
 $1 \text{ NAND4} = 5$ 

Total area cost: 31 Total area cost: 19

## Logic Optimization Takeaways

- Synthesizing an optimized circuit is a very complex problem
  - Boolean simplification
  - Mapping to cell libraries with many gates
  - Multidimensional tradeoffs (e.g., minimize area-delaypower product)
- Infeasible to do by hand for all but the smallest circuits!
- Instead, hardware designers write circuits in a hardware description language, and use a synthesis tool to derive optimized implementations

### Summary

- Any combinational (Boolean) function can be specified by a truth table or a Boolean expression (binary literals and AND, OR, NOT, which form a Boolean algebra)
- Any combinational function can be expressed as a sumof-products (SOP) and implemented with three levels of logic gates (NOTs, ANDs, OR)
- Boolean simplification (finding a minimal SOP, multilevel simplification) results in simpler circuits
- There are MANY design tradeoffs in mapping Boolean functions to gates. We will use synthesis tools to find optimized circuit implementations

## Thank you!

Next lecture: CMOS