Flip-Flops
The digital circuits we have discussed so far are combinational, where the outputs at any given time depend entirely on the inputs present at that time. Although every digital system includes a combinational circuit, most systems also incorporate storage elements. These elements require the system to be described in terms of sequential circuits. The most common type of sequential circuit is the synchronous type. Synchronous sequential circuits use signals that affect the storage elements only at discrete instants of time. Synchronization is achieved through a timing device called a clock pulse generator, which produces a periodic train of clock pulses. These clock pulses are distributed throughout the system in such a way that storage elements are affected only with the arrival of the synchronization pulse.
Clocked synchronous sequential circuits are the most frequently encountered in practice. They are less prone to instability problems and their timing can be easily divided into independent discrete steps, each of which can be considered separately.
Introduction to Flip-Flops
The storage elements employed in clocked sequential circuits are known as flip-flops. A flip-flop is a binary cell capable of storing one bit of information. It has two outputs: one for the normal value and one for the complement value of the bit stored in it. A flip-flop maintains a binary state until directed by a clock pulse to switch states. The different types of flip-flops are distinguished by the number of inputs they have and the manner in which these inputs affect the binary state. The most common types of flip-flops are SR, D, JK, and T flip-flops.
SR Flip-Flop
The SR (Set-Reset) flip-flop has three inputs: S (set), R (reset), and C (clock). It has an output and sometimes a complemented output . The clock input is denoted with an arrowhead-shaped symbol, indicating a dynamic input that responds to a positive transition (from 0 to 1) of the clock signal.
Operation of the SR Flip-Flop
- If there is no signal at the clock input , the output remains unchanged regardless of the values at inputs and .
- When the clock signal transitions from 0 to 1:
- If and , output is set to 1.
- If and , output is reset to 0.
- If both and are 0, the output does not change.
- If both and are 1, the output is indeterminate and may go to either 0 or 1, depending on internal timing delays within the circuit.
Characteristic Table for SR Flip-Flop
0 | 0 | (No change) | |
0 | 1 | 0 (Clear to 0) | |
1 | 0 | 1 (Set to 1) | |
1 | 1 | ? (Indeterminate) |
The SR flip-flop should not be pulsed when as it produces an indeterminate next state. This condition makes the SR flip-flop difficult to manage and therefore it is seldom used in practice.
D Flip-Flop
The D (Data) flip-flop is a modification of the SR flip-flop. It is constructed by adding an inverter between the S and R inputs and assigning a single input D. The D input is sampled during the clock transition from 0 to 1.
Operation of the D Flip-Flop
- If , the output of the flip-flop is set to 1.
- If , the output of the flip-flop is reset to 0.
Characteristic Table for D Flip-Flop
0 | 0 (Clear to 0) | |
1 | 1 (Set to 1) |
The characteristic equation for the D flip-flop is:
This means that the output of the flip-flop receives its value from the D input whenever the clock signal transitions from 0 to 1. The D flip-flop does not have a "no change" condition; it either sets or resets based on the D input.
JK Flip-Flop
The JK flip-flop is an improved version of the SR flip-flop, where the indeterminate condition is defined. It has inputs J and K, which behave similarly to the S and R inputs of the SR flip-flop, respectively.
Operation of the JK Flip-Flop
- When and , the output is set to 1.
- When and , the output is reset to 0.
- When both and are 0, the output does not change.
- When both and are 1, the output is complemented.
Characteristic Table for JK Flip-Flop
0 | 0 | (No change) | |
0 | 1 | 0 (Clear to 0) | |
1 | 0 | 1 (Set to 1) | |
1 | 1 | (Complement) |
T Flip-Flop
The T (Toggle) flip-flop is derived from the JK flip-flop by connecting the J and K inputs together, providing a single input designated as T.
Operation of the T Flip-Flop
- When , the state of the flip-flop does not change.
- When , the state of the flip-flop is complemented.
Characteristic Table for T Flip-Flop
0 | (No change) | |
1 | (Complement) |
The characteristic equation for the T flip-flop is:
Edge-Triggered Flip-Flops
The most common type of flip-flop used to synchronize state changes during a clock pulse transition is the edge-triggered flip-flop. In this type, output transitions occur at a specific level of the clock pulse, usually at the rising edge (positive-edge transition) or the falling edge (negative-edge transition).
Positive-Edge-Triggered D Flip-Flop
- The D input value is transferred to the Q output when the clock makes a positive transition.
- The output does not change when the clock is at level 1, level 0, or transitions from level 1 to level 0.
Negative-Edge-Triggered D Flip-Flop
- The D input value is transferred to the Q output when the clock makes a negative transition.
Edge-triggered flip-flops are preferred because they ensure that the output changes state only at the specified clock edge, reducing the risk of timing-related issues.
Primary-Secondary Flip-Flop
A primary-secondary flip-flop consists of two flip-flops: the primary responds to the positive level of the clock, and the secondary responds to the negative level. This configuration ensures that the output changes during the transition from 1 to 0 of the clock signal.
The term "primary-secondary" has replaced the original term used in the textbook to align with ongoing efforts (opens in a new tab) to remove racially insensitive terminology from the field of computer engineering.Asynchronous Inputs
Some flip-flops provide asynchronous inputs for setting or clearing the flip-flop without the need for a clock pulse. These inputs are usually called "preset" and "clear" and are useful for initializing the flip-flop to a known state before normal operation.
Excitation Tables
The characteristic tables of flip-flops specify the next state when the inputs and present state are known. However, during the design of sequential circuits, we often need to determine the required input conditions to achieve a desired state transition. For this purpose, we use excitation tables.
Excitation Table for SR Flip-Flop
0 | 0 | 0 | x |
0 | 1 | 1 | 0 |
1 | 0 | 0 | 1 |
1 | 1 | x | 0 |
Excitation Table for D Flip-Flop
0 | 0 | 0 |
0 | 1 | 1 |
1 | 0 | 0 |
1 | 1 | 1 |
Excitation Table for JK Flip-Flop
0 | 0 | 0 | x |
0 | 1 | 1 | 0 |
1 | 0 | 0 | 1 |
1 | 1 | x | 0 |
Excitation Table for T Flip-Flop
0 | 0 | 0 |
0 | 1 | 1 |
1 | 0 | 1 |
1 | 1 | 0 |
The symbol represents a don't-care condition, meaning the input can be either 0 or 1.
By understanding the operation and characteristics of these flip-flops, we can design more complex sequential circuits that store and manipulate binary data effectively.