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 Turing machine that computes the function \(f{\bf{(n) = 3}}\) if \(n \ge 5\) and \(f\left( n \right) = 0\) if \(n = 0,1,2,3\) or \(4\).

Short Answer

Expert verified

The constructed Turing machine that computes the function \(f\left( n \right) = 3\) if \(n \ge 5\) and \(f\left( n \right) = 0\) if \(n = 0,1,2,3\) or \(4\) is

\(\begin{array}{c}T &= \left( {S,I,f,{s_0}} \right)\\S &= \left\{ {{s_0},{s_1},{s_2},{s_3},{s_4},{s_5},{s_6},{s_7},{s_8},{s_9},{s_{10}}} \right\}\\I &= \left\{ {0,1,B} \right\}\end{array}\)

\(\begin{array}{c}\left( {{s_0},1,{s_1},B,R} \right)\\\left( {{s_1},1,{s_2},B,R} \right)\\\left( {{s_1},B,{s_9},1,R} \right)\\\left( {{s_2},1,{s_3},B,R} \right)\end{array}\)

\(\begin{array}{c}\left( {{s_2},B,{s_9},1,R} \right)\\\left( {{s_3},1,{s_4},B,R} \right)\\\left( {{s_3},B,{s_9},1,R} \right)\\\left( {{s_4},1,{s_5},B,R} \right)\end{array}\)

\(\begin{array}{c}\left( {{s_4},B,{s_9},1,R} \right)\\\left( {{s_5},1,{s_6},B,R} \right)\\\left( {{s_5},B,{s_9},1,R} \right)\\\left( {{s_6},1,{s_6},1,R} \right)\end{array}\)

\(\begin{array}{c}\left( {{s_6},B,{s_7},1,L} \right)\\\left( {{s_7},B,{s_8},1,L} \right)\\\left( {{s_8},B,{s_9},1,L} \right)\\\left( {{s_9},B,{s_{10}},1,L} \right)\end{array}\)

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 Turing machine \(T = \left( {S,I,f,{s_0}} \right)\) consists of a finite set \(S\) of states, an alphabet \(I\) containing the blank symbol \(B\), a partial function \(f\) from \({\bf{S \times I}}\) to \(S \times I \times \{ R,L\} \), and a starting state \({s_0}\).

Given:

\(f(n) = 3\)if \(n \ge 5\) and \(f(n) = 0\) if \(n = 0,1,2,3,4\)

\(n\)is represented by \(n + 1\).

The Turing machine computes the function by subtracting 3 when it removes the three leading 1's at the beginning of the number.

Note: The partial function \(f\) is often represented as \(5 - \)tuples.

02

Form of constructing machine

Require 10 states \({s_0},{s_1}, \ldots ,{s_9},{s_{10}},{s_0}\) is the start state and \({s_9}\) will be the final state), which will be contained in the set \(S\).

\(S = \left\{ {{s_0},{s_1},{s_2},{s_3},{s_4},{s_5},{s_6},{s_7},{s_8},{s_9},{s_{10}}} \right\}\)

The alphabet \({\bf{I}}\) needs to contain the tape symbols. The tape symbols are given as \(0,1\)and\(B\).

\(I = \left\{ {0,1,B} \right\}\)

03

Construction of Turing machine

Next, define the partial function as five tuples.

Remove the first leading one by replacing the first 1 in the string by \(B\). Then move to state \({s_1}\) (where removing the second 1) and move one position to the right.

\(\left( {{s_0},1,{s_1},B,R} \right)\)

Once at the state \({s_1}\), know that a 1 was removed at the beginning of the string. If the input is a 1, then remove the second 1 by replacing the 1 by \(B\). Then also move to the state \({s_2}\) (where removing the third 1).

\(\left( {{s_1},1,{s_2},B,R} \right)\)

04

Construction of Turing machine

However, if the second element was a blank \(B\) instead, then the input was 0 and thus need to return 0 (while the string at this point will contain only \(B's\)). This then means that it is sufficient to then move the machine to the final state \({s_9}\) while changing one of the \(B's\) to 1.

\(\left( {{s_1},B,{s_9},1,R} \right)\)

Once at the state \({s_2}\), know that two \(1's\) were removed at the beginning of the string. If the input is a 1, then remove the third 1 by replacing the 1 by \(B\). Then also move to the state \({s_3}\).

\(\left( {{s_2},1,{s_3},B,R} \right)\)

However, if the third element was a blank \(B\) instead, then the input was \({\bf{1}}\) and thus need to return \(0\) (while the string at this point will contain only \(B's\)). This then means that it is sufficient to then move the machine to the final state \({s_9}\) while

changing one of the \(B's\) to 1.

\(\left( {{s_2},B,{s_9},1,R} \right)\)

05

Construction of Turing machine

Once at the state \({s_3}\), know that three \(1's\)were removed at the beginning of the string. If the input is a \(1\), then remove the fourth \({\bf{1}}\) by replacing the 1 by \(B\). Then also move to the state \({{\bf{s}}_{\bf{4}}}\).

\(\left( {{s_3},1,{s_4},B,R} \right)\)

However, if the third element was a blank \(B\) instead, then the input was \(2\) and thus need to return \(0\) (while the string at this point will contain only \(B's\)). This then means that it is sufficient to then move the machine to the final state \({s_9}\) while changing one of the \(B's\) to 1.

\(\left( {{s_3},B,{s_9},1,R} \right)\)

Once at the state \({s_4}\), know that four \(1's\) were removed at the beginning of the string. If the input is a 1, then remove the fifth 1 by replacing the 1 by \(B\). Then also move to the state \({s_5}\).

\(\left( {{s_4},1,{s_5},B,R} \right)\)

06

Construction of Turing machine

However, if the third element was a blank \(B\) instead, then the input was 3 and thus need to return 0 (while the string at this point will contain only \(B's\)). This then means that it is sufficient to then move the machine to the final state \({s_9}\) while changing one of the \(B's\) to 1.

\(\left( {{s_4},B,{s_9},1,R} \right)\)

Once at the state \({s_5}\), know that five \(1's\) were removed at the beginning of the string. If the input is a 1, then remove the sixth 1 by replacing the 1 by \(B\). Then also move to the state \({s_6}\).

\(\left( {{s_5},1,{s_6},B,R} \right)\)

However, if the third element was a blank \(B\) instead, then the input was 4 and thus you then need to return 0 (while the string at this point will contain only \(B's\)). This then means that it is sufficient to then move the machine to the final state \({s_9}\) while changing one of the \(B's\) to 1.

\(\left( {{s_5},B,{s_9},1,R} \right)\)

07

Construction of Turing machine

Once at the state \({s_6}\), knows that at least six \(1's\) were removed at the beginning of the string and thus the integer is at least \(5\). If the input is a 1, then replace the 1 by a blank and move to the right (which thus do until comes to the first blank).

\(\left( {{s_6},1,{s_6},1,R} \right)\)

If the input is a blank \(B\), then the current string contains only blanks and then need to add three \(1's\) (as you need to return 3). This is done by moving from state \({s_6}\) to \({{\bf{s}}_{\bf{7}}}\)to\({{\bf{s}}_{\bf{8}}}\)to\({s_9}\)to\({s_{10}}\) and changing a blank \(B\) to a 1 in each step (such that you obtain output 3 in the end then have a string with four \(1's\)).

\(\begin{array}{c}\left( {{s_6},B,{s_7},1,L} \right)\\\left( {{s_7},B,{s_8},1,L} \right)\\\left( {{s_8},B,{s_9},1,L} \right)\\\left( {{s_9},B,{s_{10}},1,L} \right)\end{array}\)

Finally, add no five-tuples that have \({s_9}\) as its first element such that the machine always halts when arriving at state \({s_9}\).

Hence, the constructed Turing machine that computes the function \(f\left( n \right) = 3\) if \(n \ge 5\) and \(f\left( n \right) = 0\) if \(n = 0,1,2,3\) or 4 is

\(\begin{array}{c}\left( {{s_0},1,{s_1},B,R} \right)\\\left( {{s_1},1,{s_2},B,R} \right)\\\left( {{s_1},B,{s_9},1,R} \right)\\\left( {{s_2},1,{s_3},B,R} \right)\end{array}\)

\(\begin{array}{c}\left( {{s_2},B,{s_9},1,R} \right)\\\left( {{s_3},1,{s_4},B,R} \right)\\\left( {{s_3},B,{s_9},1,R} \right)\\\left( {{s_4},1,{s_5},B,R} \right)\end{array}\)

\(\begin{array}{c}\left( {{s_4},B,{s_9},1,R} \right)\\\left( {{s_5},1,{s_6},B,R} \right)\\\left( {{s_5},B,{s_9},1,R} \right)\\\left( {{s_6},1,{s_6},1,R} \right)\end{array}\)

\(\begin{array}{c}\left( {{s_6},B,{s_7},1,L} \right)\\\left( {{s_7},B,{s_8},1,L} \right)\\\left( {{s_8},B,{s_9},1,L} \right)\\\left( {{s_9},B,{s_{10}},1,L} \right)\end{array}\)

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