Теорема Бейкера — Гилла — Соловэя — различия между версиями
| Строка 29: | Строка 29: | ||
'''Существование оракула <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>B</tex>, что <tex>U_B \not\in \mathrm{P^B}</tex>.    | + | Пусть <tex>B</tex> — произвольное множество, а <tex>U_B = \{1^n \bigm| \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>B</tex>, и рассмотрим последовательность <tex>M_i</tex>, в которой каждая машина Тьюринга встречается бесконечное число раз. Очевидно, это можно сделать в силу счетности множества машин Тьюринга. Построение множества <tex>B</tex> разделим на счетное число стадий, на каждой из которых множество пополнится конечным числом элементов. Будем строить <tex>B</tex> так, чтобы на <tex>i</tex>-й стадии было выполнено: <tex>M_i</tex> не разрешает язык <tex>U_B</tex> за время не большее, чем <tex>2^{n-1}</tex>.  Это утверждение сильнее, чем <tex>U_B \not\in \mathrm{P^B}</tex>, так как <tex>2^n</tex> растет быстрее любого полинома.  | 
* 0-я стадия: <tex>B \leftarrow \emptyset </tex>.  | * 0-я стадия: <tex>B \leftarrow \emptyset </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>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> следующим образом:  | ||
| Строка 43: | Строка 43: | ||
Во множестве <tex>B</tex> на каждой стадии содержится конечное число элементов, так как на каждой стадии в <tex>B</tex> может быть добавлено не более чем <tex>2^{n-1}+1</tex> слов.    | Во множестве <tex>B</tex> на каждой стадии содержится конечное число элементов, так как на каждой стадии в <tex>B</tex> может быть добавлено не более чем <tex>2^{n-1}+1</tex> слов.    | ||
| − | Из построения получаем, что   | + | Из построения получаем, что для любой машины Тьюринга <tex>M_i</tex> существует бесконечно много слов из <tex>U_B</tex>, которые <tex>M_i</tex> не может разрешить за время меньшее <tex>2^{n-1}</tex>. Следовательно, <tex>U_B \not\in \mathrm{P_B}</tex>.  | 
}}  | }}  | ||
Версия 15:31, 3 июня 2012
Теорема
| Теорема: | 
Существуют такие оракулы  и , что  и .  | 
| Доказательство: | 
| 
 Существование оракула Рассмотрим PS-полный язык . 
 
 Существование оракула Пусть — произвольное множество, а . Ясно, что (сертификатом будет слово нужной длины из ). Построим такое множество , что . Пронумеруем некоторым образом все машины Тьюринга, имеющие доступ к оракулу языка , и рассмотрим последовательность , в которой каждая машина Тьюринга встречается бесконечное число раз. Очевидно, это можно сделать в силу счетности множества машин Тьюринга. Построение множества разделим на счетное число стадий, на каждой из которых множество пополнится конечным числом элементов. Будем строить так, чтобы на -й стадии было выполнено: не разрешает язык за время не большее, чем . Это утверждение сильнее, чем , так как растет быстрее любого полинома. 
 Но могла остановится раньше, чем за шагов и вернуть какое-либо значение. Так как строится с условием не разрешает за время , то решение машины о принадлежности слова должно быть неверным: 
 Во множестве на каждой стадии содержится конечное число элементов, так как на каждой стадии в может быть добавлено не более чем слов. Из построения получаем, что для любой машины Тьюринга существует бесконечно много слов из , которые не может разрешить за время меньшее . Следовательно, . | 
Следствия
| Утверждение: | 
Методом диагонализации нельзя доказать, что .  | 
| Утверждение: | 
Если существует решение вопроса равенства  и , то оно не должно "релятивизоваться", поэтому стандартные техники, например, диагонализация не применима.  |