Перечислимые языки
Версия от 18:29, 24 января 2012; Roman Kolganov (обсуждение | вклад)
Определение: |
Полуразрешимый язык — язык, для которого существует программа | такая, что .
Определение: |
Перечислимый язык — язык, для которого существует программа | такая, что .
Определение: |
Пусть имеется некоторая программа | , которая может либо завершиться за конечное время и что-то вернуть, либо зависнуть. Запуск программы с тайм-лимитом будем обозначать как и иметь в виду следующее: если за операций программа корректно завершилась и что-то вернула, то вернёт то же самое; если же за операций программа не успела завершиться, то вернёт (символ зависания).
Теорема: |
— перечислимый — полуразрешимый. |
Доказательство: |
Пусть — перечислимый язык. Тогда для него существует программа , которая по номеру выводит слово из . Значит, для всех из путем перебора значений функции мы можем найти такое , что . Следовательно, существует программа , такая, что . Тогда является полуразрешимым языком.for if return Пусть — полуразрешимый язык. Тогда для него существует программа , результат которой равен для любого слова из . Чтобы программа не зависала на словах, которые не принадлежат , будем запускать ее с тайм-лимитом. Для поиска -го слова из языка будем перебирать — тайм-лимит с которым будем запускать программу . Таким образом существует программа , которая выводит слово языка с повторениями. Для того, чтобы выводить слова без повторений, заведем множество , в котором будем хранить уже выведенные слова. Программа доказывает, что является перечислимым языком.Приведённые программы доказывают эквивалентность определений. for for if ++ if return for if ++ if return |
Теорема: |
Любой разрешимый язык является перечислимым. |
Доказательство: |
Любой разрешимый язык | является полуразрешимым. Так как любой полуразрешимый язык является перечислимым, то является перечислимым.
Литература
- Н. К. Верещагин, А. Шень. Лекции по математической логике и теории алгоритмов. Часть 3. Вычислимые функции. — М.: МЦНМО, 1999. С. 134. ISBN 5-900916-36-7