400 likes | 499 Views
Learn about FSM, state diagrams, Mealy and Moore Machines, designing state diagrams for applications like counters and controllers, and implementations for system outputs.
E N D
Chapter 2 Introduction to Finite State Machine
Introduction • FSM(Finite State Machine) • A tool to model the desired behavior of a sequential system • A FSM consists of several states. • Inputs to the machine are combined with the current state to determine the next state. • Outputs are generated based on either the state of the machine, or the state of the machine and machine inputs.
2.1 State Diagram and State Table • State diagrams and state tables • Convenient mechanism for specifying the behavior of sequential systems. • Table 2.1 shows the state tables the alarm clock example. • Figure 2.2 shows the state diagram for the alarm clock example. • Each state is represented by a circled vertex. • Mutually exclusive: No input values should meet the conditions of more than one arc. • Self-arcs
2.2 Mealy and Moore Machines • A finite state machine can be represent outputs in one of two ways. • Moore machine (Figure 2.2 (a) ) • Mealy machine (Figure 2.2 (b) ) • Notice that the self-arcs must be shown for the Mealy machines, but not for Moore machines.
Figure 2.4 JK flip-flop with modified outputs: Table 2.2 (b)
2.3 Designing State Diagrams • Modulo 6 counter • String checker • Toll booth controller
Modulo 6 counter • Modulo 6 counter • 000001010011100101000 • Table 2.3
Figure 2.5 (a) State diagram for the modulo 6 counter: Mealy
Figure 2.5 (b) State diagram for the modulo 6 counter: Moore
String Checker • A string checker inputs a string of bits, one bit per clock cycle. • When the previous three bits form the pattern 110, it sets output M=1; otherwise M=0 • Refer to Table 2.4 and Figure 2.6
Figure 2.6 State diagrams for the string checker: (a) Mealy (b)Moore
Figure 2.A State Diagram for the string checker with revised state assignment
Toll Booth Controller • A toll booth controller has two external sensors. • Whether a car is at the toll booth • C=1 when a car is present • Whether a coin has been deposited in the toll booth’s collection basket and its value • I0I1=00 : no coins I0I1=01 : a nickel • I0I1=10 : a dime I0I1=00 : a quarter • This toll booth does not accept pennies nor coins with values above 25 cents. • Two output lights and one alarm • R • G • A
Figure 2.7 State diagram for the Moore machine for the toll booth controller
2.4 From State Diagram to Implementation • Assigning the state values • Mealy and Moore machine implementation • Generating the next states • Generating system outputs • An alternative design
Assigning the state values • Each state must be assigned a unique binary value. • For a machine with n state, the state value will have log2 n bits. • Although any values can be assigned to the states, some assignments are better than others
Mealy and Moore machine implementation • The generic Mealy machine implementation: Figure 2.9 • The generic Moore machine implementation: Figure 2.10
Generating the next states • Table 2.7 shows the truth table needed for the modulo 6 counter.
Figure 2.11 K-map for the next state of the modulo 6 counter
Figure 2.12 Implementation of the next state logic for the modulo 6 counter
Figure 2.13 Primary implementation of the next state logic for the modulo 6 counter using a multiplexer Refer to Table 2.8
Figure 2.14 Final implementation of the next state logic for the modulo 6 counter using a multiplexer
Figure 2.15 Implementation of the next state logic for the modulo 6 counter using a lookup ROM
Generating system outputs • Table 2.9 shows the tables for the Mealy and Moore machines for the modulo 6 counter.
Figure 2.16 Mealy machine implementation of the modulo 6 counter
Figure 2.17 Moore machine implementation of the modulo 6 counter
Figure 2.18 (a) Moore machine implementation of the modulo 6 counter using a lookup ROM
An alternative design • There are other methods of implementing finite state machines.
Figure 2.19 (a) Alternative state machine hardware design: generic hardware
Figure 2.19 (b) Moore machine implementation of the modulo 6 counter