Теорема Карпа-Липтона
Формулировка
Теорема Карпа-Липтона
то
Доказательство
Пусть есть логические схемы для
(любой задаче из NP).Зафиксируем любую задачу из . Например пусть разрешается логическими схемами ( с одним битом разрешается логической схемой , с двумя переменными логической схемой и так далее).Что значит разрешается логической схемой? Это значит что если на вход логической схеме подать каким-то логичным образом закодированную формулу, то на выходе получется логичным образом в виде 0 и 1 закодированный ответ - имеется разложение или нет. И причем размер этой логической схемы
, где - какой-то полином от .Не утверждается, что их можно как то конструктивно построить. Если бы их было возможно построить за полином, то это бы означало, что
и значит .Итак, это означает, что если зафиксировать
, для этого фиксированного.
Рассмотрим язык . Это означает, что
Что такое
? Обозначим пары , для которых такой существует как какой нибудь язык ..
Заметим что
по определению Итого
Нужно доказать что
Что такое <x,y> \in L1 ? Если
по карпу с помощью , т.е.Что такое
?- для некоторого набора логических схем это означает выполнимость всего этого набора. Если предположить, что набор этих схем нам известен то получится что где - длина входа . Требуется откуда то взять этот набор. Его можно угадать, используя квантор " снаружи. Cn он существует по предположению что NP входит в P/poly т.е.
Что такое Cn Решает SAT? Нам разрешается использовать только квантор для любого.
решает еслиВоспользуемся самосведением
: Внутри будем проверять используемый набор// Если Cn(фи)=0 то для любого x (для любого тут можем использовать) фи(х)=0 Если Cn(фи)=1 то либо фи(ч1=0) принадлежит сат либо фи(х1=1) принадлежит сат тут не N а длина фи Вот когда подставим x1=0 нужно будет использовать(получится более короткая формула) и используем для проверки логическую схему более короткую . Если она выдает 1 то мы опять подставляем либо 0 либо 1 и так далее. Это правильная проверка причем за полином
Если
решает то все хорошо, если нет то зафиксируем формулу которую он не решает. Если выдаст 0 а должна выдать 1 то вот эту первую часть не удолветворяет и тут не будет работать, если наоборот выдаст 1 а на самом деле формула не удавлетворима то ни эта ни эта не будет работатьРассмотрим минимальную схему которая неправильна, тогда на той формуле, на которой эта схема неправильна по предположению что все более короткие формулы правильны,эта распознается схемами с меньшим числом входов, поэтому и эта и эта будут 0 и мы не узнаем набор схем. Можно попробовать развернуть формулу до конца. Видимо это будет выглядеть так
И рекурсивно вызываемся от того из них которое равно 1. Ту же самую формулу но записываем от того из них которое равно 1 (это же предикат но для того из них фи при х1= для которого труе) Второй вариант был угадать не только будевы схемы для сат но и те которые выдают нам правильные значения
Получаем что
Теорема доказана