PS-полнота языка верных булевых формул с кванторами (TQBF) — различия между версиями
м |
Kirelagin (обсуждение | вклад) |
||
| Строка 1: | Строка 1: | ||
{{Определение | {{Определение | ||
|definition=<tex>\mathrm{TQBF}</tex> расшифровывается как '''True Quantified Boolean Formula'''. Это язык верных булевых формул с кванторами.<br/> | |definition=<tex>\mathrm{TQBF}</tex> расшифровывается как '''True Quantified Boolean Formula'''. Это язык верных булевых формул с кванторами.<br/> | ||
| − | <tex>TQBF=\{Q_1 x_1 Q_2 x_2 \ldots Q_n x_n \phi(x_1, x_2, \dots, x_n), Q_i \in \{\forall, \exists\}\}</tex>. | + | <tex>\mathrm{TQBF}=\{Q_1 x_1 Q_2 x_2 \ldots Q_n x_n \phi(x_1, x_2, \dots, x_n), Q_i \in \{\forall, \exists\}\}</tex>. |
}} | }} | ||
| Строка 39: | Строка 39: | ||
Размер полученной функции <tex>\phi(A, B, t)</tex> полиномиален относительно <tex>n</tex>. | Размер полученной функции <tex>\phi(A, B, t)</tex> полиномиален относительно <tex>n</tex>. | ||
| − | Теперь мы можем записать функцию <tex>f(M, w)</tex>, которая будет переводить ДМТ <tex>M</tex> и слово на ленте <tex>w</tex> в формулу из <tex>TQBF</tex>. | + | Теперь мы можем записать функцию <tex>f(M, w)</tex>, которая будет переводить ДМТ <tex>M</tex> и слово на ленте <tex>w</tex> в формулу из <tex>\mathrm{TQBF}</tex>. |
<tex>f(M, w) = \exists S \, \exists F \, (S - start) \land (F - accept) \land \phi(S, F, log_2(2^{\Omega r(n)})))</tex>. | <tex>f(M, w) = \exists S \, \exists F \, (S - start) \land (F - accept) \land \phi(S, F, log_2(2^{\Omega r(n)})))</tex>. | ||
Версия 18:25, 4 июня 2012
| Определение: |
| расшифровывается как True Quantified Boolean Formula. Это язык верных булевых формул с кванторами. . |
| Лемма (1): |
. |
| Доказательство: |
|
Чтобы доказать это, просто приведём программу , решающую булеву формулу с кванторами на дополнительной памяти и работающую за конечное время. if return if returnЭта программа требует дополнительной памяти для хранения стека рекурсивных вызовов. Максимальная глубина стека — . |
| Лемма (2): |
. |
| Доказательство: |
|
Рассмотрим язык . Построим такую функцию , что и , где — полином. Так как , то существует детерминированная машина Тьюринга , распознающая его с использованием памяти полиномиального размера. Будем считать, что длина ленты машины есть , где — полином, а — длина входа. Пусть , — конфигурация . Конфигурация однозначно задаётся позицией и содержанием рабочей ленты. Введём обозначение — в конфигурации на -том месте стоит символ . Тогда размер конфигурации равен . Следовательно всего конфигураций . Под выражением будем понимать Аналогично выражение обозначает Рассмотрим функцию , проверяющую следующее условие: конфигурация достижима из конфигурации не более, чем за шагов. . . Заметим, что данная формула имеет экспоненциальный размер, поэтому воспользуемся квантором и перепишем её следующим образом: . Размер полученной функции полиномиален относительно . Теперь мы можем записать функцию , которая будет переводить ДМТ и слово на ленте в формулу из . . Выражения и можно записать следующим образом: . .
Если , то существует путь из стартовой конфигурации в финишную, причём длины не более, чем , а значит формула верна. Если формула оказалась верна, то существует путь из стартовой конфигурации в финишную длины не более, чем . Значит, ДМТ допускает слово . Тогда . Таким образом, . |
| Теорема: |
. |
| Доказательство: |
| Доказательство непосредственно следует из лемм. |