Вычислимые функции — различия между версиями
м (→Примеры вычислимых функций) |
|||
| Строка 11: | Строка 11: | ||
''Замечание''<br/> | ''Замечание''<br/> | ||
Входами и выходами программ могут быть не только натуральные числа, но и двоичные строки, пары натуральных чисел, конечные последовательности слов и т.п. Поэтому аналогичным образом можно определить понятие вычислимой функции для счетных множеств. | Входами и выходами программ могут быть не только натуральные числа, но и двоичные строки, пары натуральных чисел, конечные последовательности слов и т.п. Поэтому аналогичным образом можно определить понятие вычислимой функции для счетных множеств. | ||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
{{Теорема | {{Теорема | ||
| Строка 28: | Строка 20: | ||
'''if''' a == x && f(a) == y | '''if''' a == x && f(a) == y | ||
'''then return''' 1 | '''then return''' 1 | ||
| − | Так как [[#D(f)|область определения вычислимой функции | + | Так как [[#D(f)|область определения вычислимой функции перечислима]], то можно перебрать элементы области определения. Если алгоритм нашел нужную нам пару, то вернуть 1.<br/> |
<tex>2 \Rightarrow 1</tex><br/> | <tex>2 \Rightarrow 1</tex><br/> | ||
Напишем программу, вычисляющую <tex>f</tex>. | Напишем программу, вычисляющую <tex>f</tex>. | ||
| Строка 37: | Строка 29: | ||
Так как <tex>F</tex> перечислимое множество, то можно перебрать элементы этого множества. | Так как <tex>F</tex> перечислимое множество, то можно перебрать элементы этого множества. | ||
}} | }} | ||
| + | |||
| + | === Примеры вычислимых функций === | ||
| + | * Нигде не определённая функция вычислима. | ||
| + | p(x) | ||
| + | '''return''' <tex>\bot</tex> | ||
| + | * <tex>f(x) = x^2</tex>, где <tex>x</tex> — рациональное число. | ||
| + | p(x) | ||
| + | '''return''' <tex>x^2</tex> | ||
== Свойства вычислимой функции == | == Свойства вычислимой функции == | ||
Версия 17:57, 10 декабря 2011
Содержание
Основные определения
| Определение: |
(1) Функция называется вычислимой, если существует программа, вычисляющая функцию . То есть существует такая программа, что:
|
| Определение: |
| (2) Функция называется вычислимой, если её график определено и равно является перечислимым множеством пар натуральных чисел. |
Замечание
Входами и выходами программ могут быть не только натуральные числа, но и двоичные строки, пары натуральных чисел, конечные последовательности слов и т.п. Поэтому аналогичным образом можно определить понятие вычислимой функции для счетных множеств.
| Теорема: |
Определения (1) и (2) эквивалентны. |
| Доказательство: |
|
p() for if a == x && f(a) == y then return 1 Так как область определения вычислимой функции перечислима, то можно перебрать элементы области определения. Если алгоритм нашел нужную нам пару, то вернуть 1. f(n)
for
if x == n
then return y
Так как перечислимое множество, то можно перебрать элементы этого множества. |
Примеры вычислимых функций
- Нигде не определённая функция вычислима.
p(x)
return
- , где — рациональное число.
p(x)
return
Свойства вычислимой функции
| Утверждение: |
— вычислимая функция. Тогда — перечислимое множество, где — область определения функции . |
|
Для доказательства достаточно написать полуразрешающую программу. p(x) f(x) return 1Если функция определена на входе , следовательно, . Тогда необходимо вернуть 1. Иначе программа зависнет при вызове . |
| Утверждение: |
— вычислимая функция. Тогда — перечислимое множество, где — область изменения функции ; |
|
Для доказательства достаточно написать полуразрешающую программу. p(x)
for
if x == f(y)
then return 1
Так как перечислимо, то можно перебрать элементы этого множества. Если программа находит слово, то она возвращает 1. |
| Утверждение: |
— вычислимая функция. — перечислимое множество, где — перечислимое множество. |
|
Для доказательства достаточно написать полуразрешающую программу. p(x)
for
if x == f(y)
then return 1
Из замкнутости перечислимых языков относительно операции пересечения следует, что элементы множества можно перебрать. Если программа находит слов, то она возвращает 1. |
| Утверждение: |
— вычислимая функция. — перечислимое множество, где — разрешимое множество. |
| Для доказательства достаточно написать полуразрешающую программу. |
| Утверждение: |
— вычислимая функция. — перечислимое множество, где — перечислимое множество. |
| Для доказательства достаточно написать полуразрешающую программу. |
Теорема об униформизации
| Теорема: |
Пусть — перечислимое множество пар натуральных чисел. Тогда существует вычислимая функция , определенная на тех и только тех , для которых найдется , при котором , причем значение является одним из таких . |
| Доказательство: |
|
Напишем программу, вычисляющую функцию . f(x)
for
if x == a
then return b
Так как множество перечислимо, то его элементы можно перебрать. |
Теорема о псевдообратной функции
| Теорема: |
Для любой вычислимой функции существует вычислимая функция , являющаяся псевдообратной в следующем смысле: , и при этом для всех , при которых определена. |
Литература
- Верещагин Н. К., Шень А. Лекции по математической логике и теории алгоритов. Часть 3. Вычислимые функции -- М.: МЦНМО, 1999 - С. 176