WikiDer > Преобразование Цейтина

Tseytin transformation

В Преобразование Цейтина, альтернативно написано Преобразование Цейтина, принимает на вход произвольный комбинаторная логика цепь и производит логическая формула в конъюнктивная нормальная форма (CNF), которую можно решить с помощью CNF-SAT решатель. Длина формулы линейна по размеру цепи. Входные векторы, которые делают выход схемы "истинным", находятся в Индивидуальная переписка с присвоениями, удовлетворяющими формуле. Это уменьшает проблему выполнимость схемы на любой цепи (включая любую формулу) в выполнимость задача о формулах 3-КНФ.

Мотивация

Наивный подход состоит в том, чтобы написать схему как логическое выражение и использовать Закон де Моргана и распределительное свойство преобразовать его в CNF. Однако это может привести к экспоненциальному увеличению размера уравнения. Преобразование Цейтина выводит формулу, размер которой линейно растет относительно входной цепи.

Подход

Выходное уравнение - это константа 1, равная выражению. Это выражение является комбинацией подвыражений, где удовлетворение каждого подвыражения обеспечивает правильную работу одного элемента во входной цепи. Таким образом, соответствие всему выходному выражению обеспечивает правильную работу всей входной цепи.

Для каждого гейта вводится новая переменная, представляющая его выход. Небольшой предварительно рассчитанный CNF Выражение, которое связывает входы и выходы, добавляется (с помощью операции «и») к выходному выражению. Обратите внимание, что входными данными для этих вентилей могут быть либо исходные литералы, либо введенные переменные, представляющие выходы вспомогательных вентилей.

Хотя выходное выражение содержит больше переменных, чем входное, оно остается равноправный, что означает, что оно выполнимо тогда и только тогда, когда выполняется исходное входное уравнение. Когда удовлетворительное присвоение переменных найдено, эти назначения для введенных переменных можно просто отбросить.

К последнему предложению добавляется единственный литерал: конечная выходная переменная ворот. Если этот литерал дополняется, то выполнение этого предложения приводит к тому, что выходное выражение принимает значение false; в противном случае выражение становится истинным.

Примеры

Рассмотрим следующую формулу .

Рассмотрим все подформулы (без переменных):

Введите новую переменную для каждой подформулы:

Соедините все замены и замену на :

Все замены могут быть преобразованы в CNF, например

Подвыражения ворот

Перечислены некоторые из возможных подвыражений, которые могут быть созданы для различных логических вентилей. В операционном выражении C действует как выход; в подвыражении CNF C действует как новая логическая переменная. Для каждой операции подвыражение CNF истинно тогда и только тогда, когда C придерживается контракта логической операции для всех возможных входных значений.

ТипОперацияCNF Подвыражение
Символ И И
Символ NAND NAND
Символ ИЛИ ИЛИ ЖЕ
Символ NOR НИ
НЕ символ НЕТ
Символ XOR XOR
Символ XNOR XNOR

Простая комбинаторная логика

Следующая схема возвращает истину, если хотя бы некоторые из ее входов истинны, но не более двух одновременно. Он реализует уравнение y = x1 · X2 + x1 · x2 + x2 · X3. Для каждого выхода ворот вводится переменная; здесь каждый отмечен красным:

Расческа логика tseitin.svg

Обратите внимание, что выход инвертора с x2 в качестве входных данных введены две переменные. Хотя это является избыточным, это не влияет на равносильную выполнимость результирующего уравнения. Теперь замените каждые ворота соответствующими CNF подвыражение:

воротаCNF подвыражение
gate1(ворота1 ∨ x1) ∧ (gate1x1)
gate2(gate2 ∨ gate1) ∧ (gate2 ∨ x2) ∧ (x2 ∨ gate2 ∨ gate1)
ворота3(ворота3 ∨ x2) ∧ (ворота3x2)
ворота4(ворота4 ∨ x1) ∧ (ворота4 ∨ gate3) ∧ (ворота3 ∨ gate4 ∨ x1)
ворота5(ворота5 ∨ x2) ∧ (ворота5x2)
ворота6(ворота6 ∨ gate5) ∧ (ворота6 ∨ x3) ∧ (x3 ∨ gate6 ∨ ворота5)
ворота7(gate7 ∨ gate2) ∧ (gate7 ∨ ворота4) ∧ (ворота2 ∨ ворота7 ∨ ворота4)
ворота8(gate8 ∨ ворота6) ∧ (gate8 ∨ ворота7) ∧ (gate6 ∨ ворота8 ∨ ворота7)

Конечной выходной переменной является gate8, поэтому для обеспечения того, чтобы выход этой схемы был истинным, добавляется одно последнее простое предложение: (gate8). Объединение этих уравнений приводит к последнему экземпляру SAT:

(ворота1 ∨ x1) ∧ (gate1x1) ∧ (gate2 ∨ gate1) ∧ (gate2 ∨ x2) ∧
(x2 ∨ gate2 ∨ gate1) ∧ (ворота3 ∨ x2) ∧ (ворота3x2) ∧ (ворота4 ∨ x1) ∧
(ворота4 ∨ gate3) ∧ (ворота3 ∨ gate4 ∨ x1) ∧ (вентиль5 ∨ x2) ∧
(ворота5x2) ∧ (ворота6 ∨ gate5) ∧ (ворота6 ∨ x3) ∧
(x3 ∨ gate6 ∨ ворота5) ∧ (gate7 ∨ gate2) ∧ (gate7 ∨ ворота4) ∧
(ворота2 ∨ ворота7 ∨ gate4) ∧ (gate8 ∨ ворота6) ∧ (gate8 ∨ ворота7) ∧
(gate6 ∨ ворота8 ∨ ворота7) ∧ (ворота8) = 1

Одно из возможных удовлетворительных назначений этих переменных:

Переменнаяценить
gate20
ворота31
gate11
ворота61
gate70
ворота40
ворота51
ворота81
x20
x31
x10

Значения введенных переменных обычно не учитываются, но их можно использовать для отслеживания логического пути в исходной схеме. Здесь (x1, x2, x3) = (0,0,1) действительно соответствует критериям исходной схемы для вывода true. Чтобы найти другой ответ, предложение (x1 ∨ x2 ∨ x3) можно добавить, и решатель SAT будет запущен снова.

Вывод

Представлен один из возможных выводов CNF подвыражение для некоторых выбранных ворот:

ИЛИ Ворота

Логический элемент ИЛИ с двумя входами А и B и один выход C удовлетворяет следующим условиям:

  1. если выход C верно, то хотя бы один из его входов А или же B правда,
  2. если выход C ложно, то оба его входа А и B ложны.

Мы можем выразить эти два условия как сочетание двух импликаций:

Замена импликаций эквивалентными выражениями, включающими только конъюнкции, дизъюнкции и отрицания, дает

что почти в конъюнктивная нормальная форма уже. Распределение самого правого предложения дважды дает

и применение ассоциативности конъюнкции дает формулу CNF

НЕ ворота

Элемент НЕ работает правильно, когда его вход и выход противоположны друг другу. То есть:

  1. если выход C - истина, вход A - ложь
  2. если выход C - ложь, вход A - истина

выразите эти условия как выражение, которое должно быть выполнено:

,

NOR Gate

Вентиль ИЛИ-НЕ работает нормально, когда выполняются следующие условия:

  1. если вывод C верен, то ни A, ни B не верны
  2. если выход C ложный, то хотя бы одно из A и B было истинным

выразите эти условия как выражение, которое должно быть выполнено:

, , , ,

Рекомендации