Download presentation
Presentation is loading. Please wait.
1
Instructor: Alexander Stoytchev
CprE 281: Digital Logic Instructor: Alexander Stoytchev
2
Algorithmic State Machine (ASM) Charts
CprE 281: Digital Logic Iowa State University, Ames, IA Copyright © Alexander Stoytchev
3
Administrative Stuff Homework 12 is out
It is due on Monday Dec 4pm Last homework for the semester!
4
Administrative Stuff The FINAL exam is scheduled for
Monday Dec 2:15 – 4:15 PM It will be in this room.
6
Final Exam Format The exam will cover: Chapter 1 to Chapter 6, and Sections Emphasis will be on Chapter 5, 6, and 7 The exam will be open book and open notes. You can bring up to 5 pages of handwritten or typed notes plus your textbook.
7
Final Exam Format The exam will be out of 130 points
You need 95 points to get an A on this exam It will be great if you can score more than 100 points. but you can’t roll over your extra points
8
Topics for the Final Exam
K-maps for 2, 3, and 4 variables Multiplexers (circuits and function) Synthesis of logic functions using multiplexers Shannon’s Expansion Theorem 1’s complement and 2’s complement representation Addition and subtraction of binary numbers Circuits for adding and subtracting Serial adder Latches (circuits, behavior, timing diagrams) Flip-Flops (circuits, behavior, timing diagrams) Counters (up, down, synchronous, asynchronous) Registers and Register Files
9
Topics for the Final Exam
Synchronous Sequential Circuits FSMs Moore Machines Mealy Machines State diagrams, state tables, state-assigned tables State minimization Designing a counter Arbiter Circuits Reverse engineering a circuit ASM Charts Register Machines Bus structure and Simple Processors Something from Star Wars
10
Reading Material for Next Lecture
“The Seven Secrets of Computer Power Revealed” by Daniel Dennett. This is Chapter 24 in his latest book “Intuition Pumps and Other Tools for Thinking”, 2013
11
Elements used in ASM charts
State name Output signals 0 (False) 1 (True) Condition or actions expression (Moore type) (a) State box (b) Decision box Conditional outputs or actions (Mealy type) (c) Conditional output box [ Figure 6.81 from the textbook ]
12
State Box State name Output signals or actions (Moore type)
[ Figure 6.81a from the textbook ]
13
State Box Indicated with a rectangle
Output signals or actions (Moore type) State name Indicated with a rectangle Equivalent to a node in the State diagram The name of the state is written outside the box Moore-type outputs are written inside the box Only the output that must be set to 1 is written (by default, if an output is not listed it is set to 0)
14
Decision Box Condition expression 0 (False) 1 (True)
[ Figure 6.81b from the textbook ]
15
Decision Box Indicated with a diamond shape
Condition expression 0 (False) 1 (True) Indicated with a diamond shape Used for a condition expression that must be tested The exit path is chosen based on the outcome of the test The condition is on one or more inputs to the FSM Shortcut notation: w means “is w equal to 1?”
16
Conditional Output Box
Conditional outputs or actions (Mealy type) Indicated with an oval shape Used for a Mealy-type output signals The outputs depend on the state variables and inputs The condition that determines when such outputs are generated is placed in a separate decision box [ Figure 6.81c from the textbook ]
17
Some Examples
18
FSM ASM chart ¤ C z 1 = Reset B A w [ Figure 6.3 from the textbook ]
A w [ Figure 6.3 from the textbook ] [ Figure 6.82 from the textbook ]
19
FSM ASM chart [ Figure 6.23 from the textbook ]
20
FSM ASM chart [ Figure 6.73 from the textbook ]
21
ASM Chart is different from a Flow Chart
The ASM chart implicitly includes timing info It is assumed that the underlying FSM changes from one state to another on every active clock edge Flow charts don’t make that assumption.
22
The general model for a sequential circuit
Combinational circuit Y k 1 y w n z m Outputs Next-state variables Present-state Inputs [ Figure 6.85 from the textbook ]
23
The general model for a sequential circuit
24
Examples of Solved Problems
25
Example 6.12
26
Goal Design an FSM that detects if the previous two values of the input w were equal to 00 or 11. If either condition is true then the output z should be set to 1; otherwise to 0.
27
State Diagram [ Figure 6.86 from the textbook ]
28
State Table for the FSM [ Figure 6.86 from the textbook ]
29
State Table for the FSM [ Figure 6.87 from the textbook ]
30
State-Assigned Table for the FSM
[ Figure 6.88 from the textbook ]
31
State-Assigned Table for the FSM
[ Figure 6.88 from the textbook ]
32
State-Assigned Table for the FSM
How can we derive this expression?
33
State-Assigned Table for the FSM
101 110 111 ddd ddd d
34
Truth Table for the Output z
y3 y2 y1 z 1
35
Truth Table for the Output z
y3 y2 y1 z 1 d
36
Truth Table for the Output z
y3 y2 y1 z 1 d
37
K-Map for the Output z 0 1 d 1 0 0 d d z y3 00 01 11 10 1 y y3 y2 y1 z
1 y 2 z d 1 d d y3 y2 y1 z 1 d
38
The Expression for the Output z
y1 00 01 11 10 1 y 3 2 z d 1 d d y1 y2 y3 y3 y2 y1 z 1 d
39
State-Assigned Table for the FSM
How can we derive these expressions?
40
Truth Table for Y3 w y3 y2 y1 Y3 Y2 Y1 1 d
41
Truth Table for Y2 w y3 y2 y1 Y3 Y2 Y1 1 d
42
Truth Table for Y1 w y3 y2 y1 Y3 Y2 Y1 1 d
43
K-Maps for Y3, Y2, Y1 Y3 w y3 y2 y1 Y2 w y3 y2 y1 Y1 w y3 y2 y1 w y3
1 d w y3 y2 y1 00 01 11 10 1 d Y3 w y3 y2 y1 00 01 11 10 1 d Y2 w y3 y2 y1 1 00 01 11 10 d Y1
44
K-Maps for Y3, Y2, Y1 Y3 w y3 y2 y1 Y2 w y3 y2 y1 Y1 w y3 y2 y1 w y3
1 d w y3 y2 y1 00 01 11 10 1 d Y3 w y3 y2 y1 00 01 11 10 1 d Y2 w y3 y2 y1 1 00 01 11 10 d Y1
45
Expressions for Y3, Y2, Y1 Y3 w y3 y2 y1 Y2 w y3 y2 y1 Y1 w y3 y2 y1 w
1 d w y3 y2 y1 00 01 11 10 1 d Y3 w y3 y2 y1 00 01 11 10 1 d Y2 w y3 y2 y1 1 00 01 11 10 d Y1
46
Next State and Output Expressions
47
An Improved State-Assigned Table
B,C, D, E – when y3=1 [ Figure 6.87 from the textbook ] [ Figure 6.89 from the textbook ]
48
An Improved State-Assigned Table
[ Figure 6.89 from the textbook ]
49
An Improved State-Assigned Table
cut here
50
An Improved State-Assigned Table
001 010 011 ddd ddd d
51
Truth Table for the Output z
y3 y2 y1 z 1 d
52
Expression for the Output z
y1 00 01 11 10 1 y 3 2 z 0 d d d y1 y3 y2 y1 z 1 d
53
Truth Table for Y3 w y3 y2 y1 Y3 Y2 Y1 1 d
54
Truth Table for Y2 w y3 y2 y1 Y3 Y2 Y1 1 d
55
Truth Table for Y1 w y3 y2 y1 Y3 Y2 Y1 1 d
56
K-Maps for Y3, Y2, Y1 Y3 w y3 y2 y1 Y2 w y3 y2 y1 Y1 w y3 y2 y1 w y3
1 d w y3 y2 y1 1 00 01 11 10 d Y3 w y3 y2 y1 00 01 11 10 1 d Y2 w y3 y2 y1 00 01 11 10 1 d Y1
57
K-Maps for Y3, Y2, Y1 Y3 w y3 y2 y1 Y2 w y3 y2 y1 Y1 w y3 y2 y1 w y3
1 d w y3 y2 y1 1 00 01 11 10 d Y3 w y3 y2 y1 00 01 11 10 1 d Y2 w y3 y2 y1 00 01 11 10 1 d Y1
58
K-Maps for Y3, Y2, Y1 Y3 w y3 y2 y1 Y2 w y3 y2 y1 Y1 w y3 y2 y1 w y3
1 d w y3 y2 y1 1 00 01 11 10 d Y3 w y3 y2 y1 00 01 11 10 1 d Y2 w y3 y2 y1 00 01 11 10 1 d Y1
59
An Improved State-Assigned Table
60
An Improved State-Assigned Table
61
Example 6.13
62
Goal Design an FSM that detects if the previous two values of the input w were equal to 00 or 11. But do this with two different FSMs. The first one detects two consecutive 1's. The second one detects two consecutive 0's. If either condition (i.e., output of FSM) is true then the output z should be set to 1; otherwise to 0.
63
Example 6.13 (Construct the first FSM)
64
FSM to detect two consecutive 1's (this was the first example in Chapter 6)
C: z = 1 Reset B: z = 0 A: z = 0 w = 1 [ Figure 6.3 from the textbook ]
65
Next state Present Output state A B C z w = w = 1 C: z = 1 Reset
B: z = 0 A: z = 0 w = 1 Next state Present Output state z w = w = 1 A B C
66
Next state Present Output state A A B B A C C A C 1 z w = w = 1
Reset B: z = 0 A: z = 0 w = 1 Next state Present Output state z w = w = 1 A A B B A C C A C 1 [ Figure 6.4 from the textbook ]
67
A Better State Encoding
Next state Present Output state z w = w = 1 A A B B A C C A C 1 Suppose we encoded our states another way: A ~ 00 B ~ 01 C ~ 11
68
A Better State Encoding
Next state Present Output state z w = w = 1 A A B B A C C A C 1 Next state Present Output state w = w = 1 A ~ 00 B ~ 01 C ~ 11 z
69
A Better State Encoding
Next state Present Output state z w = w = 1 A A B B A C C A C 1 Present Next state state w = 1 Output y 2 Y z A 00 01 B 11 C 10 dd d
70
Let's Derive the Logic Expressions
Present Next state state w = 1 Output y 2 Y z A 00 01 B 11 C 10 dd d [ Figure 6.16 from the textbook ]
71
Let's Derive the Logic Expressions
Present Next state state w = 1 Output y 2 Y z A 00 01 B 11 C 10 dd d Warning: This table does not enumerate y2y1, in the standard way, so be careful when filling out the K-Map. w 00 01 11 10 1 y 2 Y2 Y1 w 00 01 11 10 1 y 2 1 y 2 z
72
Let's Derive the Logic Expressions
Present Next state state w = 1 Output y 2 Y z A 00 01 B 11 C 10 dd d Warning: This table does not enumerate y2y1, in the standard way, so be careful when filling out the K-Map. Y2 Y1 y y y y z y 2 1 2 1 1 w y 2 00 01 11 10 00 01 11 10 1 w d d 1 1 1 1 d 1 1 1 1 d d 1 Y2(w, y2, y1) = wy1 Y1(w, y2, y1) = w z(y2, y1) = y2
73
Original State Encodings
New State Encodings Y1 Y 1 y y y y 2 1 2 1 w 00 01 11 10 w 00 01 11 10 d d 1 1 d 1 1 1 1 d Y2 Y 2 y y y y 2 1 2 1 w w 00 01 11 10 00 01 11 10 d d 1 1 1 d 1 1 1 d z y z y 1 1 y y 2 1 2 1 1 1 d 1 d 1
74
The Circuit Diagram Y1(w, y2, y1) = w Y2(w, y2, y1) = wy1
Q z Y2(w, y2, y1) = wy1 Q z(y2, y1) = y2 Y y 1 1 w D Q Clock Q Resetn [ Figure 6.17 from the textbook ]
75
Example 6.13 (Construct the second FSM)
76
FSM to detect two consecutive 0's
F: z = 1 Reset E: z = 0 D: z = 0 w 1 = This is similar to the previous one. Just invert the w's and relabel the states to D,E,F.
77
Next state Present Output state D E F z w = w = 1 F: z = 1 Reset
E: z = 0 D: z = 0 w 1 = Next state Present Output state z w = w = 1 D E F
78
Next state Present Output state D E D E F D F F D 1 z w = w = 1
F: z = 1 Reset E: z = 0 D: z = 0 w 1 = Next state Present Output state z w = w = 1 D E D E F D F F D 1
79
FSM that detects a sequence of two zeros
[ Figure 6.90 from the textbook ]
80
FSM that detects a sequence of two zeros
Only these two columns are swapped relative to the first FSM. And the states have different names now. Only these two columns are swapped relative to the first FSM. [ Figure 6.90 from the textbook ]
81
Let's Derive the Logic Expressions
Present Next state state w = 1 Output y 4 3 Y z D 00 01 E 11 F 10 dd d [ Figure 6.90 from the textbook ]
82
Let's Derive the Logic Expressions
Present Next state state w = 1 Output y 4 3 Y z D 00 01 E 11 F 10 dd d Y4 Y3 z y y y y y 4 3 4 3 4 w y 3 00 01 11 10 00 01 11 10 1 w 1 1 1
83
Let's Derive the Logic Expressions
Present Next state state w = 1 Output y 4 3 Y z D 00 01 E 11 F 10 dd d Y4 Y3 z y y y y y 4 3 4 3 3 w y 4 00 01 11 10 1 w 00 01 11 10 1 1 d 1 1 1 d 1 d 1 1 d d 1 Y4(w, y4 , y3 ) = w y3 Y3(w, y4 , y3 ) = w z(y4 , y3 ) = y4
84
The Circuit Diagram Y3(w, y4 , y3 ) = w Y4(w, y4 , y3 ) = w y3
Q z Y4(w, y4 , y3 ) = w y3 Q z(y2, y1 ) = y4 Y y 3 3 w D Q Clock Q Resetn
85
Example 6.13 (Combine the two FSMs)
86
The Two FSMs Detect two consecutive 1's Detect two consecutive 0's
C: z = 1 Reset B: z = 0 A: z = 0 w = 1 F: z = 1 Reset E: z = 0 D: z = 0 w 1 = Detect two consecutive 1's Detect two consecutive 0's
87
The Two Circuit Diagrams
Detect two consecutive 1's Detect two consecutive 0's
88
The Combined Circuit Diagram
Detect two consecutive 1's or two consecutive 0's
89
Example 6.14
90
Goal Design an FSM that detects if the previous two values of the input w were equal to 00 or 11. If either condition is true then the output z should be set to 1; otherwise to 0. Implement this as a Mealy-type machine
91
State Diagram [ Figure 6.91 from the textbook ]
92
Building the State Table
[ Figure 6.92 from the textbook ]
93
State Table [ Figure 6.92 from the textbook ]
94
Building the State-Assigned Table
[ Figure 6.93 from the textbook ]
95
State-Assigned Table [ Figure 6.93 from the textbook ]
96
State-Assigned Table cut here
97
State-Assigned Table
98
State-Assigned Table 1 0 d d d d d d
99
Truth Table for Y2, Y1, and z w y2 y1 Y2 Y1 z 1 d
100
K-Maps for Y2, Y1, and z 0 d d 1 0 0 1 1 1 d 1 1 1 1 1 1 0 d d 0
00 01 11 10 1 w y 2 Y2 0 d d 1 w y2 y1 Y2 Y1 z 1 d y1 00 01 11 10 1 w y 2 Y1 1 d y1 00 01 11 10 1 w y 2 z 0 d d 0
101
K-Maps for Y2, Y1, and z 0 d d 1 0 0 1 1 Y2 = w 1 d 1 1 1 1 1 1 Y1 = 1
00 01 11 10 1 w y 2 Y2 0 d d 1 w y2 y1 Y2 Y1 z 1 d Y2 = w y1 00 01 11 10 1 w y 2 Y1 1 d Y1 = 1 y1 00 01 11 10 1 w y 2 z 0 d d 0 z = w y1 y2 + w y2
102
State-Assigned Table Y1 = 1 Y2 = w z = w y1 y2 + w y2
103
State-Assigned Table Y1 = 1 Y2 = w z = w y1 y2 + w y2
104
Example 6.15
105
Goal Implement this state-assigned Table using JK flip-flops
106
Excitation table with JK flip-flops
[ Figure 6.94 from the textbook ]
107
Excitation table with JK flip-flops
108
Excitation table with JK flip-flops
109
Excitation table with JK flip-flops
110
Excitation table with JK flip-flops
111
Excitation table with JK flip-flops
112
Excitation table with JK flip-flops
113
Excitation table with JK flip-flops
And so on...
114
The Expression for z z is equal to y1
115
The Expression for J3 J3 is equal to 1
116
The Expression for K3 K3 is equal to 0
117
The Expression for J2 J2 is equal to w
118
The Expression for K2 K2 is equal to w
119
The Expression for J1 J1 is equal to w y2 + w y3 y2
120
The Expression for K1 d 001 K1 is equal to w y2 + w y2 y1
121
All Logic Expressions
122
Questions?
123
THE END
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.