Перечислимые языки — различия между версиями
Nafanya (обсуждение | вклад) |
AMaltsev (обсуждение | вклад) м |
||
Строка 24: | Строка 24: | ||
<tex> \Longrightarrow </tex>: | <tex> \Longrightarrow </tex>: | ||
− | Пусть <tex>L</tex> {{---}} перечислимый язык. Тогда для него существует программа <tex>g</tex>, которая по номеру <tex>i</tex> выводит слово из <tex>L</tex>. Значит, для всех <tex>x</tex> из <tex>L</tex> путем перебора значений функции <tex>g</tex> мы можем найти такое <tex>i</tex>, что <tex> g(i) = x</tex>. Следовательно, существует программа <tex>p</tex>, такая, что <tex>\forall x: x \in L \Leftrightarrow p(x)=1</tex>. Тогда <tex>L</tex> является полуразрешимым языком. | + | : Пусть <tex>L</tex> {{---}} перечислимый язык. Тогда для него существует программа <tex>g</tex>, которая по номеру <tex>i</tex> выводит слово из <tex>L</tex>. Значит, для всех <tex>x</tex> из <tex>L</tex> путем перебора значений функции <tex>g</tex> мы можем найти такое <tex>i</tex>, что <tex> g(i) = x</tex>. Следовательно, существует программа <tex>p</tex>, такая, что <tex>\forall x: x \in L \Leftrightarrow p(x)=1</tex>. Тогда <tex>L</tex> является полуразрешимым языком. |
<tex>{\bf p}</tex>(x): | <tex>{\bf p}</tex>(x): | ||
'''for''' <tex> i = 1 ~ .. ~ \infty</tex> | '''for''' <tex> i = 1 ~ .. ~ \infty</tex> | ||
Строка 32: | Строка 32: | ||
<tex> \Longleftarrow </tex>: | <tex> \Longleftarrow </tex>: | ||
− | Пусть <tex>L</tex> {{---}} полуразрешимый язык. Тогда для него существует программа <tex>p</tex>, результат которой равен <tex>1</tex> для любого слова из <tex>L</tex>. Чтобы программа <tex>p</tex> не зависала на словах, которые не принадлежат <tex>L</tex>, будем запускать ее с тайм-лимитом. Для поиска <tex>i</tex>-го слова из языка <tex>L</tex> будем перебирать <tex>k</tex> {{---}} тайм-лимит с которым будем запускать программу <tex>p</tex>. Таким образом существует программа <tex>g_0</tex>, которая выводит <tex>i</tex> слово языка <tex>L</tex> с повторениями. Для того, чтобы выводить слова без повторений, заведем множество <tex>U</tex>, в котором будем хранить уже выведенные слова. Программа <tex>g</tex> доказывает, что <tex>L</tex> является перечислимым языком. | + | :Пусть <tex>L</tex> {{---}} полуразрешимый язык. Тогда для него существует программа <tex>p</tex>, результат которой равен <tex>1</tex> для любого слова из <tex>L</tex>. Чтобы программа <tex>p</tex> не зависала на словах, которые не принадлежат <tex>L</tex>, будем запускать ее с тайм-лимитом. Для поиска <tex>i</tex>-го слова из языка <tex>L</tex> будем перебирать <tex>k</tex> {{---}} тайм-лимит с которым будем запускать программу <tex>p</tex>. Таким образом существует программа <tex>g_0</tex>, которая выводит <tex>i</tex> слово языка <tex>L</tex> с повторениями. Для того, чтобы выводить слова без повторений, заведем множество <tex>U</tex>, в котором будем хранить уже выведенные слова. Программа <tex>g</tex> доказывает, что <tex>L</tex> является перечислимым языком. |
− | <code> | + | : <code> |
<tex>{\bf g_0}</tex>(i): | <tex>{\bf g_0}</tex>(i): | ||
<tex>cnt = 0</tex> | <tex>cnt = 0</tex> |
Версия 18:46, 19 ноября 2016
Содержание
Основные определения
Определение: |
Полуразрешимый язык (англ. semi-decidable language) — язык, для которого существует программа
| такая, что
Определение: |
Перечислимый язык (англ. recursively enumerable language) — язык, для которого существует программа | такая, что . Язык называется коперечислимым (англ. co-enumerable), если — перечислимый. Класс всех перечислимых языков называется , а всех коперечислимих - .
Определение: |
Пусть имеется некоторая программа | , которая может либо завершиться за конечное время и что-то вернуть, либо зависнуть. Запуск программы с тайм-лимитом (англ. time limit) будем обозначать как и иметь в виду следующее: если за операций программа корректно завершилась и что-то вернула, то вернёт то же самое; если же за операций программа не успела завершиться, то вернёт (символ зависания).
Теорема: |
— перечислимый — полуразрешимый. |
Доказательство: |
:
(x): for if x return :
(i): for for if ++ if return
(i): for if ++ if return |
Теорема: |
Любой разрешимый язык является перечислимым. |
Доказательство: |
Любой разрешимый язык | является полуразрешимым. Так как любой полуразрешимый язык является перечислимым, то является перечислимым.
Теорема: |
— перечислим и коперечислим — |
Доказательство: |
Рассмотрим полуразрешители для | и и одновременно запустим их для одного и того же элемента . принадлежит либо , либо , поэтому один из полуразрешителей успешно отработает и не зависнет. Значит, мы за конечное время узнаем, лежит ли в или нет. Таким образом, мы построили разрешитель для , то есть — разрешимый.
Примеры перечислимых языков
Утверждение: |
Язык натуральных чисел перечислим. |
Приведём программу, перечисляющую язык натуральных чисел:
return i
|
Утверждение: |
Язык чётных неотрицательных чисел перечислим. |
Приведём программу, перечисляющую язык чётных неотрицательных чисел:
return i * 2
|
Примеры коперечислимых языков
Утверждение: |
Язык нечётных неотрицательных чисел коперечислим. |
- язык чётных неотрицательных чисел. Так как язык чётных неотрицательных чисел перечислим, то и язык нечётных неотрицательных чисел тоже перечислим. |
Примеры неперечислимых языков
Утверждение: |
Язык пар неперечислим. |
Функция busy beaver — невычислима, следовательно такой язык неперечислим. |
Источники информации
- Н. К. Верещагин, А. Шень. Лекции по математической логике и теории алгоритмов. Часть 3. Вычислимые функции. — М.: МЦНМО, 1999. С. 134. ISBN 5-900916-36-7
- Wikipedia — Recursively enumerable language
- Википедия — Рекурсивно перечислимый язык