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 with output that produces an output of\[{\bf{1}}\]if the bit string read so far as input contains four or more consecutive\[{\bf{1}}\]. Then construct a deterministic finite-state automaton that recognizes this set.

Short Answer

Expert verified

Let \[{\bf{S = }}\left\{ {{{\bf{s}}_{\bf{0}}}{\bf{,}}{{\bf{s}}_{\bf{1}}}{\bf{,}}{{\bf{s}}_{\bf{2}}}{\bf{,}}{{\bf{s}}_{\bf{3}}}{\bf{,}}{{\bf{s}}_{\bf{4}}}} \right\}\] where \[{{\bf{s}}_{\bf{i}}}\] represents that the last \[{\bf{i}}\] elements of the string are \[{\bf{1's}}\] and \[{{\bf{s}}_{\bf{4}}}\] represents that the string contains four or more consecutive \[{\bf{1's}}\].

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

Definition

A finite state machine may be a six-tuple \[\left( {{\bf{S,I,O,f,g,}}{{\bf{s}}_{\bf{0}}}} \right)\] where \[{\bf{S}}\] is that the set of States, \[{\bf{i}}\] is the input alphabet, \[{\bf{O}}\] is the output alphabet, \[{\bf{f}}\] is the transition function that assigns a next state to a pair of a state and input, \[{\bf{g}}\] is an output function that assigns an output to every pair of a state and input, and \[{{\bf{s}}_{\bf{0}}}\] is the starting state.

The states of the finite-state machine are the labels written within the circles (states).

02

Initial state

Let \[{\bf{S = }}\left\{ {{{\bf{s}}_{\bf{0}}}{\bf{,}}{{\bf{s}}_{\bf{1}}}{\bf{,}}{{\bf{s}}_{\bf{2}}}{\bf{,}}{{\bf{s}}_{\bf{3}}}{\bf{,}}{{\bf{s}}_{\bf{4}}}} \right\}\], where \[{{\bf{s}}_{\bf{i}}}\] represents that the last \[{\bf{i}}\] elements of the string are \[{\bf{1's}}\] and \[{{\bf{s}}_{\bf{4}}}\] represents that the string contains four or more consecutive \[{\bf{1's}}\].

The finite-state machine's input symbols are examples of potential inputs.

\[{\bf{I = }}\left\{ {{\bf{0,1}}} \right\}\]

\[{{\bf{s}}_{\bf{0}}}\] is the first state of the finite-state machine.

03

Finding the ultimate state

When a \[{\bf{1}}\] is read, it needs to move from state \[{{\bf{s}}_{\bf{i}}}\] to \[{{\bf{s}}_{{\bf{i + 1}}}}\] when \[{\bf{i = 0,1,2,3}}\].

When a \[{\bf{0}}\] is read, it needs to move from state \[{{\bf{s}}_{\bf{i}}}\] to \[{{\bf{s}}_{\bf{0}}}\] when \[{\bf{i = 0,1,2,3}}\].

When you are at the final state \[{{\bf{s}}_{\bf{4}}}\], the string contains four or more consecutive \[{\bf{1's}}\] and thus it does not must leave the state anymore (on any input).

The output must to be \[{\bf{1}}\] when there are four or more consecutive ones and \[{\bf{0}}\] otherwise.

04

Initial state of the finite state

A deterministic finite state automaton could be a five-tuple \[\left( {{\bf{S,I,f,g,}}{{\bf{s}}_{\bf{0}}}{\bf{,F}}} \right)\] where \[{\bf{S}}\] is the set of states, \[{\bf{i}}\] is the input alphabet, \[{\bf{f}}\] is the transition function that assigns a next state to a pair of a state and input, \[{{\bf{s}}_{\bf{0}}}\] is the starting state and \[{\bf{f}}\] is the set of final states.

The states of the finite-state automaton are the labels written within the circles (states).

\[{\bf{S = }}\left\{ {{{\bf{s}}_{\bf{0}}}{\bf{,}}{{\bf{s}}_{\bf{1}}}{\bf{,}}{{\bf{s}}_{\bf{2}}}{\bf{,}}{{\bf{s}}_{\bf{3}}}{\bf{,}}{{\bf{s}}_{\bf{4}}}} \right\}\], where \[{{\bf{s}}_{\bf{i}}}\] represents that the last \[{\bf{i}}\] elements of the string are \[{\bf{1's}}\] and \[{{\bf{s}}_{\bf{4}}}\] represents that the string contains four or more consecutive \[{\bf{1's}}\].

The finite-state machine's input symbols are examples of potential inputs.

\[{\bf{I = }}\left\{ {{\bf{0,1}}} \right\}\]

\[{{\bf{s}}_{\bf{0}}}\]is the first state of the finite-state machine

The final state of the finite-state automaton is that the state \[{{\bf{s}}_{\bf{4}}}\] which represents that there are four or more \[{\bf{1's}}\].

\[{\bf{F = }}\left\{ {{{\bf{s}}_{\bf{4}}}} \right\}\]

05

Constructing the finite-state automaton

When a \[{\bf{1}}\] is read, it would like to move from state \[{{\bf{s}}_{\bf{i}}}\] to \[{{\bf{s}}_{{\bf{i + 1}}}}\] when \[{\bf{i = 0,1,2,3}}\].

When a \[{\bf{0}}\] is read, it would like to move from state \[{{\bf{s}}_{\bf{i}}}\] to \[{{\bf{s}}_{\bf{0}}}\] when \[{\bf{i = 0,1,2,3}}\].

When it is at the ultimate state \[{{\bf{s}}_{\bf{4}}}\], the string contains four or more consecutive \[{\bf{1's}}\] and thus it don't need to leave the state anymore (on any input).

Hence, let \[{\bf{S = }}\left\{ {{{\bf{s}}_{\bf{0}}}{\bf{,}}{{\bf{s}}_{\bf{1}}}{\bf{,}}{{\bf{s}}_{\bf{2}}}{\bf{,}}{{\bf{s}}_{\bf{3}}}{\bf{,}}{{\bf{s}}_{\bf{4}}}} \right\}\] where \[{{\bf{s}}_{\bf{i}}}\] represents that the last \[{\bf{i}}\] elements of the string are \[{\bf{1's}}\] and \[{{\bf{s}}_{\bf{4}}}\] represents that the string contains four or more consecutive \[{\bf{1's}}\].

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