Универсальные функции


 

Пусть F — некоторый класс функций от k переменных. Функцию U(n, x1, …, xk) от k + 1 переменных называют универсальной для класса F, если выполнимы условия:

а) для всякого n Î N0 выполняется

fn(x1, …, xk) = U(n, x1, …, xk) Î F;

б) для всякой f(x1, …, xk) Î F существует n Î N0 такое, что f(x1, …, xk) = U(n, x1, …, xk).

Теорема 15.4. Для класса Ч1 — одноместных частично рекурсивных функций существует универсальная частично рекурсивная функция U(n, x).

Доказательство. Определим U(n, x) = , точнее

U(n, x) = (15.1)

Данное соотношение определяет частичную функцию. Функция U(n, x) является частично рекурсивной. Действительно, для произвольных (n, x) нужно найти программу Pn (эффективная процедура) и применить Pn к начальной конфигурации (x, 0, …, 0, …). Если Pn ¯, то положить U(n, x) = r1, где r1 — содержимое регистра R1 в заключительной конфигурации. Если Pn ­, то считать значение U(n, x) неопределенным. По тезису Черча функция U(n, x) частично рекурсивна. Покажем, что функция U(n, x) универсальна. Поскольку U(n, x) частично рекурсивна, то и fn = U(n, x) для всякого n Î N0 частично рекурсивна, так как fn получена подстановкой константы вместо первого аргумента. Пусть теперь f(x) — произвольная одноместная частично рекурсивная функция. Тогда по доказанному она может быть вычислена некоторой МПД-программой Р. Пусть n = g(P). Следовательно, f = и значит f = U(n, x), что и требовалось доказать.

Следствие 15.5. Для всякого k ³ 1 существует частично рекурсивная функция Uk(n, x1, …, xk) универсальная для всех k-местных частично рекурсивных функций.

Это делается с использованием нумерационных функций. Полагаем

и так далее.

Покажем, например, что функция удовлетворяет нужным условиям. Во-первых, функция U2 — частично рекурсивна, так как является суперпозицией частично рекурсивных функций. Во-вторых, функция частично рекурсивна, так как получается из частично рекурсивной подстановкой константы. Пусть теперь f(x1, x2) — произвольная частично рекурсивная функция. Образуем функцию g(x) = f(l(x), r(x)), где l, r — нумерационные функции. Так как g(x) — частично рекурсивна, то существует n такое, что g(x) = U(n, x). Теперь положим x = p(x1, x2), и тогда имеем

f(x1, x2) = g(p(x1, x2)) = U(n, p(x1, x2)) = ,

что и требовалось доказать.

Представляет интерес вопрос о существовании универсальной функции для других рассмотренных выше классов Ч0 и Чпр — общерекурсивных и примитивно рекурсивных функций соответственно.

Теорема 15.6. Не существует общерекурсивной функции Uk(n, x1, …, xk), универсальной для класса Чk0k-местных общерекурсивных функций при любом k ³ 1.

Доказательство. Пусть, наоборот, существует такая функция Uk(n, x1, …, xk) для некоторого k. Образуем функцию f(x1, …, xk) == Uk(x1, x1, …, xk) + 1. Согласно свойству универсальности существует n0 такое, что

Uk(n0, x1, …, xk) = f(x1, …, xk) = Uk(x1, x1, …, xk) + 1.

Поскольку данные функции всюду определены, то они определены и при x1, x1 = … = xk = n0. Тогда получаем противоречивое равенство Uk(n0, n0, …, n0) = Uk(n0, n0, …, n0) + 1. Значит, предположение о существовании универсальной функции ложно, что и требовалось доказать.

В то же время справедлива следующая теорема.

Теорема 15.7. Для каждого k Î N класс всех k-местных примитивно рекурсивных функций имеет общерекурсивную универсальную функцию.

Доказательство данной теоремы приведено в [11, § 5].

Заметим, что из данной теоремы следует, что класс общерекурсивных функций шире класса примитивно рекурсивных функций, так как универсальная функция не может быть примитивно рекурсивной и является общерекурсивной.

Дадим еще одно применение универсальной функции. Пусть f:N0 à N0 — частичная функция. Функцию f0 будем называть доопределением f, если f0 всюду определена и совпадает с f в ее области определения. Покажем, что рассмотрение частичных вычислимых функций вызвано существом дела, а именно — существуют частичные вычислимые функции, любое доопределение которых делает их невычислимыми.

Теорема 15.8. Существует частично рекурсивная функция f(x), которая не может быть доопределена до общерекурсивной.

Доказательство. Рассмотрим функцию f(x) = , где U — универсальная функция. Данная фунция частично рекурсивна, так как она получается суперпозицией частично рекурсивных функций. Предположим, что существует общерекурсивная функция f0(x), которая является доопределением для f(x). По свойству универсальности U существует n такое, что f0(x) = U(n, x). Поскольку f0(x) всюду определена, то она определена при x = n, и тогда значение U(n, n) определено, и, следовательно, определено значение . Поскольку f0(x) есть доопределение f(x), то в области определения их значения должны совпадать. Поэтому имеем U(n, n) = f0(x). Однако последнее равенство дает противоречие, так как, если U(n, n) = 0, то , если U(n, n) ¹ 0, то . Значит, допущение о существовании рекурсивного доопределения для функции f(x) приводит к противоречию, что и требовалось доказать.

 


 

 

Л е к ц и я 16

 



Дата добавления: 2022-05-27; просмотров: 129;


Поиск по сайту:

Воспользовавшись поиском можно найти нужную информацию на сайте.

Поделитесь с друзьями:

Считаете данную информацию полезной, тогда расскажите друзьям в соц. сетях.
Poznayka.org - Познайка.Орг - 2016-2024 год. Материал предоставляется для ознакомительных и учебных целей.
Генерация страницы за: 0.009 сек.