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

a) Define a nondeterministic finite-state automaton.

b) Show that given a nondeterministic finite-state automaton, there is a deterministic finite-state automaton that recognizes the same language.

Short Answer

Expert verified

a) Therefore, the definition of nondeterministic finite-state automaton is “Afive-tuple\({\bf{M = }}\left( {{\bf{S,I,f,}}{{\bf{s}}_{\bf{0}}}{\bf{,F}}} \right)\) containing a set S of states, an input alphabet I,a transition function f that assigns a set of possible nextstates to every pair of a state and an input, a starting state\({{\bf{s}}_0}\), and a set of final states F”.

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

(a)

Finite-state automaton (Definition): A finite-state automaton\({\bf{M = }}\left( {{\bf{S,I,f,}}{{\bf{s}}_{\bf{0}}}{\bf{,F}}} \right)\)consists of a finite set S of states, a finite input alphabet I, a transition function f that assigns a next state to every pair of state and input (so\({\bf{f:S \times I}} \to {\bf{S}}\)that ), an initial or start state\({{\bf{s}}_0}\), and a subset F of S consisting of final (or accepting states).

Deterministic finite-state automaton\({\bf{M = }}\left( {{\bf{S,I,f,}}{{\bf{s}}_{\bf{0}}}{\bf{,F}}} \right)\):a five-tuple containing a set S of states, an input alphabet I, a transition function f that assigns a next state to every pair of a state and an input, a starting state\({{\bf{s}}_{\bf{0}}}\), and a set of final states F.

02

Step 2: Describe the nondeterministic finite-state automaton

Nondeterministic finite-state automaton:

Afive-tuple\({\bf{M = }}\left( {{\bf{S,I,f,}}{{\bf{s}}_{\bf{0}}}{\bf{,F}}} \right)\) containing a set S of states, an input alphabet I,a transition function f that assigns a set of possible nextstates to every pair of a state and an input, a starting state\({{\bf{s}}_0}\), and a set of final states F.

Hence, the definition of nondeterministic finite-state automaton is shown above.

03

Proof of the given statement

(b)

Given that, nondeterministic finite-state automaton.

Theorem-1: “If the language L is recognized by a non-deterministic finite-state automaton \({{\bf{M}}_0}\), then L isalso recognized by a deterministic finite-state automaton \({{\bf{M}}_1}\)”.

Proof:

Describing how to construct the deterministic finite-state automaton \({{\bf{M}}_1}\) that recognizes L from \({{\bf{M}}_0}\), the nondeterministic finite-state automaton that recognizes this language.

Each state in \({{\bf{M}}_1}\) will be made up of a set of states in \({{\bf{M}}_0}\).

The start symbol of \({{\bf{M}}_1}\) is \(\left\{ {{{\bf{s}}_0}} \right\}\), whichis the set containing the start state of \({{\bf{M}}_0}\).

The input set of \({{\bf{M}}_1}\) is the same as the input set of \({{\bf{M}}_0}\).

Given a state \(\left\{ {{{\bf{s}}_{{{\bf{i}}_{\bf{1}}}}}{\bf{,}}{{\bf{s}}_{{{\bf{i}}_{\bf{2}}}}}{\bf{,}}...{\bf{,}}{{\bf{s}}_{{{\bf{i}}_{\bf{k}}}}}} \right\}\)of \({{\bf{M}}_1}\), the input symbol x takes this state to the unionof the sets of next states for the elements of this set, that is, the union of the sets\({\bf{f}}\left( {{{\bf{s}}_{{{\bf{i}}_{\bf{1}}}}}{\bf{,x}}} \right){\bf{,f}}\left( {{{\bf{s}}_{{{\bf{i}}_{\bf{2}}}}}{\bf{,x}}} \right){\bf{,}}...{\bf{,f}}\left( {{{\bf{s}}_{{{\bf{i}}_{\bf{k}}}}}{\bf{,x}}} \right)\).

The states of \({{\bf{M}}_1}\)are all the subsets of S, the set of states of \({{\bf{M}}_0}\), that areobtained in this way starting with \({{\bf{s}}_0}\). (There are as many as \({2^{\bf{n}}}\) states in the deterministic machine,where n is the number of states in the nondeterministic machine, because all subsets may occuras states, including the empty set, although states are typically far less frequent.)

The final statesof \({{\bf{M}}_1}\)are those sets that contain a final state of \({{\bf{M}}_0}\).

Assume that an input string is recognized by \({{\bf{M}}_0}\). Then one of the states that can be reachedfrom \({{\bf{s}}_0}\)using this input string is a final state (the reader should provide an inductive proof ofthis).

This means that in \({{\bf{M}}_1}\), this input strings leads from \(\left\{ {{{\bf{s}}_0}} \right\}\)to a set of states of \({{\bf{M}}_0}\)that containsa final state.

This subset is a final state of \({{\bf{M}}_1}\), so this string is also recognized by \({{\bf{M}}_1}\). Also, aninput string not recognized by \({{\bf{M}}_0}\)does not lead to any final states in \({{\bf{M}}_0}\). (The reader must provide the details that prove the statement.)

Consequently, this input string does not lead from\(\left\{ {{{\bf{s}}_0}} \right\}\) to a final state in \({{\bf{M}}_1}\).

Hence, the given statement is proved as true.

One App. One Place for Learning.

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

Get started for free

Most popular questions from this chapter

See all solutions

Recommended explanations on Math Textbooks

View all explanations

What do you think about this solution?

We value your feedback to improve our textbook solutions.

Study anywhere. Anytime. Across all devices.

Sign-up for free