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_1},{n_2}} \right) = {n_2} - {n_1}\) if \({n_2} \ge {n_1}\) and \(f\left( {{n_1},{n_2}} \right) = 0\) if \({n_2} < {n_1}\)

Short Answer

Expert verified

Constructed Turning machine is:

\(\begin{array}{l}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_1},B,R} \right),\left( {{s_0},*,{s_5},1,R} \right),\left( {{s_1},1,{s_1},1,R} \right),\left( {{s_1},*,{s_1},*,R} \right),\\\left( {{s_1},B,{s_2},B,L} \right),\left( {{s_2},1,{s_3},B,L} \right),\left( {{s_2},*,{s_4},B,L} \right),\left( {{s_3},1,{s_3},1,L} \right),\\\left( {{s_3},*,{s_3},*,L} \right),\left( {{s_3},B,{s_0},B,R} \right),\left( {{s_4},1,{s_5},B,L} \right),\left( {{s_4},B,{s_5},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 \(S \times I\) to \(S \times I \times {\rm{\{ }}R,L{\rm{\} }}\), and a starting state \({s_0}\).

02

Finding the six states

A Turing machine \(T = \left( {S,I,f,{s_0}} \right)\) contains a finite set \(S\) of states, an alphabet \(I\) containing the blank symbol \(B\), a starting state \({s_0}\) and a partial function from \(S \times I\) to \(S \times I \times {\rm{\{ }}R,L{\rm{\} }}\). Note: The partial function \(f\) is often represented as \(5\)-tuples.

The integer \(n\) will be represented by \(n + 1\) zeros. The input \(\left( {{n_1},{n_2}} \right)\) will then be represented by \({n_1}\), \(1's\), followed by an asterisk \({\bf{*}}\), followed by a string of \({n_2} + 1\) ones.

You will require \(6\) states \({s_0},{s_1}, \ldots .{s_6}\) ( \({s_0}\) 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\}\)

03

Scanning

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

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

Next, define the partial function as five tuples.

Start by changing the first \(1\) of the string corresponding to \({n_1}\) by a blank \(B\). Then you move to the next state \({s_2}\) and to the position to the right on the tape.

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

Next, scan to the right until obtained the first blank \(B\) (which thus signifies the end of the input and the end of the string corresponding to \({n_2}\)). Once find the blank, moving to state \({s_2}\).

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

04

Constructing the Turning machine

When at the state \({s_2}\), then at the last \(1\) of the string corresponding to \({s_2}\). Then change this \(1\) to a blank \(B\) and move to state \({s_3}\).

However, if an \(*\) instead of a \(I\), then this means that \({n_2} < {n_1}\) and then move to state \({s_4}\) (while removing the \(*\) symbol) \(\left( {{s_2},1,{s_3},B,L} \right),\left( {{s_2},*,{s_4},B,L} \right)\)

Once at the state \({s_3}\), then removed the first \(1\) of the string corresponding to \({n_1}\) and the last \(1\) of the string corresponding to \({n_2}\). Then scan to the left until you obtain a blank \(B\), which will represent the beginning of the input. Then move to state \({s_0}\) such that repeating the procedure of removing the first and last \(1\) until one of the strings are empty.

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

If returned to state \({s_0}\) then at the beginning of the string corresponding to \({n_1}\). However, it is possible that this string no longer contains any \(1's\). If this is the case, the current symbol is \({\bf{*}}\). Then change this symbol to a \(1\) (such that you have \({n_2} - {n_1} + 1\) ones remaining) and move to the final state \({s_5}\).

\(\left( {{s_0},*,{s_5},1,R} \right)\)

05

Constructing the Turning machine

When you are at state \({s_4}\), then you know that \({n_2} < {n_1}\). The algorithm needs to return \(0\), which is represented by a single l, thus you then need to change all l's to a blank \(B\) (while all the l's are to the left of the current position). Once you arrive at the first blank \(B\), all l's were changed to blanks \(B\) and you then change the input to \(1\) while moving to the final state \({s_5}\) (such that the output is a single \(1\)).

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

You do not add any five-tuples with \({s_5}\) as its first coordinate such that the machine halts when at the final state \({s_5}\).

Therefore, the constructed Turning machine is:

\(\begin{array}{l}{\bf{T = }}\left( {{\bf{S,I,f,}}{{\bf{s}}_{\bf{0}}}} \right){\bf{,S = }}\left\{ {{{\bf{s}}_{\bf{0}}}{\bf{,}}{{\bf{s}}_{\bf{1}}}{\bf{,}}{{\bf{s}}_{\bf{2}}}{\bf{,}}{{\bf{s}}_{\bf{3}}}{\bf{,}}{{\bf{s}}_{\bf{4}}}{\bf{,}}{{\bf{s}}_{\bf{5}}}{\bf{,}}{{\bf{s}}_{\bf{6}}}} \right\}{\bf{,I = \{ 0,1,B\} ,}}\\\left( {{{\bf{s}}_{\bf{0}}}{\bf{,1,}}{{\bf{s}}_{\bf{1}}}{\bf{,B,R}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{0}}}{\bf{,*,}}{{\bf{s}}_{\bf{5}}}{\bf{,1,R}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{1}}}{\bf{,1,}}{{\bf{s}}_{\bf{1}}}{\bf{,1,R}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{1}}}{\bf{,*,}}{{\bf{s}}_{\bf{1}}}{\bf{,*,R}}} \right){\bf{,}}\\\left( {{{\bf{s}}_{\bf{1}}}{\bf{,B,}}{{\bf{s}}_{\bf{2}}}{\bf{,B,L}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{2}}}{\bf{,1,}}{{\bf{s}}_{\bf{3}}}{\bf{,B,L}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{2}}}{\bf{,*,}}{{\bf{s}}_{\bf{4}}}{\bf{,B,L}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{3}}}{\bf{,1,}}{{\bf{s}}_{\bf{3}}}{\bf{,1,L}}} \right){\bf{,}}\\\left( {{{\bf{s}}_{\bf{3}}}{\bf{,*,}}{{\bf{s}}_{\bf{3}}}{\bf{,*,L}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{3}}}{\bf{,B,}}{{\bf{s}}_{\bf{0}}}{\bf{,B,R}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{4}}}{\bf{,1,}}{{\bf{s}}_{\bf{5}}}{\bf{,B,L}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{4}}}{\bf{,B,}}{{\bf{s}}_{\bf{5}}}{\bf{,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

Give production rules in Backusโ€“Naur form that generate all identifiers in the C programming language. In โ€˜Cโ€™ an identifier starts with a letter or an underscore (_) that is followed by one or more lowercase letters, uppercase letters, underscores, and digits.

Several extensions to Backusโ€“Naur form are commonly used to define phrase-structure grammars. In one such extension, a question mark (?) indicates that the symbol, or group of symbols inside parentheses, to its left can appear zero or once (that is, it is optional), an asterisk (*) indicates that the symbol to its left can appear zero or more times, and a plus (+) indicates that the symbol to its left can appear one or more times. These extensions are part of extended Backusโ€“Naur form (EBNF), and the symbols?, *, and + are called metacharacters. In EBNF the brackets used to denote nonterminal are usually not shown.

Describe how productions for a grammar in extended Backusโ€“Naur form can be translated into a set of productions for the grammar in Backusโ€“Naur form.

This is the Backusโ€“Naur form that describes the syntax of expressions in postfix (or reverse Polish) notation.

\(\begin{array}{c}\left\langle {{\bf{expression}}} \right\rangle {\bf{ :: = }}\left\langle {{\bf{term}}} \right\rangle {\bf{|}}\left\langle {{\bf{term}}} \right\rangle \left\langle {{\bf{term}}} \right\rangle \left\langle {{\bf{addOperator}}} \right\rangle \\{\bf{ }}\left\langle {{\bf{addOperator}}} \right\rangle {\bf{:: = + | - }}\\\left\langle {{\bf{term}}} \right\rangle {\bf{:: = }}\left\langle {{\bf{factor}}} \right\rangle {\bf{|}}\left\langle {{\bf{factor}}} \right\rangle \left\langle {{\bf{factor}}} \right\rangle \left\langle {{\bf{mulOperator}}} \right\rangle {\bf{ }}\\\left\langle {{\bf{mulOperator}}} \right\rangle {\bf{:: = *|/}}\\\left\langle {{\bf{factor}}} \right\rangle {\bf{:: = }}\left\langle {{\bf{identifier}}} \right\rangle {\bf{|}}\left\langle {{\bf{expression }}} \right\rangle \\\left\langle {{\bf{identifier}}} \right\rangle {\bf{:: = a }}\left| {{\bf{ b }}} \right|...{\bf{| z}}\end{array}\)

Give production rules in extended Backusโ€“Naur form for identifiers in the C programming language (see Exercise 33).

Let A = {0, 11} and B = {00, 01}. Find each of these sets.

a) AB b) BA c) \({{\bf{A}}^{\bf{2}}}\)d) \({{\bf{B}}^{\bf{3}}}\)

Determine whether all the strings in each of these sets are recognized by the deterministic finite-state automaton in Figure 1.

a){0}* b){0} {0}* c){1} {0}*

d){01}* e){0}*{1}* f){1} {0,1}*

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