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

Материал из Викиконспекты
Перейти к: навигация, поиск
м
Строка 1: Строка 1:
 
{{Определение
 
{{Определение
 
|definition =
 
|definition =
Перечисляющая программа для языка <tex>L</tex> - программа, по очереди выводящая все слова языка <tex>L</tex>. Если слово принадлежит языку, то программа за конечное время выдаст его на выходе. Слова, не принадлежащие языку, программа выводить не будет.
+
'''Полуразрешимый язык''' <tex>-</tex> язык, для которого существует программа <tex>p</tex> такая, что <tex>\forall x \in L \Leftrightarrow p(x)=1</tex>.
 
}}
 
}}
  
 
{{Определение
 
{{Определение
 
|definition =
 
|definition =
Полуразрешающая программа для языка <tex>L</tex> - программа, которая при подаче на вход слова из языка за конечное время завершится и вернет <tex>1</tex>, а при подаче на вход слова не из языка может за конечное время вернуть <tex>0</tex>, а может и зависнуть.
+
'''Перечислимый язык''' <tex>-</tex> язык, для которого существует программа <tex>g</tex> такая, что <tex>g(i) = x_i, L = \{x_1, x_2, .., x_n, ..\}</tex>.
 
}}
 
}}
  
 
{{Определение
 
{{Определение
 
|definition =
 
|definition =
Перечислимый язык - язык, для которого существует перечисляющая программа.
+
Пусть имеется некоторая программа <tex>p</tex>, которая может либо завершиться за конечное время и что-то вернуть, либо зависнуть. Тогда запуск программы <tex>p</tex> с тайм-лимитом <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> (специально зарезервированное значение).
}}
 
 
 
{{Определение
 
|definition =
 
Перечислимый язык - язык, для которого существует полуразрешающая программа.
 
 
}}
 
}}
  
{{Определение
 
|definition =
 
Пусть имеется некоторая программа <tex>p</tex>, которая может либо завершиться за конечное время и что-то вернуть, либо зависнуть. Тогда запуск программы <tex>p</tex> с тайм-лимитом <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> (специально зарезервированное значение).
 
}}
 
  
 
{{Теорема
 
{{Теорема
 
|id=th1
 
|id=th1
 
|statement=
 
|statement=
Два определения перечислимого языка эквивалентны.
+
<tex>L-</tex> перечислимый <tex>\Leftrightarrow L-</tex> полуразрешимый.
 
|proof=
 
|proof=
Пусть имеется перечисляющая программа для языка <tex>L</tex>, построим полуразрешающую. Сделаем это следующим образом. Получаем на вход некоторое слово <tex>w</tex>, запускаем перечисляющую программу. Если в процессе вывода слов встретится <tex>w</tex>, то завершаем работу, вернув <tex>1</tex>. Таким образом при подаче на вход слова из языка построенная программа вернет <tex>1</tex> и завершится. Если же мы подадим на вход слово не из языка, то построенная программа будет работать бесконечно долго, что вполне устраивает. Таким образом полуразрешающая программа построена.
+
Пусть <tex>L-</tex> перечислимый.
 
+
:<tex>p(x):</tex>
Теперь пусть имеется полуразрешающая программа <tex>p</tex> для языка <tex>L</tex>, построим перечисляющую.
+
:: <tex>for ~ i = 1 ~ .. ~ \infty</tex>
 
+
::: <tex>if ~ g(i) = x</tex>
:     for <tex>TL</tex> = <tex>1</tex> .. <tex>+\infty</tex> {
+
:::: <tex>return ~ 1</tex>
::   for <tex>length</tex> = <tex>1</tex> .. <tex>TL</tex> {
+
Пусть <tex>L-</tex> полуразрешимый.
:::   for <tex>w \in L</tex>, <tex>|w| = length</tex> {
+
:<tex>g_0(i):</tex>
 
+
::<tex>cnt = 0</tex>
:::: if <tex>p|_{TL}(w)=1</tex>
+
:: <tex>for ~ k = 1 ~ .. ~ \infty</tex>
::::: выводим <tex>w</tex>;
+
::: <tex>for ~ x \in \{x_1, x_2, .., x_k\}</tex>
:::}
+
:::: <tex>if ~ p|_k(i) = 1</tex>
::}
+
::::: <tex>cnt++</tex>
:}
+
:::: <tex>if ~ cnt = i</tex>
 
+
::::: <tex>return ~ x</tex>
Если слово <tex>w</tex> принадлежит языку, то условие <tex>p|_{TL}(w)=1</tex> будет выполнено для какого-то <tex>TL</tex>, а значит на выходе построенной программы рано или поздно появится <tex>w</tex>. Если же слово <tex>w</tex> не принадлежит языку, то <tex>p|_{TL}(w)=1</tex> ну будет выполнено ни для какого <tex>TL</tex>, а значит оно никогда не появится на выходе.
 
  
Таким образом мы построили перечисляющую программу.
+
:<tex>g(i):</tex>
 
+
::<tex>U = \emptyset</tex>
В итоге теорема доказана.
+
:: <tex>for ~ j = 1 ~ .. ~ \infty</tex>
 +
::: <tex>x \leftarrow g_0(j)</tex>
 +
:::: <tex>if ~ x \notin U</tex>
 +
::::: <tex>cnt++</tex>
 +
::::: <tex>if ~ cnt = i</tex>
 +
:::::: <tex>return ~ x</tex>
 +
::::: <tex>U.insert(x)</tex>
 +
Приведённые программы доказывают эквивалентность определений.
 
}}
 
}}
 
  
 
{{Теорема
 
{{Теорема
Строка 55: Строка 51:
 
|statement=
 
|statement=
 
Любой разрешимый язык <tex>L</tex> является перечислимым.
 
Любой разрешимый язык <tex>L</tex> является перечислимым.
|proof=
+
|proof=  
Язык <tex>L</tex> резрешимый, значит существует программа <tex>p</tex>, которая за конечное время определит, принадлежит ли поданное на вход слово языку <tex>L</tex>. Таким образом перечисляющая программа будет иметь следующий вид.
+
Любой разрешимый язык <tex>L</tex> является полуразрешимым. А так как любой полуразрешимый язык является перечислимым, то разрешимый язык <tex>L</tex> является перечислимым.
 
 
:  for <tex>w \in L</tex> {
 
 
 
::  if <tex>p(w)=1</tex>
 
::: выводим <tex>w</tex>;
 
:}
 
 
 
Таким образом, на выходе появится слово <tex>w</tex> тогда и только тогда, когда <tex>w \in L</tex>, теорема доказана.
 
}}
 
 
 
 
 
{{Теорема
 
|id=th3
 
|statement=
 
Существуют перечислимые, но не разрешимые языки.
 
 
}}
 
}}

Версия 05:12, 18 декабря 2011

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


Определение:
Перечислимый язык [math]-[/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]p(x):[/math]
[math]for ~ i = 1 ~ .. ~ \infty[/math]
[math]if ~ g(i) = x[/math]
[math]return ~ 1[/math]

Пусть [math]L-[/math] полуразрешимый.

[math]g_0(i):[/math]
[math]cnt = 0[/math]
[math]for ~ k = 1 ~ .. ~ \infty[/math]
[math]for ~ x \in \{x_1, x_2, .., x_k\}[/math]
[math]if ~ p|_k(i) = 1[/math]
[math]cnt++[/math]
[math]if ~ cnt = i[/math]
[math]return ~ x[/math]
[math]g(i):[/math]
[math]U = \emptyset[/math]
[math]for ~ j = 1 ~ .. ~ \infty[/math]
[math]x \leftarrow g_0(j)[/math]
[math]if ~ x \notin U[/math]
[math]cnt++[/math]
[math]if ~ cnt = i[/math]
[math]return ~ 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]