Sequential Circuits
Sequential Circuits
Sequential Circuits
The memory elements are devices capable of storing binary info. The binary info stored
in the memory elements at any given time defines the state of the sequential circuit. The
input and the present state of the memory element determines the output. Memory
elements next state is also a function of external inputs and present state. A sequential
circuit is specified by a time sequence of inputs, outputs, and internal states.
There are two types of sequential circuits. Their classification depends on the timing of
their signals:
This is a system whose outputs depend upon the order in which its input variables change
and can be affected at any instant of time.
This type of system uses storage elements called flip-flops that are employed to change
their binary value only at discrete instants of time. Synchronous sequential circuits use
logic gates and flip-flop storage devices. Sequential circuits have a clock signal as one of
their inputs. All state transitions in such circuits occur only when the clock value is either
0 or 1 or happen at the rising or falling edges of the clock depending on the type of
memory elements used in the circuit. Synchronization is achieved by a timing device
called a clock pulse generator. Clock pulses are distributed throughout the system in such
a way that the flip-flops are affected only with the arrival of the synchronization pulse.
Synchronous sequential circuits that use clock pulses in the inputs are called clocked-
sequential circuits. They are stable and their timing can easily be broken down into
independent discrete steps, each of which is considered separately.
A clock signal is a periodic square wave that indefinitely switches from 0 to 1 and from 1
to 0 at fixed intervals. Clock cycle time or clock period: the time interval between two
consecutive rising or falling edges of the clock.
Clock Frequency = 1 / clock cycle time (measured in cycles per second or Hz)
A sequential circuit as seen in the last page, is combinational logic with some feedback to
maintain its current value, like a memory cell. To understand the basics let's consider the
basic feedback logic circuit below, which is a simple NOT gate whose output is
connected to its input. The effect is that output oscillates between HIGH and LOW (i.e. 1
and 0). Oscillation frequency depends on gate delay and wire delay. Assuming a wire
delay of 0 and a gate delay of 10ns, then oscillation frequency would be (on time + off
time = 20ns) 50Mhz.
The basic idea of having the feedback is to store the value or hold the value, but in the
above circuit, output keeps toggling. We can overcome this problem with the circuit
below, which is basically cascading two inverters, so that the feedback is in-phase, thus
avoids toggling. The equivalent circuit is the same as having a buffer with its output
connected to its input.
But there is a problem here too: each gate output value is stable, but what will it be? Or in
other words buffer output can not be known. There is no way to tell. If we could know or
set the value we would have a simple 1-bit storage/memory element.
The circuit below is the same as the inverters connected back to back with provision to
set the state of each gate (NOR gate with both inputs shorted is like a inverter). I am not
going to explain the operation, as it is clear from the truth table. S is called set and R is
called Reset.
S R Q Q+
0 0 0 0
0 0 1 1
0 1 X 0
1 0 X 1
1 1 X 0
There still seems to be some problem with the above configuration, we can not control
when the input should be sampled, in other words there is no enable signal to control
when the input is sampled. Normally input enable signals can be of two types.
Level Sensitive: The circuit below is a modification of the above one to have level
sensitive enable input. Enable, when LOW, masks the input S and R. When HIGH,
presents S and R to the sequential logic input (the above circuit two NOR Gates). Thus
Enable, when HIGH, transfers input S and R to the sequential cell transparently, so this
kind of sequential circuits are called transparent Latch. The memory element we get is
an RS Latch with active high Enable.
Edge Sensitive: The circuit below is a cascade of two level sensitive memory elements,
with a phase shift in the enable input between first memory element and second memory
element. The first RS latch (i.e. the first memory element) will be enabled when CLK
input is HIGH and the second RS latch will be enabled when CLK is LOW. The net effect
is input RS is moved to Q and Q' when CLK changes state from HIGH to LOW, this
HIGH to LOW transition is called falling edge. So the Edge Sensitive element we get is
called negative edge RS flip-flop.
Now that we know the sequential circuits basics, let's look at each of them in detail in
accordance to what is taught in colleges. You are always welcome to suggest if this can
be written better in any way.
• Asynchronous Circuits.
• Synchronous Circuits.
As seen in last section, Latches and Flip-flops are one and the same with a slight
variation: Latches have level sensitive control signal input and Flip-flops have edge
sensitive control signal input. Flip-flops and latches which use this control signals are
called synchronous circuits. So if they don't use clock inputs, then they are called
asynchronous circuits.
RS Latch
RS latch have two inputs, S and R. S is called set and R is called reset. The S input is
used to produce HIGH on Q ( i.e. store binary 1 in flip-flop). The R input is used to
produce LOW on Q (i.e. store binary 0 in flip-flop). Q' is Q complementary output, so it
always holds the opposite value of Q. The output of the S-R latch depends on current as
well as previous inputs or state, and its state (value stored) can change as soon as its
inputs change. The circuit and the truth table of RS latch is shown below. (This circuit is
as we saw in the last page, but arranged to look beautiful :-) ).
S R Q Q+
0 0 0 0
0 0 1 1
0 1 X 0
1 0 X 1
1 1 X 0
The operation has to be analyzed with the 4 inputs combinations together with the 2
possible previous states.
The waveform below shows the operation of NOR gates based RS Latch.
It is possible to construct the RS latch using NAND gates (of course as seen in Logic
gates section). The only difference is that NAND is NOR gate dual form (Did I say that
in Logic gates section?). So in this case the R = 0 and S = 0 case becomes the invalid
case. The circuit and Truth table of RS latch using NAND is shown below.
S R Q Q+
1 1 0 0
1 1 1 1
0 1 X 0
1 0 X 1
0 0 X 1
If you look closely, there is no control signal (i.e. no clock and no enable), so this kind of
latches or flip-flops are called asynchronous logic elements. Since all the sequential
circuits are built around the RS latch, we will concentrate on synchronous circuits and not
on asynchronous circuits.
We have seen this circuit earlier with two possible input configurations: one with level
sensitive input and one with edge sensitive input. The circuit below shows the level
sensitive RS latch. Control signal "Enable" E is used to gate the input S and R to the RS
Latch. When Enable E is HIGH, both the AND gates act as buffers and thus R and S
appears at the RS latch input and it functions like a normal RS latch. When Enable E is
LOW, it drives LOW to both inputs of RS latch. As we saw in previous page, when both
inputs of a NOR latch are low, values are retained (i.e. the output does not change).
For synchronous flip-flops, we have special requirements for the inputs with respect to
clock signal input. They are
• Setup Time: Minimum time period during which data must be stable before the
clock makes a valid transition. For example, for a posedge triggered flip-flop,
with a setup time of 2 ns, Input Data (i.e. R and S in the case of RS flip-flop)
should be stable for at least 2 ns before clock makes transition from 0 to 1.
• Hold Time: Minimum time period during which data must be stable after the
clock has made a valid transition. For example, for a posedge triggered flip-flop,
with a hold time of 1 ns. Input Data (i.e. R and S in the case of RS flip-flop)
should be stable for at least 1 ns after clock has made transition from 0 to 1.
If data makes transition within this setup window and before the hold window, then the
flip-flop output is not predictable, and flip-flop enters what is known as meta stable
state. In this state flip-flop output oscillates between 0 and 1. It takes some time for the
flip-flop to settle down. The whole process is called metastability. You could refer to
tidbits section to know more information on this topic.
The waveform below shows input S (R is not shown), and CLK and output Q (Q' is not
shown) for a SR posedge flip-flop.
D Latch
The RS latch seen earlier contains ambiguous state; to eliminate this condition we can
ensure that S and R are never equal. This is done by connecting S and R together with an
inverter. Thus we have D Latch: the same as the RS latch, with the only difference that
there is only one input, instead of two (R and S). This input is called D or Data input. D
latch is called D transparent latch for the reasons explained earlier. Delay flip-flop or
delay latch is another name used. Below is the truth table and circuit of D latch.
D Q Q+
1 X 1
0 X 0
Below is the D latch waveform, which is similar to the RS latch one, but with R removed.
JK Latch
The ambiguous state output in the RS latch was eliminated in the D latch by joining the
inputs with an inverter. But the D latch has a single input. JK latch is similar to RS latch
in that it has 2 inputs J and K as shown figure below. The ambiguous state has been
eliminated here: when both inputs are high, output toggles. The only difference we see
here is output feedback to inputs, which is not there in the RS latch.
J K Q
1 1 0
1 1 1
1 0 1
0 1 0
T Latch
When the two inputs of JK latch are shorted, a T Latch is formed. It is called T latch as,
when input is held HIGH, output toggles.
T Q Q+
1 0 1
1 1 0
0 1 1
0 0 0
All sequential circuits that we have seen in the last few pages have a problem (All level
sensitive sequential circuits have this problem). Before the enable input changes state
from HIGH to LOW (assuming HIGH is ON and LOW is OFF state), if inputs changes,
then another state transition occurs for the same enable pulse. This sort of multiple
transition problem is called racing.
If we make the sequential element sensitive to edges, instead of levels, we can overcome
this problem, as input is evaluated only during enable/clock edges.
In the figure above there are two latches, the first latch on the left is called master latch
and the one on the right is called slave latch. Master latch is positively clocked and slave
latch is negatively clocked.
Sequential Circuits Design
We saw in the combinational circuits section how to design a combinational circuit from
the given problem. We convert the problem into a truth table, then draw K-map for the
truth table, and then finally draw the gate level circuit for the problem. Similarly we have
a flow for the sequential circuit design. The steps are given below.
Looks like sequential circuit design flow is very much the same as for combinational
circuit.
State Diagram
The state diagram is constructed using all the states of the sequential circuit in question. It
builds up the relationship between various states and also shows how inputs affect the
states.
To ease the following of the tutorial, let's consider designing the 2 bit up counter (Binary
counter is one which counts a binary sequence) using the T flip-flop.
Below is the state diagram of the 2-bit binary counter.
State Table
The state table is the same as the excitation table of a flip-flop, i.e. what inputs need to be
applied to get the required output. In other words this table gives the inputs required to
produce the specific outputs.
Q1 Q0 Q1+ Q0+ T1 T0
0 0 0 1 0 1
0 1 1 0 1 1
1 0 1 1 0 1
1 1 0 0 1 1
K-map
The K-map is the same as the combinational circuits K-map. Only difference: we draw
K-map for the inputs i.e. T1 and T0 in the above table. From the table we deduct that we
don't need to draw K-map for T0, as it is high for all the state combinations. But for T1
we need to draw the K-map as shown below, using SOP.
Circuit
There is nothing special in drawing the circuit, it is the same as any circuit drawing from
K-map output. Below is the circuit of 2-bit up counter using the T flip-flop.