Перечислимые языки — различия между версиями
Nafanya (обсуждение | вклад)  | 
				м (rollbackEdits.php mass rollback)  | 
				||
| (не показано 18 промежуточных версий 4 участников) | |||
| Строка 22: | Строка 22: | ||
<tex>L</tex> {{---}} перечислимый <tex>\Leftrightarrow L</tex> {{---}} полуразрешимый.  | <tex>L</tex> {{---}} перечислимый <tex>\Leftrightarrow L</tex> {{---}} полуразрешимый.  | ||
|proof=  | |proof=  | ||
| − | <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> \  | + |  '''function''' p(x: '''int'''): '''int'''  | 
| + |    '''for''' i = 1 '''to''' <tex>\infty</tex>  | ||
| + |      '''if'''  g(i) == x  | ||
| + |        '''return''' 1  | ||
| − | Пусть <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> \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>  | + | :   | 
| − | + | ||
| − |     '''for''' <tex>   | + |   '''function''' <tex>g_0</tex>(i: '''int'''): '''int'''  | 
| − |       '''for''' <tex>   | + |     cnt = 0  | 
| − |         '''if''' <tex> p|_k(x) == 1  | + |     '''for''' k = 1 '''to''' <tex> \infty</tex>  | 
| − | + |       '''for''' x <tex>\in \{x_1, x_2, .., x_k\}</tex>  | |
| − |         '''if'''   | + |         '''if''' <tex> p|_k</tex>(x) == 1  | 
| − |           '''return'''   | + |           cnt++  | 
| − | + |         '''if''' cnt == i  | |
| − | + |           '''return''' x  | |
| − |   <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> <tex>U</tex>  | 
| − | + |        cnt++  | |
| − |       '''if'''   | + |       '''if''' cnt == i  | 
| − |         '''return'''   | + |         '''return''' x  | 
| − | + |       U.insert(x)  | |
| − | + | '''''}}  | |
| − | }}  | ||
{{Теорема  | {{Теорема  | ||
| Строка 70: | Строка 69: | ||
Рассмотрим полуразрешители для <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>  {{---}} разрешимый.  | ||
}}  | }}  | ||
| + | |||
== Примеры перечислимых языков ==  | == Примеры перечислимых языков ==  | ||
| Строка 78: | Строка 78: | ||
|proof=  | |proof=  | ||
Приведём программу, перечисляющую язык натуральных чисел:  | Приведём программу, перечисляющую язык натуральных чисел:  | ||
| − | + | ||
| − | + |   '''function''' p(i: '''int'''): '''int'''  | |
    '''return''' i  |     '''return''' i  | ||
| − | + | '''''}}  | |
| − | |||
| − | }}  | ||
{{Утверждение  | {{Утверждение  | ||
| Строка 91: | Строка 89: | ||
|proof=  | |proof=  | ||
Приведём программу, перечисляющую язык чётных неотрицательных чисел:  | Приведём программу, перечисляющую язык чётных неотрицательных чисел:  | ||
| − | + | ||
| − | + |   '''function'''  p(i: '''int'''): '''int'''  | |
    '''return''' i * 2  |     '''return''' i * 2  | ||
| − | + | '''''}}  | |
| − | |||
| − | }}  | ||
== Примеры коперечислимых языков ==  | == Примеры коперечислимых языков ==  | ||
| Строка 105: | Строка 101: | ||
Язык нечётных неотрицательных чисел коперечислим.  | Язык нечётных неотрицательных чисел коперечислим.  | ||
|proof=  | |proof=  | ||
| − | <tex>\overline L</tex> - язык чётных неотрицательных чисел. Так как язык чётных неотрицательных чисел перечислим, то и язык нечётных неотрицательных чисел тоже перечислим.  | + | <tex>\overline L</tex> {{---}} язык чётных неотрицательных чисел. Так как язык чётных неотрицательных чисел перечислим, то и язык нечётных неотрицательных чисел тоже перечислим.  | 
}}  | }}  | ||
| + | {{Утверждение  | ||
| + | |id=st2  | ||
| + | |statement=  | ||
| + | Язык простых чисел коперечислим.  | ||
| + | |proof=  | ||
| + | Пусть <tex>L</tex> {{---}} язык простых чисел, тогда <tex>\overline L</tex> {{---}} язык, состоящий из составных чисел и единицы. Покажем, что <tex>\overline L</tex> полуразрешим, а, следовательно, и перечислим согласно теореме, приведённой выше.  | ||
| + | |||
| + | Построим простой полуразрешитель:  | ||
| + | |||
| + |  '''function''' p(n: '''int'''): '''int'''  | ||
| + |    '''for''' i = 2 '''to''' <tex>\lceil \sqrt{n} \rceil</tex>  | ||
| + |      '''if''' n mod i == 0  | ||
| + |         '''return''' 0  | ||
| + |    '''return''' 1  | ||
| + | '''''}}  | ||
== Примеры неперечислимых языков ==  | == Примеры неперечислимых языков ==  | ||
| Строка 118: | Строка 129: | ||
Функция [[Busy_beaver | busy beaver]] <tex>bb(n)</tex> {{---}} невычислима, следовательно такой язык неперечислим.  | Функция [[Busy_beaver | busy beaver]] <tex>bb(n)</tex> {{---}} невычислима, следовательно такой язык неперечислим.  | ||
}}  | }}  | ||
| + | |||
| + | == См. также ==  | ||
| + | |||
| + | * [[Разрешимые (рекурсивные) языки]]  | ||
| + | * [[Замкнутость разрешимых и перечислимых языков относительно теоретико-множественных и алгебраических операций]]  | ||
== Источники информации ==  | == Источники информации ==  | ||
| Строка 126: | Строка 142: | ||
[[Категория: Теория формальных языков]]  | [[Категория: Теория формальных языков]]  | ||
[[Категория: Теория вычислимости]]  | [[Категория: Теория вычислимости]]  | ||
| + | [[Категория: Разрешимые и перечислимые языки]]  | ||
Текущая версия на 19:22, 4 сентября 2022
Содержание
Основные определения
| Определение: | 
Полуразрешимый язык (англ. 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 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
 - Википедия — Рекурсивно перечислимый язык