Перечислимые языки — различия между версиями
Nafanya (обсуждение | вклад) |
|||
Строка 1: | Строка 1: | ||
+ | == Основные определения == | ||
{{Определение | {{Определение | ||
|definition = | |definition = | ||
− | '''Полуразрешимый язык''' ( | + | '''Полуразрешимый язык''' (англ. ''semi-decidable language'') {{---}} язык, для которого существует программа <tex>p</tex> такая, что |
+ | * <tex>\forall x \in L \Leftrightarrow p(x)=1</tex>, | ||
+ | * <tex>\forall x \notin L \Leftrightarrow p(x)=0</tex> или зависнет. | ||
}} | }} | ||
{{Определение | {{Определение | ||
|definition = | |definition = | ||
− | '''Перечислимый язык''' ( | + | '''Перечислимый язык''' (англ. ''recursively enumerable language'') {{---}} язык, для которого существует программа <tex>g</tex> такая, что <tex>g(i) = x_i, L = \{x_1, x_2, .., x_n, ..\}</tex>. Язык <tex>L</tex> называется '''коперечислимым''' (англ. ''co-enumerable''), если <tex>\overline L</tex> {{---}} перечислимый. Класс всех перечислимых языков называется <tex> \mathrm{RE} </tex>, а всех коперечислимих <tex> \mathrm{co}</tex>-<tex>\mathrm{RE}</tex> . |
}} | }} | ||
{{Определение | {{Определение | ||
|definition = | |definition = | ||
− | Пусть имеется некоторая программа <tex>p</tex>, которая может либо завершиться за конечное время и что-то вернуть, либо зависнуть. Запуск программы <tex>p</tex> с '''тайм-лимитом''' ( | + | Пусть имеется некоторая программа <tex>p</tex>, которая может либо завершиться за конечное время и что-то вернуть, либо зависнуть. Запуск программы <tex>p</tex> с '''тайм-лимитом''' (англ. ''time limit'') <tex>TL</tex> будем обозначать как <tex>p|_{TL}</tex> и иметь в виду следующее: если за <tex>TL</tex> операций программа <tex>p</tex> корректно завершилась и что-то вернула, то <tex>p|_{TL}</tex> вернёт то же самое; если же за <tex>TL</tex> операций программа <tex>p</tex> не успела завершиться, то <tex>p|_{TL}</tex> вернёт <tex>\bot</tex> (символ зависания). |
}} | }} | ||
Строка 19: | Строка 22: | ||
<tex>L</tex> {{---}} перечислимый <tex>\Leftrightarrow L</tex> {{---}} полуразрешимый. | <tex>L</tex> {{---}} перечислимый <tex>\Leftrightarrow L</tex> {{---}} полуразрешимый. | ||
|proof= | |proof= | ||
+ | <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>p(x): | + | <tex>{\bf p}</tex>(x): |
− | for <tex> i = 1 ~ .. ~ \infty</tex> | + | '''for''' <tex> i = 1 ~ .. ~ \infty</tex> |
− | if <tex> g(i) == | + | '''if''' <tex> g(i) == </tex>x |
− | return <tex> 1</tex> | + | '''return''' <tex> 1</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> является перечислимым языком. | ||
− | <tex>g_0(i): | + | <code> |
+ | <tex>{\bf g_0}</tex>(i): | ||
<tex>cnt = 0</tex> | <tex>cnt = 0</tex> | ||
− | for <tex> k = 1 ~ .. ~ \infty</tex> | + | '''for''' <tex> k = 1 ~ .. ~ \infty</tex> |
− | for <tex> x \in \{x_1, x_2, .., x_k\}</tex> | + | '''for''' <tex> x \in \{x_1, x_2, .., x_k\}</tex> |
− | if <tex> p|_k(x) == 1</tex> | + | '''if''' <tex> p|_k(x) == 1</tex> |
<tex>cnt</tex>++ | <tex>cnt</tex>++ | ||
− | if <tex> cnt == i</tex> | + | '''if''' <tex> cnt == i</tex> |
− | return <tex> x</tex> | + | '''return''' <tex> x</tex> |
− | <tex>g(i): | + | </code> |
+ | <code> | ||
+ | <tex>{\bf g}</tex>(i): | ||
<tex>U = \emptyset</tex> | <tex>U = \emptyset</tex> | ||
− | for <tex> j = 1 ~ .. ~ \infty</tex> | + | '''for''' <tex> j = 1 ~ .. ~ \infty</tex> |
− | <tex>x = g_0(j)</tex> | + | <tex>x = {\bf g_0}(j)</tex> |
− | if <tex> x \notin U</tex> | + | '''if''' <tex> x \notin U</tex> |
<tex>cnt</tex>++ | <tex>cnt</tex>++ | ||
− | if <tex> cnt == i</tex> | + | '''if''' <tex> cnt == i</tex> |
− | return <tex> x</tex> | + | '''return''' <tex> x</tex> |
<tex>U.insert(x)</tex> | <tex>U.insert(x)</tex> | ||
− | + | </code> | |
− | |||
}} | }} | ||
Строка 59: | Строка 69: | ||
|proof= | |proof= | ||
Рассмотрим полуразрешители для <tex>L</tex> и <tex>\overline L</tex> и одновременно запустим их для одного и того же элемента <tex>x</tex>. <tex>x</tex> принадлежит либо <tex> L </tex>, либо <tex>\overline{L}</tex>, поэтому один из полуразрешителей успешно отработает и не зависнет. Значит, мы за конечное время узнаем, лежит ли <tex>x</tex> в <tex>L</tex> или нет. Таким образом, мы построили разрешитель для <tex>L</tex>, то есть <tex>L</tex> {{---}} разрешимый. | Рассмотрим полуразрешители для <tex>L</tex> и <tex>\overline L</tex> и одновременно запустим их для одного и того же элемента <tex>x</tex>. <tex>x</tex> принадлежит либо <tex> L </tex>, либо <tex>\overline{L}</tex>, поэтому один из полуразрешителей успешно отработает и не зависнет. Значит, мы за конечное время узнаем, лежит ли <tex>x</tex> в <tex>L</tex> или нет. Таким образом, мы построили разрешитель для <tex>L</tex>, то есть <tex>L</tex> {{---}} разрешимый. | ||
+ | }} | ||
+ | == Примеры перечислимых языков == | ||
+ | |||
+ | {{Утверждение | ||
+ | |id=st1 | ||
+ | |statement= | ||
+ | Язык натуральных чисел перечислим. | ||
+ | |proof= | ||
+ | Приведём программу, перечисляющую язык натуральных чисел: | ||
+ | <code> | ||
+ | <tex>p(i) {:} </tex> | ||
+ | '''return''' i | ||
+ | </code> | ||
+ | |||
+ | }} | ||
+ | |||
+ | {{Утверждение | ||
+ | |id=st2 | ||
+ | |statement= | ||
+ | Язык чётных неотрицательных чисел перечислим. | ||
+ | |proof= | ||
+ | Приведём программу, перечисляющую язык чётных неотрицательных чисел: | ||
+ | <code> | ||
+ | <tex>p(i) {:} </tex> | ||
+ | '''return''' i * 2 | ||
+ | </code> | ||
+ | |||
+ | }} | ||
+ | |||
+ | == Примеры коперечислимых языков == | ||
+ | |||
+ | {{Утверждение | ||
+ | |id=st2 | ||
+ | |statement= | ||
+ | Язык нечётных неотрицательных чисел коперечислим. | ||
+ | |proof= | ||
+ | <tex>\overline L</tex> - язык чётных неотрицательных чисел. Так как язык чётных неотрицательных чисел перечислим, то и язык нечётных неотрицательных чисел тоже перечислим. | ||
+ | |||
+ | }} | ||
+ | |||
+ | == Примеры неперечислимых языков == | ||
+ | |||
+ | {{Утверждение | ||
+ | |id=st2 | ||
+ | |statement= | ||
+ | Язык пар <tex>\langle n, bb(n)\rangle</tex> неперечислим. | ||
+ | |proof= | ||
+ | Функция [[Busy_beaver | busy beaver]] <tex>bb(n)</tex> {{---}} невычислима, следовательно такой язык неперечислим. | ||
}} | }} | ||
− | == Источники == | + | == Источники информации == |
* Н. К. Верещагин, А. Шень. Лекции по математической логике и теории алгоритмов. Часть 3. Вычислимые функции. {{---}} М.: МЦНМО, 1999. С. 134. ISBN 5-900916-36-7 | * Н. К. Верещагин, А. Шень. Лекции по математической логике и теории алгоритмов. Часть 3. Вычислимые функции. {{---}} М.: МЦНМО, 1999. С. 134. ISBN 5-900916-36-7 | ||
− | * [http://en.wikipedia.org/wiki/Recursively_enumerable_language | + | * [http://en.wikipedia.org/wiki/Recursively_enumerable_language Wikipedia {{---}} Recursively enumerable language] |
− | *[http://ru.wikipedia.org/wiki/%D0%A0%D0%B5%D0%BA%D1%83%D1%80%D1%81%D0%B8%D0%B2%D0%BD%D0%BE_%D0%BF%D0%B5%D1%80%D0%B5%D1%87%D0%B8%D1%81%D0%BB%D0%B8%D0%BC%D1%8B%D0%B9_%D1%8F%D0%B7%D1%8B%D0%BA Википедия | + | * [http://ru.wikipedia.org/wiki/%D0%A0%D0%B5%D0%BA%D1%83%D1%80%D1%81%D0%B8%D0%B2%D0%BD%D0%BE_%D0%BF%D0%B5%D1%80%D0%B5%D1%87%D0%B8%D1%81%D0%BB%D0%B8%D0%BC%D1%8B%D0%B9_%D1%8F%D0%B7%D1%8B%D0%BA Википедия {{---}} Рекурсивно перечислимый язык] |
[[Категория: Теория формальных языков]] | [[Категория: Теория формальных языков]] | ||
[[Категория: Теория вычислимости]] | [[Категория: Теория вычислимости]] |
Версия 03:58, 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
- Википедия — Рекурсивно перечислимый язык