Перечислимые языки — различия между версиями
AMaltsev (обсуждение | вклад) м |
AMaltsev (обсуждение | вклад) (пример коперечисл. языка + отформатирован псевдокод) |
||
| Строка 25: | Строка 25: | ||
: Пусть <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> является полуразрешимым языком. | ||
| − | + | ||
| − | '''for''' <tex> | + | <code> |
| − | '''if''' | + | '''function''' p(x: '''int'''): '''int''' |
| − | '''return''' | + | '''for''' i = 1 to <tex>\infty</tex> |
| + | '''if''' g(i) == x | ||
| + | '''return''' 1 | ||
<tex> \Longleftarrow </tex>: | <tex> \Longleftarrow </tex>: | ||
| − | + | </code> | |
:Пусть <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> | + | '''function''' <tex>g_0</tex>(i: '''int'''): '''int''' |
| − | + | cnt = 0 | |
| − | '''for''' <tex> | + | '''for''' k = 1 to <tex> \infty</tex> |
| − | '''for''' <tex> | + | '''for''' x <tex>\in \{x_1, x_2, .., x_k\}</tex> |
| − | '''if''' <tex> p|_k(x) == 1 | + | '''if''' <tex> p|_k</tex>(x) == 1 |
| − | + | cnt++ | |
| − | '''if''' | + | '''if''' cnt == i |
| − | '''return''' | + | '''return''' x |
</code> | </code> | ||
<code> | <code> | ||
| − | <tex> | + | '''function''' <tex>g</tex>(i: '''int'''): '''int''' |
<tex>U = \emptyset</tex> | <tex>U = \emptyset</tex> | ||
| − | '''for''' <tex> | + | '''for''' j = 1 to <tex>\infty</tex> |
| − | <tex> | + | x = <tex> g_0</tex>(j) |
| − | '''if''' <tex> | + | '''if''' x <tex>\notin</tex> U |
| − | + | cnt++ | |
| − | '''if''' | + | '''if''' cnt == i |
| − | '''return''' | + | '''return''' x |
| − | + | U.insert(x) | |
</code> | </code> | ||
}} | }} | ||
| Строка 79: | Строка 81: | ||
Приведём программу, перечисляющую язык натуральных чисел: | Приведём программу, перечисляющую язык натуральных чисел: | ||
<code> | <code> | ||
| − | + | '''function''' p(i: '''int'''): '''int''' | |
'''return''' i | '''return''' i | ||
</code> | </code> | ||
| Строка 92: | Строка 94: | ||
Приведём программу, перечисляющую язык чётных неотрицательных чисел: | Приведём программу, перечисляющую язык чётных неотрицательных чисел: | ||
<code> | <code> | ||
| − | + | '''function''' p(i: '''int'''): '''int''' | |
'''return''' i * 2 | '''return''' i * 2 | ||
</code> | </code> | ||
| Строка 108: | Строка 110: | ||
}} | }} | ||
| + | {{Утверждение | ||
| + | |id=st2 | ||
| + | |statement= | ||
| + | Язык простых чисел коперечислим. | ||
| + | |proof= | ||
| + | Пусть <tex>L</tex> - язык простых чисел, тогда <tex>\overline L</tex> - язык, состоящий из составных чисел и единицы. Покажем, что <tex>\overline L</tex> полуразрешим, а, следовательно, и перечислим согласно теореме, приведённой выше. | ||
| + | |||
| + | Построим простой полуразрешитель: | ||
| + | |||
| + | <code> | ||
| + | '''function''' p(n: '''int'''): '''int''' | ||
| + | '''for''' i = 2 to <tex>\sqrt{n}</tex> | ||
| + | '''if''' n mod i == 0 | ||
| + | '''return''' 0 | ||
| + | '''return''' 1 | ||
| + | </code> | ||
| + | }} | ||
| + | |||
== Примеры неперечислимых языков == | == Примеры неперечислимых языков == | ||
Версия 15:41, 20 ноября 2016
Содержание
Основные определения
| Определение: |
Полуразрешимый язык (англ. semi-decidable language) — язык, для которого существует программа такая, что
|
| Определение: |
| Перечислимый язык (англ. recursively enumerable language) — язык, для которого существует программа такая, что . Язык называется коперечислимым (англ. co-enumerable), если — перечислимый. Класс всех перечислимых языков называется , а всех коперечислимих - . |
| Определение: |
| Пусть имеется некоторая программа , которая может либо завершиться за конечное время и что-то вернуть, либо зависнуть. Запуск программы с тайм-лимитом (англ. time limit) будем обозначать как и иметь в виду следующее: если за операций программа корректно завершилась и что-то вернула, то вернёт то же самое; если же за операций программа не успела завершиться, то вернёт (символ зависания). |
| Теорема: |
— перечислимый — полуразрешимый. |
| Доказательство: |
|
:
function p(x: int): int
for i = 1 to
if g(i) == x
return 1
:
function (i: int): int cnt = 0 for k = 1 to for x if (x) == 1 cnt++ if cnt == i return x
function (i: int): int for j = 1 to x = (j) if x U cnt++ if cnt == i return x U.insert(x) |
| Теорема: |
Любой разрешимый язык является перечислимым. |
| Доказательство: |
| Любой разрешимый язык является полуразрешимым. Так как любой полуразрешимый язык является перечислимым, то является перечислимым. |
| Теорема: |
— перечислим и коперечислим — разрешим. |
| Доказательство: |
| Рассмотрим полуразрешители для и и одновременно запустим их для одного и того же элемента . принадлежит либо , либо , поэтому один из полуразрешителей успешно отработает и не зависнет. Значит, мы за конечное время узнаем, лежит ли в или нет. Таким образом, мы построили разрешитель для , то есть — разрешимый. |
Примеры перечислимых языков
| Утверждение: |
Язык натуральных чисел перечислим. |
|
Приведём программу, перечисляющую язык натуральных чисел:
function p(i: int): int return i |
| Утверждение: |
Язык чётных неотрицательных чисел перечислим. |
|
Приведём программу, перечисляющую язык чётных неотрицательных чисел:
function p(i: int): int return i * 2 |
Примеры коперечислимых языков
| Утверждение: |
Язык нечётных неотрицательных чисел коперечислим. |
| - язык чётных неотрицательных чисел. Так как язык чётных неотрицательных чисел перечислим, то и язык нечётных неотрицательных чисел тоже перечислим. |
| Утверждение: |
Язык простых чисел коперечислим. |
|
Пусть - язык простых чисел, тогда - язык, состоящий из составных чисел и единицы. Покажем, что полуразрешим, а, следовательно, и перечислим согласно теореме, приведённой выше. Построим простой полуразрешитель:
function p(n: int): int
for i = 2 to
if n mod i == 0
return 0
return 1
|
Примеры неперечислимых языков
| Утверждение: |
Язык пар неперечислим. |
| Функция busy beaver — невычислима, следовательно такой язык неперечислим. |
Источники информации
- Н. К. Верещагин, А. Шень. Лекции по математической логике и теории алгоритмов. Часть 3. Вычислимые функции. — М.: МЦНМО, 1999. С. 134. ISBN 5-900916-36-7
- Wikipedia — Recursively enumerable language
- Википедия — Рекурсивно перечислимый язык