

# Sequential Logic

## Learning Objectives

1. State the difference between combinational and sequential logic.
2. Identify rising and falling edges of a signal.
3. State the difference between edge triggered and level triggered circuit.
4. Complete timing diagrams for an SR latch, D latch, and D flip-flop.

## Combinational versus Sequential

There are two types of locks:



\_\_\_\_\_ always give the same output for a given set of inputs

ex/ \_\_\_\_\_

\_\_\_\_\_ depend on the current state and the input. Therefore,

these circuits have \_\_\_\_\_. They are used to \_\_\_\_\_

ex/ \_\_\_\_\_

## S\_\_\_\_\_ R\_\_\_\_\_ (S-R) Latch

Latches are \_\_\_\_\_ devices. They are \_\_\_\_\_ sensitive.

\_\_\_\_\_ sensitive: the output changes when the value of the input changes.

\_\_\_\_\_ - value of Q becomes \_\_\_\_, regardless of previous value

\_\_\_\_\_ - value of Q becomes \_\_\_\_, regardless of previous value

This logic circuit has two versions: active \_\_\_\_\_ and active \_\_\_\_\_.

**Active** \_\_\_\_\_

Review - Nor Truth Table

|                                 |                                                                   |
|---------------------------------|-------------------------------------------------------------------|
| <b>Symbol &amp; Truth Table</b> | If one of the inputs of a nor gate is 1, the output must be _____ |
|---------------------------------|-------------------------------------------------------------------|

Reset and Set Conditions

|                                                                                                                   |                                                                                               |
|-------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|
| <b>reset:</b> $S = 0, R = 1$<br> | If $R = 1$ , $Q$ "resets" to _____<br>Since $Q$ is _____ and $S$ is 0,<br>$Q'$ becomes _____  |
| <b>set:</b> $S = 1, R = 0$<br>  | If $S = 1$ , $Q'$ becomes _____<br>Since $Q'$ is _____ and $R$ is 0,<br>$Q$ is "set" to _____ |

Hold Condition,  $R = S = 0$

We can't predict the output of a nor gate if we know only one of the inputs is \_\_\_\_\_.  
 So for  $S = R = 0$ , we must know the initial values of  $Q$  &  $Q'$  to determine the outputs.

|                                                                                                                                               |                                                                                                                                                      |
|-----------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| $S = R = 0, Q_{\text{init}} = 0, Q'_{\text{init}} = 1$<br> | If $Q$ is initially 0 and $Q'$ is initially 1, then the output of the _____ nor gate stays _____, and the output of the other nand gate stays _____. |
| $S = R = 0, Q_{\text{init}} = 1, Q'_{\text{init}} = 0$<br> | If $Q$ is initially 1 and $Q'$ is initially 0, then the output of the _____ nor gate stays _____, and the output of the other nand gate stays _____. |

Invalid Input Combination:  $S = R = 1$

**Problem 1: Conflict**

$S = 1, R = 1$



If both  $S$  and  $R$  are equal to 1, then

both  $Q$  and  $Q'$  will want to be \_\_\_\_.

This creates a \_\_\_\_\_.

**Problem 2: Race Condition**

The final values of  $Q$  and  $Q'$  are \_\_\_\_\_ when changing from

\_\_\_\_\_ to \_\_\_\_\_.

The \_\_\_\_\_ for a signal to travel through a wire is \_\_\_\_\_.

So, we cannot assume two signals can change at precisely the same time.

$S = R = 0; Q_{\text{init}} = Q'_{\text{init}} = 0;$   
 $R$  changes first



If  $R$  changes from 1 to 0 first,

$Q$  will become \_\_\_\_ which will cause  
 $Q'$  to become \_\_\_\_

$S = R = 0; Q_{\text{init}} = Q'_{\text{init}} = 0;$   
 $S$  changes first



If  $S$  changes from 1 to 0 first,

$Q'$  will become \_\_\_\_ which will cause  
 $Q$  to become \_\_\_\_

## Summary

| S | R | Q | Q' | Action   |
|---|---|---|----|----------|
| 0 | 0 |   |    |          |
| 0 | 1 |   |    |          |
| 1 | 0 |   |    |          |
| 1 | 1 |   |    | Yellow L |

Active \_\_\_\_\_ S-R Latch Timing Diagrams

Fill out Q and Q' for given S and R signals.

|    |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|--|--|--|--|--|--|--|--|--|--|--|--|--|
| S  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| R  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Q  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Q' |  |  |  |  |  |  |  |  |  |  |  |  |  |

  

|    |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|--|--|--|--|--|--|--|--|--|--|--|--|--|
| S  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| R  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Q  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Q' |  |  |  |  |  |  |  |  |  |  |  |  |  |

  

|    |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----|--|--|--|--|--|--|--|--|--|--|--|--|--|
| S  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| R  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Q  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Q' |  |  |  |  |  |  |  |  |  |  |  |  |  |

**Active** \_\_\_\_\_

Review - Nand Truth Table

|                      |                                                        |
|----------------------|--------------------------------------------------------|
| Symbol & Truth Table | If one of the inputs is 0,<br>the output must be _____ |
|----------------------|--------------------------------------------------------|

Reset and Set Conditions

|                                                                                                                      |                                                                                               |
|----------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|
| <b>set:</b> $S' = 0, R' = 1$<br>    | If $S' = 0$ , Q is "set" to _____<br><br>Since Q is _____ and R' is 1,<br>Q' becomes _____    |
| <b>reset:</b> $S' = 1, R' = 0$<br> | If $R' = 0$ , Q' becomes _____<br><br>Since Q' is _____ and S' is 1,<br>Q is "reset" to _____ |

Hold Condition,  $R' = S' = 1$ We can't predict the output of a nand gate if we know only one of the inputs is \_\_\_\_\_.  
So for  $S' = R' = 1$ , we must know the initial values of Q & Q' to determine the outputs.

|                                                                                                                                   |                                                                                                                                                   |
|-----------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| $S' = R' = 1, Q_{init} = 0, Q'_{init} = 1$<br> | If Q is initially 0 and Q' is initially 1, then the output of the _____ nand gate stays _____, and the output of the other nand gate stays _____. |
| $S' = R' = 1, Q_{init} = 1, Q'_{init} = 0$<br> | If Q is initially 1 and Q' is initially 0, then the output of the _____ nand gate stays _____, and the output of the other nand gate stays _____. |

Invalid Input Combination:  $S' = R' = 0$

**Problem 1: Conflict**

$$S' = R' = 0$$



If both  $S'$  and  $R'$  are equal to 0, then both  $Q$  and  $Q'$  will want to be \_\_\_\_\_. This creates a \_\_\_\_\_.

**Problem 2: Race Condition**

The final values of  $Q$  and  $Q'$  are \_\_\_\_\_ when changing from \_\_\_\_\_

to \_\_\_\_\_.

As previously stated, we cannot assume two signals can change at precisely the same time.

$$S' = R' = 1; Q_{\text{init}} = 1, Q'_{\text{init}} = 1; \\ R' \text{ changes first}$$



If  $R'$  changes from 0 to 1 first,  $Q'$  will become \_\_\_\_ which will cause  $Q$  to become \_\_\_\_\_.  
If  $S'$  changes from 0 to 1 first,  $Q$  will become \_\_\_\_ which will cause  $Q'$  to become \_\_\_\_\_.

$$S' = R' = 1; Q_{\text{init}} = 1, Q'_{\text{init}} = 1; \\ S' \text{ changes first}$$



## Summary

| S' | R' | Q | Q' | Action                                                                            |
|----|----|---|----|-----------------------------------------------------------------------------------|
| 0  | 0  |   |    |  |
| 0  | 1  |   |    |                                                                                   |
| 1  | 0  |   |    |                                                                                   |
| 1  | 1  |   |    |                                                                                   |

## Active \_\_\_\_\_ S-R Latch Timing Diagrams

Fill out Q and Q' for given S' and R' signals.

## D Latch

Draw the schematic here:

## Timing Diagram Examples

Fill out Q and Q' for given WE and D signals.



## Register

A D latch is a device for storing \_\_\_\_\_. A \_\_\_\_\_ stores several bits.

Draw a diagram for a register:

## Clock

The \_\_\_\_\_ for a signal to travel through a wire is \_\_\_\_\_.  
For this reason, a \_\_\_\_\_ is used to \_\_\_\_\_ signals in a computer.

A clock is a free-running \_\_\_\_\_ signal  
with a fixed \_\_\_\_\_.

The \_\_\_\_\_ of a clock is the \_\_\_\_\_.

Draw a clock signal. Label the rising edge, falling edge, and period.



## D Flip Flop

Flip flops are \_\_\_\_\_ sensitive.

\_\_\_\_\_ sensitive: the output changes on the \_\_\_\_\_ of the enable signal.

### Positive Edge-Triggered Flip Flop

Draw the schematic here:

| WE / CLK | Q | Q' |
|----------|---|----|
| ↑ 1      |   |    |
| other    |   |    |

#### Timing Diagram Examples

Assume a positive edge-triggered flip flop. Fill out Q for given WE and D signals.



*Negative Edge-Triggered Flip Flop*

Draw the schematic here:

| WE / CLK | Q | Q' |
|----------|---|----|
| ↓ 0      |   |    |
| other    |   |    |

Timing Diagram Examples

Assume a negative edge-triggered flip flop. Fill out Q for given WE and D signals.

