

# Logic Circuits

↳ Composed of



↳ high-level classification.

- **Nodes**

- Inputs: A, B, C
- Outputs: Y, Z
- Internal: n1



- **Circuit elements**

- E1, E2, E3
- Each a circuit

↳ types of logic circuits.

↳ combinational → no memory  
→ output depends on current val of inputs.

↳ sequential → memory  
→ outputs dep. on current & prev inputs.

## Rules of Combinational Composition

- Every element is combinational
- Every node is either an input or connects to *exactly one* output
- The circuit contains no cyclic paths
- Example:



## Boolean Equations

this is an adder

- Functional specification of outputs in terms of inputs

- Example:**  $S = F(A, B, C_{in})$   
 $C_{out} = F(A, B, C_{in})$

$$0+1=1$$



$$\begin{aligned} S &= A \oplus B \oplus C_{in} \\ C_{out} &= AB + AC_{in} + BC_{in} \end{aligned}$$

$$0+1=1 \quad \frac{01}{2^1} \frac{1}{2^0}$$

© Digital Design and Computer Architecture, 2nd Edition, 2012



## Some Definitions

- Variable:** A, B, C... (without bars)
- Complement:** variable with a bar over it  
 $\bar{A}, \bar{B}, \bar{C}$
- Literal:** variable or its complement  
 $A, \bar{A}, B, \bar{B}, C, \bar{C}$
- Implicant:** product of literals  
 $ABC, \bar{A}C, BC$
- Minterm:** product that includes all input variables  
 $ABC, \bar{A}\bar{B}\bar{C}, \bar{A}BC$
- Maxterm:** sum that includes all input variables  
 $(A+\bar{B}+C), (\bar{A}+B+\bar{C}), (\bar{A}+\bar{B}+C)$



# Sum-of-Products (SOP) Form

- All equations can be written in SOP form
- Each row has a **minterm**
- A minterm is a **product** (AND) of literals
- Each minterm is **TRUE** for that row (and only that row)
- Form function by **ORing** minterms where **output is 1**
- Thus, a **sum** (OR) of products (AND terms)

| A | B | Y | minterm           | minterm name |
|---|---|---|-------------------|--------------|
| 0 | 0 | 0 | $\bar{A} \bar{B}$ | $m_0$        |
| 0 | 1 | 1 | $\bar{A} B$       | $m_1$        |
| 1 | 0 | 0 | $A \bar{B}$       | $m_2$        |
| 1 | 1 | 1 | $A B$             | $m_3$        |

$$Y = F(A, B) = \overline{AB} + AB = \Sigma(1, 3)$$



© Digital Design and Computer Architecture, 2nd Edition, 2012

AND      AND  
OR

# Product-of-Sums (POS) Form

- we are defining a different way because we want the default outcome to give us the desired outcome.*
- All Boolean equations can be written in POS form
  - Each row has a **maxterm**
  - A maxterm is a **sum** (OR) of literals
  - Each maxterm is **FALSE** for that row (and only that row)
  - Form function by **ANDing** maxterms where **output is 0**
  - Thus, a **product** (AND) of sums (OR terms)

*A=0*

| A | B | Y | maxterm             | maxterm name |
|---|---|---|---------------------|--------------|
| 0 | 0 | 0 | $A + B$             | $M_0$        |
| 0 | 1 | 1 | $A + \bar{B}$       | $M_1$        |
| 1 | 0 | 0 | $\bar{A} + B$       | $M_2$        |
| 1 | 1 | 1 | $\bar{A} + \bar{B}$ | $M_3$        |

$$Y = F(A, B) = (A + B)(\bar{A} + \bar{B}) = \Pi(0, 2)$$



© Digital Design and Computer Architecture, 2nd Edition, 2012

The 2 forms are related  $\bar{A}\bar{B} + A\bar{B} = (\bar{A} + B)(\bar{A} + \bar{B})$

An example.

## SOP & POS Form

- **SOP** – sum-of-products

| O | C | E | minterm           |
|---|---|---|-------------------|
| 0 | 0 | 0 | $\bar{O} \bar{C}$ |
| 0 | 1 | 0 | $\bar{O} C$       |
| 1 | 0 | 1 | $O \bar{C}$       |
| 1 | 1 | 0 | $O C$             |

$$E = O\bar{C}$$
$$= \Sigma(2)$$

- **POS** – product-of-sums

| O | C | E | maxterm             |
|---|---|---|---------------------|
| 0 | 0 | 0 | $O + C$             |
| 0 | 1 | 0 | $O + \bar{C}$       |
| 1 | 0 | 1 | $\bar{O} + C$       |
| 1 | 1 | 0 | $\bar{O} + \bar{C}$ |

$$E = (O + C)(O + \bar{C})(\bar{O} + C)$$
$$= \Pi(0, 1, 3)$$



An example of multiple-output circuit.

## Priority Circuit Hardware

| $A_3$ | $A_2$ | $A_1$ | $A_0$ | $Y_3$ | $Y_2$ | $Y_1$ | $Y_0$ |
|-------|-------|-------|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0     | 0     | 0     | 1     | 0     | 0     | 0     | 1     |
| 0     | 0     | 1     | 0     | 0     | 0     | 1     | 0     |
| 0     | 0     | 1     | 1     | 0     | 0     | 1     | 0     |
| 0     | 1     | 0     | 0     | 0     | 1     | 0     | 0     |
| 0     | 1     | 0     | 1     | 0     | 1     | 0     | 0     |
| 0     | 1     | 1     | 0     | 0     | 1     | 0     | 0     |
| 0     | 1     | 1     | 1     | 0     | 1     | 0     | 0     |
| 1     | 0     | 0     | 0     | 1     | 0     | 0     | 0     |
| 1     | 0     | 0     | 1     | 1     | 0     | 0     | 0     |
| 1     | 0     | 1     | 0     | 1     | 0     | 0     | 0     |
| 1     | 0     | 1     | 1     | 1     | 0     | 0     | 0     |
| 1     | 1     | 0     | 0     | 1     | 0     | 0     | 0     |
| 1     | 1     | 0     | 1     | 1     | 0     | 0     | 0     |
| 1     | 1     | 1     | 0     | 1     | 0     | 0     | 0     |
| 1     | 1     | 1     | 1     | 1     | 0     | 0     | 0     |



## ~~X~~-Notation:

# Don't Cares: X

| $A_3$ | $A_2$ | $A_1$ | $A_0$ | $Y_3$ | $Y_2$ | $Y_1$ | $Y_0$ |
|-------|-------|-------|-------|-------|-------|-------|-------|
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0     | 0     | 0     | 1     | 0     | 0     | 0     | 1     |
| 0     | 0     | 1     | 0     | 0     | 0     | 1     | 0     |
| 0     | 0     | 1     | 1     | 0     | 0     | 1     | 0     |
| 0     | 1     | 0     | 0     | 0     | 1     | 0     | 0     |
| 0     | 1     | 0     | 1     | 0     | 1     | 0     | 0     |
| 0     | 1     | 1     | 0     | 0     | 1     | 0     | 0     |
| 0     | 1     | 1     | 1     | 0     | 1     | 0     | 0     |
| 1     | 0     | 0     | 0     | 1     | 0     | 0     | 0     |
| 1     | 0     | 0     | 1     | 1     | 0     | 0     | 0     |
| 1     | 0     | 1     | 0     | 1     | 0     | 0     | 0     |
| 1     | 0     | 1     | 1     | 1     | 0     | 0     | 0     |
| 1     | 1     | 0     | 0     | 1     | 0     | 0     | 0     |
| 1     | 1     | 0     | 1     | 1     | 0     | 0     | 0     |
| 1     | 1     | 1     | 0     | 1     | 0     | 0     | 0     |
| 1     | 1     | 1     | 1     | 1     | 0     | 0     | 0     |

| $A_3$ | $A_2$ | $A_1$ | $A_0$ | $Y_3$ | $Y_2$ | $Y_1$ | $Y$ |
|-------|-------|-------|-------|-------|-------|-------|-----|
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0   |
| 0     | 0     | 0     | 1     | 0     | 0     | 0     | 1   |
| 0     | 0     | 1     | X     | 0     | 1     | X     | 1   |
| 0     | 1     | 0     | X     | 0     | 1     | X     | 1   |
| 0     | 1     | 1     | X     | 0     | 1     | X     | 1   |
| 1     | 0     | 0     | X     | 0     | 1     | X     | 1   |
| 1     | 0     | 1     | X     | 0     | 1     | X     | 1   |
| 1     | 1     | 0     | X     | 0     | 1     | X     | 1   |
| 1     | 1     | 1     | X     | 0     | 1     | X     | 1   |

© Digital Design and Computer Architecture, 2<sup>nd</sup> Edition, 2012



# Contention: X

- Contention: circuit tries to drive output to 1 **and** 0
  - Actual value somewhere in between
  - Could be 0, 1, or in forbidden zone
  - Might change with voltage, temperature, time, noise
  - Often causes excessive power dissipation



- Warnings:**
  - Contention usually indicates a **bug**.
  - X is used for**
    - “don’t care” in a truth table
    - and contention in logic simulation

© Digital Design and Computer Architecture, 2<sup>nd</sup> Edition, 2012



# Floating - Z

## Floating: Z

- Floating, high impedance, open, high Z
- Floating output might be 0, 1, or somewhere in between
  - A voltmeter won't indicate whether a node is floating



| E | A | Y |
|---|---|---|
| 0 | 0 | Z |
| 0 | 1 | Z |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

© Digital Design and Computer Architecture, 2<sup>nd</sup> Edition, 2012



## Tristate Busses

- Floating nodes are used in tristate busses
  - Many different drivers
  - Exactly one is active at once

*Z's value is  
set by the bus's  
state.*



© Digital Design and Computer Architecture, 2<sup>nd</sup> Edition, 2012



## Boolean Algebra

# Boolean Axioms

## Boolean Axioms

| Number | Axiom                           | Dual                         | Name         |
|--------|---------------------------------|------------------------------|--------------|
| A1     | $B = 0 \text{ if } B \neq 1$    | $B = 1 \text{ if } B \neq 0$ | Binary Field |
| A2     | $0 = \bar{1}$                   | $1 = \bar{0}$                | NOT          |
| A3     | $0 \bullet 0 = 0$               | $1 + 1 = 1$                  | AND/OR       |
| A4     | $1 \bullet 1 = 1$               | $0 + 0 = 0$                  | AND/OR       |
| A5     | $0 \bullet 1 = 1 \bullet 0 = 0$ | $1 + 0 = 0 + 1 = 1$          | AND/OR       |

**Dual:** Replace: • with +  
0 with 1

© Digital Design and Computer Architecture, 2<sup>nd</sup> Edition, 2012.



## Boolean Theorems of One Variable

| Number | Theorem                 | Name         |
|--------|-------------------------|--------------|
| T1     | $B \bullet 1 = B$       | Identity     |
| T2     | $B \bullet 0 = 0$       | Null Element |
| T3     | $B \bullet B = B$       | Idempotency  |
| T4     | $\bar{\bar{B}} = B$     | Involution   |
| T5     | $B \bullet \bar{B} = 0$ | Complements  |

© Digital Design and Computer Architecture, 2<sup>nd</sup> Edition, 2012.



## Boolean Theorems of One Variable

| Number | Theorem                 | Dual                | Name         |
|--------|-------------------------|---------------------|--------------|
| T1     | $B \bullet 1 = B$       | $B + 0 = B$         | Identity     |
| T2     | $B \bullet 0 = 0$       | $B + 1 = 1$         | Null Element |
| T3     | $B \bullet B = B$       | $B + B = B$         | Idempotency  |
| T4     |                         | $\bar{\bar{B}} = B$ | Involution   |
| T5     | $B \bullet \bar{B} = 0$ | $B + \bar{B} = 1$   | Complements  |

**Dual:** Replace: • with +  
0 with 1

T1: Identity Theorem

$$B \cdot 1 = B, \quad B + 0 = B$$

T2: Null Element Theorem

$$B \cdot 0 = 0, \quad B + 1 = 1$$

T3: Idempotency Theorem

$$B \cdot B = B, \quad B + B = B$$

T4: Identity Theorem

$$\bar{\bar{B}} = B, \quad B \cdot 0 \cdot \bar{D} = B$$

T5: Complement Theorem

$$\bar{B} \cdot \bar{B} = 0$$

$$\frac{B}{B} = 1$$