Перечислимые языки — различия между версиями
Vincent (обсуждение | вклад) |
|||
Строка 20: | Строка 20: | ||
<tex>L</tex> {{---}} перечислимый <tex>\Leftrightarrow L</tex> {{---}} полуразрешимый. | <tex>L</tex> {{---}} перечислимый <tex>\Leftrightarrow L</tex> {{---}} полуразрешимый. | ||
|proof= | |proof= | ||
− | Пусть <tex>L</tex> {{---}} перечислимый язык. | + | Пусть <tex>L</tex> {{---}} перечислимый язык, тогда для него существует программа <tex>g</tex> которая по номеру <tex>i</tex> выводит слово из <tex>L</tex>. Значит для <tex>\forall x \in L </tex>, путем перебора значений функции <tex>g</tex>, мы можем найти такое <tex>i</tex>, что <tex> g(i) </tex> равно <tex> x</tex>. Следовательно существует программа <tex>p</tex> такая, что <tex>\forall x \in L \Leftrightarrow p(x)=1</tex>. Тогда <tex>L</tex> является полуразрешимым языком. |
<tex>p(x):</tex> | <tex>p(x):</tex> | ||
for <tex> i = 1 ~ .. ~ \infty</tex> | for <tex> i = 1 ~ .. ~ \infty</tex> | ||
if <tex> g(i) == x</tex> | if <tex> g(i) == x</tex> | ||
return <tex> 1</tex> | return <tex> 1</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):</tex> | <tex>g_0(i):</tex> | ||
<tex>cnt = 0</tex> | <tex>cnt = 0</tex> | ||
Строка 43: | Строка 44: | ||
return <tex> x</tex> | return <tex> x</tex> | ||
<tex>U.insert(x)</tex> | <tex>U.insert(x)</tex> | ||
− | |||
Приведённые программы доказывают эквивалентность определений. | Приведённые программы доказывают эквивалентность определений. |
Версия 00:42, 24 января 2012
Определение: |
Полуразрешимый язык — язык, для которого существует программа | такая, что .
Определение: |
Перечислимый язык — язык, для которого существует программа | такая, что .
Определение: |
Пусть имеется некоторая программа | , которая может либо завершиться за конечное время и что-то вернуть, либо зависнуть. Запуск программы с тайм-лимитом будем обозначать как и иметь в виду следующее: если за операций программа корректно завершилась и что-то вернула, то вернёт то же самое; если же за операций программа не успела завершиться, то вернёт (символ зависания).
Теорема: |
— перечислимый — полуразрешимый. |
Доказательство: |
Пусть — перечислимый язык, тогда для него существует программа которая по номеру выводит слово из . Значит для , путем перебора значений функции , мы можем найти такое , что равно . Следовательно существует программа такая, что . Тогда является полуразрешимым языком.for if return Пусть — полуразрешимый язык, тогда для него существует программа , результат которой равен для любого слова из . Чтобы программа не зависала на словах которые не принадлежат , будем запускать ее с тайм-лимитом. Для поиска слова из языка будем перебирать — тайм-лимит с которым будем запускать программу . Таким образом существует программа , которая выводит слово языка с повторениями. Для того, чтобы выводить слова без повторений заведем множество в котором будем хранить уже выведенные слова. Программа доказывает, что является перечислимым языком.Приведённые программы доказывают эквивалентность определений. for for if ++ if return for if ++ if return |
Теорема: |
Любой разрешимый язык является перечислимым. |
Доказательство: |
Любой разрешимый язык | является полуразрешимым. Так как любой полуразрешимый язык является перечислимым, то является перечислимым.
Литература
- Н. К. Верещагин, А. Шень. Лекции по математической логике и теории алгоритмов. Часть 3. Вычислимые функции. — М.: МЦНМО, 1999. С. 134. ISBN 5-900916-36-7