### **Combinational logic topics**

- Logic functions, truth tables, and switches
  - NOT, AND, OR, NAND, NOR, XOR, . . .
  - minimal sét
- Axioms and theorems of Boolean algebra
  - proofs by re-writing
  - proofs by perfect induction
- Gate logic
  - networks of Boolean functions
  - I time behavior
- Canonical forms
- I two-level incompletely specified functions
- - Boolean cubes and Karnaugh maps
  - two-level simplification



### Cost of different logic functions

- Different functions are easier or harder to implement
  - each has a cost associated with the number of switches needed
  - 0 (F0) and 1 (F15): require 0 switches, directly connect output to low/high
  - X (F3) and Y (F5): require 0 switches, output is one of inputs
  - X' (F12) and Y' (F10): require 2 switches for "inverter" or NOT-gate
  - X nor Y (F4) and X nand Y (F14): require 4 switches X or Y (F7) and X and Y (F1): require 6 switches
  - I X = Y (F9) and X ⊕ Y (F6): require 16 switches
  - I thus, because NOT, NOR, and NAND are the cheapest they are the functions we implement the most in practice

### Minimal set of functions

- Can we implement all logic functions from NOT, NOR, and NAND?
  - For example, implementing X and Y is the same as implementing not (X nand Y)
- In fact, we can do it with only NOR or only NAND
  - I NOT is just a NAND or a NOR with both inputs tied together
    - 1 1 0 1 1 0

  - and NAND and NOR are "duals", that is, its easy to implement one using the other
    - $X \underline{\text{nand}} Y \equiv \underline{\text{not}} ( (\underline{\text{not}} X) \underline{\text{nor}} (\underline{\text{not}} Y) )$   $X \underline{\text{nor}} Y \equiv \underline{\text{not}} ( (\underline{\text{not}} X) \underline{\text{nand}} (\underline{\text{not}} Y) )$
- But let's not move too fast . .
  - let's look at the mathematical foundation of logic

### An algebraic structure

- An algebraic structure consists of
  - a set of elements B
  - binary operations { + , }
  - and a unary operation { ' } such that the following axioms hold:

### Boolean algebra

- Boolean algebra
  - B = {0,1}
  - + is logical OR, is logical AND
- is logical NOT
- All algebraic axioms hold

# Logic functions and Boolean algebra • Any logic function that can be expressed as a truth table can be written as an expression in Boolean algebra using the operators: ', +, and • Boolean expression that is true when the variables X and Y have the same value and false, otherwise X, Y are Boolean algebra variables

### Axioms and theorems of Boolean algebra identity 1. X + 0 = X 1D. X • 1 = X null 2. X + 1 = 1 2D. X • 0 = 0 idempotency: 3. X + X = X 3D. X • X = X involution: 4. (X')' = X complementarity: 5D. X • X' = 0 commutativity: 6. X + Y = Y + X 6D. $X \bullet Y = Y \bullet X$ associativity: 7. (X + Y) + Z = X + (Y + Z) 7D. $(X \cdot Y) \cdot Z = X \cdot (Y \cdot Z)$

### Axioms and theorems of Boolean algebra (cont'd)

```
distributivity:
        8. X \bullet (Y + Z) = (X \bullet Y) + (X \bullet Z) 8D. X + (Y \bullet Z) = (X + Y) \bullet (X + Z)
```

uniting: 9. X • Y + X • Y' = X 9D. (X + Y) • (X + Y') = X absorption:

factoring: (X + Z) • (X + Y)

concensus: 13.  $(X \bullet Y) + (Y \bullet Z) + (X' \bullet Z) =$  17D.  $(X + Y) \bullet (Y + Z) \bullet (X' + Z) =$   $X \bullet Y + X' \bullet Z$   $(X + Y) \bullet (X' + Z)$ 

### Axioms and theorems of Boolean algebra (cont')

de Morgan's: 14.  $(X + Y + ...)' = X' \bullet Y' \bullet ...$  12D.  $(X \bullet Y \bullet ...)' = X' + Y' + ...$ 

generalized de Morgan's: 15.  $f(X_1, X_2, ..., X_n, 0, 1, +, \bullet) = f(X_1, X_2, ..., X_n, 1, 0, \bullet, +)$ 

establishes relationship between • and +

### Axioms and theorems of Boolean algebra (cont')

- Duality

  - a dual of a Boolean expression is derived by replacing by +, + by •, 0 by 1, and 1 by 0, and leaving variables unchanged
  - I any theorem that can be proven is thus also proven for its dual!
  - I a meta-theorem (a theorem about theorems)
- duality: 16. X + Y + ... ⇔ X Y ...
- generalized duality: 17. f (X1 X2,...,Xn,0,1,+,•) ⇔ f(X1 X2,...,Xn,1,0,•,+)
- Different than deMorgan's Law
  - I this is a statement about theorems
  - I this is not a way to manipulate (re-write) expressions

### Proving theorems (rewriting)

Using the axioms of Boolean algebra:

e.g., prove the theorem:  $X \bullet Y + X \bullet Y' = X$ 

 $X \bullet Y + X \bullet Y' = X \bullet (Y + Y')$   $X \bullet (Y + Y') = X \bullet (1)$   $X \bullet (1) = X \Longrightarrow$ distributivity (8) complementarity (5) identity (1D)

e.g., prove the theorem: X + X • Y = X

> $\begin{array}{cccccccc} X + X \bullet Y & = & X \bullet 1 + X \bullet Y \\ X \bullet 1 + X \bullet Y & = & X \bullet (1 + Y) \\ X \bullet (1 + Y) & = & X \bullet (1) \\ X \bullet (1) & = & X \Longrightarrow \end{array}$ identity (1D) distributivity (8) identity (2) identity (1D)

# 











## Waveform view of logic functions Just a sideways truth table but note how edges don't line up exactly I it takes time for a gate to switch its output! time 100 X & Y Not (X & Y) X + Y Not (X + Y) X xor Y Not (X xor Y) change in Y takes time to "propagate" through gates



### Which realization is best?

Reduce number of inputs

- - literal: input variable (complemented or not)
    - can approximate cost of logic gate as 2 transitors per literal
    - why not count inverters?
  - I fewer literals means less transistors
    - smaller drouits
  - I fewer inputs implies faster gates
    - gates are smaller and thus also faster
  - I fan-ins (# of gate inputs) are limited in some technologies
- Reduce number of gates
  - fewer gates (and the packages they come in) means smaller circuits directly influences manufacturing costs

### Which is the best realization? (cont'd)

- Reduce number of levels of gates
  - fewer level of gates implies reduced signal propagation delays
  - minimum delay configuration typically requires more gates
  - wider, less deep drcuits
- How do we explore tradeoffs between increased circuit delay and size?
  - automated tools to generate different solutions
  - logic minimization: reduce number of gates and complexity
  - I logic optimization: reduction while trading off against delay

### Are all realizations equivalent?

- Under the same input stimuli, the three alternative implementations have almost the same waveform behavior
  - delays are different
  - glitches (hazards) may arise
  - variations due to differences in number of gate levels and structure
- The three implementations are functionally equivalent



### Implementing Boolean functions

- Technology independent
  - canonical forms
  - I two-level forms
  - I multi-level forms
- Technology choices
  - packages of a few gates
  - regular logic
  - two-level programmable logic
    multi-level programmable logic

# Canonical forms Truth table is the unique signature of a Boolean function Many alternative gate realizations may have the same truth table Canonical forms standard forms for a Boolean expression provides a unique algebraic signature







```
Product-of-sums canonical form (cont'd)

Sum term (or maxterm)

ORed sum of literals – input combination for which output is false
each variable appears exactly once, in true or inverted form (but not both)

A B C | maxterms | M5 | Fin canonical form:
F(A, B, C) = IIM(0,2,4) | M0 * M2 * M4 |
M1 0 1 0 A+B+C | M2 | M3 | M2 * M4 * M4 |
M3 1 0 0 A+B+C | M3 | M4 * M4 |
M4 1 0 1 1 A+B+C | M3 | Canonical form * minimal form |
M5 | M7 | M7 | M7 |
M6 | M8 + C | (A+B+C) (A+B+C) |
M7 | (A+B+C) (A+B+C) |
M8 | (A+B+C) (A+B+C) |
M9 | (A+B+C) (A+B+C) (A+B+C) (A+B+C) (A+B+C) |
M9 | (A+B+C) (A+B+C) (A+
```

```
S-o-P, P-o-S, and de Morgan's theorem

Sum-of-products

F' = A'B'C' + A'BC' + AB'C'

Apply de Morgan's

(A' F')' = (A'B'C' + A'BC' + AB'C')'

F = (A + B + C) (A + B' + C) (A' + B + C)

Product-of-sums

F' = (A + B + C') (A + B' + C') (A' + B + C') (A' + B' + C) (A' + B' + C')

Apply de Morgan's

(F')' = ((A + B + C')(A + B' + C')(A' + B + C')(A' + B' + C)(A' + B' + C))'

F = AB'C + A'BC + AB'C + ABC' + ABC

CSE 370 - Spring 2001 - Combinational Logic - 30
```





### Mapping between canonical forms

- Minterm to maxterm conversion
  - use maxterms whose indices do not appear in minterm expansion
  - e.g.,  $F(A,B,C) = \Sigma m(1,3,5,6,7) = \Pi M(0,2,4)$
- Maxterm to minterm conversion
  - use minterms whose indices do not appear in maxterm expansion
  - e.g.,  $F(A,B,C) = \Pi M(0,2,4) = \Sigma m(1,3,5,6,7)$
- Minterm expansion of F to minterm expansion of F'
  - use minterms whose indices do not appear
  - e.g.,  $F(A,B,C) = \Sigma m(1,3,5,6,7)$  $F'(A,B,C) = \Sigma m(0,2,4)$
- Maxterm expansion of F to maxterm expansion of F
  - use maxterms whose indices do not appear
  - e.g., F(A,B,C) = ΠM(0,2,4)
- $F'(A,B,C) = \Pi M(1,3,5,6,7)$



### Notation for incompletely specified functions

- Don't cares and canonical forms
  - I so far, only represented on-set
  - also represent don't-care-set
  - need two of the three sets (on-set, off-set, dc-set)
- Canonical representations of the BCD increment by 1 function:
  - I Z = m0 + m2 + m4 + m6 + m8 + d10 + d11 + d12 + d13 + d14 + d15
  - $Z = \Sigma [m(0,2,4,6,8) + d(10,11,12,13,14,15)]$
  - I Z = M1 M3 M5 M7 M9 D10 D11 D12 D13 D14 D15
  - $Z = \Pi [M(1,3,5,7,9) \bullet D(10,11,12,13,14,15)]$

### Simplification of two-level combinational logic

- Finding a minimal sum of products or product of sums realization
- exploit don't care information in the process
- Algebraic simplification
  - not an algorithmic/systematic procedure
  - I how do you know when the minimum realization has been found?
- Computer-aided design tools
  - precise solutions require very long computation times, especially for functions with many inputs (> 10) heuristic methods employed "educated guesses" to reduce amount of computation and yield good if not best solutions
- Hand methods still relevant
  - to understand automatic tools and their strengths and weaknesses
  - ability to check results (on small examples)













































# Implicant I single element of ON-set or DC-set or any group of these elements that can be combined to form a subcube Prime implicant I implicant that can't be combined with another to form a larger subcube Essential prime implicant I prime implicant is essential if it alone covers an element of ON-set I will participate in ALL possible covers of the ON-set DC-set used to form prime implicants but not to make implicant essential Objective: I grow implicant into prime implicants (minimize literals per term) cover the ON-set with as few prime implicants as possible (minimize number of product terms)



### Algorithm for two-level simplification

- Algorithm: minimum sum-of-products expression from a Karnaugh map
  - Step 1: choose an element of the ON-set
  - Step 2: find "maximal" groupings of 1s and Xs adjacent to that element
    - consider top/bottom row, left/right column, and corner adjacencies
    - this forms prime implicants (number of elements always a power of 2)
  - Repeat Steps 1 and 2 to find all prime implicants
  - I Step 3: revisit the 1s in the K-map
    - if covered by single prime implicant, it is essential, and participates in final cover
  - 1s covered by essential prime implicant do not need to be revisited
  - Step 4: if there remain 1s not covered by essential prime implicants
    - select the smallest number of prime implicants that cover the remaining 1s



### **Combinational logic summary**

- Logic functions, truth tables, and switches
- NOT, AND, OR, NAND, NOR, XOR, . . . , minimal set
- Axioms and theorems of Boolean algebra
  - proofs by re-writing and perfect induction
- Gate logic
  - I networks of Boolean functions and their time behavior
- Canonical forms
  - I two-level and incompletely specified functions
- Simplification
  - two-level simplification
- Later
  - automation of simplification
  - multi-level logic
  - design case studies time behavior