## Lecture No. 13

## LECTURE OUTLINE

7-1 Latches
7-2 Flip-Flops

## 7-1 Latches



FIGURE 7-2 Negative-OR equivalent of the NAND gate S-R latch in Figure 71(b).

The latch is a type of temporary storage device that has two stable states (bistable) and is normally placed in a category separate from that of flip-flops. Latches are similar to flipflops because they are bistable devices that can reside in either of two states using a feedback arrangement, in which the outputs are connected back to the opposite inputs. The main difference between latches and flip-flops is in the method used for changing their state.

## The S-R (SET-RESET) Latch

A latch is a type of bistable logic device or multivibrator. An active-HIGH input S-R (SET-RESET) latch is formed with two cross-coupled NOR gates, as shown in Figure 7-1(a); an active-LOW input $\bar{S}-\bar{R}$ latch is formed with two cross-coupled NAND gates, as shown in Figure 7-1(b). Notice that the output of each gate is connected to an input of the opposite gate. This produces the regenerative feedback that is characteristic of all latches and flip-flops.

(a) Active-HIGH input S-R latch

(b) Active-LOW input $\overline{\mathrm{S}}-\overline{\mathrm{R}}$ latch

FIGURE 7-1 Two versions of SET-RESET (S-R) latches. Open files F07-01(a) and (b) and verify the operation of both latches. A Multisim tutorial is available on the website.

To explain the operation of the latch, we will use the NAND gate $\overline{\mathrm{S}}-\overline{\mathrm{R}}$ latch in Figure $7-1$ (b). This latch is redrawn in Figure 7-2 with the negative-OR equivalent symbols used for the NAND gates. This is done because LOWs on the $\bar{S}$ and $\bar{R}$ lines are the activating inputs.

The latch in Figure 7-2 has two inputs, $\bar{S}$ and $\bar{R}$, and two outputs, $Q$ and $\bar{Q}$. Let's start by assuming that both inputs and the $Q$ output are HIGH, which is the normal latched state. Since the $Q$ output is connected back to an input of gate $G_{2}$, and the $\bar{R}$ input is HIGH, the output of $G_{2}$ must be LOW. This LOW output is coupled back to an input of gate $G_{1}$, ensuring that its output is HIGH.

When the $Q$ output is HIGH, the latch is in the SET state. It will remain in this state indefinitely until a LOW is temporarily applied to the $\bar{R}$ input. With a LOW on the $\bar{R}$ input and a HIGH on $S$, the output of gate $G_{2}$ is forced HIGH. This HIGH on the $\bar{Q}$ output is coupled back to an input of $G_{1}$, and since the $\bar{S}$ input is HIGH , the output of $G_{1}$ goes LOW. This LOW on the $Q$ output is then coupled back to an input of $G_{2}$, ensuring that the $\bar{Q}$ output remains HIGH even when the LOW on the $R$ input is removed. When the $Q$ output is LOW, the latch is in the RESET state. Now the latch remains indefinitely in the RESET state until a momentary LOW is applied to the $S$ input.

In normal operation, the outputs of a latch are always complements of each other.

## When $Q$ is HIGH, $\bar{Q}$ is LOW, and when $Q$ is LOW, $\bar{Q}$ is HIGH.

An invalid condition in the operation of an active-LOW input $\overline{\mathrm{S}}-\overline{\mathrm{R}}$ latch occurs when LOWs are applied to both $\bar{S}$ and $\bar{R}$ at the same time. As long as the LOW levels are simultaneously held on the inputs, both the $Q$ and $\bar{Q}$ outputs are forced HIGH, thus violating the basic complementary operation of the outputs. Also, if the LOWs are released simultaneously, both outputs will attempt to go LOW. Since there is always some small difference in the propagation delay time of the gates, one of the gates will dominate in its transition to the LOW output state. This, in turn, forces the output of the slower gate to remain HIGH. In this situation, you cannot reliably predict the next state of the latch.

Figure 7-3 illustrates the active-LOW input $\overline{\mathrm{S}}-\overline{\mathrm{R}}$ latch operation for each of the four possible combinations of levels on the inputs. (The first three combinations are valid, but the last is not.) Table 7-1 summarizes the logic operation in truth table form. Operation of the active-HIGH input NOR gate latch in Figure 7-1(a) is similar but requires the use of opposite logic levels.


FIGURE 7-3 The three modes of basic $\overline{\mathrm{S}}-\overline{\mathrm{R}}$ latch operation (SET, RESET, no-change) and the invalid condition.

TABLE 7-1
Truth table for an active-LOW input $\overline{\mathrm{S}}-\overline{\mathrm{R}}$ latch.

| Inputs |  | Outputs |  |  |
| :---: | :---: | :---: | :---: | :--- |
| $\overline{\boldsymbol{S}}$ | $\overline{\boldsymbol{R}}$ | $\boldsymbol{Q}$ | $\overline{\boldsymbol{Q}}$ | Comments |
| 1 | 1 | NC | NC | No change. Latch remains in present state. |
| 0 | 1 | 1 | 0 | Latch SET. |
| 1 | 0 | 0 | 1 | Latch RESET. |
| 0 | 0 | 1 | 1 | Invalid condition |

Logic symbols for both the active-HIGH input and the active-LOW input latches are shown in Figure 7-4.


FIGURE 7-4 Logic symbols for the S-R and $\bar{S}-\bar{R}$ latch.

Example 7-1 illustrates how an active-LOW input $\bar{S}-\bar{R}$ latch responds to conditions on its inputs. LOW levels are pulsed on each input in a certain sequence and the resulting $Q$ output waveform is observed. The $\bar{S}=0, \bar{R}=0$ condition is avoided because it results in an invalid mode of operation and is a major drawback of any SET-RESET type of latch.

## EXAMPLE 7-1

If the $\bar{S}$ and $\bar{R}$ waveforms in Figure 7-5(a) are applied to the inputs of the latch in Figure 7-4(b), determine the waveform that will be observed on the $Q$ output. Assume that $Q$ is initially LOW.


FIGURE 7-5

## Solution

See Figure 7-5(b).

## Related Problem*

Determine the $Q$ output of an active-HIGH input S -R latch if the waveforms in Figure 7-5(a) are inverted and applied to the inputs.

## The Gated S-R Latch

A gated latch requires an enable input, $E N$ ( $G$ is also used to designate an enable input). The logic diagram and logic symbol for a gated S-R latch are shown in Figure 7-8. The $S$ and $R$ inputs control the state to which the latch will go when a HIGH level is applied to the $E N$ input. The latch will not change until $E N$ is HIGH; but as long as it remains HIGH, the output is controlled by the state of the $S$ and $R$ inputs. The gated latch is a level-sensitive device. In this circuit, the invalid state occurs when both $S$ and $R$ are simultaneously HIGH and $E N$ is also HIGH.


FIGURE 7-8 A gated S-R latch.

## EXAMPLE 7-2

Determine the $Q$ output waveform if the inputs shown in Figure 7-9(a) are applied to a gated S-R latch that is initially RESET.
(a)


FIGURE 7-9

## Solution

The $Q$ waveform is shown in Figure 7-9(b). When $S$ is HIGH and $R$ is LOW, a HIGH on the $E N$ input sets the latch. When $S$ is LOW and $R$ is HIGH, a HIGH on the $E N$ input resets the latch. When both $S$ and $R$ are LOW, the $Q$ output does not change from its present state.

## Related Problem

Determine the $Q$ output of a gated S-R latch if the $S$ and $R$ inputs in Figure 7-9(a) are inverted.

## The Gated D Latch

Another type of gated latch is called the D latch. It differs from the S-R latch because it has only one input in addition to $E N$. This input is called the $D$ (data) input. Figure 7-10 contains a logic diagram and logic symbol of a $D$ latch. When the $D$ input is HIGH and the $E N$ input is HIGH, the latch will set. When the $D$ input is LOW and $E N$ is HIGH, the latch will reset. Stated another way, the output $Q$ follows the input $D$ when $E N$ is HIGH.


FIGURE 7-10 A gated $D$ latch. Open file F07-10 and verify the operation.

## EXAMPLE 7-3

Determine the $Q$ output waveform if the inputs shown in Figure 7-11(a) are applied to a gated D latch, which is initially RESET.


FIGURE 7-11

## Solution

The $Q$ waveform is shown in Figure 7-11(b). When $D$ is HIGH and $E N$ is HIGH, $Q$ goes HIGH. When $D$ is LOW and $E N$ is HIGH, $Q$ goes LOW. When $E N$ is LOW, the state of the latch is not affected by the $D$ input.

## Related Problem

Determine the $Q$ output of the gated $D$ latch if the $D$ input in Figure 7-11(a) is inverted.

## SECTION 7-1 CHECKUP

Answers are at the end of the chapter.

1. List three types of latches.
2. Develop the truth table for the active-HIGH input S-R latch in Figure 7-1(a).
3. What is the $Q$ output of a D latch when $E N=1$ and $D=1$ ?

## 7-2 Flip-Flops

Flip-flops are synchronous bistable devices, also known as bistable multivibrators. In this case, the term synchronous means that the output changes state only at a specified point (leading or trailing edge) on the triggering input called the clock (CLK), which is designated as a control input, $C$; that is, changes in the output occur in synchronization with the clock. Flip-flops are edge-triggered or edge-sensitive whereas gated latches are level-sensitive.

An edge-triggered flip-flop changes state either at the positive edge (rising edge) or at the negative edge (falling edge) of the clock pulse and is sensitive to its inputs only at this transition of the clock. Two types of edge-triggered flip-flops are covered in this section: D and J-K. The logic symbols for these flip-flops are shown in Figure 7-13. Notice that each type can be either positive edge-triggered (no bubble at $C$ input) or negative edge-triggered (bubble at $C$ input). The key to identifying an edge-triggered flipflop by its logic symbol is the small triangle inside the block at the clock ( $C$ ) input. This triangle is called the dynamic input indicator.


FIGURE 7-13 Edge-triggered flip-flop logic symbols (top: positive edgetriggered; bottom: negative edge-triggered).

## The D Flip-Flop

The $D$ input of the $\mathbf{D}$ flip-flop is a synchronous input because data on the input are transferred to the flip-flop's output only on the triggering edge of the clock pulse. When $D$ is HIGH, the $Q$ output goes HIGH on the triggering edge of the clock pulse, and the flip-flop
is SET. When $D$ is LOW, the $Q$ output goes LOW on the triggering edge of the clock pulse, and the flip-flop is RESET.

This basic operation of a positive edge-triggered D flip-flop is illustrated in Figure 7-14, and Table $7-2$ is the truth table for this type of flip-flop. Remember, the flip-flop cannot change state except on the triggering edge of a clock pulse. The $D$ input can be changed at any time when the clock input is LOW or HIGH (except for a very short interval around the triggering transition of the clock) without affecting the output. Just remember, $Q$ follows $D$ at the triggering edge of the clock.

(a) $D=1$ flip-flop SETS on positive clock edge. (If already SET, it remains SET.)

(b) $D=0$ flip-flop RESETS on positive clock edge. (If already RESET, it remains RESET.)

FIGURE 7-14 Operation of a positive edge-triggered D flip-flop.
TABLE 7-2
Truth table for a positive edge-triggered D flip-flop.

EXAMPLE 7-4

| Inputs |  | Outputs |  |  |
| :---: | :---: | :---: | :---: | :---: |
| $\boldsymbol{D}$ | CLK | $\boldsymbol{Q}$ | $\overline{\boldsymbol{Q}}$ | Comments |
| 0 | $\uparrow$ | 0 | 1 | RESET |
| 1 | $\uparrow$ | 1 | 0 | SET |

$\uparrow=$ clock transition LOW to HIGH
The operation and truth table for a negative edge-triggered D flip-flop are the same as those for a positive edge-triggered device except that the falling edge of the clock pulse is the triggering edge.

Determine the $Q$ and $Q$ output waveforms of the flip-flop in Figure 7-15 for the $D$ and CLK inputs in Figure 7-16(a). Assume that the positive edge-triggered flip-flop is initially RESET.


FIGURE 7-15


FIGURE 7-16

## Solution

1. At clock pulse $1, D$ is LOW, so $Q$ remains LOW (RESET).
2. At clock pulse $2, D$ is LOW, so $Q$ remains LOW (RESET).
3. At clock pulse $3, D$ is HIGH, so $Q$ goes HIGH (SET).
4. At clock pulse $4, D$ is LOW, so $Q$ goes LOW (RESET).
5. At clock pulse $5, D$ is HIGH, so $Q$ goes HIGH (SET).
6. At clock pulse $6, D$ is HIGH, so $Q$ remains HIGH (SET).

Once $Q$ is determined, $\bar{Q}$ is easily found since it is simply the complement of $Q$. The resulting waveforms for $Q$ and $\bar{Q}$ are shown in Figure 7-16(b) for the input waveforms in part (a).

## Related Problem

Determine $Q$ and $\bar{Q}$ for the $D$ input in Figure 7-16(a) if the flip-flop is a negative edge-triggered device.

## The J-K Flip-Flop

The $J$ and $K$ inputs of the J-K flip-flop are synchronous inputs because data on these inputs are transferred to the flip-flop's output only on the triggering edge of the clock pulse. When $J$ is HIGH and $K$ is LOW, the $Q$ output goes HIGH on the triggering edge of the clock pulse, and the flip-flop is SET. When $J$ is LOW and $K$ is HIGH, the $Q$ output goes LOW on the triggering edge of the clock pulse, and the flip-flop is RESET. When both $J$ and $K$ are LOW, the output does not change from its prior state. When $J$ and $K$ are both HIGH, the flip-flop changes state. This called the toggle mode.

This basic operation of a positive edge-triggered flip-flop is illustrated in Figure 7-17, and Table $7-3$ is the truth table for this type of flip-flop. Remember, the flip-flop cannot change state except on the triggering edge of a clock pulse. The $J$ and $K$ inputs can be changed at any time when the clock input is LOW or HIGH (except for a very short interval around the triggering transition of the clock) without affecting the output.


FIGURE 7-17 Operation of a positive edge-triggered J-K flip-flop.
$\Delta$
TABLE 7-3
Truth table for a positive edge-triggered J-K flip-flop.

| Inputs |  |  |  | Outputs |  |
| :--- | :--- | :--- | :--- | :--- | :--- |
|  |  |  |  |  |  |
| $\boldsymbol{J}$ | $\boldsymbol{K}$ | CLK | $\boldsymbol{Q}$ | $\overline{\boldsymbol{Q}}$ | Comments |
| 0 | 0 | $\uparrow$ | $Q_{0}$ | $\bar{Q}_{0}$ | No change |
| 0 | 1 | $\uparrow$ | 0 | 1 | RESET |
| 1 | 0 | $\uparrow$ | 1 | 0 | SET |
| 1 | 1 | $\uparrow$ | $\bar{Q}_{0}$ | $Q_{0}$ | Toggle |

$\uparrow=$ clock transition LOW to HIGH
$Q_{0}=$ output level prior to clock transition

## EXAMPLE 7-5

The waveforms in Figure 7-18(a) are applied to the $J, K$, and clock inputs as indicated. Determine the $Q$ output, assuming that the flip-flop is initially RESET.


FIGURE 7-18

## Solution

Since this is a negative edge-triggered flip-flop, as indicated by the "bubble" at the clock input, the $Q$ output will change only on the negative-going edge of the clock pulse.

1. At the first clock pulse, both $J$ and $K$ are HIGH; and because this is a toggle condition, $Q$ goes HIGH.
2. At clock pulse 2, a no-change condition exists on the inputs, keeping $Q$ at a HIGH level.
3. When clock pulse 3 occurs, $J$ is LOW and $K$ is HIGH, resulting in a RESET condition; $Q$ goes LOW.
4. At clock pulse $4, J$ is HIGH and $K$ is LOW, resulting in a SET condition; $Q$ goes HIGH.
5. A SET condition still exists on $J$ and $K$ when clock pulse 5 occurs, so $Q$ will remain HIGH.

The resulting $Q$ waveform is indicated in Figure 7-18(b).
Related Problem
Determine the $Q$ output of the J-K flip-flop if the $J$ and $K$ inputs in Figure 7-18(a) are inverted.

## Edge-Triggered Operation D Flip-Flop

A simplified implementation of an edge-triggered D flip-flop is illustrated in Figure 7-19(a) and is used to demonstrate the concept of edge-triggering. Notice that the basic D flip-flop differs from the gated D latch only in that it has a pulse transition detector.

One basic type of pulse transition detector is shown in Figure 7-19(b). As you can see, there is a small delay through the inverter on one input to the NAND gate so that the inverted clock pulse arrives at the gate input a few nanoseconds after the true clock pulse. This circuit produces a very short-duration spike on the positive-going transition of the clock pulse. In a negative edge-triggered flip-flop the clock pulse is inverted first, thus producing a narrow spike on the negative-going edge.

The circuit in Figure 7-19(a) is partitioned into two sections, one labeled Steering gates and the other labeled Latch. The steering gates direct, or steer, the clock spike either to the input to gate $G_{3}$ or to the input to gate $G_{4}$, depending on the state of the $D$ input. To understand the operation of this flip-flop, begin with the assumptions that it is in the RESET state

(a) A simplified logic diagram for a positive edge-triggered D flip-flop

(b) A type of pulse transition detector

FIGURE 7-19 Edge triggering.
( $Q=0$ ) and that the $D$ and CLK inputs are LOW. For this condition, the outputs of gate $G_{1}$ and gate $G_{2}$ are both HIGH. The LOW on the $Q$ output is coupled back into one input of gate $G_{4}$, making the $\bar{Q}$ output HIGH. Because $Q$ is HIGH, both inputs to gate $G_{3}$ are HIGH (remember, the output of gate $G_{1}$ is HIGH), holding the $Q$ output LOW. If a pulse is applied to the CLK input, the outputs of gates $G_{1}$ and $G_{2}$ remain HIGH because they are disabled by the LOW on the $D$ input; therefore, there is no change in the state of the flip-flop-it remains in the RESET state.

Let's now make $D$ HIGH and apply a clock pulse. Because the $D$ input to gate $G_{1}$ is now HIGH, the output of gate $G_{1}$ goes LOW for a very short time (spike) when CLK goes HIGH, causing the $Q$ output to go HIGH. Both inputs to gate $G_{4}$ are now HIGH (remember, gate $G_{2}$ output is HIGH because $D$ is HIGH), forcing the $\bar{Q}$ output LOW. This LOW on $\bar{Q}$ is coupled back into one input of gate $G_{3}$, ensuring that the $Q$ output will remain HIGH. The flip-flop is now in the SET state. Figure 7-20 illustrates the logic level transitions that take place within the flip-flop for this condition.

Next, let's make $D$ LOW and apply a clock pulse. The positive-going edge of the clock produces a negative-going spike on the output of gate $G_{2}$, causing the $\bar{Q}$ output to go HIGH. Because of this HIGH on $Q$, both inputs to gate $G_{3}$ are now HIGH (remember, the output of gate $G_{1}$ is HIGH because of the LOW on $D$ ), forcing the $Q$ output to go LOW. This LOW on $Q$ is coupled back into one input of gate $G_{4}$, ensuring that $\bar{Q}$ will remain HIGH. The flip-flop is now in the RESET state. Figure 7-21 illustrates the logic level transitions that occur within the flip-flop for this condition.


FIGURE 7-20 Flip-flop making a transition from the RESET state to the SET state on the positive-going edge of the clock pulse.


FIGURE 7-21 Flip-flop making a transition from the SET state to the RESET state on the positive-going edge of the clock pulse.

## EXAMPLE 7-6

Given the waveforms in Figure 7-22(a) for the $D$ input and the clock, determine the $Q$ output waveform if the flip-flop starts out RESET.


FIGURE 7-22

## Solution

The $Q$ output goes to the state of the $D$ input at the time of the positive-going clock edge. The resulting output is shown in Figure 7-22(b).

## Related Problem

Determine the $Q$ output for the D flip-flop if the $D$ input in Figure 7-22(a) is inverted.

