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 ends with four or more consecutive \({\bf{1}}\). Then construct a deterministic finite-state automaton that recognizes this set.

Short Answer

Expert verified

Thus, \({\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}}\).

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

Step \({\bf{1}}\): 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 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

Finding the possible input

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}}\).

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.

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{1}}\) is read and when it is at state \({{\bf{s}}_4}\), then the string still ends with four or more ones and thus it remains at \({{\bf{s}}_4}\).

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,4}}\).

03

Constructing the finite-state

The output has to be \({\bf{1}}\) when there are four or more consecutive ones and \({\bf{0}}\) otherwise.

A deterministic finite-state automaton is a five-tuple \(\left( {{\bf{S,I,O,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}}\).

04

Finding the possible inputs

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 the state \({{\bf{s}}_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

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

When a \({\bf{1}}\) is read and when it is at state \({{\bf{s}}_4}\), then the string still ends with four or more ones and thus it remains at \({{\bf{s}}_4}\).

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,4}}\).

Hence, \({\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}}\).

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