CMP设计分享 http://blog.sciencenet.cn/u/accsys 没有逆向思维就没有科技原创。 不自信是科技创新的大敌。

博文

SAT问题基本定义和术语

已有 4166 次阅读 2016-12-17 08:30 |个人分类:生活点滴|系统分类:科研笔记| 术语, SAT问题


Basic definitions and terminology

propositional logic formula, also called Booleanexpression, is built from variables, operators AND (conjunction, also denoted by ∧), OR (disjunction, ∨), NOT (negation, ¬),and parentheses. A formula is said to be satisfiable if it can be madeTRUE by assigning appropriate logicalvalues (i.e. TRUE, FALSE) to its variables. The Boolean satisfiabilityproblem (SAT) is, given a formula, to check whether it issatisfiable. This decision problem is of central importance invarious areas of computer science, including theoretical computer sciencecomplexity theoryalgorithmics,cryptographyand artificial intelligence.

命题逻辑公式(也称为布尔表达式),由变量、与运算符、或运算符、非运算符¬和括号组成。设定适当的逻辑变量值使逻辑表达式的值为真,就说逻辑表达式是能够满足的。布尔可满足性问题(SAT)就是检查逻辑表达式是否是可满足的。这个判定问题是计算机科学,包括计算机理论、复杂性理论、算法、密码学和人工智能众多领域的核心重要问题。


There are several special cases of the Boolean satisfiabilityproblem in which the formulas are required to have a particular structure. A literalis either a variable, then called positive literal, or the negation of avariable, then called negative literal. A clause is a disjunctionof literals (or a single literal). A clause is called Horn clause if it contains at most one positive literal. A formula is in conjunctive normal form (CNF) ifit is a conjunction of clauses (or a single clause). For example, x1is a positive literal, ¬x2 is a negative literal, x1∨ ¬x2 is a clause, and (x1 ∨ ¬x2)∧ (¬x1 ∨ x2 ∨ x3) ∧ ¬x1is a formula in conjunctive normal form, its 1st and 3rd clause are Hornclauses, but its 2nd clause is not. The formula is satisfiable, choosing x1 = FALSE,x2 = FALSE, and x3 arbitrarily,since (FALSE ∨ ¬FALSE) ∧ (¬FALSE ∨ FALSE ∨ x3) ∧ ¬FALSEevaluates to (FALSE ∨ TRUE) ∧ (TRUE ∨ FALSE ∨ x3) ∧ TRUE, andin turn to TRUE ∧ TRUE ∧ TRUE (i.e. to TRUE). In contrast, the CNF formula a∧ ¬a, consisting of two clauses of one literal, is unsatisfiable, sincefor a=TRUE and a=FALSE it evaluates to TRUE ∧ ¬TRUE (i.e. toFALSE) and FALSE ∧ ¬FALSE (i.e. again to FALSE), respectively.

一些具体情况下,布尔满足性问题表达式要求有特定的结构。逻辑变量叫正文字,它的非运算形式叫反文字,子句是它们的或运算形式(包括一个文字)。最多有一个正文字的子句叫强子句。子句进行与运算的表达式叫合取范式(CNF)。例如,x1是正文字,¬x2是反文字,x1 ∨ ¬x2就是一个子句。而(x1 ∨ ¬x2) ∧ (¬x1∨ x2 ∨ x3) ∧ ¬x1是合取范式。此式的第一和第三子句是强子句,第二个子句不是。选择x1 = 假, x2 = 假, x3任意,从 (假∨ ¬假) ∧ (¬假∨假∨ x3) ∧ ¬假,得出 (假∨ 真) ∧ (真 ∨假∨ x3) ∧ 真, 子句值运算为 真 ∧ 真 ∧ 真 (即结果为真)。



批注:真够啰嗦的!




https://wap.sciencenet.cn/blog-340399-1021253.html

上一篇:同行评议可信可不信
下一篇:限位数——一个人们不曾研究的领域
收藏 IP: 124.127.65.*| 热度|

0

该博文允许注册用户评论 请点击登录 评论 (0 个评论)

数据加载中...
扫一扫,分享此博文

Archiver|手机版|科学网 ( 京ICP备07017567号-12 )

GMT+8, 2025-1-7 12:17

Powered by ScienceNet.cn

Copyright © 2007- 中国科学报社

返回顶部