Теорема Бейкера — Гилла — Соловэя — различия между версиями
Kirelagin (обсуждение | вклад) (→Теорема: немного подправил, но всё плохо) |
|||
Строка 28: | Строка 28: | ||
'''Существование оракула <tex>B</tex>''' | '''Существование оракула <tex>B</tex>''' | ||
− | Пусть <tex>B</tex> — произвольное множество, а <tex>U_B = \{1^n | \exists x \in B : |x| = n\}</tex>. Ясно, что <tex>\forall B \Rightarrow U_B \in \mathrm{NP^B}</tex> ( | + | Пусть <tex>B</tex> — произвольное множество, а <tex>U_B = \{1^n | \exists x \in B : |x| = n\}</tex>. Ясно, что <tex>\forall B \Rightarrow U_B \in \mathrm{NP^B}</tex> (сертификатом будет слово нужной длины из <tex>B</tex>). Построим такое множество <tex>B</tex>, что <tex>U_B \not\in \mathrm{P^B}</tex>. |
− | + | Пронумеруем некоторым образом все машины Тьюринга, имеющие доступ к оракулу языка <tex>B</tex>, и рассмотрим получившуюся последовательность <tex>M_i</tex>. Построение множества <tex>B</tex> разделим на счетное число стадий, на каждой из которых множество пополнится конечным числом элементов. Будем строить <tex>B</tex> так, чтобы на <tex>i</tex>-й стадии было выполнено: <tex>T(M_i, x) \ge 2^{|x|-1}</tex>. Очевидно, что это утверждение сильнее, чем <tex>U_B \not\in \mathrm{P^B}</tex>. | |
* 0-я стадия: <tex>B \leftarrow \emptyset </tex>. | * 0-я стадия: <tex>B \leftarrow \emptyset </tex>. | ||
− | * <tex>i</tex>-я стадия. | + | * <tex>i</tex>-я стадия. Стадии с 0-й по <tex>(i-1)</tex>-ю пройдены, <tex>B</tex> — конечное множество слов. Пусть самое длинное из них состоит из <tex>(n-1)</tex>-го символа. Запустим машину <tex>M_i</tex> на входе <tex>1^n</tex> на <tex>2^{n-1}</tex> шагов. Когда <tex>M_i</tex> требуется ответ оракула языка <tex>B</tex> о слове <tex>x</tex>, будем определять принадлежность этого слова к <tex>B</tex> следующим образом: |
− | ** если принадлежность <tex>x</tex> множеству <tex>B</tex> была определена на | + | ** если принадлежность <tex>x</tex> множеству <tex>B</tex> была определена на одной из предудщих стадий, то она сохраняется; |
** если принадлежность <tex>x</tex> множеству <tex>B</tex> не установлена ранее, то далее считаем, что <tex>x \not\in B</tex>. | ** если принадлежность <tex>x</tex> множеству <tex>B</tex> не установлена ранее, то далее считаем, что <tex>x \not\in B</tex>. | ||
Версия 10:58, 8 мая 2012
Теорема
Теорема: |
Существуют такие оракулы и , что и . |
Доказательство: |
Существование оракула Рассмотрим PS-полный язык .
Существование оракула Пусть — произвольное множество, а . Ясно, что (сертификатом будет слово нужной длины из ). Построим такое множество , что .Пронумеруем некоторым образом все машины Тьюринга, имеющие доступ к оракулу языка , и рассмотрим получившуюся последовательность . Построение множества разделим на счетное число стадий, на каждой из которых множество пополнится конечным числом элементов. Будем строить так, чтобы на -й стадии было выполнено: . Очевидно, что это утверждение сильнее, чем .
Но могла остановится раньше, чем за шагов и вернуть какое-либо значение. Так как строится с условием , то решение машины о принадлежности слова должно быть неверным:
Во множестве на каждой стадии содержится конечное число элементов, так как на каждой стадии в может быть добавлено не более чем слов.Рассмотрим построенное по описанному выше алгоритму множество . Предположим, что отработала менее, чем за время , на слове , где определено для каждого в алгоритме, описанном выше. Тогда
|
Следствия
Утверждение: |
Методом диагонализации нельзя доказать, что . |
Утверждение: |
Никакой метод, который использует операции релятивизации, не может сказать равны ли и . |