

# EECS151/251A

# Introduction to Digital Design and ICs

## Lecture 5: Combinational Logic

### NVIDIA to Acquire Arm for \$40 Billion **Or not?**

NVIDIA and SoftBank Group Corp. (SBG) today announced a definitive agreement under which NVIDIA will acquire Arm Limited from SBG and the SoftBank Vision Fund (together, “SoftBank”) in a transaction valued at \$40 billion.

<https://nvidianews.nvidia.com/news/nvidia-to-acquire-arm-for-40-billion-creating-worlds-premier-computing-company-for-the-age-of-ai>

Sophia Shao



arm  NVIDIA.

# Review

- Verilog
  - Hardware description language: describe hardware!
  - Logic synthesis: Verilog -> Gate-level netlists
  - Used in both ASIC and Verilog
    - Modules
    - Structural vs behavioral
    - Operators and logic values
  - Combinational Circuits
    - Assign statement
    - Always blocks
  - Sequential Circuits
    - Always blocks
    - Blocking vs NonBlocking

# The Sequential always Block

## Combinational

```
module comb(input a, b, sel,
             output reg out);
    always @(*) begin
        if (sel) out = b;
        else out = a;
    end
endmodule
```

## Sequential

```
module seq(input a, b, sel, clk,
             output reg out);
    always @ (posedge clk) begin
        if (sel) out <= b;
        else out <= a;
    end
endmodule
```



# Blocking vs. Nonblocking Assignments

- Verilog supports two types of assignments within `always` blocks, with subtly different behaviors.
  - Blocking assignment (`=`): evaluation and assignment are immediate

```
always @(*) begin
    x = a | b;          // 1. evaluate a|b, assign result to x
    y = a ^ b ^ c;      // 2. evaluate a^b^c, assign result to y
    z = b & ~c;         // 3. evaluate b&(~c), assign result to z
end
```

- Nonblocking assignment (`<=`): all assignments deferred to end of simulation time step after all right-hand sides have been evaluated (even those in other active `always` blocks)

```
always @(*) begin
    x <= a | b;        // 1. evaluate a|b, but defer assignment to x
    y <= a ^ b ^ c;    // 2. evaluate a^b^c, but defer assignment to y
    z <= b & ~c;       // 3. evaluate b&(~c), but defer assignment to z
    // 4. end of time step: assign new values to x, y and z
end
```

# Assignment Styles for Sequential Logic

```
module blocking(
    input in, clk,
    output reg out
);
    reg q1, q2;
    always @ (posedge clk) begin
        q1 = in;
        q2 = q1;
        out = q2;
    end
endmodule
```

```
module nonblocking(
    input in, clk,
    output reg out
);
    reg q1, q2;
    always @ (posedge clk) begin
        q1 <= in;
        q2 <= q1;
        out <= q2;
    end
endmodule
```

# Use Nonblocking for Sequential Logic

```
always @ (posedge clk) begin  
    q1 = in;  
    q2 = q1; // uses new q1  
    out = q2; // uses new q2  
end
```

```
always @ (posedge clk) begin  
    q1 <= in;  
    q2 <= q1; // uses old q1  
    out <= q2; // uses old q2  
end
```

(“old” means value before clock edge, “new” means the value after most recent assignment)

“At each rising clock edge,  $q_1 = \text{in}$ .  
After that,  $q_2 = q_1$ .  
After that,  $\text{out} = q_2$ .  
Therefore  $\text{out} = \text{in}$ .”



“At each rising clock edge,  $q_1$ ,  $q_2$ , and  $\text{out}$  simultaneously receive the old values of  $\text{in}$ ,  $q_1$ , and  $q_2$ .”



- Blocking assignments **do not** reflect the intrinsic behavior of multi-stage sequential logic
- Guideline: use **nonblocking** assignments for sequential always blocks

# Simplified Verilog Guidelines

- Combinational logic:
  - Continuous Assignment:  
**assign** a = b & c;
  - Always block with @(\*)  
**always** @(\*) **begin**  
    a = b & c; // blocking statement  
**end**



- Sequential logic:
  - Always block with @(posedge clk)  
**always** @(posedge clk) **begin**  
    a <= b & c; // nonblocking statement  
**end**

# Verilog in EECS 151/251A

- We use behavioral modeling at the bottom of the hierarchy
- Use instantiation to:
  - 1) build hierarchy and,
  - 2) map to FPGA and ASIC resources not supported by synthesis.
- Use named ports.
- Verilog is a big language. This is only an introduction.
  - Harris & Harris book chapter 4 is a good source.
  - We will be introducing more useful constructs throughout the semester. Stay tuned!

# Final Thoughts on Verilog Examples

A large part of digital design is knowing how to write Verilog that gets you the desired circuit.

First understand the circuit you want then figure out how to code it in Verilog.

If you try to write Verilog without a clear idea of the desired circuit, you will struggle.

# Administrivia

- Hope you enjoy Lab 2!
- Lab 3 starts this week.
  - Don't fall behind.
- Hybrid instruction this week (semester).



- **Combinational Logic**

- **Introduction**
- **Boolean Algebra**
  - DeMorgan's Law
  - Sum of Products
  - Product of Sums

# Combinational Logic

- The outputs depend *\*only\** on the current values of the inputs.
  - Memoryless: compute the output values using the current inputs.
- If we change X, Y will change immediately (well almost!)
  - There is an implementation dependent delay from X to Y.



# Combinational Logic Example



Boolean Equations:

$$\begin{aligned} y &= a\bar{b} + \bar{a}b \\ &= a \text{ } XOR \text{ } b \end{aligned}$$

Truth Table Description:

| a | b | out |
|---|---|-----|
| 0 | 0 | 0   |
| 0 | 1 | 1   |
| 1 | 0 | 1   |
| 1 | 1 | 0   |

Gate Representations:



# Relationship Among Representations



# Boolean Algebra Background

- 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 in 1937.
  - Shannon's work became the foundation of digital circuit design.



# Boolean Algebra Fundamentals

- Two elements {0, 1}
- Two binary operators: AND ( $\cdot$ ), OR (+)
- One unary operator: NOT ( $\neg$ , ' )



| X | Y | Z |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |



| X | Y | Z |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 1 |



| X | Z |
|---|---|
| 0 | 1 |
| 1 | 0 |

# Boolean Operations of 2 variables

- Given two variables ( $x, y$ ), 16 logic functions

| X | Y | $F_0$ | $F_1$ | $F_2$ | $F_3$ | $F_4$ | $F_5$ | $F_6$ | $F_7$ | $F_8$ | $F_9$ | $F_A$ | $F_B$ | $F_C$ | $F_D$ | $F_E$ | $F_F$ |
|---|---|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0 | 0 | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
| 0 | 1 | 0     | 0     | 0     | 0     | 1     | 1     | 1     | 1     | 0     | 0     | 0     | 0     | 1     | 1     | 1     | 1     |
| 1 | 0 | 0     | 0     | 1     | 1     | 0     | 0     | 1     | 1     | 0     | 0     | 1     | 1     | 0     | 0     | 1     | 1     |
| 1 | 1 | 0     | 1     | 0     | 1     | 0     | 1     | 0     | 1     | 0     | 1     | 0     | 1     | 0     | 1     | 0     | 1     |

$$F_0 = 0 \quad F_1 = X \bullet Y \quad F_3 = X \quad F_5 = Y \quad F_7 = X + Y$$

$$F_A = \overline{Y} \quad F_F = 1 \quad F_C = \overline{X} \quad F_8 = \overline{X+Y}$$

$$F_6 = X \oplus Y \quad F_9 = \overline{X \oplus Y}$$

*XOR*

*NOR*

*XNOR*

*NAND*

# Decomposition in Digital Design

- For  $n$  inputs, need  $2^n$  rows in truth table.

- Truth Table Representation:



$$R = A + B,$$

c is carry out

| a <sub>3</sub> | a <sub>2</sub> | a <sub>1</sub> | a <sub>0</sub> | b <sub>3</sub> | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | r <sub>3</sub> | r <sub>2</sub> | r <sub>1</sub> | r <sub>0</sub> | c |   |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|---|---|
| 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0 | 0 |
| 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 1              | 0 | 0 |
| 0              | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 1              | 0              | 0 | 0 |
| 0              | 0              | 0              | 0              | 0              | 0              | 1              | 1              | 0              | 0              | 1              | 1              | 0 | 0 |
| 0              | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 1              | 0              | 0              | 0 | 0 |
| ⋮              |                |                |                |                |                |                |                | ⋮              |                |                |                |   |   |
| 0              | 0              | 1              | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 1              | 0              | 0 | 0 |
| 0              | 0              | 1              | 0              | 0              | 0              | 0              | 1              | 1              | 0              | 1              | 0              | 1 | 0 |
| ⋮              |                |                |                |                |                |                |                | ⋮              |                |                |                |   |   |
| 0              | 0              | 0              | 1              | 1              | 1              | 1              | 1              | 0              | 0              | 0              | 0              | 1 |   |

256  
rows!

# Decomposition in Digital Design

- Motivate the adder circuit design by hand addition:

$$\begin{array}{r} a_3 \ a_2 \ a_1 \boxed{a_0} \\ + b_3 \ b_2 \ b_1 \boxed{b_0} \\ \hline c \ r_3 \ r_2 \boxed{r_1} \boxed{r_0} \end{array}$$

- Add  $a_0$  and  $b_0$  as follows:

| a | b | r | c |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 1 |

carry to next stage

$$r = ab' + a'b = a \text{ XOR } b$$

$$c = a \text{ AND } b = ab$$

$$\begin{array}{r} a_3 \ a_2 \boxed{a_1} \ a_0 \\ + b_3 \ b_2 \boxed{b_1} \ b_0 \\ \hline c \ r_3 \ r_2 \boxed{r_1} \ r_0 \end{array}$$

- Add  $a_1$  and  $b_1$  as follows:

| ci | a | 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 \text{ XOR } b \text{ XOR } c_i$$

$$co = ab + (a + b)c_i$$

# Decomposition in Digital Design

- In general:

$$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$$

- Now, the 4-bit adder:





- **Combinational Logic**

- Introduction
- Boolean Algebra
  - DeMorgan's Law
  - Sum of Products
  - Product of Sums

# Laws of Boolean Algebra

- Identities:

- $X+0=X, X \cdot 1=X$
- $X+1=1, X \cdot 0=0$

- Idempotence:

- $X+X=X, X \cdot X=X$

- Complements:

- $X+X'=1, X \cdot X'=0$

- Commutative

- $X+Y=Y+X, X \cdot Y=Y \cdot X$

- Associative:

- $(X + Y) + Z = X + (Y + Z) = X + Y + Z$
- $(X \cdot Y) \cdot Z = X \cdot (Y \cdot Z) = X \cdot Y \cdot Z$

- Distributive:

- $X \cdot (Y+Z) = (X \cdot Y) + (X \cdot Z)$
- $X + (Y \cdot Z) = (X+Y) \cdot (X+Z)$

- Duality

- AND  $\rightarrow$  OR and vice versa
- 0  $\rightarrow$  1 and vice versa
- Leave literals unchanged

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

# DeMorgan's Law

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



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



| $x'$ | $y'$ | $x' y'$ |
|------|------|---------|
| 1    | 1    | 1       |
| 1    | 0    | 0       |
| 0    | 1    | 0       |
| 0    | 0    | 0       |

| $x$ | $y$ | $(x + y)'$ |
|-----|-----|------------|
| 0   | 0   | 1          |
| 0   | 1   | 0          |
| 1   | 0   | 0          |
| 1   | 1   | 0          |

| $x'$ | $y'$ | $x' + y'$ |
|------|------|-----------|
| 1    | 1    | 1         |
| 1    | 0    | 1         |
| 0    | 1    | 1         |
| 0    | 0    | 0         |

| $x$ | $y$ | $(x y)'$ |
|-----|-----|----------|
| 0   | 0   | 1        |
| 0   | 1   | 1        |
| 1   | 0   | 1        |
| 1   | 1   | 0        |

# DeMorgan's Law

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



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



- The product of the complement of each term.
  - Is equal to the complement of the sum of all the terms
- The sum of the complement of each term.
  - Is equal to the complement of the product of all the terms
- Powerful tool in digital design
  - A NAND gate is equivalent to an OR gate with inverted inputs.
  - A NOR gate is equivalent to an AND gate with inverted inputs.
- Bubble Pushing
  - Pushing a bubble from input through the gate
    - Bubble comes out in the output
    - The gate flips from AND to OR or vice versa.

# DeMorgan's Law

- Mapping from AND/OR  $\rightarrow$  NAND/NOR

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



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



# Relationship Among Representations



# Canonical Forms

- From truth table -> Boolean Expression
- Two types:
  - Sum of Products (SOP)
  - Product of Sums (POS)
- Sum of Products
  - a.k.a Disjunctive normal form, minterm expansion
  - Minterm: a product (AND) involving all inputs for the term to be 1
  - SOP: Summing minterms for which the output is True

| Minterms | a | b | c | f | f' |
|----------|---|---|---|---|----|
| a'b'c'   | 0 | 0 | 0 | 0 | 1  |
| a'b'c    | 0 | 0 | 1 | 0 | 1  |
| a'bc'    | 0 | 1 | 0 | 0 | 1  |
| a'bc     | 0 | 1 | 1 | 1 | 0  |
| ab'c'    | 1 | 0 | 0 | 1 | 0  |
| ab'c     | 1 | 0 | 1 | 1 | 0  |
| abc'     | 1 | 1 | 0 | 1 | 0  |
| abc      | 1 | 1 | 1 | 1 | 0  |

One product (and) term for each 1 in f:

$$f = a'b'c + ab'c' + ab'c + abc' + abc$$

$$f' = a'b'c' + a'b'c + a'bc'$$

# Quiz

- Derive the sum of products form of  $\bar{Y}$  based on the truth table.

a)  $\bar{Y} = (A + B)(A + \bar{B})$

b)  $\bar{Y} = A\bar{B} + AB$

c)  $\bar{Y} = \bar{A}\bar{B} + \bar{A}B$

| A | B | Y | $\bar{Y}$ |
|---|---|---|-----------|
| 0 | 0 | 0 | 1         |
| 0 | 1 | 0 | 1         |
| 1 | 0 | 1 | 0         |
| 1 | 1 | 1 | 0         |

# Simplifying Sum of Products

- Canonical Forms are usually not minimal:
- Example:

$$\begin{aligned}f &= a'b'c + ab'c' + ab'c + abc' + abc \quad (xy' + xy = x) \\&= a'b'c + ab' + ab \\&= a'b'c + a \\&= a + bc\end{aligned}$$

$$\begin{aligned}f' &= a'b'c' + a'b'c + a'bc' \\&= a'b' + a'bc' \\&= a' ( b' + bc' ) \\&= a' ( b' + c' )\end{aligned}$$

$$x + x'y = x + y$$

- Recall distributive theorem  
 $X+YZ = (X+Y)(X+Z)$

# Canonical Forms

- From truth table -> Boolean Expression
- Two types:
  - Sum of Products (SOP)
  - Product of Sums (POS)
- Product of Sums:
  - a.k.a. conjunctive normal form, maxterm expansion
  - Maxterm: a sum (OR) involving all inputs for the term to be 0.
  - POS: Product (AND) maxterms for which the output is FALSE
  - Can obtain POSs from applying DeMorgan's law to the SOPs of F (and vice versa)

| 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 | 0 | 1 | 0  |
| a'+b+c'  | 1 | 0 | 1 | 1 | 0  |
| a'+b'+c  | 1 | 1 | 0 | 1 | 0  |
| a'+b'+c' | 1 | 1 | 1 | 1 | 0  |

One sum (**or**) term for each 0 in f:

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

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

# Summary

- Combinational circuits:
  - The outputs only depend on the current values of the inputs (memoryless).
  - The functional specification of a combinational circuit can be expressed as:
    - A truth table
    - A Boolean equation
- Boolean algebra
  - Deal with variables that are either True or False.
  - Map naturally to hardware logic gates.
  - Use theorems of Boolean algebra and Karnaugh maps to simplify equations.
- Common job interview questions ☺