Top Qs
Timeline
Chat
Perspective

XOR-SAT

From Wikipedia, the free encyclopedia

Remove ads

In computational complexity, XOR-SAT (also known as XORSAT) is the class of boolean satisfiability problems where each clause contains XOR (i.e. exclusive or, written "⊕") rather than (plain) OR operators.[a] XOR-SAT is in P,[1] since an XOR-SAT formula can also be viewed as a system of linear equations mod 2, and can be solved in cubic time by Gaussian elimination;[2]. This recast is based on the kinship between Boolean algebras and Boolean rings, and the fact that arithmetic modulo two forms the finite field GF(2).

Remove ads

Examples

Here is an unsatisfiable XOR-SAT instance of 2 variables and 3 clauses[b]:

(ab) ∧ (a) ∧ (b)

Here is a satisfiable XOR-SAT instance of 2 variables and 1 clause admitting 2 solutions:

(ab)

And here is a unique XOR-SAT instance, that is to say a satisfiable XOR-SAT instance of 2 variables and 2 clauses admitting exactly one solution:

(ab) ∧ (a)

Comparison with SAT variations

Thumb
A formula with 2 clauses may be unsatisfied (red), 3-satisfied (green), xor-3-satisfied (blue), or/and 1-in-3-satisfied (yellow), depending on the TRUE-literal count in the 1st (hor) and 2nd (vert) clause.

Since abc evaluates to TRUE if and only if exactly 1 or 3 members of {a,b,c} are TRUE, each solution of the 1-in-3-SAT problem for a given CNF formula is also a solution of the XOR-3-SAT problem, and in turn each solution of XOR-3-SAT is a solution of 3-SAT; see the picture. As a consequence, for each CNF formula, it is possible to solve the XOR-3-SAT problem defined by the formula, and based on the result infer either that the 3-SAT problem is solvable or that the 1-in-3-SAT problem is unsolvable.

Provided that the complexity classes P and NP are not equal, neither 2-, nor Horn-, nor XOR-satisfiability is NP-complete, unlike SAT.

Remove ads

Solving an XOR-SAT example by Gaussian elimination

Summarize
Perspective

Given formula (the red clause is optional):

(x1 ⊕ ¬x2x4) ∧ (x2x4 ⊕ ¬x3) ∧ (x1x2 ⊕ ¬x3) ∧ (x1x2x4)

Equation system

"1" means TRUE, "0" means FALSE. Each clause leads to one equation.

x1¬x2x4= 1
x2x4¬x3= 1
x1x2¬x3= 1
x1x2x4 ≃ 1

Normalized equation system

Using properties of Boolean ringsx=1⊕x, xx=0)

x1x2x4= 0
x2x4x3= 0
x1x2x3= 0
x1x2x41

If the red equation is present, it contradicts the first black one, so the system is unsolvable. Therefore, Gauss' algorithm is used only for the black equations.

Associated coefficient matrix

More information x1, x2 ...

Transforming to echelon form

More information x1, x2 ...

Transforming to diagonal form

More information x1, x2 ...

Variable random assignments

For all the variables at the right of the diagonal form (if any), we assign any random value.

More information x1, x2 ...

Solution

If the red clause is present, the instance is unsolvable. Otherwise:

  • x1 = 1 = TRUE
  • x2 = 0 = FALSE
  • x3 = 1 = TRUE
  • x4 = 1 = TRUE

As a consequence, R(x1, ¬x2, x4) ∧ R(x2, x4, ¬x3) ∧ R(x1, x2, ¬x3) Rx1,x2,x4) is not 1-in-3-satisfiable, while (x1 ∨ ¬x2x4) ∧ (x2x4 ∨ ¬x3) ∧ (x1x2 ∨ ¬x3) ∧ (x1x2x4) is 3-satisfiable with x1=x2=x3=x4=TRUE.

Notes

  1. Formally, generalized conjunctive normal forms with a ternary Boolean function R are employed, which is TRUE just if 1 or 3 of its arguments is. An input clause with more than 3 literals can be transformed into an equisatisfiable conjunction of clauses á 3 literals similar to above; i.e. XOR-SAT can be reduced to XOR-3-SAT.
  2. All the examples can be proved by the table of truth.

References

Loading related searches...

Wikiwand - on

Seamless Wikipedia browsing. On steroids.

Remove ads