# **COMP2611: Computer Organization**

Introduction to Combinational Logic and Sequential Logic □ You will learn about the following in this tutorial

- Combinational logic circuits
  - Do not have internal states (i.e. memoryless),
  - The output is solely determined by the present input and the circuit,
  - Can be specified with a truth table or a logic equation (in Boolean algebra expression).
- □ Sequential Logic circuits
  - Have memory,
  - The output depends on both the current input and the value stored in the memory of the circuits (called state).

#### **Combinational logic**

Boolean algebra

- review of the Boolean algebra
- the Sum of Product (SoP) representation
- from Boolean algebra to circuit
- PLA implementation
- K-Maps

Exercises

- □ The Input-Output relationship of any combinational logic circuit can be completely specified using either
  - □ a truth table,
  - □ or a Boolean algebra expression.
- □ When there are N inputs, the truth table would require as many as 2<sup>N</sup> entries.
- □ The Boolean algebra expression does not have this "cardinality explosion" problem.

Boolean algebra consists of

 $\Box$  Boolean variables (with values equal to either '0' or '1'),

 $\Box$  and binary operators AND ('•'), OR ('+'), NOT ('\_') or ('').

□ The AND, OR, and NOT operations form a functionally complete set, as they can specify any logic function.

**Identity laws**:

$$A + 0 = A \qquad A \cdot 1 = A$$

□ Annihilator (or Zero and one) laws:

 $A+1=1 \qquad A\cdot 0=0$ 

**Complement laws**:

$$A + \overline{A} = 1$$
  $A \cdot \overline{A} = 0$ 

**Commutativity laws**:

A + B = B + A  $A \cdot B = B \cdot A$ 

□ Associativity laws:

 $A + (B + C) = (A + B) + C \qquad A \cdot (B \cdot C) = (A \cdot B) \cdot C$ 

**Distributivity laws**:

 $A \cdot (B+C) = (A \cdot B) + (A \cdot C) \qquad A + (B \cdot C) = (A+B) \cdot (A+C)$ 

**Idempotence**:

$$A + A = A$$
  $A \cdot A = A$ 

- □ Absorption laws:
  - $A + (A \cdot B) = A$   $A \cdot (A + B) = A$
- **De Morgan Laws**:

$$\overline{A+B} = \overline{A} \cdot \overline{B}$$
$$\overline{A \cdot B} = \overline{A} + \overline{B}$$

#### **An Exercise On Using Boolean Algebra**

#### **Show that**

$$A + AB = A + B$$

- Any logic function can be expressed as a two-level representation, either as
  - □ the Sum-of-Products (SoP) representation,
  - □ or as the Product-of-Sums (PoS) representation.

**Example:** Assume the truth table for a circuit is given as:

| Inputs |     | Outputs |      |
|--------|-----|---------|------|
| In0    | In1 | Out0    | Out1 |
| 0      | 0   | 1       | 0    |
| 0      | 1   | 1       | 1    |
| 1      | 0   | 0       | 1    |
| 1      | 1   | 0       | 0    |

Can we express the truth table using SoP representation in Boolean Algebra?

- □ For each output (Out0, Out1),
  - 1. Observe the rows that the output has a value of `1'.
    - □ For Out0, the 1's are at the 1<sup>st</sup> and the 2<sup>nd</sup> rows.



- 2. Write the minterms for the inputs such that the minterms will give 1's for the input patterns in the same rows.
  - ☐ For Out0, the two 1's correspond to the input patterns (in0=0,in1=0) and (in0=0,in1=1).

**The two minterms that will give 1's are**  $\overline{in0} \cdot \overline{in1}$  and  $\overline{in0} \cdot in1$ 

3. Write the outputs as the OR operation of the minterms found in step two. For Out0, we have

$$out0 = in0 \cdot in1 + in0 \cdot in1$$

□ By following the above steps. The required expressions for the two outputs (Out0, Out1)

 $out0 = in0 \cdot in1 + in0 \cdot in1$  $out1 = in0 \cdot in1 + in0 \cdot in1$ 

Could the expressions for Out0 and Out1 be further simplified using the laws on slide 6?

### **Reducing a Boolean expression to a circuit 1**

- □ The expression  $out0 = in0 \cdot in1 + in0 \cdot in1$  can be viewed as performing the OR operation on two ANDed minterms  $in0 \cdot in1$  and  $in0 \cdot in1$ .
- □ The circuit is as follows.
  - Mind the two AND gates that correspond to the AND expressions and the single OR gate that corresponds to the OR expression.



□ What will be the impact on the circuit if we use the simplified expression (mentioned in the last slide) to build the circuit.

### **Reducing a Boolean expression to a circuit 2**

- □ Using the same approach, the expression  $out1 = in0 \cdot in1 + in0 \cdot in1$  can also be drawn.
- □ Combine it with the previous figure we have the overall circuit:



*Combinational Logic* 

### **PLA implementation of a Boolean expression**

The same circuit can be equivalently represented by a programmable logic array (PLA) circuit.



14

Combinational Logic

### K-Maps

- □ K-Map is a graphical representation of the truth table or logic function
- □ In a K-map each cell represents one possible minterm
- □ Cells are arranged following a Gray code
  - That is, two adjacent cells are such that the corresponding minterms differ in only one variable
- Simplify expression by finding largest size groups of adjacent cells at 1 in the K-Map
  - □ Can only group  $2^n$  adjacent cells where n = 0, 1, 2, 3, 4, ...
  - □ Table is a toroid
    - That is, rightmost cells are adjacent to the leftmost cells and topmost cells are adjacent to bottom cells)
- $\Box \quad \text{Example: Simplify F} = AB' + AB + A'B$





$$=$$
  $=$   $B$   $+$   $A$ 

#### **K-Maps**

Example: Consider a 7-segment digital display which displays a hexadecimal digit. Each segment is represented by a logic function



- That is, 4 inputs i<sub>3</sub>, i<sub>2</sub>, i<sub>1</sub>, i<sub>0</sub> to represent values 0, ..., 9, a, b, c, d, e, f (to avoid confusion between 0, and 8 on one hand and D and B respectively, on the other hand, we use miniscule b and d representation)
- □ What is the truth table for segment C?
- □ Also, use a K-Map to simplify the equation

#### □ Truth Table for segment C:

|                      | Inputs         |                |                | Output         |   |
|----------------------|----------------|----------------|----------------|----------------|---|
| Hexadecimal<br>Digit | i <sub>3</sub> | i <sub>2</sub> | i <sub>1</sub> | i <sub>o</sub> | С |
| Cy                   | 0              | 0              | 0              | 0              | 1 |
| ¢.                   | 0              | 0              | 0              | 1              | 1 |
| സം                   | 0              | 0              | 1              | 0              | 0 |
| rr.                  | 0              | 0              | 1              | 1              | 1 |
|                      | 0              | 1              | 0              | 0              | 1 |
| տ                    | 0              | 1              | 0              | 1              | 1 |
| ιØ                   | 0              | 1              | 1              | 0              | 1 |
| (° "                 | 0              | 1              | 1              | 1              | 1 |
| 60                   | 1              | 0              | 0              | 0              | 1 |
| <u>c</u> rı          | 1              | 0              | 0              | 1              | 1 |
| œ                    | 1              | 0              | 1              | 0              | 1 |
| <u>.</u>             | 1              | 0              | 1              | 1              | 1 |
| L.I                  | 1              | 1              | 0              | 0              | 0 |
| ö                    | 1              | 1              | 0              | 1              | 1 |
| LLS                  | 1              | 1              | 1              | 0              | 0 |
| ų                    | 1              | 1              | 1              | 1              | 0 |

Combinational Logic

#### **K-Maps**

□ K-Map:

| i <sub>1</sub> i <sub>0</sub><br>i <sub>3</sub> i <sub>2</sub> | 00 | 01 | 11 | 10 |
|----------------------------------------------------------------|----|----|----|----|
| 00                                                             | 1  | 1  | 1  | 0  |
| 01                                                             | 1  | 1  | 1  | 1  |
| 11                                                             | 0  | 1  | 0  | 0  |
| 10                                                             | 1  | 1  | 1  | 1  |

 $\Box \quad C = \mathbf{i_3' i_1' + i_3' i_0 + i_3' i_2 + i_1' i_0 + i_3 i_2'}$ 

## **Sequential logic**

- clock
- Memory elements: SR latch, D latch, D flip flop, register file
  Exercises

### Clock

- A clock acts as a global signal that gives all the components in the system an indication of time.
- Clock is used in sequential logic to decide and co-ordinate state updates.
- Just to remind you, a clock signal has three important key words that you need to know:



Sequential logic, data representation

## **Sequential logic**

- clock

 Memory elements: SR latch, D latch, D flip flop, register file
Exercises

- □ A S-R latch (Set-Reset latch) shown below is the simplest memory element.
  - Unclocked memory element (Asynchronous device)



| S | R | Action on Q        |
|---|---|--------------------|
| 0 | 0 | Nothing<br>changed |
| 0 | 1 | Q=0                |
| 1 | 0 | Q=1                |
| 1 | 1 | forbidden          |

Question: How does this circuit "stores" information? What is the size of the information being stored?

Sequential logic, data representation

### A clocked memory element – D latch

□ The value stored in a D-latch can be updated iff the clock is asserted (i.e. C=1).



| C (Clock) | D | Action on Q     |
|-----------|---|-----------------|
| 0         | 0 | Nothing changed |
| 0         | 1 | Nothing changed |
| 1         | 0 | Q=0             |
| 1         | 1 | Q=1             |

- □ Note the S-R latch on the right part of the D-latch circuit.
- Question: From the circuit, argue whether it is possible to do update when the clock is not asserted?

A D Flip-flop can be updated only on a falling/rising clock edge.
There are many ways to create a D flip flop, the figure below (from the lecture notes) shows a D flip flop created from two D latches.



This flip flop can be updated in a falling edge or in a rising edge?
Question: Without adding new hardware, how to modify the device so that it can only be updated on rising edges (if this is not already the case)?

□ A register file is a piece of hardware that allows reading from and writing to the desired registers. The following figure shows a sample register file.



How do you read from a register (what are the inputs)?How do you write to a register (what are the inputs)?

Sequential logic, data representation

#### **Combinational logic**

Boolean algebra

- review of the Boolean algebra
- the Sum of Product (SoP) representation
- from Boolean algebra to circuit
- PLA implementation
- K-maps

#### **Sequential logic**

- clock
- Memory elements: SR latch, D latch, D
  - flip flop, register file

#### Exercises

Question 1: A decoder takes a single N-bit input and outputs  $2^{N}$  1-bit signals. The 1-bit output corresponds to the N-bit input bit pattern is true while all other outputs are false. The following figure shows a block diagram for a 2-to-4 decoder.



A 2-bit decoder

- Why a 2-bit input can generate 4 outputs in the decoder?
- If the input bits are 11, what will happen to the outputs of the decoder?
- Is it possible to have more than one outputs asserted?
- Name two potential uses of the decoder.
- Implement the decoder using Logisim

Question 2: A multiplexor is a devices that given the control signal, selects one of the inputs to be forwarded to the output. The following figure shows a 4-input multiplexor.



#### Combinational Logic

- If the inputs A/B are 32-bit in width, what is the data width of the Output O?
- What is the maximum number of inputs if the control signal is 10-bit in width?
- What is the bit-width of the control signal for the multiplexor if there are 9 inputs?

- □ Today we have reviewed:
  - □ simple Boolean algebra and the related laws,
  - reducing truth table to the canonical Sum-of-Products form,
  - converting simple Boolean algebra expressions to circuits,
  - □ simple combinational logic circuits,
  - □ K-maps.
  - □ clock,
  - □ simple memory elements (SR latch, D latch, D flip flop),
  - register file.