Перечислимые языки — различия между версиями
| Строка 11: | Строка 11: | ||
{{Определение  | {{Определение  | ||
|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> (  | + | Пусть имеется некоторая программа <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> (символ зависания).  | 
}}  | }}  | ||
| Строка 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>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>g_0(i):</tex>  |   <tex>g_0(i):</tex>  | ||
    <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(  | + |         if <tex> p|_k(x) == 1</tex>  | 
          <tex>cnt</tex>++  |           <tex>cnt</tex>++  | ||
        if <tex> cnt == i</tex>  |         if <tex> cnt == i</tex>  | ||
| Строка 43: | Строка 43: | ||
        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>.   | ||
| + | |||
Приведённые программы доказывают эквивалентность определений.  | Приведённые программы доказывают эквивалентность определений.  | ||
}}  | }}  | ||
| Строка 49: | Строка 51: | ||
|id=th2  | |id=th2  | ||
|statement=  | |statement=  | ||
| − | Любой разрешимый язык <tex>L</tex> является перечислимым.  | + | Любой [[Разрешимые_(рекурсивные)_языки | разрешимый язык]] <tex>L</tex> является перечислимым.  | 
|proof=    | |proof=    | ||
Любой разрешимый язык <tex>L</tex> является полуразрешимым. А так как любой полуразрешимый язык является перечислимым, то разрешимый язык <tex>L</tex> является перечислимым.  | Любой разрешимый язык <tex>L</tex> является полуразрешимым. А так как любой полуразрешимый язык является перечислимым, то разрешимый язык <tex>L</tex> является перечислимым.  | ||
}}  | }}  | ||
| + | |||
| + | == Литература ==  | ||
| + | Н. К. Верещагин,  А. Шень. Лекции по математической логике и теории алгоритмов. Часть 3. Вычислимые функции. -- М.: МЦНМО, 1999  | ||
Версия 01:24, 19 декабря 2011
| Определение: | 
| Полуразрешимый язык язык, для которого существует программа такая, что . | 
| Определение: | 
| Перечислимый язык язык, для которого существует программа такая, что . | 
| Определение: | 
| Пусть имеется некоторая программа , которая может либо завершиться за конечное время и что-то вернуть, либо зависнуть. Тогда запуск программы с тайм-лимитом будем обозначать как и иметь в виду следующее: если за операций программа корректно завершилась и что-то вернула, то вернет то же самое; если же за операций программа не успела завершиться, то вернет (символ зависания). | 
| Теорема: | 
 перечислимый  полуразрешимый.  | 
| Доказательство: | 
| 
 Пусть перечислимый язык. Докажем, что он полуразрешим, приведя соответствующую программу. for if return Пусть полуразрешимый язык. Докажем, что он перечислим, приведя соответствующую программу. for for if ++ if return for if ++ if return На каждой итерации цикла программы , в множестве , хранятся все выведенные на данный момент слова языка . Приведённые программы доказывают эквивалентность определений. | 
| Теорема: | 
Любой  разрешимый язык  является перечислимым.  | 
| Доказательство: | 
| Любой разрешимый язык является полуразрешимым. А так как любой полуразрешимый язык является перечислимым, то разрешимый язык является перечислимым. | 
Литература
Н. К. Верещагин, А. Шень. Лекции по математической логике и теории алгоритмов. Часть 3. Вычислимые функции. -- М.: МЦНМО, 1999