Главные нумерации — различия между версиями
Haliullin (обсуждение | вклад) (Новая страница: «В этом разделе равенство двух вычислимых функций при заданных аргументах понимается в то…») |
Haliullin (обсуждение | вклад) м |
||
Строка 2: | Строка 2: | ||
{{Теорема | {{Теорема | ||
|statement=Существует универсальная функция | |statement=Существует универсальная функция | ||
− | |proof=Зафиксируем какой-либо язык программирования. Пусть программами на этом языке являются слова над алфавитом <tex>\Sigma</tex>. Программа будет иметь номер <tex>n</tex>, если ее код - <tex>n</tex>-е слово среди всех слов над алфавитом <tex>\Sigma</tex>, отсортированных сначала по возрастанию длины, а при равной длине - в лексикографическом порядке. При этом если <tex>n</tex>-я программа не компилируется, будем считать, что она всегда зависает. Рассмотрим функцию <tex>U(n,x):\mathbb{N}\times\mathbb{N}\rightarrow\mathbb{N}\cup\perp</tex> такую, что <tex>U(n,x)=p_n(x)</tex>, где <tex>p_n</tex> - <tex>n</tex>-я программа. Заметим, что по определению вычислимой функции существует программа, вычисляющая ее. Но в заданной нумерации у любой программы есть номер. Таким образом для любой вычислимой функции <tex>f</tex> существует номер <tex>n: U(n,x)=f(x)</tex>. И наоборот - <tex>f_n=U(n)</tex> - является вычислимой функцией. Вычисляющая программа содержит интерпретатор для зафиксированного языка программирования, по номеру программы (первый аргумент) восстанавливает ее код, и передает ей второй аргумент, возвращая результат ее работы. | + | |proof=Зафиксируем какой-либо язык программирования. Пусть программами на этом языке являются слова над алфавитом <tex>\Sigma</tex>. Программа будет иметь номер <tex>n</tex>, если ее код - <tex>n</tex>-е слово среди всех слов над алфавитом <tex>\Sigma</tex>, отсортированных сначала по возрастанию длины, а при равной длине - в лексикографическом порядке. При этом если <tex>n</tex>-я программа не компилируется, будем считать, что она всегда зависает. Рассмотрим функцию <tex>U(n,x):\mathbb{N}\times\mathbb{N}\rightarrow\mathbb{N}\cup\perp</tex> такую, что <tex>U(n,x)=p_n(x)</tex>, где <tex>p_n</tex> - <tex>n</tex>-я программа. Заметим, что по определению вычислимой функции существует программа, вычисляющая ее. Но в заданной нумерации у любой программы есть номер. Таким образом для любой вычислимой функции <tex>f</tex> существует номер <tex>n: U(n,x)=f(x)</tex>. И наоборот - <tex>f_n=U(n)</tex> - является вычислимой функцией. Вычисляющая программа для <tex>U</tex> содержит интерпретатор для зафиксированного языка программирования, по номеру программы (первый аргумент) восстанавливает ее код, и передает ей второй аргумент, возвращая результат ее работы. Таким образом <tex>U_n(x)=U(n,x)</tex> - вычислима для любого <tex>n\in\mathbb{N}</tex>, и <tex>\forall f(x) \exists n\in\mathbb{N}: f(x)=U(n,x)</tex>, <tex>f(x)</tex> - вычислима, значит U(n,x) - универсальная функция. |
}} | }} | ||
Рассмотрим двуместную универсальную функцию <tex>U(n,x)</tex>. Будем говорить, что она задает нумерацию для класса одноместных функций следующим образом: <tex>f_n(x)=U(n,x)</tex>. | Рассмотрим двуместную универсальную функцию <tex>U(n,x)</tex>. Будем говорить, что она задает нумерацию для класса одноместных функций следующим образом: <tex>f_n(x)=U(n,x)</tex>. |
Версия 20:39, 9 декабря 2010
В этом разделе равенство двух вычислимых функций при заданных аргументах понимается в том смысле, что при этих аргументах вычисляющие программы для этих функций зависают, либо равны значения, возвращаемые ими.
Теорема: |
Существует универсальная функция |
Доказательство: |
Зафиксируем какой-либо язык программирования. Пусть программами на этом языке являются слова над алфавитом | . Программа будет иметь номер , если ее код - -е слово среди всех слов над алфавитом , отсортированных сначала по возрастанию длины, а при равной длине - в лексикографическом порядке. При этом если -я программа не компилируется, будем считать, что она всегда зависает. Рассмотрим функцию такую, что , где - -я программа. Заметим, что по определению вычислимой функции существует программа, вычисляющая ее. Но в заданной нумерации у любой программы есть номер. Таким образом для любой вычислимой функции существует номер . И наоборот - - является вычислимой функцией. Вычисляющая программа для содержит интерпретатор для зафиксированного языка программирования, по номеру программы (первый аргумент) восстанавливает ее код, и передает ей второй аргумент, возвращая результат ее работы. Таким образом - вычислима для любого , и , - вычислима, значит U(n,x) - универсальная функция.
Рассмотрим двуместную универсальную функцию
. Будем говорить, что она задает нумерацию для класса одноместных функций следующим образом: .Определение: |
Нумерация, заданная двуместной универсальной функцией | называется главной (Гёделевой), если для любой двуместной вычислимой функции существует вычислимая, всюду определенная функция такая, что .
Теорема: |
Существует главная нумерация. |
Доказательство: |
Рассмотрим универсальную функцию, построенную ранее, и нумерацию, соответствующую ей. Обозначим программу, вычисляющую функцию | как . Построим программу (назовем ее ) с одним параметром - , которая генерирует код программы , но с фиксированным , и возвращает ее номер в заданной нумерации. Построенная программа вычисляет искомую функцию для универсальной двуместной функции и двуместной функции , то есть , где - функция, вычисляемая программой . Из вычислимости следует существование , и за конечное время мы можем вернуть номер любой программы в выбранной нумерации. Таким образом - вычислимая, всюду определенная.