M.Sc.
Physics , Department of Physics
CDOE ,Kakatiya University, Warangal
Prof.C.J.Sreelatha
Topic: Sequential Logic Circuits
UNIT IV
SEQUENTIAL LOGIC CIRCUITS:
we studied the logic circuits whose outputs at any instant of time depend only on the input signals present at that time
are known as combinational circuits.
Moreover, in a combinational circuit, the output appears immediately for a change in input.
On the other hand, the logic circuits whose outputs at any instant of time depend on the present inputs as well as on
the past outputs are called sequential circuits. In sequential circuits, the output signals are fed back to the input side.
A block diagram of a sequential circuit is shown in Figure
above:-
It consists of a combinational circuit to which storage elements are
connected to form a feedback path. The storage elements are devices
capable of storing binary information. The binary information stored
in these elements at any given time defines the state of the
sequential circuit at that time. The sequential circuit receives binary
information from external inputs that, together with the present state
of the storage elements, determine the binary value of the outputs.
These external inputs also determine the condition for changing the
state in the storage elements.
The block diagram demonstrates that the outputs in a sequential circuit
are a function not only of the inputs, but also of the present state of the
storage elements. The next state of the storage elements is also a
function of external inputs and the present state. Thus, a sequential
circuit is specified by a time sequence of inputs, outputs, and internal
states.
There are two types of sequential circuits, and their classification is a
function of the timing of their signals.
Asynchronous sequential circuit:
A sequential circuit whose behavior depends upon the sequence in
which the input signals change is referred to as an asynchronous
sequential circuit. The output will be affected whenever the input
changes. The commonly used memory elements in these circuits
are time-delay devices. There is no need to wait for a clock pulse.
Therefore, in general, asynchronous circuits are faster than
synchronous sequential circuits. However, in an asynchronous
circuit, events are allowed to occur without any synchronization.
And in such a case, the system becomes unstable.
Since the designs of asynchronous circuits are more tedious and
difficult, their uses are rather limited. The memory elements used in
sequential circuits are flip-flops which are capable of storing binary
information.
Sequential circuits
A sequential circuit whose behavior can be defined from the knowledge of
its signal at discrete instants of time is referred to as a synchronous
sequential circuit. In these systems, the memory elements are affected
only at discrete instants of time. The synchronization is achieved by a
timing device known as a system clock, which generates a periodic train of
lock pulses. The outputs are affected only with the application of a clock
pulse.
The storage elements (memory) used in clocked
sequential circuits are called Flip-flops
FLIP-FLOPS
The basic 1-bit digital memory circuit is known as a flip-flop. It can have
only two states, either the 1 state or the 0 state.
A flip-flop is also known as a bistable multivibrator. Flip-flops can be
obtained by using NAND or NOR gates.
The general block diagram representation of a flip-flop is shown in Figure
below. It has one or more inputs and two outputs. The two outputs are
complementary to each other. If Q is 1 i.e., Set, then Q' is 0; if Q is 0 i.e.,
Reset, then Q' is 1. That means Q and Q' cannot be at the same state
simultaneously. If it happens by any chance, it violates the definition of a
flip-flop and hence is called an undefined condition. Normally, the state of
Q is called the state of the flip-flop, whereas the state of Q' is called the
complementary state of the flip-flop.
When the output Q is either 1 or 0, it remains in that state unless one or
more inputs are excited to effect a change in the output.
Since the output of the flip-flop remains in the same state until the trigger
pulse is applied to change the state, it can be regarded as a memory device
to store one binary bit. The block diagram of a flip-flop is given below:-
The Bistable multivibrator circuit of a flip-flop is
given below:-
From the circuit shown in above, the multivibrator is basically two cross coupled
inverting amplifiers, consist of two transistors and four resistors. Obviously, if
transistor T1 is initially turned ON (saturated) by applying a
positive signal through the Set input at its base, its collector will be at VCE(sat)
(0.2 to 0.4 V). The collector of T1 is connected to the base of T2, which cannot
turn T2 On. Hence, T2 remains OFF (cut off). Therefore, the
voltage at the collector of T2 tries to reach VCC. This action only enhances the
initial positive signal applied to the base of T1. Now if the initial signal at the Set
input is removed, the circuit will maintain T1 in the ON state
and T2 in the OFF state indefinitely, i.e., Q = 1 & Q' = 0. In this condition the
bistable multivibrator is said to be in the Set state. A positive signal applied to the
Reset input at the base of T2 turns it ON. As we have discussed earlier, in the
same sequence T2 turns ON & T1 turns OFF, resulting in a second stable state i.e.
Q = 0 & Q' = 1.In this condition the bistable multivibrator is said to be in the Reset
state.
LATCHES
The basic difference between a latch & flip-flop is, Storage elements that
operate with signal levels (rather than signal transitions) are referred to as
latches; those controlled by a clock transition are flip-flops. Latches are
said to be level sensitive devices; flip-flops are edge-sensitive devices.
TYPES OF FLIP-FLOPS
There are different types of flip-flops depending on how their inputs and
clock pulses cause transition between two states. We will discuss four
different types of flip-flops, viz., S-R, D, J-K, and T. Basically D, J-K, and T
are three different modifications of the S-R flip-flop.
S-R (Set-Reset) Flip-flop
An S-R flip-flop has two inputs named Set (S) and Reset (R), and two
outputs Q and Q'. The outputs are complement of each other, i.e., if one
of the outputs is 0 then the other should be 1. This can be implemented
using NAND or NOR gates. The block diagram of an S-R flip-flop is shown
in Figure below:-
S-R Flip-flop Based on NOR Gates
An S-R flip-flop can be constructed with NOR gates at ease by connecting
the NOR gates back to back as shown in Figure below. The cross-coupled
connections from the output of gate 1 to the input of gate 2 constitute a
feedback path. This circuit is not clocked and is classified as an
asynchronous sequential circuit. The truth table for the S-R flip-flop based
on a NOR gate is shown in the table below.
Truth Table of SR
CLOCKED S-R FLIP-FLOP
Generally, synchronous circuits change their states only when clock pulses
are present. The operation of the basic flip-flop can be modified by
including an additional input to control the behavior of the circuit. Such a
circuit is shown below:-
The circuit shown above consists of two AND gates. The clock input is
connected to both of the AND gates, resulting in LOW outputs when the
clock input is LOW. In this situation the changes in S and R inputs will not
affect the state (Q) of the flip-flop. On the other hand, if the clock input is
HIGH, the changes in S and R will be passed over by the AND gates and
they will cause changes in the output (Q) of the flip-flop. This way, any
information, either 1 or 0, can be stored in the flip-flop by applying a HIGH
clock input and be retained for any desired period of time by applying a
LOW at the clock input. This type of flip-flop is called a clocked S-R flip-
flop.
Preset and Clear
Till now the flip-flops we discussed there when the power is switched on,
the state of the circuit is uncertain.
It may come to reset (Q = 0) or set (Q = 1) state. But in many applications
it is required to initially set or reset the flip-flop., i.e., the initial state of the
flip-flop is to be assigned. This is done by using the direct or asynchronous
inputs. These inputs are referred to as preset (Pr) and clear (Cr) inputs.
These inputs may be applied at any time between clock pulses and is not
in synchronism with the clock. Such an S-R flip-flop containing preset and
clear inputs is shown in Figure below.
Preset and Clear
CLOCKED D FLIP-FLOP
One way to eliminate the undesirable condition of the indeterminate state in
the SR latch is to ensure that inputs S and R are never equal to 1 at the same
time. This is done in the D latch. The D flip-flop has only one input referred to as
the D (data) input & two outputs as usual Q and Q'. It transfers the data at the
input after the delay of one clock pulse at the output Q. So in some cases the
input is referred to as a delay input and the flip-flop gets the name delay (D)
flip-flop. It can be easily constructed from an S-R flip-flop by simply
incorporating an inverter between S and R such that the input of the inverter is
at the S end & the output of the inverter is at the R end. We can get rid of the
undefined condition, i.e., S = R = 1 condition, of the S-R flip-flop in the D flip
flop.
The D flip-flop is either used as a delay device or as a latch to store one bit
of binary information. The truth table of D flip-flop is given in the table
below. The structure of the D flip-flop is shown in Figure below, which is
being constructed using NAND gates. The same structure can be
constructed using only NOR gates.
A simple way to construct a D flip-flop using an S-R flip-flop is shown in
Figure below.
The logic symbol of a D flip-flop is shown in Figure below. A D flip-flop is
most often used in the construction of sequential circuits like registers.
J-K FLIP-FLOP
A J-K flip-flop has very similar characteristics to an S-R flip-flop. The only
difference is that the undefined condition for an S-R flip-flop, i.e., Sn =
Rn = 1 condition, is also included in this case. Inputs J and K behave like
inputs S and R to set and reset the flip-flop respectively. When J = K = 1,
the flip-flop is said to be in a toggle state, which means the output
switches to its complementary state every time a clock passes.
The data inputs are J and K, which are ANDed with Q' and Q
respectively to obtain the inputs for S and R respectively. A J-K flip-flop
thus obtained is shown in Figure below.
An S-R flip-flop converted into a J-K flip-flop:-
K
A J-K flip-flop using NAND gates:-
Logic symbol of a J-K flip-flop:-
Race-around Condition of a J-K Flip-flop
The inherent difficulty of an S-R flip-flop (i.e., S = R = 1) is eliminated by
using the feedback connections from the outputs to the inputs of gate 1
and gate 2 as discussed in JK flip-flop. Truth tables JK flip-flop were formed
with the assumption that the inputs do not change during the clock pulse
(CLK = 1). But the consideration is not true because of the feedback
connections. Consider, for example, that the inputs are J = K = 1 and Q = 1,
and a pulse as shown in Figure below is applied at the clock input
Consider, for example, that the inputs are J = K = 1 and Q = 1, and a pulse
as shown above is applied at the clock input. After a time interval Δt equal
to the propagation delay through two NAND gates in series, the outputs
will change to Q = 0. So now we have J = K = 1 and Q = 0. After another
time interval of Δt the output will change back to Q = 1. Hence, we
conclude that for the time duration of tp of the clock pulse, the output will
oscillate between 0 and 1. Hence, at the end of the clock pulse, the value
of the output is not certain. This situation is referred to as a race-around
condition.
Master-Slave J-K Flip-flop
A master-slave (M-S) flip-flop is shown in Figure below. Basically, a master-slave
flip-flop is a system of two flip-flops—one being designated as master and the
other is the slave. From the figure below we see that a clock pulse is applied to
the master and the inverted form of the same clock pulse is applied to the
slave.
When CLK = 1, the first flip-flop (i.e., the master) is enabled and the outputs Qm
and Q'm respond to the inputs J and K according to the table shown in Figure
7.13. At this time the second flip-flop (i.e., the slave) is disabled because the
CLK is LOW to the second flip-flop. Similarly, when CLK becomes LOW, the
master becomes disabled and the slave becomes active, since now the CLK to
it is HIGH. Therefore, the outputs Q and Q' follow the outputs Qm and Q'm
Since the second flip-flop just follows the first one, it is referred to as a
slave and the first one is called the master. Hence, the configuration is
referred to as a master-slave (M-S) flipflop.
In this type of circuit configuration the inputs to the gates 5 and 6 do not
change at the time of application of the clock pulse. Hence the race-
around condition does not exist. The state of the master-slave flip-flop,
shown in above Figure, changes at the negative transition (trailing edge) of
the clock pulse. Hence, it becomes negative triggering a master-slave flip-
flop. This can be changed to a positive edge triggering flip-flop by adding
two inverters to the system—one before the clock pulse is applied to the
master and an additional one in between the master and the slave. The
logic symbol of a negative edge master-slave is shown in Figure below.
T Flip-flop
With a slight modification of a J-K flip-flop, we can construct a new flip-flop
called a T flip-flop. If the two inputs J and K of a J-K flip-flop are tied
together it is referred to as a T flip-flop. Hence, a T flip-flop has only one
input T and two outputs Q and Q'. The name T flip-flop actually indicates
the fact that the flip-flop has the ability to toggle. It has actually only two
states—toggle state and memory state. Since there are only two states,
a T flip-flop is a very good option to use in counter design and in
sequential circuits design where switching an operation is required. The
truth table of a T flip-flop is given below
The circuit diagram of a T flip-flop and the block
diagram of the T flip-flop is shown below
REGISTERS
A register is a group of binary storage cells capable of holding binary
information. A group of flip-flops constitutes a register, since each flip-flop can
work as a binary cell. An n-bit register, has n flip-flops and is capable of
holding n-bits information. In addition to flip-flops a register can have a
combinational part that performs data-processing tasks.
Register:
• A set of n flip-flops
• Each flip-flop stores one bit
• Two basic functions: data storage and data movement.
Shift Register: A register that allows each of the flip-flops to pass the stored
information to its adjacent neighbor.
Counter: A register that goes through a predetermined sequence of states.
Basic data movement operation in shift registers
Storage Capacity of a register
The storage capacity of a register is the total number of bits (1 or 0) of
digital data it can retain. Each stage (flip flop) in a shift register represents
one bit of storage capacity. Therefore the number of stages in a register
determines its storage capacity.
The effect of data movement from left to right through a shift
register can be presented graphically as:
Shift Register
A shift register is a storage device that used to store binary data. When a
number of flip flop are connected in series it is called a register. A single
flip flop is supposed to stay in one of the two stable states 1 or 0 or in
other words the flip flop contains a number 1 or 0 depending upon the
state in which it is. A register will thus contain a series of bits which can be
termed as a word or a byte.
If in these registers the connection is done in such a way that the output
of one of the flip flop forms in input to other, it is known as a shift register.
The data in a shift register is moved serially (one bit at a time). The shift
register can be built using RS, JK or D flip-flops various types of shift
registers are available some of them are given as under.
1. Shift Left Register
2. Shift Right Register
3. Shift Around Register
4. Bi-directional Shift Register
There are two ways to shift data into a register (serial or parallel) and
similarly two ways to shift the data out of the register. This leads to the
construction of four basic types of registers:-
1. Serial in/Serial out (SISO)
2. Serial in/Parallel out (SIPO)
3. Parallel in/Serial out (PISO)
4. Parallel in/Parallel out (PIPO)
SERIAL-IN–-SERIAL-OUT SHIFT REGISTER
From the name itself it is obvious that this type of register accepts data
serially, i.e., one bit at a time at the single input line. The output is also
obtained on a single output line in a serial fashion. The data within the
register may be shifted from left to right using shift-left register, or may be
shifted from right to left using shift right register.
Figure of Shift-right register (a) using D flip-flops, (b) using J-K flip-flops.
In the shift register using D flip-flop, D input of the left most flip-flop is
used as a serial input line. To input 0,one should apply 0 at the D input and
vice versa.
The clock pulse is applied to all the flip-flops simultaneously. When the
clock pulse is applied, each flip-flop is either set or reset according to the
data available at that point of time at the respective inputs of the
individual flip-flops. Hence the input data bit at the serial input line is
entered into flip-flop A by the first clock pulse. At the same time, the data
of stage A is shifted into stage B and so on to the following stages. For
each clock pulse, data stored in the register is shifted to the right by one
stage. New data is entered into stage A, whereas the data present in stage
D are shifted out (to the right).
Operation of the Shift-right Register
The 0 in the binary number is now applied at the serial input line, and the
third clock pulse is now applied.
For example, consider that all the stages are reset and a logical input 1011 is
applied at the serial input line connected to stage A. The data after four
clock pulses is shown in above Table.
Let us now illustrate the entry of the 4-bit number 1011 into the register,
beginning with the right-most bit. A 1 is applied at the serial input line,
making D = 1. As the first clock pulse is applied, flip-flop A is SET, thus
storing the 1. Next, a 1 is applied to the serial input, making D = 1 for flip-
flop A and D = 1 for flip-flop B also, because the input of flip-flop B is
connected to the QA output.
When the second clock pulse occurs, the 1 on the data input is “shifted”
to the flip-flop A and the 1 in the flip flop A is “shifted” to flip-flop B.
This 0 is entered in flip-flop A and the 1 stored in flip-flop A is now
“shifted” to flip-flop B and the 1 stored in flip-flop B is now “shifted” to
flip-flop C. The last bit in the binary number that is the 1 is now applied at
the serial input line and the fourth clock pulse is now applied. This 1 now
enters the flip flop A and the 0 stored in flip-flop A is now “shifted” to flip-
flop B and the 1 stored in flip-flop B is now “shifted” to flip-flop C and the
1 stored in flip-flop C is now “shifted” to flip-flop D. Thus the entry of the
4-bit binary number in the shift-right register is now completed.
Shift-left Register
A shift-left register can also be constructed with either J-K or D flip-flops as
shown in Figure below. Let us now illustrate the entry of the 4-bit number
1110 into the register, beginning with the right-most bit. A 0 is applied at
the serial input line, making D = 0. As the first clock pulse is applied, flip-
flop A is RESET, thus storing the 0. Next a 1 is applied to the serial input,
making D = 1 for flip-flop A and D = 0 for flip-flop B, because the input of
flip-flop B is connected to the QA output.
When the second clock pulse occurs, the 1 on the data input is “shifted” to
the flip-flop A and the 0 in the flip flop A is “shifted” to flip-flop B. The 1 in
the binary number is now applied at the serial input line, and the third
clock pulse is now applied. This 1 is entered in flip-flop A and the 1 stored
in flip-flop A is now “shifted” to flip-flop B and the 0 stored in flip-flop B is
now “shifted” to flip-flop C. The last bit in the binary number that is the 1
is now applied at the serial input line and the fourth clock pulse is now
applied. This 1 now enters the flip flop A and the 1 stored in flip-flop A is
now “shifted” to flip-flop B and the 1 stored in flip-flop B is now “shifted”
to flip-flop C and the 0 stored in flip-flop C is now “shifted” to flip-flop D.
Thus the entry of the 4-bit binary number in the shift-left register is now
completed.
8-bit Serial-in–Serial-out Shift Register
The pin out and logic diagram of IC 74L91 is shown in Figure below. This IC
is actually an example of an 8-bit serial-in–serial-out shift register. There
are eight S-R flip-flops connected to provide a serial input as well as a
serial output. The clock input at each flip-flop is negative edge-triggered.
However, the applied clock signal is passed through an inverter. Hence the
data will be shifted on the positive edges of the input clock pulses.
An inverter is connected in between R and S on the first flip-flop. This
means that this circuit functions as a D type flip-flop. So the input to the
register is a single liner on which the data can be shifted into the register
appears serially. The data input is applied at either A (pin 12) or B (pin 11).
The data level at A (or B) is complemented by the NAND gate and then
applied to the R input of the first flip-flop. The same data level is
complemented by the NAND gate and then again complemented by the
inverter before it appears at the S input So, a 0 at input A will reset the
first flip-flop (in other words this 0 is shifted into the first flip-flop) on a
positive clock transition. The NAND gate with A and B inputs provide a
gating function for the input data stream if required, if gating is not
required, simply connect pins 11 and 12 together and apply the input data
stream to this connection.
8-bit Serial-in–Serial-out Shift Register
SERIAL-IN–PARALLEL-OUT REGISTER
In this type of register, the data is shifted in serially, but shifted out in
parallel. To obtain the output data in parallel, it is required that all the
output bits are available at the same time. This can be accomplished by
connecting the output of each flip-flop to an output pin. Once the data is
stored in the flip-flop the bits are available simultaneously. The basic
configuration of a serial-in–parallel-out is shift register shown in below.
8-bit Serial-in–Parallel-out Shift Register
The pin out and logic diagram of IC 74164 is shown in Figure below. IC 74164 is
an example of an 8-bit SIPO shift register. There are eight S-R flip-flops, which
are all sensitive to negative clock transitions. The logic diagram in Figure below
is almost the same as shown in SISO with only two exceptions: (1) each flip-
flop has an asynchronous CLEAR input; and (2) the true side of each flip-flop is
available as an output—thus all 8 bits of any number stored in the register are
available simultaneously as an output (this is a parallel data output).
Hence, a low level at the CLR input to the chip (pin 9) is applied through an
amplifier and will reset every flip flop. As long as the CLR input to the chip is
LOW, the flip-flop outputs will all remain low. It means that, in effect, the
register will contain all zeros.
PARALLEL-IN–SERIAL-OUT REGISTER
In the preceding two cases the data was shifted into the registers in a serial
manner. Here we develop an idea for the parallel entry of data into the
register. Here the data bits are entered into the flip-flops simultaneously,
rather than a bit-by-bit basis.
A 4-bit parallel-in–serial-out register is illustrated in Figure below. A, B, C,
and D are the four parallel data input lines and SHIFT / LOAD is a control
input that allows the four bits of data at A, B, C, and D inputs to enter into
the register in parallel or shift the data in serial. When SHIFT / LOAD is HIGH,
AND gates G1, G3 & G5 are enabled, allowing the data bits to shift right
from one stage to the next. When SHIFT /LOAD is LOW, AND gates G2, G4,
and G6 are enabled, allowing the data bits at the parallel inputs.
When a clock pulse is applied, the flip-flops with D = 1 will be set and the
flip-flops with D = 0 will be reset, thereby storing all the four bits
simultaneously. The OR gates allow either the normal shifting operation or
the parallel data-entry operation, depending on which of the AND gates
are enabled by the level on the SHIFT /LOAD input.
Figure:- A 4-bit parallel-in–serial-out shift register.
8-bit Parallel-in–Serial-out Shift Register
The pin out and logic diagram of IC 74165 is shown in Figure below. IC 74165 is an
example of an 8-bit serial/parallel-in and serial-out shift register. The data can be
loaded into the register in parallel and shifted out serially at QH using either of two
clocks (CLK or CLK inhibit). It also contains a serial input, DS through which the data can
be serially shifted in.
When the input SHIFT /LOAD is LOW, it enables all the NAND gates for parallel loading.
When an input data bit is a 0, the flip-fl op is asynchronously RESET by a LOW output of
the lower NAND gate.
Similarly, when the input data bit is a 1, the flip-flop is asynchronously SET by a LOW
output of the upper NAND gate. The clock is inhibited during parallel loading operation.
A HIGH on the SHIFT /LOAD input enables the clock causing the data in the register to
shift right. With the low to high transitions of either clock, the serial input data (DS) are
shifted into the 8-bit register.
8-bit Parallel-in–Serial-out Shift Register
8-bit Parallel-in–Serial-out Shift Register
PARALLEL-IN–PARALLEL-OUT REGISTER
The parallel input of data has already been discussed in the preceding
section of parallel-in–serial-out shift register. Also, in this type of register
there is no interconnection between the flip-flops since no serial shifting is
required. Hence, the moment the parallel Entry of the data is
accomplished the data will be available at the parallel outputs of the
register. A simple parallel-in–parallel out shift register is shown in Figure
below.
Here the parallel inputs to be applied at A, B, C, and D inputs are directly
connected to the D inputs of the respective fl ip-fl ops. On Applying the
clock transitions, these inputs are entered into the register and are
immediately available at the outputs Q1, Q2, Q3, and Q4.
UNIVERSAL REGISTER
A register that is capable of transferring data in only one direction is called
a ‘unidirectional shift register’ whereas the register that is capable of
transferring data in both left and right direction is called a ‘bidirectional
shift register’. Now if the register has both the shift-right and shift-left
capabilities, along with the necessary input and output terminals for
parallel transfer, then it is called a shift register with parallel load or
‘universal shift register’. The most general shift register has all the
capabilities listed below. Others may have only some of these functions,
with at least one shift operation.
1) A shift-right control to enable the shift-right operation and the serial input
and output lines associated with the shift-right.
2) A shift-left control to enable the shift-left operation and the serial input
and output lines associated with the shift-left.
3) A parallel-load control to enable a parallel transfer and the n input lines
associated with the parallel transfer.
4) n parallel output lines.
5) A clear control to clear the register to 0.
6) A CLK input for clock pulses to synchronize all operations.
7) A control state that leaves the information in the register unchanged even
though clock pulses are continuously applied.
Figure:- 4-bit universal shift register
The diagram of a shift-register with all the capabilities listed above is
shown in Figure above. This is similar to IC type 74194. Though it consists
of four D flip-flops, S-R flip-flops can also be used with an inverter inserted
between the S and R terminals. The four multiplexers drawn are also part
of the register. The four multiplexers have two common selection lines S1
and S0. When S1S0 = 00, the input 0 is selected for each of the
multiplexers.
Similarly, when S1S0 = 01, the input 1, when S1S0 = 10, the input 2 and for
S1S0 = 11, the input 3, is selected for each of the multiplexers.
The S1 and S0 inputs control the mode of operation of the register as specified in the
entries of functions in the below Table. When S1S0 = 00, the present value of the
register is applied to the D inputs of the flip-flops. Hence this condition forms a path
from the output of each flip-flop into the input of the same flip-flop. The next clock
pulse transition transfers into each flip-flop the binary value held previously & no
change of state occurs. When S1S0 = 01, terminals 1 of each of the multiplexer
inputs have a path to the D inputs of each of the flip-flops. This causes a shift-right
operation, with the serial input transferred into flip-flop A4. Similarly, with S1S0 =
10, a
shift-left operation results, with the other serial input going into flip-flop A1. Finally,
when S1S0 = 11, the binary information on the parallel input lines is transferred into
the register simultaneously during the next clock pulse.
Table:- Function table for the universal register
A universal register is a general-purpose register capable of performing three
operations: shift-right, shift-left, and parallel load. Not all shift registers
available in MSI circuits have all these capabilities. The particular application
dictates the choice of one MSI circuit over another. As we have already
mentioned IC 74194 is a 4-bit bidirectional shift register with parallel load. The
pin out diagram of IC 74194 is shown in Figure :-
The parallel loading of data is accomplished with a positive transition of the
clock and by applying the four bits of data to the parallel inputs and a HIGH to
the S1 and S0 inputs. Similarly, shift-right is accomplished synchronously with
the positive edge of the clock when S0 is HIGH and S1 is LOW. In this mode the
serial data is entered at the shift right serial input. In the same manner, when
S0 is LOW and S1 is HIGH, data bits shift left synchronously with the clock pulse
and new data is entered at the shift-left serial input .
SHIFT REGISTER COUNTERS
Shift registers may be arranged to form different types of counters. These
shift registers use feedback, where the output of the last flip-flop in the
shift register is fed back to the first flip-flop. Based on the type of this
feedback connection, the shift register counters are classified as (i) ring
counter and (ii) twisted ring or Johnson or Shift counter.
Ring Counter
It is possible to devise a counter-like circuit in which each flip-flop reaches
the state Q = 1 for exactly one count, while for all other counts Q = 0. Then
Q indicates directly an occurrence of the corresponding count.
Actually, since this does not represent binary numbers, it is better to say
that the outputs of the flip-flops represent a code. Such a circuit is shown
in Figure below, which is known as a ring counter
The Q output of the last stage in the shift register is fed back as the input
to the first stage, which creates a ring-like structure.
Hence a ring counter is a circular shift register with only one flip-flop being
set at any particular time and all others being cleared. The single bit is
shifted from one flip-flop to the other to produce the sequence of timing
signals. Such encoding where there is a single 1 and the rest of the code
variables are 0, is called a one-hot code.
Figure:- A 4-bit ring counter using D flip-flops
The circuit shown in Figure above consists of four flip-flops and their outputs
are QA,QB, QC, and QE respectively. The PRESET input of the last flip-fl op
and the CLEAR inputs of the other three flip-flops are connected together.
Now, by applying a LOW pulse at this line, the last flip-flop is SET and all the
others are RESET, i.e., QAQBQCQE = 0001. Hence, from the circuit it is clear
that DA = 1, DB = 0, DC = 0, and DE = 0.
Therefore, when a clock pulse is applied, the 1st flip-flop is set to 1, while the
other three flip-flops are reset to 0 i.e., the output of the ring counter is
QAQBQCQE = 1000. Similarly, when the 2nd clock pulse is applied, the 1 in
the first flip-flop is shifted to the second flip-flop & the output of the counter
becomes QAQBQCQE = 0100;
on occurrence of the 3rd clock pulse, the output will be QAQBQCQE = 0010;
on occurrence of the fourth clock pulse the output becomes QAQBQCQE =
0001, i.e., the initial state. Thus, the 1 is shifted around the register as long as
the clock pulses are applied.
The truth table that describes the operation of the above 4-bit ring counter is shown in
Table below:-
Johnson Counter
A k-bit ring counter circulates a single bit among the flip-flops to provide k
distinguishable states. The number of sates can be doubled if the shift register is
connected as a switch-tail ring counter. A switch-tail ring counter is a circular shift
register with the complement of the last flip-flop being connected to the input of
the first flip flop.The circular connection is made from the complement of the
rightmost flip-flop to the input of the leftmost flip-flop. The register shifts its
contents once to the right with every clock pulse, and at the same time, the
complement value of the E flip-flop is transferred into the A flip-flop. Starting from
a cleared state, the switch-tail ring counter goes through a sequence of eight states
as listed in Table below. In general a k-bit switch-tail counter will go through 2k
states. Starting with all 0s each shift operation inserts 1s from the left until the
register is filled with all 1s. In the following sequences, 0s are inserted from the left
until the register is again filled with all 0s.
Fig:- A 4-bit Johnson counter using D flip-flops and decoding gates
A Johnson or moebius counter is a switch-tail ring counter with 2k
decoding gates to provide outputs for 2k timing signals. The decoding
gates are also shown in Figure above. Since each gate is enabled during
one particular state sequence, the outputs of the gates generate eight
timing sequences in succession.
The decoding of a k-bit switch-tail ring counter to obtain 2k timing sequences
follows a regular pattern. The all-0s state is decoded by taking the complement
of the two extreme flip-flop outputs. The all-1s state is decoded by taking the
normal outputs of the two extreme flip-flops. All other states are decoded from
an adjacent 1, 0 or 0, 1 pattern in the sequence.
For example, sequence 6 has an adjacent 0 and 1 pattern in flip-flops A and B. the
decoded output is then obtained by taking the complement A and the normal of
B, or the A′B.
Table :- Count sequence of a 4-bit Johnson counter
Asynchronous and Synchronous Shift Registers
Asynchronous circuits changes state each time the input changes the state,
while synchronous circuit changes state only when triggered by a
momentary change in the input signal. This momentary change is called
triggering.
Shift registers are made of flip flops and their operation depends upon the
state at the flip flops. Flip flops changes their states due to triggering when
flip flop change their state on the base of input pulse then it is called Edge
triggering. In edge triggering flip flop change its state on the basses of
Leading edge or trailing edge.
When flip flop works on the bases of change in DC level, that
is called Asynchronous Triggering. And the shift registers work
on this principle is called Asynchronous shift registers. On the
other hand, shift registers changes their state only when
triggered by clock pulse are called Synchronous shift registers
these type of shift registers usually used in counters.
Counters
Counting is frequently required in digital computers and other digital
systems to record the number of events occurring in a specified interval of
time. Normally an electronic counter is used for counting the number of
pulses coming at the input line in a specified time period. The counter must
possess memory since it has to remember its past states. As with other
sequential logic circuits counters can be synchronous or asynchronous.
As the name suggests, it is a circuit which counts. The main purpose of the
counter is to record the number of occurrence of some input. There are
many types of counter both binary and decimal. Commonly used counters
are
1. Binary Ripple Counter
2. Ring Counter
3. BCD Counter
4. Decade counter
5. Up down Counter
6. Frequency Counter
Ripple Counter
A counter that follows the binary number sequence is called a binary counter.
An n ‐bit binary counter consists of n flip‐flops and can count in binary from
0 through 2n - 1. Counters are available in two categories: ripple counters
and synchronous counters. In a ripple counter, a flip‐flop output transition
serves as a source for triggering other flip‐flops. In other words, the C input
of some or all flip‐flops are triggered, not by the common clock pulses, but
rather by the transition that occurs in other flip‐flop outputs. In a
synchronous counter, the C inputs of all flip‐flops receive the common clock.
Binary Ripple Counter
A binary ripple counter consists of a series connection of complementing
flip‐flops, with the output of each flip‐flop connected to the C input of the
next higher order flip‐flop. The flip‐flop holding the least significant bit
receives the incoming count pulses. A complementing flip‐flop can be
obtained from a JK flip‐flop with the J and K inputs tied together or from a
T flip‐flop. A third possibility is to use a D flip‐flop with the complement
output connected to the D input. In this way, the D input is always the
complement of the present state, and the next clock pulse will cause the
flip‐flop to complement. The logic diagram of two 4‐bit binary ripple
counters is shown in Fig. below . The output of each flip‐flop is connected
to the C input of the next flip‐flop in sequence. The flip‐flop holding the
least significant bit receives the incoming count pulses.
The T inputs of all the flip‐flops in (a) are connected to a permanent logic 1,
making each flip‐flop complement if the signal in its C input goes through
a negative transition. connected goes from 1 to 0. The bubble in front of
the dynamic indicator symbol next to C indicates that the flip‐flops
respond to the negative‐edge transition of the input. The negative tran
sition occurs when the output of the previous flip‐flop to which C is
connected goes from 1 to 0. The count starts with binary 0 and increments
by 1 with each count pulse input. After the count of 15, the counter goes
back to 0 to repeat the count. The least significant bit,A0, is
complemented with each count pulse input. Every time that A0 goes from
1 to 0, it complementsA1. Every time thatA1 goes from 1 to 0, it
complements A2.
Every time that A2 goes from 1 to 0, it complements A3, and so on for any
other higher order bits of a ripple counter. For example, consider the
transition from count 0011 to 0100.A0 is complemented with the count
pulse. SinceA0 goes from 1 to 0, it triggersA1 and complements it. As a
result,A1 goes from 1 to 0, which in turn complementsA2, changing it from
0 to 1.A2 does not triggerA3, becauseA2 produces a positive transition and
the flip‐flop responds only to negative transitions. Thus, the count from
0011 to 0100 is achieved by changing the bits one at a time, so the count
goes from 0011 to 0010, then to 0000, and finally to 0100. The flip‐flops
change one at a time in succession, and the signal propagates through the
counter in a ripple fashion from one stage to the next.
A binary counter with a reverse count is called a binary countdown counter. In
a countdown counter, the binary count is decremented by 1 with every input
count pulse. The count of a four‐bit countdown counter starts from binary 15
and continues to binary counts 14, 13, 12, . . . , 0 and then back to 15. A list
of the count sequence of a binary countdown counter shows that the least
significant bit is complemented with every count pulse. Any other bit in the
sequence is complemented if its previous least significant bit goes from 0 to
1. Therefore, the diagram of a binary countdown counter looks the same as
the binary ripple counter in Fig. above , provided that all flip‐flops trigger on
the positive edge of the clock. (The bubble in the C inputs must be absent.) If
negative‐edge‐triggered flip‐flops are used, then the C input of each flip‐flop
must be connected to the complemented output of the previous flip‐flop.
Then, when the true output goes from 0 to 1, the complement will go from 1
to 0 and complement the next flip‐flop as required.
BCD Ripple Counter
A decimal counter follows a sequence of 10 states returns to 0 after
the count of 9.Such a counter must have at least four flip‐flops to
represent each decimal digit, since a decimal digit is represented by
a binary code with at least four bits. The sequence of states in a
decimal counter is dictated by the binary code used to represent a
decimal digit. If BCD is used, the sequence of states is as shown in
the state diagram in the Fig.:-
Fig:- State diagram for a decimal BCD counter
BCD Ripple Counter
A decimal counter is similar to a binary counter, except that the state
after 1001 (the code for decimal digit 9) is0000 (the code for
decimal digit 0).
The logic diagram of a BCD ripple counter using JK flip‐flops is shown
in Figure below. The four outputs are designated by the letter
symbol Q, with a numeric subscript equal to the binary weight of
the corresponding bit in the BCD code. Note that the output of Q1
is applied to the C inputs of both Q2 and Q8 and the output of Q2
is applied to the C input of Q4. The J and K inputs are connected
either to a permanent 1 signal or to outputs of other flip‐flops.
Fig: - Block diagram of a three‐decade decimal BCD counter
The BCD counter of Fig. above is a decade counter, since it counts from 0 to
9. To count in decimal from 0 to 99, we need a two‐decade counter. To count
from 0 to 999, we need a three‐decade counter. Multiple decade counters
can be constructed by connecting BCD counters in cascade, one for each
decade. A three‐decade counter is shown in Fig.
Synchronous counters
Synchronous counters are different from ripple counters in that clock
pulses are applied to the inputs of all flip‐flops. A common clock triggers
all flip‐flops simultaneously, rather than one at a time in succession as in a
ripple counter. The decision whether a flip‐flop is to be complemented is
determined from the values of the data inputs, such as T or J and K at the
time of the clock edge. If T = 0 or J = K = 0, the flip‐flop does not change
state. If T = 1 or J = K = 1, the flip‐flop complements. Here we present some
typical synchronous counters and explain their operation.
Binary Counter
The design of a synchronous binary counter is so simple that there is no need
to go through a sequential logic design process. In a synchronous binary
counter, the flip‐flop in the least significant position is complemented with
every pulse. A flip‐flop in any other position is complemented when all the
bits in the lower significant positions are equal to 1. For example, if the
present state of a four‐bit counter isA3A2A1A0 = 0011, the next count is
0100.A0 is always complemented.A1 is complemented because the
present state of A0 = 1.A2 is complemented because the present state of
A1A0 = 11. However, A3 is not complemented, because the present state
of A2A1A0 = 011, which does not give an all‐1’s condition.
Synchronous binary counters have a regular pattern and can be
constructed with complementing flip flops and gates. The regular
pattern can be seen from the 4Rbit counter depicted in Fig.
below
The C inputs of all flip flops are connected to a common clock. The counter is
enabled by Count enable. If the enable input is 0, all J and K inputs are
equal to 0 and the clock does not change the state of the counter. The first
stage, A0, has its J and K equal to 1 if the counter is enabled. The other J
and K inputs are equal to 1 if all previous least significant stages are equal
to 1 and the count is enabled. The chain of AND gates generates the
required logic for the J and K inputs in each stage. The counter can be
extended to any number of stages, with each stage having an additional
flip flop and an AND gate that gives an output of 1 if all previous flip flop
outputs are 1.
Up–Down Binary Counter
A synchronous countdown binary counter goes through the binary states
in reverse order, from 1111 down to 0000 and back to 1111 to repeat the
count. It is possible to design a countdown counter in the usual manner,
but the result is predictable by inspection of the downward binary count.
The bit in the least significant position is complemented with each pulse. A
bit in any other position is complemented if all lower significant bits are
equal to 0. For example, the next state after the present state of 0100 is
0011. The least significant bit is always complemented. The second
significant bit is complemented because the first bit is 0. The third
significant bit is complemented because the first two bits are equal to 0.
But the fourth bit does not change, because not all lower significant bits
are equal to 0.A countdown binary counter can be constructed as shown
in previous Fig., except that the inputs to the AND gates must come from
the complemented outputs, instead of the normal outputs, of the
previous flip flops. The two operations can be combined in one circuit to
form a counter capable of counting either up or down. The circuit of a 4bit
up–down binary counter using T flip flops is shown in Fig. below.
Up–Down Binary Counter
It has an up control input and a down control input. When the up input is
1, the circuit counts up, since the T inputs receive their signals from the
values of the previous normal outputs of the flip flops. When the down
input is 1 and the up input is 0, the circuit counts down, since the
complemented outputs of the previous flip flops are applied to the T
inputs. When the up and down inputs are both 0, the circuit does not
change state and remains.
Decade Counter
A decade counter is the one which goes through 10 unique combinations of
outputs and then resets as the clock proceeds. We may use some sort of a
feedback in a 4-bit binary counter to skip any six of the sixteen possible output
states from 0000 to 1111 to get to a decade counter. A decade counter does not
necessarily count from 0000 to 1001 it could count as 0000,0001, 0010, 1000,
1001, 1010, 1011, 1110, 1111, 0000, 0001 and so on.
Figure below shows a decade counter having a binary count that is always
equivalent to the input pulse count.
The circuit is essentially, a ripple counter which count up to 16. We desire
however, a circuit operation in which the count advance from 0 to 9 and then
reset to 0 for a new cycle. This reset is a accomplished at the desired count as
follows.
1. With counter REST count = 0000 the .counter is ready to stage counter cycle.
2. Input pulses advance counter in binary sequence up to count of a (count =
1001)
3. The next count pulse advance the count to 10 count = 1010. A logic NAND
gate decodes the count of 10 providing a level change at that time to
trigger the one shot unit which then resets all counter stages Thus, the
pulse after the counter is at count = 9, effectively results in the
counter going to count = 0.
Table below provides a count table showing the binary count equivalent to the decimal
count of input pulses. The table also shows that the count goes momentarily count from
nine (1001) to ten (1010) before resetting to zero(0000). The NAND gate provides an
output of 1 until the count reach ten. The count of ten is decoded (or sensed in this case )
by using logic inputs that are all 1 at the count of ten. When the count becomes ten the
NAND gate output goes to logical 0, providing a 1 to 0 logic change to trigger the one shot
unit, which then provides a short pulse to reset all counter stages.
Ring Counter
The ring counter is the simplest example of a shift register. The simplest
counter is called a Ring counter. The ring counter contains only one logical
1 or 0 which it circulates. The total cycle length is equal to the number of
stages. The ring counter is useful in applications where count has to be
recognized in order to perform some other logical operation. Since only
one output is ever at logic 1 at given time extra logic gates are not
required to decode the counts and the flip flop outputs may be used
directly to perform the required operation.
Note that in the diagram the Reset will reset Q2, Q3 and Q4 but will put
Q1 to a logic 1 state. This 1 will circulate when clock pulses are applied
(Figure: Simple Ring Counter)
Table: Ring Counter Truth Table
Clock Q1 Q2 Q3 Q4
1 1 0 0 0
2 0 1 0 0
3 0 0 1 0
4 0 0 0 1
5 1 0 0 0
Up-Down Counter
An up down counter is a bi-directional counter and it can be made to count
upwards as well as downwards. In other words an up down counter is one
which can provide both count up and down counts operations in a single
unit. In the previous section it was seen that if triggering pulses are
obtained from output the counter is a count up and if the triggering pulses
are obtained from outputs, the counter is a countdown. Figure below
gives an up down counter. When the count up signal is high the AND gate
connecting Q output and count up signal gives and output 1 which passes
through the OR gate to trigger the next flip flop. This results in the count
up operation. Similarly a signal from countdown line will result the circuit
to act as a down counter.