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

Using the constructions described in the proof of Kleene’s theorem, find non-deterministic finite-state automata that recognize each of these sets.

  1. \({\bf{01*}}\)
  2. \(\left( {0 \cup 1} \right){\bf{1*}}\)
  3. \({\bf{00}}\left( {{\bf{1*}} \cup {\bf{10}}} \right)\)

Short Answer

Expert verified

1. Therefore, the nondeterministic finite-state automata that recognize the set \({\bf{01*}}\) are shown below.

2. Hence, the nondeterministic finite-state automata that recognize the set \(\left( {0 \cup 1} \right){\bf{1*}}\)are shown below.

3. So, the nondeterministic finite-state automata that recognize the set \({\bf{00}}\left( {{\bf{1*}} \cup {\bf{10}}} \right)\)are 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 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 the next state to every pair of states and input (so that \({\bf{f:S \times I}} \to {\bf{S}}\)), an initial or start state \({{\bf{s}}_0}\), and a subset F of S consisting of final (or accepting states).

Kleene’s theorem:A set is regular if and only if it is recognized by a finite-state automaton.

Rules of regular expression represent a set:

\(\emptyset \)represents the empty set, that is, the set with no strings;

\({\bf{\lambda }}\)represents the set\(\left\{ {\bf{\lambda }} \right\}\), which is the set containing the empty string;

x represents the set \(\left\{ {\bf{x}} \right\}\) containing the string with one symbol x;

(AB) represents the concatenation of the sets represented by A and by B;

\(\left( {{\bf{A}} \cup {\bf{B}}} \right)\)represents the union of the sets represented by A and by B;

\({\bf{A*}}\)represents the Kleene closure of the sets represented by A.

02

Step 2: Construct the nondeterministic finite-state automata

Given,\({\bf{01*}}\).

The third image in Kleene's theorem's proof gives the nondeterministic finite-state automata that can recognize 0; the second image gives the nondeterministic finite-state automata that canrecognize\({\bf{1*}}\).

The next step is to combine these two machines, which is accomplished by using the same input as the first machine and by drawing an arrow from the first machine's start to the second machine's start state.

So, the diagram of the non-deterministic finite-state automaton is shown below.

03

Construct the nondeterministic finite-state automata

Given,\(\left( {0 \cup 1} \right){\bf{1*}}\).

The third illustration of Kleene's theorem's proof provides the nondeterministic finite-state automata that can recognize 0; the nondeterministic finite-state automata that can recognize 1 is analogous. Concatenating the two machines to the same start state allows us to take their union.

The second graphic shows the nondeterministic finite-state that can identify\({\bf{1*}}\).

The next step is to combine these two machines (the union \(0 \cup 1\) and \({\bf{1*}}\)), which is done by drawing an arrow from the first machine's start state to the second machine's start state and using the same input as in the first machine.

So, the diagram of the non-deterministic finite-state automaton is shown below.

04

Construct the nondeterministic finite-state automata

Given,\({\bf{00}}\left( {{\bf{1*}} \cup {\bf{10}}} \right)\)

In the fourth illustration of Kleene's theorem proof, where the 1 is replaced with a 0, we find the nondeterministic finite-state automata that understand 00.

In the second image is the nondeterministic finite-state that recognizes\({\bf{1*}}\), while in the fourth image, with 1 and 0 switched around, is the nondeterministic finite-state that recognizes 10. Concatenating the two machines to the same start state allows us to take the unions of the two machines.

The two produced machines must then be concatenated. This is done by drawing an arrow from the state immediately before the final state in the first machine to the start state in the second machine, using the same input as in the first machine.

So, the diagram of the deterministic finite-state automaton is shown below.

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