# Lecture 4: Gate-level Minimisation II

CS207: Digital Logic

#### Jialin Liu

Department of Computer Science and Engineering (CSE) Southern University of Science and Technology (SUSTech)

30 September 2022

# Acknowledgement



These slides were prepared based on the slides by Dr. Jianqiao Yu and the ones by Prof. Georgios Theodoropoulos of the Department of CSE at the SUSTech, as well as the contents of the following book:

M. M. Mano and M. Ciletti, *Digital design: with an introduction to the Verilog HDL*. Pearson, 2013

### Outline of This Lecture



#### Review of Last Week

NAND and NOR Implementation

Other Two-Level Implementations

Exclusive-OR Function

# Recap: The Map Method for Gate-level Minimisation I



#### Karnaugh map

- The map is a diagram consisting of **squares** or **cells**. For n variables on a Karnaugh map there are  $2^n$  numbers of squares.
- Each square represents one of the minterms of the function that is to be minimised.
- Since any Boolean function can be expressed as a sum of minterms, it is possible to recognise a Boolean function graphically in the map from the area enclosed by those squares whose minterms appear in the function.





| AB/CI | 00    | 01    | 11       |       |
|-------|-------|-------|----------|-------|
| 00    | $m_0$ | $m_1$ | $m_3$    | $m_2$ |
| 01    | $m_4$ | $m_5$ | $m_7$    | $m_6$ |
| 11    |       |       | $m_{15}$ |       |
| 10    |       |       | $m_{11}$ |       |

## Recap: The Map Method for Gate-level Minimisation II



#### Properties of the adjacent squares:

- Any two adjacent squares in the Karnaugh map differ by only one variable, which is complemented in one square and uncomplemented in one of the adjacent squares.
- ► The sum of two minterms in adjacent squares can be simplified to a single AND term consisting of fewer literals.

#### Remarks:

- The simplified expressions produced by the map are always in one of the two standard forms: sum of products or product of sums.
  - → So we can use either a map of minterms or a map of maxterms.
- ► The simplest algebraic expression is an algebraic expression with a minimum number of terms and with the smallest possible number of literals in each term.
- ▶ The simplest expression is not unique. In that case, either solution is satisfactory.

## Recap: K-map of Maxterms



- ▶ When an expression is given in respect to the maxterms. In a K-map, 0's are to placed instead of 1's at the corresponding maxterm squares.
- ► Two ways of simplifying an expression:
  - Way 1: Simplify the expression using properties of the adjacent squares (combining the pairs, quads, octets of adjacent squares of 0's).
  - Way 2: Consider the 1's of the K-map. Thus, combining the pairs, quads, octets of adjacent squares of 1's.

### Outline of This Lecture



Review of Last Week

NAND and NOR Implementation
NAND Circuits
NOR Circuits

Other Two-Level Implementations

Exclusive-OR Function

### NAND and NOR Implementation



- ► Recap: NAND gates (与非门) and NOR gates (或非门) are called universal gates or universal building blocks.
  - Any type of gates or logic functions can be implemented by these gates.
- Digital circuits are frequently constructed with NAND or NOR gates rather than with AND and OR gates.
  - NAND and NOR gates are easier to fabricate with electronic components.
  - They are the basic gates used in all IC digital logic families.
- Rules and procedures have been developed for the conversion from Boolean functions given in terms of AND, OR, and NOT into equivalent NAND and NOR logic diagrams.

### Outline



Review of Last Week

NAND and NOR Implementation NAND Circuits

Other Two-Level Implementations

Exclusive-OR. Function



- ► The NAND gate is said to be a universal gate.
- ► A convenient way to implement a Boolean function with NAND gates:
  - 1. Obtain the simplified Boolean function in terms of Boolean operators.
  - 2. Convert the function to NAND logic.
- Recall that:





Fall 2022 CS207: Digital Logic 10



► To facilitate the conversion to NAND logic, it is convenient to define an alternative graphic symbol for the gate.

AND-invert:

$$A = B = A + B' + C'$$

Invert-OR:



- ► The implementation of Boolean functions with NAND gates requires that the functions be in sum-of-products form.
  - ► Take F = AB + CD as an example:



F = AB + CD = ((AB)'(CD)')' according to **DeMorgan property**.



#### Example 1/2

► Example: Implement the following Boolean function with NAND gates:

$$F(x, y, z) = \sum (1, 2, 3, 4, 5, 7).$$

Step 1: Obtain the simplified Boolean function in terms of Boolean operators.



| ×yz | 00 | 01 | 11 | 10 |
|-----|----|----|----|----|
| 0   |    | 1  | 1  | 1  |
| 1   | 1  | 1  | 1  |    |

$$F = xy' + x'y + z.$$

# The state of the s

#### Example 2/2

► Example: Implement the following Boolean function with NAND gates:

$$F(x, y, z) = \sum (1, 2, 3, 4, 5, 7) = xy' + x'y + z.$$

- Step 1: Obtain the simplified Boolean function in terms of Boolean operators.
- ► Step 2: Convert F = xy' + x'y + z to NAND logic.  $\leftarrow$  Procedures detailed in the next slide.



### Two-level Implementation with NAND Circuits



#### Procedure

- ► A Boolean function can be implemented with two levels of NAND gates.
  - 1. Simplify the function and express it in sum-of-products form.
  - 2. Draw a NAND gate for each product term of the expression that has at least two literals. The inputs to each NAND gate are the literals of the term. This procedure produces a group of first-level gates.
  - 3. A term with a single literal requires an inverter in the first level. However, if the single literal is complemented, it can be connected directly to an input of the second level NAND gate.
  - 4. Draw a single gate using the AND-invert or the invert-OR graphic symbol in the second level, with inputs coming from outputs of first-level gates.

# Two-level Implementation with NAND Circuits



#### Example

- ▶ Implement  $F(x, y, z) = \sum (1, 2, 3, 4, 5, 7)$  with two levels of NAND gates.
  - 1. Simplify the function and express it in sum-of-products form: F(x, y, z) = xy' + x'y + z.
  - Draw a NAND gate for each product term of the expression that has at least two literals. The inputs to each NAND gate are the literals of the term. This procedure produces a group of first-level gates.
  - 3. A term with a single literal requires an inverter in the first level. However, if the single literal is complemented, it can be connected directly to an input of the second level NAND gate.
  - 4. Draw a single gate using the AND-invert or the invert-OR graphic symbol in the second level, with inputs coming from outputs of first-level gates.



#### Multilevel NAND Circuits



#### Procedure

- ► The standard form of expressing Boolean functions results in a two-level implementation.
- ► There are occasions when the design of digital systems results in gating structures with three or more levels.
  - ightharpoonup Example: F = A(CD + B) + BC'.





#### Multilevel NAND Circuits



#### Procedure

- ► The general procedure for converting a multilevel AND—OR diagram into an all-NAND diagram using mixed notation is as follows:
  - 1. Convert all AND gates to NAND gates with AND-invert graphic symbols.
  - 2. Convert all OR gates to NAND gates with invert-OR graphic symbols.
  - 3. Check all the bubbles in the diagram. For every bubble that is not compensated by another small circle along the same line, insert an inverter (a one-input NAND gate) or complement the input literal.

#### Multilevel NAND Circuits



#### Example

- Convert the following multilevel AND—OR diagram into an all-NAND diagram using mixed notation.
  - 1. Convert all AND gates to NAND gates with AND-invert graphic symbols.
  - 2. Convert all OR gates to NAND gates with invert-OR graphic symbols.
  - 3. Check all the bubbles in the diagram. For every bubble that is not compensated by another small circle along the same line, insert an inverter (a one-input NAND gate) or complement the input literal.





### Outline



Review of Last Week

NAND and NOR Implementation

NAND Circuits

NOR Circuits

Other Two-Level Implementations

Exclusive-OR Function

### **NOR Circuits**



- ► The NOR operation is the dual of the NAND operation.
- ► All procedures and rules for NOR logic are the duals of the corresponding procedures and rules developed for NAND logic.



### **NOR Circuits**



► To facilitate the conversion to NOR logic, it is convenient to define an alternative graphic symbol for the gate.

OR-invert:

$$\begin{array}{ccc}
A & & \\
B & & \\
C & & \\
\end{array}$$

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

Invert-AND:

$$\begin{array}{ccc}
A & & \\
B & & \\
C & & \\
\end{array}$$

$$-F = A'B'C$$

#### NOR. Circuits



- ► A two-level implementation with NOR gates requires that the function be simplified into product-of-sums form.
- ▶ **Procedure:** Change the OR gates to NOR gates with OR-invert graphic symbols and the AND gate to a NOR gate with an invert-AND graphic symbol.
- ▶ **Remark:** The equivalent AND-OR diagram can be recognised from the NOR diagram by removing all the bubbles.



F(A, B, C, D, E) = (A + B)(C + D)E F(A, B, C, D, E) = (AB' + A'B)(C + D')

### Outline of This Lecture



Review of Last Week

NAND and NOR Implementation

Other Two-Level Implementations

Exclusive-OR Function

### Non-degenerate Forms



- It will be instructive from a theoretical point of view to find out how many two-level combinations of gates are possible.
- We consider four types of gates: AND, OR, NAND, and NOR.
  - ► There are 16 possible combinations of two-level forms.
  - ▶ Eight of these combinations are said to be degenerate forms (退化形).
    - They degenerate to a single operation.
    - Example: AND in the first level and second level degenerates to an AND of all inputs.
  - ► The remaining eight non-degenerate forms produce an implementation in sum-of-products form or product-of-sums form.
    - 1) AND-OR 2) OR-AND 3) NAND-NAND 4) NOR-NOR
    - 5) NOR-OR 6) NAND-AND 7) OR-NAND 8) AND-NOR

### AND-OR-INVERT Implementation



- ► The two forms, NAND—AND and AND—NOR, are equivalent.
- ▶ Both perform the AND-OR-INVERT function.
- ► An AND—OR implementation requires an expression in sum-of-products form. The AND-OR-INVERT implementation is similar, except for the inversion.
  - Therefore, if the complement of the function is simplified into sum-of-products form (by combining the 0's in the map), it will be possible to implement F' with the AND—OR part of the function.



F(A, B, C, D, E) = (AB + CD + E)'

### **OR-AND-INVERT** Implementation



- ► The two forms, OR-NAND and NOR-OR, are equivalent.
- ▶ Both perform the OR-AND-INVERT function.
- ► The OR-AND-INVERT implementation requires an expression in product-of-sums form.
  - If the complement of the function is simplified into product-of-sums form, we can implement F' with the OR-AND part of the function.



### Outline of This Lecture



Review of Last Week

NAND and NOR Implementation

Other Two-Level Implementations

Exclusive-OR Function
XOR
XOR for Error Detection

### Outline



Review of Last Week

NAND and NOR Implementation

Other Two-Level Implementations

Exclusive-OR Function XOR

XOR for Error Detection

### Exclusive-OR Function



► Exclusive-OR (异或门), XOR:

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

► Exclusive-NOR (同或门), XNOR or equivalency:

$$(x \oplus y)' = xy + x'y'.$$

- ► The following identities apply to the XOR operation:
  - $x \oplus 0 = x$ .
  - $x \oplus 1 = x'$ .
  - $x \oplus x = 0.$
  - $x \oplus x' = 1$ .
  - $x \oplus y' = x' \oplus y = (x \oplus y)'.$



- ► XOR is hard to fabricate, so it is typically constructed by other gates.
  - **Example:**  $(x' + y')x + (x' + y')y = xy' + xy' = x \oplus y$ .



Or use NAND gates:



- ► The first NAND gate performs the operation (xy)' = x' + y'.
- ▶ The other two-level NAND circuit produces the sum of products.

### Outline



Review of Last Week

NAND and NOR Implementation

Other Two-Level Implementations

Exclusive-OR Function

XOF

XOR for Error Detection

#### XOR for Error Detection



- Only a limited number of Boolean functions can be expressed in terms of XOR operations.
- ▶ Particularly useful in arithmetic operations and error detection/correction circuits.

#### Odd Function



► The XOR operation with three or more variables can be converted into an ordinary Boolean function by replacing the ⊕ with its equivalent Boolean expression.

$$A \oplus B \oplus C = (AB' + A'B)C' + (AB + A'B')C$$
$$= AB'C' + A'BC' + ABC + A'B'C$$
$$= \sum (1, 2, 4, 7)$$

- ► The three-variable XOR function is equal to 1 if only one variable is equal to 1 or if all three variables are equal to 1.
  - ► An odd number of variables are equal to 1.
  - Odd function.





▶ The three-input odd function is implemented by means of two-input XOR gates.



**Even function** can also be implemented:



# Parity Generation and Checking



- XOR functions are very useful in systems requiring error detection and correction codes.
  - Recap: A parity bit is an extra bit included with a binary message to make the number of 1's either odd or even.
- The circuit that generates the parity bit in the transmitter is called a parity generator.
- ► The circuit that checks the parity in the receiver is called a **parity checker**.

# Parity generation and Checking



► Consider a three-bit message to be transmitted together with an even-parity bit.

| х | у | z | Parity bit $p$ |
|---|---|---|----------------|
| 0 | 0 | 0 | 0              |
| 0 | 0 | 1 | 1              |
| 0 | 1 | 0 | 1              |
| 0 | 1 | 1 | 0              |
| 1 | 0 | 0 | 1              |
| 1 | 0 | 1 | 0              |
| 1 | 1 | 0 | 0              |
| 1 | 1 | 1 | 1              |



3-bit even parity generator

p constitutes an odd function.

# Parity Generation and Checking



- ► The three bits in the message, together with the parity bit, are transmitted to their destination.
- ► The four bits received must have an even number of 1's with even parity.



3-bit even parity generator



4-bit even parity checker

### Outline of This Lecture



Review of Last Week

NAND and NOR Implementation

Other Two-Level Implementations

Exclusive-OR Function

# Summary



- Two-level implementations:
  - Universal gates: NAND and NOR gates.
  - ▶ Procedure of two-level implementations using NAND or NOR gates.
- Exclusive-OR gate for constructing error detection circuits.

Next week: Combinational Logic.

# Essential Reading



- Essential reading for this lecture: pages 91-118 of the textbook.
- Essential reading for next lecture: pages 125-148 of the textbook.

[1] M. M. Mano and M. Ciletti, *Digital design: with an introduction to the Verilog HDL*. Pearson, 2013