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 \({\bf{1's}}\). 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 there are \({\bf{i}}\) or more \({\bf{1's}}\) in the string read so far.

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 is 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 in the circles (states).

02

Finding the inputs

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 there are \({\bf{i}}\) or more \({\bf{1's}}\) in the string read so far.

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

Determining the finite-state automaton

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

Otherwise, it will remain at the current state at the input is a \({\bf{0}}\) or as you already know that there are four or more \({\bf{1's}}\).

The output needs to be \({\bf{1}}\) when there are four or more 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.

04

Finding the final state

The finite state automaton are the labels reflects in 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 there are \({\bf{i}}\) or more \({\bf{1's}}\) in the string read so far.

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}}_{\bf{4}}}\) which represents that there are four or more \({\bf{1's}}\).

\({\bf{F = }}\left\{ {{{\bf{s}}_{\bf{4}}}} \right\}\)

05

Determining the finite-state automaton

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

Otherwise, it will remain at the current state at the input is a \({\bf{0}}\) or as you already know that there are four or more \({\bf{1's}}\).

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 there are \({\bf{i}}\) or more \({\bf{1's}}\) in the string read so far.

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