Теорема о рекурсии — различия между версиями

Материал из Викиконспекты
Перейти к: навигация, поиск
Строка 7: Строка 7:
 
|proof=
 
|proof=
 
Начнем с доказательства леммы.
 
Начнем с доказательства леммы.
{{Лемма
+
{{Утверждение
 
|id=st1
 
|id=st1
 
|statement= Пусть на натуральных числах задано отношение эквивалентности <tex>\equiv</tex>. Тогда следущие два утверждения не могут быть выполнены одновременно: <br>
 
|statement= Пусть на натуральных числах задано отношение эквивалентности <tex>\equiv</tex>. Тогда следущие два утверждения не могут быть выполнены одновременно: <br>
Строка 16: Строка 16:
 
Определим функцию <tex>f</tex> так: <tex>f(x)=U(x,x)</tex>. Заметим что никакая всюду вычислимая функция не отличается от <tex>f</tex> всюду. <br> Согласно первому утверждению найдется всюду определенное вычислимое <tex>\equiv</tex>-продолжение <tex>g</tex> функции <tex>f</tex>. <br> Определим функцию <tex>t</tex> так: <tex>t(x)=h(g(x))</tex>, где <tex>h</tex> - функция из второго утверждения. <br >Если <tex>f(x) \ne \perp</tex>, то <tex>f(x)=g(x) \ne h(g(x))=t(x)</tex>, т.е. <tex>f(x) \ne t(x)</tex>. Если <tex>f(x)= \perp</tex>, то <tex>f(x) \ne t(x)</tex>, т.к. <tex>t</tex> - всюду определена. Значит <tex>f</tex> всюду отлична от <tex>t</tex>, противоречие.
 
Определим функцию <tex>f</tex> так: <tex>f(x)=U(x,x)</tex>. Заметим что никакая всюду вычислимая функция не отличается от <tex>f</tex> всюду. <br> Согласно первому утверждению найдется всюду определенное вычислимое <tex>\equiv</tex>-продолжение <tex>g</tex> функции <tex>f</tex>. <br> Определим функцию <tex>t</tex> так: <tex>t(x)=h(g(x))</tex>, где <tex>h</tex> - функция из второго утверждения. <br >Если <tex>f(x) \ne \perp</tex>, то <tex>f(x)=g(x) \ne h(g(x))=t(x)</tex>, т.е. <tex>f(x) \ne t(x)</tex>. Если <tex>f(x)= \perp</tex>, то <tex>f(x) \ne t(x)</tex>, т.к. <tex>t</tex> - всюду определена. Значит <tex>f</tex> всюду отлична от <tex>t</tex>, противоречие.
 
}}
 
}}
 +
Теперь определим отношение <tex>\equiv</tex> так: <tex>x \equiv y \Leftrightarrow U_x = U_y</tex>. Покажем, что для него выполнено первое утверждение леммы. <br> Для заданной <tex>f</tex> определим <tex>V(n,x) = U(f(n), x)</tex>. <br> Так как <tex>U</tex> - универсальная функция, то найдется такая всюду определенная вычислимая <tex>s</tex>, что <tex>V(n,x) = U(s(n), x)</tex>. <br> Тогда  <tex>\forall x, n </tex> <tex>U(f(n), x) = U(s(n), x)</tex>, значит <tex>\forall n </tex> <tex> s(n) \equiv f(n)</tex>, то есть <tex>s</tex> - всюду определенное <tex>\equiv</tex>-продолжение <tex>f</tex>.
 +
Значит, для нашего отношения эквивалентности второе утверждение леммы не верно, то есть для любого вычислимого всюду определенного <tex>h</tex> <tex> \exists n</tex> такое что <tex>U_{h(n)} = U_n</tex>
 
}}
 
}}
  

Версия 10:42, 29 декабря 2011

Теорема о рекурсии

Теорема (О рекурсии):
Пусть [math]U[/math] - универсальная функция, [math]h[/math] - всюду определенная вычислимая функция. Тогда найдется такое [math]n[/math], что [math]U_n=U_{h(n)}[/math]
Доказательство:
[math]\triangleright[/math]

Начнем с доказательства леммы.

Утверждение:
Пусть на натуральных числах задано отношение эквивалентности [math]\equiv[/math]. Тогда следущие два утверждения не могут быть выполнены одновременно:
  • Пусть [math]f[/math] - вычислимая функция. Тогда существует всюду определенное вычислимое [math]\equiv[/math]-продолжение [math]g[/math] функции [math]f[/math], т.е. такая [math]g[/math] что [math]D(g)=N[/math] и [math]\forall x[/math] такого что [math]f(x) \ne \perp[/math] выполнено [math]f(x) \equiv g(x)[/math]
  • Найдется такая всюду определенная вычислимая [math]h[/math] что [math]\forall n [/math] [math]h(n) \not\equiv n[/math]
[math]\triangleright[/math]

От противного. Пусть оба утверждения выполнены.

Определим функцию [math]f[/math] так: [math]f(x)=U(x,x)[/math]. Заметим что никакая всюду вычислимая функция не отличается от [math]f[/math] всюду.
Согласно первому утверждению найдется всюду определенное вычислимое [math]\equiv[/math]-продолжение [math]g[/math] функции [math]f[/math].
Определим функцию [math]t[/math] так: [math]t(x)=h(g(x))[/math], где [math]h[/math] - функция из второго утверждения.
Если [math]f(x) \ne \perp[/math], то [math]f(x)=g(x) \ne h(g(x))=t(x)[/math], т.е. [math]f(x) \ne t(x)[/math]. Если [math]f(x)= \perp[/math], то [math]f(x) \ne t(x)[/math], т.к. [math]t[/math] - всюду определена. Значит [math]f[/math] всюду отлична от [math]t[/math], противоречие.
[math]\triangleleft[/math]

Теперь определим отношение [math]\equiv[/math] так: [math]x \equiv y \Leftrightarrow U_x = U_y[/math]. Покажем, что для него выполнено первое утверждение леммы.
Для заданной [math]f[/math] определим [math]V(n,x) = U(f(n), x)[/math].
Так как [math]U[/math] - универсальная функция, то найдется такая всюду определенная вычислимая [math]s[/math], что [math]V(n,x) = U(s(n), x)[/math].
Тогда [math]\forall x, n [/math] [math]U(f(n), x) = U(s(n), x)[/math], значит [math]\forall n [/math] [math] s(n) \equiv f(n)[/math], то есть [math]s[/math] - всюду определенное [math]\equiv[/math]-продолжение [math]f[/math].

Значит, для нашего отношения эквивалентности второе утверждение леммы не верно, то есть для любого вычислимого всюду определенного [math]h[/math] [math] \exists n[/math] такое что [math]U_{h(n)} = U_n[/math]
[math]\triangleleft[/math]


Источники

Н. К. Верещагин, А. Шень. Лекции по математической логике и теории алгоритмов. Часть 3. Вычислимые функции. -- М.: МЦНМО, 1999