Теорема Лаутемана — различия между версиями
Assaron (обсуждение | вклад) м (→Доказательство) |
Assaron (обсуждение | вклад) м (→Доказательство) |
||
| Строка 8: | Строка 8: | ||
<tex>\mathrm{BPP}</tex> можно определить, как множество таких языков <tex>L</tex>, что <tex>x \in L \Leftrightarrow \exists</tex> «много» вероятностных лент <tex>y: R(x,y)</tex>. <tex>\Sigma_2</tex> определяется, как множество <tex>\{ L \mid x \in L \Leftrightarrow \exists y \forall z R(x, y, z)\}</tex>. Таким образом, необходимо уметь записывать «много» с помощью квантора <tex>\forall</tex>. | <tex>\mathrm{BPP}</tex> можно определить, как множество таких языков <tex>L</tex>, что <tex>x \in L \Leftrightarrow \exists</tex> «много» вероятностных лент <tex>y: R(x,y)</tex>. <tex>\Sigma_2</tex> определяется, как множество <tex>\{ L \mid x \in L \Leftrightarrow \exists y \forall z R(x, y, z)\}</tex>. Таким образом, необходимо уметь записывать «много» с помощью квантора <tex>\forall</tex>. | ||
| − | Рассмотрим язык <tex>G</tex> | + | Рассмотрим язык <tex>G</tex> всех слов длины <tex>k</tex> над алфавитом <tex>{0, 1}</tex>, для некоторого <tex>k</tex>, значение которого будет получено позже. Определим операцию <tex>\oplus</tex> над славами из этого языка, как побитовое исключающее или. |
Назовем <tex>X</tex>, содержащееся в <tex>G</tex> большим, если существует набор <tex>g_1, g_2, \dots g_k</tex> такой, что <tex>\bigcup_{i=1}^{k} g_i \oplus X = G</tex>. | Назовем <tex>X</tex>, содержащееся в <tex>G</tex> большим, если существует набор <tex>g_1, g_2, \dots g_k</tex> такой, что <tex>\bigcup_{i=1}^{k} g_i \oplus X = G</tex>. | ||
Версия 23:08, 9 апреля 2010
Формулировка
Теорема Лаутемана (Sipser–Lautemann theorem или Sipser–Gács–Lautemann theorem) утверждает, что класс BPP содержится в классах и полиномиальной иерархии.
Доказательство
Из того, что класс замкнут относительно дополнения и следует, что достаточно доказать включение .
можно определить, как множество таких языков , что «много» вероятностных лент . определяется, как множество . Таким образом, необходимо уметь записывать «много» с помощью квантора .
Рассмотрим язык всех слов длины над алфавитом , для некоторого , значение которого будет получено позже. Определим операцию над славами из этого языка, как побитовое исключающее или.
Назовем , содержащееся в большим, если существует набор такой, что .
Если , то точное не является большим. Найдем достаточное условие, при котором большой.
Выберем случауно набор .
Для некотрого :
- ,
Если , то существует набор , что для любого , а из этого следует, что большой.
Рассмотрим язык . Не уменьшая общности, можем считать, шагов и вероятность ошибки не превосходит , это следует из того, что если запускать программу несколько раз, то время работы растет линейно, а вероятность ошибки экспоненциально уменьшается. Пусть его распознает машина .
Зафиксируем . Возьмем . Рассмотрим множество начал длины вероятностных лент , на которых машина выдает единицу, то есть .
Из того, что вероятность ошибки не превосходит , следует:
Если , то:
- ;
- ;
- , что влечет за собой то, что большой.
Если , то , а значит не является большим.
Таким образом, , а значит , и , что и требовалось доказать.