Sequential Logic Circuits
Unlike combinational logic circuits, the output of sequential logic circuits not only depends on current inputs but also on the past sequence of inputs. Sequential circuits are constructed using combinational logic and a number of memory elements with some or all of the memory outputs fed back into the combinational logic forming a feedback path or loop. A very simple sequential circuit with no inputs created using inverters to form a feedback loop:
Q
QN
When this circuit is powered up it randomly outputs Q = 0 or Q =1
EECC341 - Shaaban
#1 Lec # 13 Winter 2001 1-29-2002
Sequential Logic Circuits
Combinational outputs Memory outputs
Combinational logic
Memory elements
Inputs
Sequential circuit = Combinational logic + Memory Elements Current State of A sequential Circuit: Value stored in memory elements (value of state variables). State transition: A change in the stored values in memory elements thus changing the sequential circuit from one state to another state.
EECC341 - Shaaban
#2 Lec # 13 Winter 2001 1-29-2002
Sequential Circuit Buliding Blocks:
Generic Memory Elements
A Memory Element: A logic device that can remember a single-bit value indefinitely, or change its value on command from its inputs.
command Memory element Q
Memory Element Output: stored single-bit value
The output Q of the memory element represents the value stored in the memory element. This is also called the state variable of the memory elements. A memory element can be in one of two possible states:
Q = 0 (the memory element has 0 stored), also said be in state 0. Q =1 (the memory element has 1 stored), also said to be in state 1. The commands to the memory element formed by its input(s) may include: Set: Store 1 (Q=1) in the memory element. Reset: Store 0 (Q=0) in the memory element. Flip: Change stored value from 0 to 1 or from 1 to 0. Hold value: Memory value does not change. Memory Element state transition: A change in the stored value from 0 to 1, or from 1 to 0 such as that caused by a flip command.
EECC341 - Shaaban
#3 Lec # 13 Winter 2001 1-29-2002
The State of A sequential Circuit
A state variable in a sequential circuit represents the single-bit variable Q stored in a memory element in circuit.
Each memory element may be in state 0 or state 1 depending on the current value stored in the memory element.
The State of A sequential Circuit:
The collection of all state variables (memory element stored values) that at any time contain all the information about the past necessary to account for the circuits future behavior. A sequential circuit that contains n memory elements could be in one of a maximum of 2n states at any given time depending on the stored values in the memory elements. Sequential Circuit State transition: A change in the stored values in memory elements thus changing the sequential circuit from one state to another.
EECC341 - Shaaban
#4 Lec # 13 Winter 2001 1-29-2002
Clock Signals & Synchronous Sequential Circuits
A clock signal is a periodic square wave that indefinitely switches values from 0 to 1 and 1 to 0 at fixed intervals.
1
Clock signal
0
Rising edges of the clock
Falling edges of the clock
Clock Cycle Time
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)
Example: Clock cycle time = 1ms clock frequency = 1000Hz
Synchronous Sequential Circuits: Sequential circuits that have a clock signal as one of its 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.
EECC341 - Shaaban
#5 Lec # 13 Winter 2001 1-29-2002
Sequential Circuit Memory Elements: Latches, Flip-Flops
Latches and flip-flops are the basic single-bit memory elements used to build sequential circuit with one or two inputs/outputs, designed using individual logic gates and feedback loops. Latches:
The output of a latch depends on its current inputs and on its previous inputs and its change of state can happen at any time when its inputs change.
Flip-Flop:
The output of a flip-flop also depends on current and previous input but the change in output (change of state or state transition) occurs at specific times determined by a clock input.
EECC341 - Shaaban
#6 Lec # 13 Winter 2001 1-29-2002
Sequential Circuit Memory Elements: Latches, Flip-Flops
Latches: S-R Latch S-R Latch With Enable D-Latch Flip-Flops: Edge-Triggered D Flip-Flop Master/Slave S-R Flip-Flop Master/Slave J-K Flip-Flop Edge-Triggered J-K Flip-Flop T Flip-Flop With Enable
EECC341 - Shaaban
#7 Lec # 13 Winter 2001 1-29-2002
S-R Latch
An S-R (set-reset) latch can be built using two NORgates forming a feedback loop. 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.
R
Function Table
Q
S 0 0 1 1 R 0 1 0 1 Q last Q 0 1 0 QN Last QN 1 0 0
S
Circuit
QN
EECC341 - Shaaban
#8 Lec # 13 Winter 2001 1-29-2002
S-R Latch With Enable
Since the S-R latch is responsive to its inputs at all times an enable line C is used to disable or enable state transitions. Behaves similar to a regular S-R latch when enable C=1
S Q Enable C
Circuit
QN R
Function Table
S C
Q Q
S 0 0 1 1 x
R 0 1 0 1 x
C 1 1 1 1 0
Q last Q 0 1 0 last Q
QN last QN 1 0 0 last QN
Logic Symbol
EECC341 - Shaaban
#9 Lec # 13 Winter 2001 1-29-2002
D-Latch
Similar to S-R latch with an enable line, but both S, R are generated from one input D (data) and an inverter. Stores the value of its input D when enable C =1.
Function Table
C 1 1 0
D 0 1 x
Q
Q 0 1 Last Q
QN 1 0 Last QN
C D C QN
Logic Symbol Circuit
Q Q
EECC341 - Shaaban
#10 Lec # 13 Winter 2001 1-29-2002
Edge-Triggered D Flip-Flop
Uses a pair of D latches and inverters. Similar in behavior to a D latch except that output and state changes happen at the rising or falling edge of an input clock. A D Flip-Flop triggered on the rising edge of the clock is given by:
Master Latch D
D C Q Q
Slave Latch QM
D C Q Q
Q QN
Q CLK Q
Logic Symbol
CLK Clock
Circuit
Function Table
D CLK Q 0 0 1 1 x 0 Last Q x x Last Q
QN 1 0 Last QN Last QN
EECC341 - Shaaban
#11 Lec # 13 Winter 2001 1-29-2002
Master/Slave S-R Flip-Flop
S-R latches are substituted for the D latches in the negative-edge triggered D flip flop
Master Latch S R CLK
S C Q Q
Slave Latch QM
Circuit
S C
Q Q
Q QN
Function Table
S C
Q Q
S x 0 0 1 1
R x 0 1 0 1
C 0
Q last Q last Q 0 1 undef.
QN last QN last QN 1 0 undef.
Logic Symbol
EECC341 - Shaaban
#12 Lec # 13 Winter 2001 1-29-2002
Master/Slave J-K Flip-Flop
Solves the problem in the problem when both S=R=1 When J=K=1 the last state is inverted.
Master Latch J K
S C Q Q
Slave Latch QM
S C Q Q
Circuit
Q QN
CLK
Function Table
S C
Q Q
Logic Symbol
J K x x 0 0 0 1 1 0 1 1
C 0
Q QN last Q last QN last Q last QN 0 1 1 0 last QN last Q
EECC341 - Shaaban
#13 Lec # 13 Winter 2001 1-29-2002
Edge Triggered J-K Flip-Flop
Created from an edge-triggered D flip-flop
Circuit
J
D Q CLK Q
Q QN
K CLK
Function Table
J K x x x x 0 0 0 1 1 0 1 1
C 0 1
Q last Q last Q last Q 0 1 last QN
QN last QN last QN last QN 1 0 last Q
Logic Symbol
j k
Q CLK Q
EECC341 - Shaaban
#14 Lec # 13 Winter 2001 1-29-2002
T Flip-Flop With Enable
Changes state on every clock cycle (rising edge of T).
En T OR
Q QN
Circuit
CLK Q
Function Table
EN T
j k
Q CLK Q
Q QN
T En x 0 1
Q QN last Q last QN last QN last Q
EECC341 - Shaaban
#15 Lec # 13 Winter 2001 1-29-2002