Перечислимые языки — различия между версиями

Материал из Викиконспекты
Перейти к: навигация, поиск
Строка 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>
На каждой итерации цикла программы <tex>g</tex> в множестве <tex>U</tex> хранятся все выведенные на данный момент слова языка <tex>L</tex>.
 
  
 
Приведённые программы доказывают эквивалентность определений.
 
Приведённые программы доказывают эквивалентность определений.

Версия 00:42, 24 января 2012

Определение:
Полуразрешимый язык — язык, для которого существует программа [math]p[/math] такая, что [math]\forall x \in L \Leftrightarrow p(x)=1[/math].


Определение:
Перечислимый язык — язык, для которого существует программа [math]g[/math] такая, что [math]g(i) = x_i, L = \{x_1, x_2, .., x_n, ..\}[/math].


Определение:
Пусть имеется некоторая программа [math]p[/math], которая может либо завершиться за конечное время и что-то вернуть, либо зависнуть. Запуск программы [math]p[/math] с тайм-лимитом [math]TL[/math] будем обозначать как [math]p|_{TL}[/math] и иметь в виду следующее: если за [math]TL[/math] операций программа [math]p[/math] корректно завершилась и что-то вернула, то [math]p|_{TL}[/math] вернёт то же самое; если же за [math]TL[/math] операций программа [math]p[/math] не успела завершиться, то [math]p|_{TL}[/math] вернёт [math]\bot[/math] (символ зависания).


Теорема:
[math]L[/math] — перечислимый [math]\Leftrightarrow L[/math] — полуразрешимый.
Доказательство:
[math]\triangleright[/math]

Пусть [math]L[/math] — перечислимый язык, тогда для него существует программа [math]g[/math] которая по номеру [math]i[/math] выводит слово из [math]L[/math]. Значит для [math]\forall x \in L [/math], путем перебора значений функции [math]g[/math], мы можем найти такое [math]i[/math], что [math] g(i) [/math] равно [math] x[/math]. Следовательно существует программа [math]p[/math] такая, что [math]\forall x \in L \Leftrightarrow p(x)=1[/math]. Тогда [math]L[/math] является полуразрешимым языком.

[math]p(x):[/math]
  for [math] i = 1 ~ .. ~ \infty[/math]
    if [math] g(i) == x[/math]
      return [math] 1[/math]

Пусть [math]L[/math] — полуразрешимый язык, тогда для него существует программа [math]p[/math], результат которой равен [math]1[/math] для любого слова из [math]L[/math]. Чтобы программа [math]p[/math] не зависала на словах которые не принадлежат [math]L[/math], будем запускать ее с тайм-лимитом. Для поиска [math]i[/math] слова из языка [math]L[/math] будем перебирать [math]k[/math] — тайм-лимит с которым будем запускать программу [math]p[/math]. Таким образом существует программа [math]g_0[/math], которая выводит [math]i[/math] слово языка [math]L[/math] с повторениями. Для того, чтобы выводить слова без повторений заведем множество [math]U[/math] в котором будем хранить уже выведенные слова. Программа [math]g[/math] доказывает, что [math]L[/math] является перечислимым языком.

[math]g_0(i):[/math]
  [math]cnt = 0[/math]
  for [math] k = 1 ~ .. ~ \infty[/math]
    for [math] x \in \{x_1, x_2, .., x_k\}[/math]
      if [math] p|_k(x) == 1[/math]
        [math]cnt[/math]++
      if [math] cnt == i[/math]
        return [math] x[/math]
[math]g(i):[/math]
  [math]U = \emptyset[/math]
  for [math] j = 1 ~ .. ~ \infty[/math]
    [math]x = g_0(j)[/math]
    if [math] x \notin U[/math]
      [math]cnt[/math]++
    if [math] cnt == i[/math]
      return [math] x[/math]
    [math]U.insert(x)[/math]
Приведённые программы доказывают эквивалентность определений.
[math]\triangleleft[/math]
Теорема:
Любой разрешимый язык [math]L[/math] является перечислимым.
Доказательство:
[math]\triangleright[/math]
Любой разрешимый язык [math]L[/math] является полуразрешимым. Так как любой полуразрешимый язык является перечислимым, то [math]L[/math] является перечислимым.
[math]\triangleleft[/math]

Литература

  • Н. К. Верещагин, А. Шень. Лекции по математической логике и теории алгоритмов. Часть 3. Вычислимые функции. — М.: МЦНМО, 1999. С. 134. ISBN 5-900916-36-7