Цейтиннің өзгеруі - Tseytin transformation

The Цейтиннің өзгеруі, балама түрде жазылған Цейтиннің трансформациясы, енгізу ретінде ерікті қабылдайды комбинаторлық логика тізбегі және а шығарады буль формуласы жылы конъюнктивті қалыпты форма (CNF), оны а арқылы шешуге болады CNF-SAT шешуші. Формуланың ұзындығы тізбектің өлшемі бойынша сызықтық болып табылады. Тізбектің шығуын «шын» ететін кіріс векторлары 1-ден 1-ге дейін хат алмасу формуланы қанағаттандыратын тапсырмалармен. Бұл проблеманы азайтады тізбектің қанағаттанушылығы кез-келген схемада (кез-келген формуланы қоса) қанағаттанушылық 3-CNF формулаларындағы есеп.

Мотивация

Аңғалдық тәсілі - тізбекті логикалық өрнек түрінде жазу және қолдану Де Морган заңы және үлестіруші мүлік оны CNF-ге айналдыру үшін. Алайда, бұл теңдеу мөлшерінің экспоненциалды ұлғаюына әкелуі мүмкін. Цейтиннің өзгеруі формуланы шығарады, оның мөлшері кіріс тізбегіне қатысты сызықтық өседі.

Тәсіл

Шығарылатын теңдеу - бұл өрнекке тең тұрақты 1 жиынтығы. Бұл өрнек ішкі өрнектердің конъюнкциясы болып табылады, мұнда әрбір ішкі өрнектің қанағаттануы кіріс тізбегіндегі бір қақпаның дұрыс жұмыс істеуін қамтамасыз етеді. Барлық шығыс өрнегінің қанағаттануы бүкіл кіріс тізбегінің дұрыс жұмыс істеуін қамтамасыз етеді.

Әр қақпа үшін оның нәтижесін көрсететін жаңа айнымалы енгізіледі. Кішкентай алдын-ала есептелген CNF кірістер мен шығыстарды байланыстыратын өрнек шығыс өрнегіне қосылады («және» әрекеті арқылы). Бұл қақпалардың кірістері түпнұсқа литералдар немесе ішкі қақпалардың нәтижелерін көрсететін енгізілген айнымалылар болуы мүмкін екенін ескеріңіз.

Шығарылым өрнегінде кіріске қарағанда көп айнымалылар болса да, ол қалады теңдестірілген, демек, егер бастапқы кіріс теңдеуі қанағаттанарлық болса, қанағаттанарлық. Айнымалылардың қанағаттанарлық тағайындауы табылған кезде, енгізілген айнымалыларға арналған тапсырмаларды жай ғана тастауға болады.

Соңғы сөйлемге бір әріптік әріп қосылады: соңғы қақпаның шығыс айнымалысы. Егер бұл сөзбе-сөз толықтырылса, онда осы тармақтың қанағаттануы шығыс өрнектің жалғанға дейін орындалуын қамтамасыз етеді; әйтпесе өрнек шындыққа мәжбүр болады.

Мысалдар

Келесі формуланы қарастырыңыз .

Барлық ішкі формулаларды қарастырыңыз (айнымалысыз):

Әрбір субформула үшін жаңа айнымалы мән енгізіңіз:

Барлық алмастыруларды және ауыстыруды жалғаңыз :

Барлық алмастыруларды CNF-ге айналдыруға болады, мысалы.

Қақпаның қосалқы өрнектері

Тізімде әртүрлі логикалық қақпалар үшін жасалуы мүмкін кейбір қосалқы өрнектер келтірілген. Операциялық өрнекте С шығыс ретінде жұмыс істейді; CNF ішкі өрнегінде C жаңа логикалық айнымалы ретінде әрекет етеді. Әрбір операция үшін CNF ішкі өрнегі шындыққа сәйкес келеді, егер С логикалық операцияның барлық мүмкін мәндері үшін келісімшартты ұстанса ғана.

ТүріПайдалануCNF Қосымша өрнек
ЖӘНЕ символ ЖӘНЕ
NAND белгісі NAND
НЕМЕСЕ символ НЕМЕСЕ
NOR таңбасы ЖОҚ
Белгісі ЕМЕС ЖОҚ
XOR белгісі XOR
XNOR белгісі XNOR

Қарапайым комбинаторлық логика

Келесі схема, егер оның кірістерінің ең болмағанда бір бөлігі шын болғанда, бірақ бір уақытта екеуден көп емес болғанда шындыққа айналады. Ол теңдеуді жүзеге асырады у = x1 · X2 + x1 · x2 + x2 · X3. Әр қақпаның шығысы үшін айнымалы енгізіледі; мұнда әрқайсысы қызылмен белгіленген:

Тарақ логикасы tseitin.svg

Назар аударыңыз, инвертордың x2 кіріс ретінде екі айнымалы енгізілген. Бұл артық болғанымен, алынған теңдеудің теңдікке әсер етпейді. Енді әр қақпаны сәйкесінше ауыстырыңыз CNF ішкі өрнек:

ҚақпаCNF қосалқы өрнек
қақпа1(қақпа1 ∨ x1) ∧ (қақпа1x1)
қақпа2(қақпа2 ∨ қақпа1) ∧ (қақпа2 ∨ x2) ∧ (x2 ∨ қақпа2 ∨ қақпа1)
қақпа3(қақпа3 ∨ x2) ∧ (қақпа3x2)
қақпа4(қақпа4 ∨ x1) ∧ (қақпа4 ∨ қақпа3) ∧ (қақпа3 ∨ қақпа4 ∨ x1)
қақпа5(қақпа5 ∨ x2) ∧ (қақпа5x2)
қақпа6(қақпа6 ∨ қақпа5) ∧ (қақпа6 ∨ x3) ∧ (x3 ∨ қақпа6 ∨ қақпа5)
қақпа7(қақпа 7 ∨ қақпа2) ∧ (қақпа7 ∨ қақпа4) ∧ (қақпа2 ∨ қақпа7 ∨ қақпа4)
қақпа8(қақпа8 ∨ қақпа6) ∧ (қақпа8 ∨ қақпа7) ∧ (қақпа6 ∨ қақпа8 ∨ қақпа7)

Қорытынды шығыс айнымалысы gate8 болып табылады, сондықтан осы тізбектің шығысы шындыққа сәйкес келуі үшін бір қарапайым қарапайым сөйлем қосылады: (gate8). Осы теңдеулерді біріктіру SAT соңғы инстанциясына әкеледі:

(қақпа1 ∨ x1) ∧ (қақпа1x1) ∧ (қақпа2 ∨ қақпа1) ∧ (қақпа2 ∨ x2) ∧
(x2 ∨ қақпа2 ∨ қақпа1) ∧ (қақпа3 ∨ x2) ∧ (қақпа3x2) ∧ (қақпа4 ∨ x1) ∧
(қақпа4 ∨ қақпа3) ∧ (қақпа3 ∨ қақпа4 ∨ x1) ∧ (қақпа5 ∨ x2) ∧
(қақпа5x2) ∧ (қақпа6 ∨ қақпа5) ∧ (қақпа6 3 x3) ∧
(x3 ∨ қақпа6 ∨ қақпа5) ∧ (қақпа7 ∨ қақпа2) ∧ (қақпа7 ∨ қақпа4) ∧
(қақпа2 ∨ қақпа7 ∨ қақпа4) ∧ (қақпа8 ∨ қақпа6) ∧ (қақпа8 ∨ қақпа7) ∧
(қақпа 6 ∨ қақпа8 ∨ қақпа7) ∧ (қақпа8) = 1

Осы айнымалылардың ықтимал тағайындауының бірі:

айнымалымәні
қақпа20
қақпа31
қақпа11
қақпа61
қақпа70
қақпа40
қақпа51
қақпа81
x20
x31
x10

Енгізілген айнымалылардың мәндері әдетте алынып тасталады, бірақ оларды бастапқы тізбектегі логикалық жолды бақылау үшін пайдалануға болады. Мұнда, (x1, x2, x3) = (0,0,1) шынымен де шынайы шығу үшін бастапқы схеманың өлшемдеріне сәйкес келеді. Басқа жауапты табу үшін сөйлем (x1 ∨ x2 ∨) x3қосуға болады және SAT шешуші қайтадан орындалады.

Шығу

Берілген - мүмкін шығарудың бірі CNF кейбір таңдалған қақпалардың ішкі өрнегі:

НЕМЕСЕ Қақпа

Екі кірісі бар OR қақпасы A және B және бір шығу C келесі шарттарды қанағаттандырады:

  1. егер шығу C дұрыс, содан кейін оның кем дегенде бір кірісі A немесе B шындық,
  2. егер шығу C жалған, содан кейін оның екі кірісі A және B жалған.

Біз осы екі шартты екі салдар байланысы ретінде білдіре аламыз:

Ықпалдарды тек конъюнкциялар, дизъюнкциялар және терістеулер қатысатын баламалы өрнектермен ауыстыру нәтиже береді

бұл шамамен конъюнктивті қалыпты форма қазірдің өзінде. Ең дұрыс сөйлемді екі рет тарату нәтиже береді

және конъюнкцияның ассоциативтілігін қолдану CNF формуласын береді

ЕМЕС қақпа

ЕМЕС қақпасы оның кірісі мен шығысы бір-біріне қарсы болған кезде дұрыс жұмыс істейді. Бұл:

  1. егер С шығысы шын болса, А кірісі жалған болады
  2. егер С шығысы жалған болса, А кірісі ақиқат

осы шарттарды қанағаттандыру керек өрнек ретінде көрсетіңіз:

,

NOR қақпасы

NOR қақпасы келесі шарттар болған кезде дұрыс жұмыс істейді:

  1. егер C шығысы ақиқат болса, онда A немесе B де дұрыс емес
  2. егер С шығысы жалған болса, онда А мен В-дің кем дегенде біреуі дұрыс болды

осы шарттарды қанағаттандыру керек өрнек ретінде көрсетіңіз:

, , , ,

Әдебиеттер тізімі