跳转至

Problems That Are Not Recursive

Examples

1. The Halting Problem

Proof 1

1

Proof 2

\(A_{TM} = \{<M, w>|M\text{ is a TM and M accepts w}\}\)

  • \(A_{TM}\) is not recursive

Construct a TM \(M^*\ H_{TM}\) to solve \(A_{TM}\):

\(H_{TM} = {<M, w>|M\text{ is a TM and M halts on w}}\)

\(M^* =\) On input x:

  1. run M on w
  2. If M accepts w, accept
  3. If M rejects w, reject
  4. If M loops on w, \(M^*\) is looping on w

Suppose \(M^*\) is a recursive TM, then we can construct a TM \(M_{H}\) to decide \(H_{TM}\):

\(M_{A} =\) On input :

  1. Construct a TM \(M^*\) as above using M
  2. Run \(M_{H}\) on \(M^*\), w
  3. If \(M_{H}\) accepts, accept
  4. If \(M_{H}\) rejects, reject

If all this is true, then \(M_A\) can decide \(A_{TM}\)

  • But \(A_{TM}\) is not recursive
  • So \(M^*\) is not recursive
  • So the halting problem is not recursive

1. \(L = \{"M"|\text{M is a TM that accepts e}\}\) is not recursive

  • Use \(A_{TM}\) to prove this

A Turing machine \(M\) accepts \(w\) if and only if \(M^*\) accepts \(e\)

\(M^* =\) On input x:

  1. Run M on w
  2. If M accepts w, accept
  3. If M rejects w, reject

If M accepts w, then \(M^*\) accepts all inputs, including e

If M rejects or loops on w, then \(M^*\) rejects all inputs, including e

Suppose \(L\) is recursive, then we can construct a TM \(M_{L}\) to decide \(L\):

\(M_{A} =\) On input :

  1. Construct a TM \(M^*\) as above using M
  2. Run \(M_{L}\) on \(M^*\), w
  3. If \(M_{L}\) accepts, accept
  4. If \(M_{L}\) rejects, reject

If all this is true, then \(M_A\) can decide \(A_{TM}\)

  • But \(A_{TM}\) is not recursive
  • So \(M_L\) is not recursive
  • So \(L\) is not recursive

2. \(L_2 = \{"M"|\text{M is a TM that accepts all strings}\}\) is not recursive

  • Same as above

A Turing Machine accepts w if and only if \(M^*\) accepts all strings

3. \(L_3 = \{"M1, M2"|\text{M1 and M2 accept the same set of strings}\}\) is not recursive

Suppose that \(L_3\) is recursive, \(\exist M_3\) that decides \(L_3\)

Use \(M_3\) to construct \(M_2\) that deides \(L_2\)

\(M_2\) = on input "M"

  1. construct \(M_E\) as follows: \(M_E\) = on input x
    1. Accept
  2. Run \(M_3\) on "\(M\)","\(M_E\)" -- check whether \(M\) and \(M_E\) accepts the same set of strings
  3. If \(M_3\) accepts, accepts \(M\)
  4. If \(M_3\) rejects, rejects \(M\)

So \(M_2\) decides \(L_2\) but \(L_2\) is not recursive

4. \(L_4 = \{"M"|\text{M is a TM with L(M) is regular}\}\) is not recursive

Proof: \(L_4\) is not recursive

Suppose that \(L_4\) is recursive, \(\exist M_4\) that decides \(L_4\)

  1. Construction of \( M^* \): - Define a modified Turing machine \( M^* \) which takes two inputs: a string \( w \) and a separate input \( x \). - \( M^* \) operates as follows: On input x
    1. It first runs \( M \) on \( w \).
    2. If \( M \) accepts on \( w \), \( M^* \) then runs a universal Turing machine \( U \) on \( x \).
      1. If U accepts,accept
      2. If U rejects, reject
    3. If \( M \) does not halt on \( w \), \( M^* \) does nothing (or rejects all inputs).

Universal Turing Machine U : On input : 1. Run M on w 2. If M accepts w, accept 3. else reject

  1. Language of \( M^* \): The language \( L(M^*) \) is constructed so that:
  • \( L(M^*) \) is non-empty if \( M \) accepts \( w \).
  • \( L(M^*) \) = \(L(U)\) = \(A_{TM}\) Not regular/Not Context-Free /Not Recursive
  • \( L(M^*) = \emptyset \) if \( M \) does not accept \( w \). -- Regular/Contex-Free/Recursive
  1. Conclusion:
  • If \( L(M^*) \) is non-regular, it implies that \( M \) accepts \( w \).
  • If \( L(M^*) \) is regular, then \( M \) does not accept \( w \).
  • Since determining whether \( L(M^*) \) is regular would solve the Halting Problem, it follows that \( R_{TM} \) is undecidable.

The undecidability of \( R_{TM} = \{ \langle M \rangle : M \text{ is a Turing machine with } L(M) \text{ regular} \} \) (i.e., determining if a Turing machine \( M \) has a regular language \( L(M) \)) stems from the fact that if we could decide \( R_{TM} \), we could also decide the Halting Problem, which is known to be undecidable.

4.1. \(L_5 = \{"M"|\text{M is a TM with L(M) is context-free}\}\) is not recursive

4.2. \(L_6 = \{"M"|\text{M is a TM with L(M) is recursive}\}\) is not recursive

Rice's Theorem

\(All_{PDA}\) is not recursive

\(All_{PDA} = \{<M>|M\text{ is a PDA and }L(M) = \Sigma^*\}\)

  • Turn into proving \(NOTAll_{PDA} = \{<M>|M\text{ is a PDA and }L(M) \neq \Sigma^*\}\) is not recursive

Construct a TM \(M\) to solve \(NOTAll_{PDA}\): * M halts on w if and only if \(L(P) \neq \Sigma^*\)

2

  • Turn the computing history of M that halts on w to a string

Construct P accepts all strings that are not computing history of M that halts on w.

  • Given a string \(C_1\#C_2\#...\#C_k\), where \(C_i\) is a configuration.
  • The string is not a computing history of M if: 1. \(C_1\) is not the start configuration of M 2. \(C_k\) is not the accept configuration of M 3. There exists \(C_i\) and \(C_{i+1}\) such that \(C_i\) does not lead to \(C_{i+1}\)

3

If \(NOTAll_{PDA}\) is recursive, then \(H_{TM}\) is recursive, which is not true.

Reduction

Let A, B be two languages, A reduces to B if there is a computable function f \(\Sigma^* \to \Sigma^*\) such that:

\(x \in A \Leftrightarrow f(x) \in B\)

Lemma 1

Suppose \(\exist f\) that reduces A to B:

  1. If B is recursive, then A is recursive
  • B is recursive, then we can construct a TM \(M_B\) to decide B
  • \(\exist f\) that reduces A to B
  • \(M_A\) = On input x: 1. Compute f(x) 2. Run \(M_B\) on f(x) 3. If \(M_B\) accepts, accept 4. If \(M_B\) rejects, reject
  1. If A is not recursive, then B is not recursive
  • If B is recursive, then A is recursive, which is not true(Clearly)


最后更新: 2025年1月5日 20:29:34
创建日期: 2024年11月11日 23:05:25