Теорема Левина — различия между версиями
SVKazakov (обсуждение | вклад) |
SVKazakov (обсуждение | вклад) |
||
Строка 1: | Строка 1: | ||
− | По одному из определений <math>NP</math> языка, язык <math>L</math> принадлежит <math>NP</math>, если существует функция <math>R(x, y) \in \tilde{P}</math> — <math>NP</math>-отношение для языка <math>L</math> (<math>NP</math>-relation) | + | По одному из определений <math>NP</math> языка, язык <math>L</math> принадлежит <math>NP</math>, если существует такая функция <math>R(x, y) \in \tilde{P}</math> — <math>NP</math>-отношение для языка <math>L</math> (<math>NP</math>-relation), что: <math>x \in L \Leftrightarrow \exists y</math> — такой сертификат для <math>x</math>, что: <math>|y| \le poly(|x|)</math> и <math>R(x, y) = 1</math>. Таким образом, для проверки принадлежности некоторого слова NP языку L с NP-отношением R необходимо предъявить соответствующий сертификат. Так как для любого слова из языка существует подтверждающий сертификат, то и существует программа g(x), которая для слов из языка возвращает нужный сертификат. А для слов не из языка никаких гарантий на возвращаемое значение функции нет и потому она может либо вернуть неправильный сертификат, либо вообще зависнуть. |
Встает вопрос о возможности построения "оптимальной" программы для заранее заданного NP языка L и NP-отношения для этого языка R, которая будет находить сертификат для слова. Оптимальность программы в данном случае означает, что время ее работы для слов из языка не сильно хуже, чем у любой другой программы, правильно находящей сертификат для слов из языка. | Встает вопрос о возможности построения "оптимальной" программы для заранее заданного NP языка L и NP-отношения для этого языка R, которая будет находить сертификат для слова. Оптимальность программы в данном случае означает, что время ее работы для слов из языка не сильно хуже, чем у любой другой программы, правильно находящей сертификат для слов из языка. | ||
== Формулировка == | == Формулировка == | ||
− | '''Теорема Левина об оптимальной NP программе''' утверждает, что для любого языка <math>L \in NP</math> и функции <math>R</math> (<math>NP</math>-отношения для <math>L</math>) существует программа <math>f</math> | + | '''Теорема Левина об оптимальной NP программе''' утверждает, что для любого языка <math>L \in NP</math> и функции <math>R</math> (<math>NP</math>-отношения для <math>L</math>) существует такая программа <math>f</math>, что: |
#<math>\forall x \in L</math> выполнено <math>R(x, f(x)) = 1</math>; | #<math>\forall x \in L</math> выполнено <math>R(x, f(x)) = 1</math>; | ||
− | #<math>\forall g</math> — программы | + | #<math>\forall g</math> — такой программы, что <math>\forall x \in L: R(x, g(x)) = 1</math> выполнено <math>\forall x \in L: T(f, x) \le C(g) \cdot (T(g, x) + poly(|x|))</math>, где T(f, x) — время работы программы f на входе x. |
Заметим, что функция C(g) не зависит от слова х, т.е. константа от х. | Заметим, что функция C(g) не зависит от слова х, т.е. константа от х. |
Версия 12:53, 14 марта 2010
По одному из определений
языка, язык принадлежит , если существует такая функция — -отношение для языка ( -relation), что: — такой сертификат для , что: и . Таким образом, для проверки принадлежности некоторого слова NP языку L с NP-отношением R необходимо предъявить соответствующий сертификат. Так как для любого слова из языка существует подтверждающий сертификат, то и существует программа g(x), которая для слов из языка возвращает нужный сертификат. А для слов не из языка никаких гарантий на возвращаемое значение функции нет и потому она может либо вернуть неправильный сертификат, либо вообще зависнуть.Встает вопрос о возможности построения "оптимальной" программы для заранее заданного NP языка L и NP-отношения для этого языка R, которая будет находить сертификат для слова. Оптимальность программы в данном случае означает, что время ее работы для слов из языка не сильно хуже, чем у любой другой программы, правильно находящей сертификат для слов из языка.
Формулировка
Теорема Левина об оптимальной NP программе утверждает, что для любого языка
и функции ( -отношения для ) существует такая программа , что:- выполнено ;
- — такой программы, что выполнено , где T(f, x) — время работы программы f на входе x.
Заметим, что функция C(g) не зависит от слова х, т.е. константа от х.
Доказательство
Для доказательства теоремы будем строить оптимальную NP программу f для некоторого NP языка L и NP отношения R(x, y) для него.
Занумеруем все программы
сначала по длине программы, а в случае равенства длин — лексикографически.Будем запускать
каждый раз на один шаг и запоминать полученное состояние запущенной программы. Запускать будем в следующем порядке: 1, 2, 1, 3, 1, 2, 1, 4, 1, 2, 1, 3, 1, 2, 1, 5 и так далее. Заметим, что мы запускаем программу каждый -й раз, а потому, если программа завершается за шагов, то совершит не больше шагов до момента завершения на входе в программе .После того, как программа
остановилась, на её месте будем запускать программу , где - значение, которое вернула . Причем f совершит не больше шагов до завершения программы , так как и она запускается каждый -й раз. Если вернула , то возвратим , так как — нужный сертификат для , а если , то ничего на этом месте больше запускать не будем.Осталось доказать, что данная программа действительно удовлетворяет пунктам 1 и 2 теоремы Левина.
- Так как программа f возвращает только те у, для которых R(x, y) = 1, то R(x, f(x)) = 0 получиться не может. Покажем, что и зависнуть на словах из языка не может. Как выше уже упоминалось, если слово принадлежит языку , то для него есть сертификат, а значит есть и программа , которая просто этот сертификат возвращает. Так как все программы рано или поздно будут занумерованы, то и будет занумерована, а следовательно и запущена. После остановки и проверки правильности программа вернет его.
- Как выше уже оговаривалось, если программа правильно находит сертификат и завершится за шагов, то программа завершится не более, чем за шагов. Заметим, что , так как — сертификат для и потому .
Теорема доказана.