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) = n + 2\) for all nonnegative integers \(n\).

Short Answer

Expert verified

The constructed Turing machine that computes the function\(f\left( n \right) = n + 2\)for all nonnegative integers\(n\)is:

\(\begin{array}{c}T = \left( {S,I,f,{s_0}} \right)\\S = \left\{ {{s_0},{s_1},{s_2}} \right\}\\I = \{ 0,1,B\} \\\left( {{s_0},0,{s_0},0,L} \right)\\\left( {{s_0},0,{s_0},1,L} \right)\\\left( {{s_0},B,{s_1},1,L} \right)\\\left( {{s_1},B,{s_2},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 \({\bf{I}}\) containing the blank symbol \(B\), a partial function \({\bf{f}}\) from \(S \times I\) to \(S \times I \times \{ R,L\} \), and a starting state \({s_0}\).

Given:

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

The Turing machine computes the function by adding when it adds two leading \(1's\) to the beginning of the number.

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

02

Form of constructing machine

You will require \(3\) states \({s_0},{\bf{ }}{s_1}\) and\({s_2}\).\({s_0}\) is 2 the start state and will be used to look for the beginning of the string, \({s_1}\) will be the state that indicates that the first 1 was added to the string, and\({s_2}\) will be the final state), which will be contained in the set \(S\).

\(S = \left\{ {{s_0},{s_1},{s_2}} \right\}\)

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

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

Next, you will define the partial function as five tuples.

As long as the input is a 0 or a 1, you will keep the input unchanged and move one position to the left (as you want to find the first symbol).

\(\begin{array}{c}\left( {{s_0},0,{s_0},0,L} \right)\\\left( {{s_0},0,{s_0},1,L} \right)\end{array}\)

03

Constructing the Turing machine 

If the input is a blank \(B\), then you move to the state \({s_1}\) as you have then arrived at the beginning of the string. You change the blank to a 1 (such that you added the first \(1\)) and move to the left again such that you add the next 1 on the next turn.

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

Once you are at state \({s_1}\), you know that the first 1 was added to the beginning of the string. If the input is a blank \(B\) again, then you can add the second 1 by replacing the \(B\) by 1. You then also move to the final state \({s_2}\).

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

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

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

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