Warning: foreach() argument must be of type array|object, bool given in /var/www/html/web/app/themes/studypress-core-theme/template-parts/header/mobile-offcanvas.php on line 20

Construct a finite-state machine for entering a security code into an automatic teller machine (ATM) that implements these rules: A user enters a string of four digits, one digit at a time. If the user enters the correct four digits of the password, the ATM displays a welcome screen. When the user enters an incorrect string of four digits, the ATM displays a screen that informs the user that an incorrect password was entered. If a user enters the incorrect password three times, the account is locked.

Short Answer

Expert verified

Therefore, the finite-state machine for entering a security code into an ATM model is shown below:

Step by step solution

Achieve better grades quicker with Premium

  • Unlimited AI interaction
  • Study offline
  • Say goodbye to ads
  • Export flashcards

Over 22 million students worldwide already upgrade their learning with Vaia!

01

General form

Finite-State Machines with Outputs (Definition):

A finite-state machine\({\bf{M = }}\left( {{\bf{S,}}\,\,{\bf{I,}}\,\,{\bf{O,}}\,\,{\bf{f,}}\,\,{\bf{g,}}\,\,{{\bf{s}}_0}} \right)\)consists of a finite set S of states, a finite input alphabet I, a finite output alphabet O, a transition function f that assigns to each state and input pair a new state, an output function g that assigns to each state and input pair output and an initial state\({{\bf{s}}_0}\).

Concept of input string and output:

An input string takes the starting state through a sequence of states, as determined by the transition function. As we read the input string symbol by symbol (from left to right), each input symbol takes the machine from one state to another. Because each transition produces an output, an input string also produces an output string.

02

Step 2: Construct a finite-state machine model

It is given that a finite-state machine for entering a security code into an automatic teller machine (ATM).

Rules of ATM: A user enters a string of four digits, one digit at a time. If the user enters the correct four digits of the password, the ATM displays a welcome screen. When the user enters an incorrect string of four digits, the ATM displays a screen that informs the user that an incorrect password was entered. If a user enters the incorrect password three times, the account is locked.

Construction:

Let us consider the correct four-digit password to be abcd. And \({{\bf{w}}_{\bf{a}}}{\bf{,}}{{\bf{w}}_{\bf{b}}}{\bf{,}}{{\bf{w}}_{\bf{c}}}{\bf{,}}{{\bf{w}}_{\bf{d}}}\) represent a digit other than a, b, c, or d respectively. Let w represent any digit being entered.

Let us consider the states\({{\bf{s}}_{\bf{i}}}\), where\({\bf{i = 0,1,2,3,4,}}...{\bf{,21}}\).

\({{\bf{s}}_4}\)represents that the correct code has been entered.

\({{\bf{s}}_{21}}\)represents that the account has been locked.

In the first attempt user states \({{\bf{s}}_{\bf{0}}}{\bf{,}}{{\bf{s}}_{\bf{1}}}{\bf{,}}{{\bf{s}}_{\bf{2}}}{\bf{,}}{{\bf{s}}_{\bf{3}}}{\bf{,}}{{\bf{s}}_{\bf{5}}}{\bf{,}}{{\bf{s}}_{\bf{6}}}{\bf{,}}{{\bf{s}}_{\bf{7}}}\) where \({{\bf{s}}_{\bf{5}}}{\bf{,}}{{\bf{s}}_{\bf{6}}}{\bf{,}}{{\bf{s}}_{\bf{7}}}\) represent that a wrong digit was entered in the code.

We start the state from\({{\bf{s}}_0}\). If a wrong digit is entered, we state\({{\bf{s}}_{\bf{5}}}\). If the correct digit is entered, we move on to\({{\bf{s}}_1}\).

If we are at a state where only correct digits were previously entered, then we move right to the next “correct” state if we enter the next correct code, else we move to the wrong state to the bottom right of the state.

Similarly for the other two attempts.

If the wrong code was entered three times, then we move on to state\({{\bf{s}}_{21}}\).

The model of the finite-state machine is shown below.

Therefore, the result shows the required finite-state machine.

One App. One Place for Learning.

All the tools & learning materials you need for study success - in one app.

Get started for free

Study anywhere. Anytime. Across all devices.

Sign-up for free