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\left( n \right) = 2{\bf{ }}n\) for all nonnegative integers \(n\).

Short Answer

Expert verified

The constructed Turing machine that computes the functionfor all nonnegative integers\(n\)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}} \right\},I = \{ 0,1,B\} ,\\\left( {{s_0},1,{s_0},1,R} \right),\left( {{s_0},B,{s_1},B,L} \right),\left( {{s_1},1,{s_2},0,L} \right),\left( {{s_2},0,{s_2},0,L} \right),\\\left( {{s_2},1,{s_3},0,R} \right),\left( {{s_2},B,{s_5},B,R} \right),\left( {{s_3},0,{s_3},0,R} \right),\left( {{s_3},1,{s_3},1,R} \right),\\\left( {{s_3},B,{s_4},1,L} \right),\left( {{s_4},0,{s_2},0,L} \right),\left( {{s_4},1,{s_4},1,L} \right),\left( {{s_5},0,{s_5},1,R} \right),\\\left( {{s_5},1,{s_6},1,R} \right),\left( {{s_5},B,{s_6},B,R} \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 \(S \times I\) to \(S \times I \times \left\{ {R,L} \right\}\), and a starting state \({s_0}\).

Given:

\(f\left( n \right) = 2{\bf{ }}n\)for all nonnegative integers \(n\)

\(n\)is represented by \(n + 1\) ones, which implies that \(2{\bf{ }}n\) will be represented by \(2n + 1\) ones.

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

02

Form of constructing machine

Require \(7\) states \({s_0},{s_1}, \ldots ,{s_6}\left( {{s_0}} \right)\) is the start state, and \({s_6}\) 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}} \right\}\)

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

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

03

Defining the partial function as five-tuples 

Next, define the partial function as five tuples.

First determine the last \(1\) in the string, thus move to the right as long as the input is a 1 (while remaining at the same state) and move to the next state \({s_1}\) when the input is a blank \(B\) (as the previous element is then the last element in the string).

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

Once at the state \({s_1}\), know that the input is the last \({\bf{1}}\) in the string, which changes to a 0 (which use to differentiate the two strings of 1 consisting of \(n\) ones that need to construct). When this 1 is changed to a 0, move to the state \({s_2}\).

\(\left( {{s_1},1,{s_2},0,L} \right)\)

04

Construction of Turing machine

Once at the state \({s_2}\), scan to the left until you obtain the first \({\bf{1}}\) . Once the first \({\bf{1}}\) is detected, move to state \({{\bf{s}}_{\bf{3}}}\) and change the \({\bf{1}}\) to. If a blank \(B\) is detected, then all \(1's\)were replaced by \(0's\) and then move to the state \({s_5}\) (wherereplacing all \(0\)’s by \(1's\) again to obtain the string of \(2n + 1\) ones).

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

Once at the state \({s_3}\), the first 1 was detected and then scan to the right to find the first blank \(B\). Once the first blank \(B\) is detected, add a 1 and move to state \({s_4}\).

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

05

Construction of Turing machine

Once at the state \({s_4}\), scan for the first 0 to the left (which represents the \(\left( {n + 1} \right)\) bit of the original string). When the first 0 is encountered, move back to state \({s_2}\).

\(\left( {{s_4},0,{s_2},0,L} \right),\left( {{s_4},1,{s_4},1,L} \right)\)

When at the state \({s_4}\) then all \(n + 1\) ones of the input were changed to \(0's\) and thus need to change these \(0's\)to\(1's\) again. Once arriving at the first 1 or blank \(B\) input, move to the final state \({s_6}\).

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

Finally, add no five-tuples \(1's\)that have \({s_6}\) as its first element such that the machine always halts when arriving at state \({s_6}\). Note that the machine will halt in the final state \({s_6}\) when the string has \(n\) additional.

Hence, the constructed Turing machine that computes the function\(f\left( n \right) = 2{\bf{ }}n\)for all nonnegative integers\(n\)is:

\(\begin{array}{c}\left( {{s_0},1,{s_0},1,R} \right),\left( {{s_0},B,{s_1},B,L} \right),\left( {{s_1},1,{s_2},0,L} \right),\left( {{s_2},0,{s_2},0,L} \right),\\\left( {{s_2},1,{s_3},0,R} \right),\left( {{s_2},B,{s_5},B,R} \right),\left( {{s_3},0,{s_3},0,R} \right),\left( {{s_3},1,{s_3},1,R} \right),\\\left( {{s_3},B,{s_4},1,L} \right),\left( {{s_4},0,{s_2},0,L} \right),\left( {{s_4},1,{s_4},1,L} \right),\left( {{s_5},0,{s_5},1,R} \right),\\\left( {{s_5},1,{s_6},1,R} \right),\left( {{s_5},B,{s_6},B,R} \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