Sie sind auf Seite 1von 43

EE 10 - Logic Circuits

Santos James Emmanuel C. Malunda


College of Engineering
Western Visayas College of Science
and Technology

CS1103

Lecture 12: Sequential Logic


Design with Flip-flops

Introduction

Flip-flop Characteristic Tables

Sequential Circuit Analysis

Flip-flop Input Functions

Analysis: Example #2

Analysis: Example #3

Flip-flop Excitation Tables

EE10

Lecture 12: Sequenti

Lecture 12: Sequential Logic


Design with Flip-flops

Sequential Circuit Design

Design: Example #1

Design: Example #2

Design: Example #3

Design of Synchronous Counters

EE10

Lecture 12: Sequenti

Introduction

Sequential circuits has an extra dimension time.


Combinational circuit output depends only on the
present inputs
Sequential circuit output depends on the history of
past inputs as well
More powerful than combinational circuit, able to
model situations that cannot be modeled by
combinational circuits
Building blocks of synchronous sequential logic
circuits: gates and flip-flops.
Flip-flops make up the memory M while the gates
form one or more combinational subcircuits C1, C2,
, Cq.

EE10

Models of Sequential

Flip-flop Characteristic Tables

Each type of flip-flop has its own behavior. The


characteristic tables for the various types of flipflops are shown below:
J

Q(t+1)

Comments

Q(t+1)

0
0
1
1

0
1
0
1

Q(t)
0
1
Q(t)'

No change
Reset
Set
Toggle

0
0
1
1

0
1
0
1

Q(t)
0
1
?

JK Flip-flop
D

Q(t+1)

0
1

0
1

EE10

No change
Reset
Set
Unpredictable

SR Flip-flop

Reset
Set

D Flip-flop

Comments

Q(t+1)

0
1

Q(t)
Q(t)'

No change
Toggle

T Flip-flop

Flip-flop Characteris

Sequential Circuit Analysis

Given a sequential circuit diagram, analyze its


behaviour by deriving its state table and hence its
state diagram.

Requires state equations to be derived for the flip-flop


inputs, as well as output functions for the circuit
outputs other than the flip-flops (if any).

We use A(t) and A(t+1) to represent the present state


and next state, respectively, of a flip-flop represented
by A.

Alternatively, we could simply use A and A+ for the


present state and next state respectively.

EE10

Sequential Circuit A

Sequential Circuit Analysis

Example (using D flip-flops):


State equations:
A+ = A.x + B.x
B+ = A'.x

Output function:
y = (A + B).x'

CP

Q'

A'

Q'

B'
y

Figure 1.

EE10

Sequential Circuit A

Sequential Circuit Analysis

From the state equations and output function, we


derive the state table, consisting of all possible binary
combinations of present states and inputs.

State table
Similar to truth table.
Inputs and present state on the left side.
Outputs and next state on the right side.

m flip-flops and n inputs 2m+n rows.

EE10

Sequential Circuit A

Sequential Circuit Analysis

State table for the circuit of Figure 1:


State equations:
A+ = A.x + B.x
B+ = A'.x
Present
State
A
B
0
0
0
0
1
1
1
1

EE10

0
0
1
1
0
0
1
1

Output function:
y = (A + B).x'

Input
x
0
1
0
1
0
1
0
1

Next
State
A+ B+
0
0
0
1
0
1
0
1

Output
y

0
1
0
1
0
0
0
0

Sequential Circuit A

0
0
1
0
1
0
1
0

Sequential Circuit Analysis

Alternate form of state table:


Present
State

Next
State

Input

0
0
0
0
1
1
1
1

0
0
1
1
0
0
1
1

0
1
0
1
0
1
0
1

A+
0
0
0
1
0
1
0
1

Present
State
AB
00
01
10
11

EE10

Output

B+
0
1
0
1
0
0
0
0

y
0
0
1
0
1
0
1
0

Next State
x=0
x=1
+ +
A B A +B +
00
00
00
00

01
11
10
10

Output
x=0 x=1
y
y
0
1
1
1

Sequential Circuit A

0
0
0
0

10

Sequential Circuit Analysis

From the state table, we can draw the state diagram.

State diagram
Each state is denoted by a circle.
Each arrow (between two circles) denotes a transition of the

sequential circuit (a row in state table).


A label of the form a/b is attached to each arrow where a
denotes the inputs while b denotes the outputs of the circuit
in that transition.

Each combination of the flip-flop values represents a


state. Hence, m flip-flops up to 2m states.

EE10

Sequential Circuit A

11

Sequential Circuit Analysis

State diagram of the circuit of Figure 1:


Present
State
AB
00
01
10
11

Next State
x=0
x=1
+ +
A B A +B +
00
00
00
00

01
11
10
10

Output
x=0 x=1
y
y
0
1
1
1

0
0
0
0

0/0
00
1/0

0/1
01

EE10

0/1

Sequential Circuit A

0/1
1/0

1/0
10
1/0
11

12

Flip-flop Input Functions

The outputs of a sequential circuit are functions of the


present states of the flip-flops and the inputs. These
are described algebraically by the circuit output
functions.
In Figure 1: y = (A + B).x'

The part of the circuit that generates inputs to the flipflops are described algebraically by the flip-flop input
functions (or flip-flop input equations).

The flip-flop input functions determine the next state


generation.

From the flip-flop input functions and the


characteristic tables of the flip-flops, we obtain the
next states of the flip-flops.

EE10

Flip-flop Input Func

13

Flip-flop Input Functions

Example: circuit with a JK flip-flop.

We use 2 letters to denote each flip-flop input: the


first letter denotes the input of the flip-flop (J or K for
JK flip-flop, S or R for SR flip-flop, D for D flip-flop, T
for T flip-flop) and the second letter denotes the
name of the flip-flop.
JA = B.C'.x + B'.C.x
KA = B + y

B
C'
x
B'
C
x'

J
B
y

K Q'
CP

EE10

Flip-flop Input Func

14

Flip-flop Input Functions

In Figure 1, we obtain the following state equations by


observing that Q+ = DQ for a D flip-flop:
A+ = A.x + B.x
B+ = A'.x

(since DA = A.x + B.x)


(since DB = A'.x)
x

CP

Figure 1.

EE10

Flip-flop Input Func

D Q

Q'

A'

D Q

Q'

B'
y

15

Analysis: Example #2

Given Figure 2, a sequential circuit with two JK flipflops A and B, and one input x.
J
x

K Q'

K Q'

Figure 2.
CP

Obtain the flip-flop input functions from the circuit:


JA = B
KA = B.x'

EE10

JB = x'
KB = A'.x + A.x' = A x

Analysis: Example

16

Analysis: Example #2

Flip-flop input functions:


JA = B
KA = B.x'

JB = x'
JB = A'.x + A.x' = A x

Fill the state table using the above functions,


knowing the characteristics of the flip-flops used.
J

Q(t+1)

Comments

0
0
1
1

0
1
0
1

Q(t)
0
1
Q(t)'

No change
Reset
Set
Toggle

EE10

Present
state
A
B
0
0
0
0
1
1
1
1

0
0
1
1
0
0
1
1

Input
x
0
1
0
1
0
1
0
1

Next
state
A+ B+
0 1
0 0
1 1
1 0
1 1
1 0
0 0
1 1

Analysis: Example

Flip-flop inputs
JA KA
JB KB
0
0
1
1
0
0
1
1

0
0
1
0
0
0
1
0

1
0
1
0
1
0
1
0

0
1
0
1
1
0
1
0

17

Analysis: Example #2

Draw the state diagram from the state table.


Present
state
A
B
0
0
0
0
1
1
1
1

0
0
1
1
0
0
1
1

Input
x
0
1
0
1
0
1
0
1

Next
state
+
+
A
B
0
0
1
1
1
1
0
1

1
0
1
0
1
0
0
1

Flip-flop inputs
JA KA
JB KB
0
0
1
1
0
0
1
1

0
0
1
0
0
0
1
0

1
0
1
0
1
0
1
0

0
1
0
1
1
0
1
0

1
00
0
01

0
0
1

11
0
10
1

EE10

Analysis: Example

18

Analysis: Example #3

Derive the state table and state diagram of the


following circuit.
J

K Q'

K Q'

CP
y

Figure 3.

Flip-flop input functions:


JA = B
KA = B'

EE10

JB = KB = (A x)' = A.x + A'.x'

Analysis: Example

19

Analysis: Example #3

Flip-flop input functions:


JB = KB = (A x)' = A.x + A'.x'

JA = B
KA = B'

State table:
Present
state
A
B
0
0
0
0
0
1
0
1
1
0
1
0
1
1
1
1

EE10

Input
x
0
1
0
1
0
1
0
1

Next
state
A+ B+

0
0
1
1
0
0
1
1

1
0
0
1
0
1
1
0

Output
y
0
1
1
0
1
0
0
1

Analysis: Example

Flip-flop inputs
JA KA
JB KB
0
1
1
1
0
1
0
0
1
0
1
1
1
0
0
0
0
1
0
0
0
1
1
1
1
0
0
0
1
0
1
1

20

Analysis: Example #3
State diagram:

Present
state

Next
state

Input

Output
+

0
0
0
0
1
1
1
1

0
0
1
1
0
0
1
1

0
1
0
1
0
1
0
1

0
0
1
1
0
0
1
1

1
0
0
1
0
1
1
0

0
1
1
0
1
0
0
1

Flip-flop inputs
JA KA
JB KB
0
0
1
1
0
0
1
1

1
1
0
0
1
1
0
0

1
0
1
0
0
1
0
1

1
0
1
0
0
1
0
1

1/1
00
0/0

01

0/1

10

0/1

1/1

1/0
1/0

11
0/0

EE10

Analysis: Example

21

Flip-flop Excitation Tables

Analysis: Starting from a circuit diagram, derive the


state table or state diagram.

Design: Starting from a set of specifications (in the


form of state equations, state table, or state diagram),
derive the logic circuit.

Characteristic tables are used in analysis.

Excitation tables are used in design.

EE10

Flip-flop Excitation

22

Flip-flop Excitation Tables

Excitation tables: given the required transition from


present state to next state, determine the flip-flop
input(s). Q Q+ J K
Q Q+
S R
0
0
1
1

0
1
0
1

0
1
X
X

X
X
1
0

JK Flip-flop

0
1
0
1

0
1
0
X

X
0
1
0

SR Flip-flop

Q+

Q+

0
0
1
1

0
1
0
1

0
1
0
1

0
0
1
1

0
1
0
1

0
1
1
0

D Flip-flop

EE10

0
0
1
1

Flip-flop Excitation

T Flip-flop

23

Sequential Circuit Design

Design procedure:
Start with circuit specifications description of circuit

behaviour.
Derive the state table.
Perform state reduction if necessary.
Perform state assignment.
Determine number of flip-flops and label them.
Choose the type of flip-flop to be used.
Derive circuit excitation and output tables from the state
table.
Derive circuit output functions and flip-flop input functions.
Draw the logic diagram.

EE10

Sequential Circuit

24

Design: Example #1

Given the following state diagram, design the sequential


circuit using JK flip-flops.
0
00
1

1
01

11
0
10

EE10

Design: Example #

25

Design: Example #1

Circuit state/excitation table, using JK flip-flops.


0

Present
State
AB
00
01
10
11

00
1

11

01
0

10
0
Q

Q+

0
0
1
1

0
1
0
1

0
1
X
X

X
X
1
0

JK Flip-flops
excitation table.

EE10

0
Present
state
A
B
0
0
0
0
1
1
1
1

0
0
1
1
0
0
1
1

Input
x
0
1
0
1
0
1
0
1

Next State
x=0
x=1
A+B+ A+B+
00
01
10
01
10
11
11
00

Next
state
A+ B+
0
0
1
0
1
1
1
0

0
1
0
1
0
1
1
0

Design: Example #

Flip-flop inputs
JA KA
JB KB
0
0
1
0
X
X
X
X

X
X
X
X
0
0
0
1

0
1
X
X
0
1
X
X

X
X
1
0
X
X
0
1

26

Design: Example #1

Block diagram.
A

Q'

Q'

CP
KA
A'
A
B
B'

What are to
go in here?

EE10

JA

KB

JB

Combinational
circuit
x

External
output(s)
(none)

External
input(s)

Design: Example #

27

Design: Example #1

From state table, get flip-flop input functions.


Present
state
A
B
0
0
0
0
1
1
1
1

Input
x

0
0
1
1
0
0
1
1
A

0
1
0
1
0
1
0
1

0
0
1
0
1
1
1
0

Flip-flop inputs
JA KA
JB KB

0
1
0
1
0
1
1
0

0
0
1
0
X
X
X
X

Bx
00
0

Next
state
A+ B+

01 11 10
1
X X
1

X
x

JB = x

EE10

A
A

X
X
X
X
0
0
0
1

0
1
X
X
0
1
X
X

00
0 X
X

01 11
X
X

10
1

00

01 11

10
1

0
A

JA = B.x'
A

Bx

X
X
1
0
X
X
0
1

Bx

Bx
00
0 X

01 11 10
X X X
1

1
x

KA = B.x

KB = (A x)'

Design: Example #

28

Design: Example #1

Flip-flop input functions.


JA = B.x'
KA = B.x

JB = x
KB = (A x)'

Logic diagram:
A

Q'

Q'

CP

EE10

Design: Example #

29

Design: Example #2

Design, using D flip-flops, the circuit based on the state


table below. (Exercise: Design it using JK flip-flops.)

Present
state
A
B
0
0
0
0
1
1
1
1

EE10

0
0
1
1
0
0
1
1

Input
x
0
1
0
1
0
1
0
1

Next
state
A+ B+
0
0
1
0
1
1
1
0

0
1
0
1
0
1
1
0

Output
y
0
1
0
0
0
1
0
0

Design: Example #

30

Design: Example #2

Determine expressions for flip-flop inputs and the


circuit output y.
Present
state
A
B
0
0
0
0
1
1
1
1

0
0
1
1
0
0
1
1

Input
x
0
1
0
1
0
1
0
1

Next
state
A+ B+
0
0
1
0
1
1
1
0

Output
y

0
1
0
1
0
1
1
0

0
1
0
0
0
1
0
0

Bx
00

01 11

10
1

0
A

1
x

Bx

00
0

01 11
1
1

DA(A, B, x) = m(2,4,5,6)
DB(A, B, x) = m(1,3,5,6)
y(A, B, x) = m(1,5)

A
A

Bx
00

DA = A.B' + B.x'

01 11
1

10

DB = A'.x + B'.x +
1
A.B.x'
B
10

y = B'.x

EE10

Design: Example #

31

Design: Example #2

From derived expressions, draw logic diagram:


DA = A.B' + B.x'
DB = A'.x + B'.x + A.B.x'
y = B'.x
D
x

CP

Q'

A'

Q'

B'
y

EE10

Design: Example #

32

Design: Example #3

Design with unused states.

Given these
Unused
state 000:
0 0 0
0
0

EE10

X
X

Derive these
X
X

X
X

X
X

X
X

X
X

Design: Example #

X
X

X
X

X
X

X
X

33

Design: Example #3

From state table, obtain expressions for flip-flop inputs.


A
B

SA = B.x

Cx

C
00

01 11

00 X

01

11 X

10 X

A
B

10

Cx

C
00

00 X

01 11
X

A
B

11 X

00 X

01 11
X

SB = A'.B'.x

A
B

10

01 X
11 X

10

X
X

X
1

10

B
A

Cx

RA = C.x'

C
00

01 11

10

00 X

01

11 X

10 X

EE10

x
C

00

01 X

x
Cx

10

Design: Example #

RB = B.C
+ B.x'

34

Design: Example #3

From state table, obtain expressions for flip-flop inputs


(contd).
A
B

Cx

C
00

00 X

01 11
X

01 1

SC = x'

11 X

A
B

10
X

10 1

Cx

C
00

01 11

00 X

01

11 X

10

x
A
B

Cx

RC = x

x
C

00

00 X

01 11

10

01
A

10

11 X

10

y = A.x

EE10

Design: Example #

35

Design: Example #3

From derived expressions, draw logic diagram:


SA = B.x
RA = C.x'
y = A.x

SB = A'.B'.x
RB = B.C + B.x'

SC = x'
RC = x
y
S

R Q'

A'

R Q'

B
B'

R Q'
CP

EE10

Design: Example #

36

Design of Synchronous Counters

Counter: a sequential circuit that cycles through a


sequence of states.

Binary counter: follows the binary sequence. An n-bit


binary counter (with n flip-flops) counts from 0 to 2n-1.

Example 1: A 3-bit binary counter (using T flip-flops).


000
001

111

010

110
011

101
100

EE10

Present
state
A2 A1 A0
0 0 0
0 0 1
0 1 0
0 1 1
1 0 0
1 0 1
1 1 0
1 1 1

A2+
0
0
0
1
1
1
1
0

Next
state
A1+ A0+
0
1
1
0
1
1
0
0
0
1
1
0
1
1
0
0

Design of Synchron

Flip-flop
inputs
TA2 TA1 TA0
0
0
1
0
1
1
0
0
1
1
1
1
0
0
1
0
1
1
0
0
1
1
1
1

37

Design of Synchronous Counters

3-bit binary counter (contd).


Present
state
A 2 A1 A0
0 0 0
0 0 1
0 1 0
0 1 1
1 0 0
1 0 1
1 1 0
1 1 1

A2+
0
0
0
1
1
1
1
0

Next
state
A1+
0
1
1
0
0
1
1
0

A0+
1
0
1
0
1
0
1
0

Flip-flop
inputs
TA2 TA1 TA0
0
0
1
0
1
1
0
0
1
1
1
1
0
0
1
0
1
1
0
0
1
1
1
1

A1

A1

1
A2

1
A0

TA2 = A1.A0

EE10

A2

A1

A2

A0

A0

TA1 = A0

TA0 = 1

Design of Synchron

38

Design of Synchronous Counters

3-bit binary counter (contd).


TA2 = A1.A0

TA1 = A0

TA0 = 1

A2

A1

A0

CP
1

EE10

Design of Synchron

39

Design of Synchronous Counters

Example 2: Counter with non-binary sequence:


000 001 010 100 101 110 and back to 000
000
001

110

010

101
100

JA = B
KA = B

EE10

Present
state
A B C
0 0 0
0 0 1
0 1 0
1 0 0
1 0 1
1 1 0

Next
state
+
A B+ C+
0 0 1
0 1 0
1 0 0
1 0 1
1 1 0
0 0 0

Flip-flop inputs
JA KA JB KB JC KC
0
X
0
X
1
X
0
X
1
X
X
1
1
X X
1
0
X
X
0
0
X
1
X
X
0
1
X
X
1
X
1
X
1
0
X

JB = C
KB = 1

Design of Synchron

JC = B'
KC = 1

40

Design of Synchronous Counters

Counter with non-binary sequence (contd).


JA = B
KA = B

JB = C
KB = 1

JC = B'
KC = 1

Q'

Q'

Q'

CP

000
001

110

010

101

EE10

111

Design of Synchron

100

011

41

Summary

Sequential circuits have memory and they are more


powerful than combinational circuits.
Analyzing sequential circuits
Flip-flop characteristic table
State Table
State diagram

Designing sequential circuits


Flip-flop excitation table
State assignment
Circuit output function
Flip-flop input function

EE10

Summary

42

End of segment

EE10

Das könnte Ihnen auch gefallen