

# Sorting Parity Encodings by Reusing Variables

Leroy  $Chew^{(\boxtimes)}$  and Marijn J. H. Heule

Computer Science Department, Carnegie Mellon University, Pittsburgh, PA, USA lchew@andrew.cmu.edu

**Abstract.** Parity reasoning is challenging for CDCL solvers: Refuting a formula consisting of two contradictory, differently ordered parity constraints of modest size is hard. Two alternative methods can solve these reordered parity formulas efficiently: binary decision diagrams and Gaussian Elimination (which requires detection of the parity constraints). Yet, implementations of these techniques either lack support of proof logging or introduce many extension variables.

The compact, commonly-used encoding of parity constraints uses Tseitin variables. We present a technique for short clausal proofs that exploits these Tseitin variables to reorder the constraints within the DRAT system. The size of our refutations of reordered parity formulas is  $\mathcal{O}(n \log n)$ .

## 1 Introduction

Modern SAT solving technology is based on Conflict Driven Clause Learning (CDCL) [12]. The resolution proof system [16] has a one-to-one correspondence [15] with CDCL solving. In practice, however, the preprocessing techniques used in modern solvers go beyond what can be succinctly represented in a resolution proof. As a consequence, when we need to present verifiable certificates of unsatisfiable instances, resolution is not always sufficient. Extended Resolution (ER) [20] is a strong proof system that can polynomially simulate CDCL and many other techniques. However, ER is not necessarily the most useful system in practice, as we also want to minimise the degree of the polynomial simulation.

The DRAT proof system [7] is polynomially equivalent to ER [8]. Yet most practitioners favour DRAT due to its ability to straightforwardly simulate known preprocessing and inprocessing techniques. DRAT works by allowing inference to go beyond preserving models and instead preserves only satisfiability.

In this paper, we demonstrate DRAT's strengths on a particular kind of unsatisfiable instances that involve parity constraints. Formulas with parity constraints have been benchmarks for SAT for decades. The Dubois family encodes the refutation of two contradictory parity constraints over the same variables using the same variable ordering. Urquhart formulas [21] encode a modulo two sum of the degree of each vertex of a graph, the unsatisfiability comes from an assertion that this sum is odd, a violation of the Handshake Lemma. The Parity family from Crawford and Kearns [3] takes multiple parity instances on a set of variables and combines them together. For these problems, practical solutions have been studied using Gaussian elimination, equivalence reasoning, binary decision diagrams and other approaches [5,6,9–11,13,18,19,22].

© Springer Nature Switzerland AG 2020

L. Pulina and M. Seidl (Eds.): SAT 2020, LNCS 12178, pp. 1–10, 2020. https://doi.org/10.1007/978-3-030-51825-7\_1 Extracting checkable proofs in a universal format has been another matter entirely. While it is believed that polynomial size circuitry exists to solve these problems, actually turning them into proofs could mean they may only be "short" in a theoretical polynomial-size sense rather than a practical one. Constructing a DRAT proof of parity reasoning has been investigated theoretically [14], but no implementation exists to actually produce them nor is it clear whether the size is still reasonable to be useful in practice.

There has been some investigation into looking at DRAT without the use of extension variables. DRAT<sup>-</sup>, which is DRAT without extension variables, is somewhere in between resolution and ER in terms of power. Several simulation results for DRAT<sup>-</sup> [2], show that it is a powerful system even without the simulation of ER. A key simulation technique was the elimination and reuse of a variable, which we use to find short DRAT<sup>-</sup> proofs of a hard parity formula.

The structure of parity constraints can be manipulated by reusing variables and we exploit the associativity and commutativity of the parity function. We demonstrate this on formulas similar to the **Dubois** family except the variables now appear in a random order in one parity constraint. We show how to obtain DRAT proofs of size  $\mathcal{O}(n \log n)$  without using additional variables. Our method can also be used to produce ER proofs of similar size with new variables.

### 2 Preliminaries

In propositional logic a literal is a variable x or its negation  $\overline{x}$ , a clause is a disjunction of literals and a *Conjunctive Normal Form* (CNF) is conjunction of clauses. A unit clause is a clause containing a single literal. We denote the negation of literal l as  $\overline{l}$  (or  $\neg l$ ). The variable corresponding to literal l is var(l). If C is a clause, then  $\overline{C}$  is the conjunction of the negation of the literals in C each a unit clause. In this paper, we treat clauses/formulas as unordered and not containing more than one copy of each literal/clause respectively.

Unit propagation simplifies a conjunctive normal form F by building a partial assignment and applying it to F. It builds the assignment by satisfying any literal that appears in a unit clause. Doing so may negate opposite literals in other clauses and result in them effectively being removed from that clause. In this way, unit propagation can create more unit clauses and can keep on propagating until no more unit clauses remain or the empty clause is reached. We denote that the empty clause can be derived by unit propagation applied to CNF Fby  $F \vdash_1 \bot$ . Since unit propagation is an incomplete but sound form of logical inference this is a sufficient condition to show that F is a logical contradiction.

The DRAT proof system. Below we define the rules of the DRAT proof system. Each rule modifies a formula by either adding or removing a clause while preserving satisfiability or unsatisfiability, respectively.

**Definition 1 (Asymmetric Tautology (AT)** [7]). Let F be a CNF formula. A clause C is an asymmetric tautology w.r.t. F if and only if  $F \wedge \overline{C} \vdash_1 \bot$ . Asymmetric tautologies are also known as RUP (reverse unit propagation) clauses. The rules ATA and ATE allow us to add and eliminate AT clauses. ATA steps can simulate resolution steps and weakening steps.

$$\frac{F}{F \wedge C}$$
(ATA: C is AT w.r.t. F) 
$$\frac{F \wedge C}{F}$$
(ATE: C is AT w.r.t. F)

**Definition 2 (Resolution Asymmetric Tautology (RAT)** [7]). Let F be a CNF formula. A clause C is a resolution asymmetry tautology w.r.t. F if and only if there exists a literal  $l \in C$  such that for every clause  $\overline{l} \lor D \in F$  it holds that  $F \land \overline{D} \land \overline{C} \vdash_1 \bot$ .

The rules RATA and RATE allow us to add and eliminate RAT clauses. RATA can be used to add new variables that neither occur in F or anywhere else. This can be used to simulate extension steps in ER.

$$\frac{F}{F \wedge C}$$
(RATA: C is RAT w.r.t. F) 
$$\frac{F \wedge C}{F}$$
(RATE: C is RAT w.r.t. F)

#### 3 A parity contradiction based on random orderings

In this section we will detail the main family of formulas investigated in this work. These formulas will be contradictions expressing both the parity and nonparity on a set of variables.

We define the parity of propositional literals a, b, c as follows

$$\operatorname{xor}(a,b,c) := (\overline{a} \lor \overline{b} \lor \overline{c}) \land (\overline{a} \lor b \lor c) \land (a \lor \overline{b} \lor c) \land (a \lor b \lor \overline{c})$$

Let  $X = \{x_1, \ldots, x_n\}$ , and let  $\sigma$  be a bijection between literals on X, that preserves negation ( $\sigma(\neg l) = \neg \sigma(l)$ ). Let e denote the identity permutation on the literals of X. Let  $T = \{t_1, \ldots, t_{n-3}\}$ . We define PARITY(X, T,  $\sigma$ ) as

$$\operatorname{xor}(\sigma(x_1), \sigma(x_2), t_1) \wedge \bigwedge_{j=1}^{n-4} \operatorname{xor}(t_j, \sigma(x_{j+2}), t_{j+1}) \wedge \operatorname{xor}(\overline{t}_{n-3}, \sigma(x_{n-1}), \sigma(x_n))$$

This formula is satisfiable if and only if the total parity of  $\{\sigma(x_i) \mid x_i \in X\}$  is 1. The *T* variables act as Tseitin variables and whenever the formula is satisfied  $t_{i+1}$  is the sum modulo two of  $\sigma(x_1), \ldots, \sigma(x_{i+2})$ . The final clauses,  $\operatorname{xor}(\bar{t}_{n-3}, \sigma(x_{n-1}), \sigma(x_n))$  thus are satisfied when the sum of  $t_{n-3}, \sigma(x_{n-1})$  and  $\sigma(x_n)$  is 1 mod 2. Suppose we pick  $\sigma$  so that there is some  $i \in [n]$  such that  $\sigma(x_j)$  is a negative literal if and only if j = i. Let  $T' = \{t'_1, \ldots, t'_{n-3}\}$  be another set of Tseitin variables. PARITY $(X, T, \sigma) \wedge \operatorname{PARITY}(X, T', e)$  is false as it states the parity of X is true but also states it false. However the permutation  $\sigma$  obfuscates the similarities between the two PARITY parts of the formula.

Were  $\sigma(x_j) = x_j$  for all  $j \neq i$  and  $\sigma(x_i) = -x_i$  then these formulas would be equivalent to the **Dubois** formulas and a linear proof could be made by inductively deriving clauses that express  $t'_j = t_j$  for j < i - 1 and then  $t'_j \neq t_j$  for  $j \geq i - 1$ . This will always allow us to derive a contradiction. While a linear

| ATA                                                       | RATE                                                           | RATA                                               | ATE                                                          |
|-----------------------------------------------------------|----------------------------------------------------------------|----------------------------------------------------|--------------------------------------------------------------|
| $\overline{q} \vee a \vee b \vee c$                       | d $\overline{p} \lor a \lor b$                                 | $\overline{p} \lor c \lor b$                       | $\texttt{d}  \overline{q} \lor a \lor b \lor c$              |
| $\overline{q} \vee \overline{a} \vee \overline{b} \vee c$ | $\texttt{d}  \overline{p} \vee \overline{a} \vee \overline{b}$ | $\overline{p} \vee \overline{c} \vee \overline{b}$ | $d  \overline{q} \vee \overline{a} \vee \overline{b} \vee c$ |
| $\overline{q} \vee a \vee \overline{b} \vee \overline{c}$ | d $p \lor a \lor \overline{b}$                                 | $p \lor c \lor \overline{b}$                       | $d  \overline{q} \lor a \lor \overline{b} \lor \overline{c}$ |
| $\overline{q} \vee \overline{a} \vee b \vee \overline{c}$ | $\texttt{d}  p \vee \overline{a} \vee b$                       | $p \vee \overline{c} \vee b$                       | $d  \overline{q} \vee \overline{a} \vee b \vee \overline{c}$ |
| $q \vee \overline{a} \vee b \vee c$                       | $\texttt{d}  \overline{p} \lor q \lor c$                       | $\overline{p} \lor q \lor a$                       | $d  q \vee \overline{a} \vee b \vee c$                       |
| $q \vee a \vee \overline{b} \vee c$                       | $\texttt{d}  \overline{p} \vee \overline{q} \vee \overline{c}$ | $\overline{p} \vee \overline{q} \vee \overline{a}$ | $d  q \vee a \vee \overline{b} \vee c$                       |
| $q \vee a \vee b \vee \overline{c}$                       | $\texttt{d}  p \lor q \lor \overline{c}$                       | $p \lor q \lor \overline{a}$                       | $d  q \lor a \lor b \lor \overline{c}$                       |
| $q \vee \overline{a} \vee \overline{b} \vee \overline{c}$ | $\texttt{d}  p \vee \overline{q} \vee c$                       | $p \vee \overline{q} \vee a$                       | $d  q \vee \overline{a} \vee \overline{b} \vee \overline{c}$ |
|                                                           |                                                                |                                                    |                                                              |

Fig. 1. DRAT steps required for Lemma 1, d denotes a deletion step.

resolution proof is known for the Dubois, it is unknown what the size of the shortest resolution proof of PARITY $(X, T, \sigma) \wedge PARITY(X, T', e)$  for a random  $\sigma$ . While the Dubois family are a special case of these formulas, these formulas are in turn a special case of the Tseitin graph formulas [20] where the vertex degree is always 3.

When  $\sigma \neq e$  we still have a contradiction due to the commutativity of the parity function. However such a straightforward DRAT proof becomes obstructed by the disarranged ordering. This permutation also makes these formulas hard for CDCL solvers (see Section 4). We will show that PARITY(X, T', e) can be efficiently reordered. Afterwards a short resolution proof arises. This brings us to our main theoretical result.

**Theorem 1.** Let  $X = \{x_1, \ldots, x_n\}$ ,  $T = \{t_1, \ldots, t_n\}$ ,  $T' = \{t'_1, \ldots, t'_n\}$  and let  $\sigma$  be a bijection between literals on X, that preserves negation. Suppose there is some  $i \in [n]$  such that  $\sigma(x_j)$  is a negative literal if and only if j = i. The 3-CNF PARITY $(X, T, \sigma) \land \text{PARITY}(X, T', e)$  has a proof of size  $O(n \log n)$ .

In the remainder of this section we will prove Theorem 1. We begin with an essential lemma that uses the DRAT rules to perform elementary adjacent swaps on literals in xor constraints.

**Lemma 1.** Suppose we have a CNF F and two sets of xor clauses xor(a, b, p) and xor(p, c, q), where variable p appears nowhere in F. We can infer

$$\frac{F \wedge \operatorname{xor}(a, b, p) \wedge \operatorname{xor}(p, c, q)}{F \wedge \operatorname{xor}(b, c, p) \wedge \operatorname{xor}(p, a, q)}$$

in a constant number of DRAT steps without adding new variables.

*Proof.* The idea is to eliminate variable p so that we define q directly as the parity of a, b, c using eight "ternary xor" clauses. Each of these clauses can

be added directly via ATA. We can now remove (using RATE) all clauses that contain variable p. These steps are equivalent to performing Davis-Putnam (DP) resolution [4] on variable p.

What we are left with is that two levels of parity have been replaced with one level of ternary parity. We can reverse the above steps to get us two levels of parity yet again, but we can swap a and c (since they appear symmetrically in our "ternary xor" clauses). We re-use the eliminated p to now mean the xor of b and c using RATA. Finally, we remove the "ternary xor" clauses using ATE.  $\Box$ 

Note that here elimination is required only because we want to re-use the variable p. We can also show a similar step in ER without the elimination steps, introducing the "ternary xor" clauses immediately with resolution. We can introduce the four  $\operatorname{xor}(p', b, c)$  extension clauses for p', and by resolving them with the ternary clauses on b we get eight intermediate clauses which can resolve with each other on c to get the remaining four  $\operatorname{xor}(p', a, q)$  clauses. Without ATA and RATA steps, this process involves 50% more addition steps, but since it contains no deletion steps we have 25% fewer steps in total. ER proofs allow us to keep lemmas without deletion so where we have more than two parity constraints we may wish to reuse derived parity clauses. On the other hand DRAT<sup>-</sup> keeps the number of variables and clauses fixed when searching when we do not know the structure of formula and can stop the search size from growing.

Sorting the input literals. We can switch the two parity inputs using Lemma 1 in a constant number of proof steps. Furthermore the technique in DRAT does not require any additional extension variables and since the number of addition and deletion steps in Lemma 1 is the same, the working CNF does not change in size. Sorting using adjacent variables requires  $\Theta(n^2)$  swaps.

Let us ignore the variables  $x_{n-1}$  and  $x_n$  and the clauses that include them as special cases. We can take  $\operatorname{xor}(x_1, x_2, t_1) \wedge \bigwedge_{i=1}^{n-4} \operatorname{xor}(t_i, x_{i+2}, t_{i+1})$  as the definition of  $t_{n-3}$  in circuit form, using the X variables as input gates and the  $t_i$ variables as  $\operatorname{xor}(\oplus)$  gates. This circuit is a tree with linear depth. the distance between two input nodes is linear in the worst-case, which is why we get  $\Omega(n^2)$ many swaps. However Lemma 1 allows us even more flexibility, we can not only rearrange the input variables but the Tseitin variables.

For example if we have  $\operatorname{xor}(t_i, x_{i+2}, t_{i+1})$  and  $\operatorname{xor}(t_{i-1}, x_{i+1}, t_i)$  clauses we can eliminate  $t_i$  so that  $t_{i+1}$  is defined as the parity of  $x_{i+1}, x_{i+2}$ , and  $t_{i-1}$ . However



Fig. 2. Swapping the position of an internal node to balance the tree.



**Fig. 3.** Moving two literals next to each other. Top: moving  $x_2$  up to the source of the tree. Bottom: moving  $x_2$  down to swap with  $x_7$ 

we can now redefine  $t_i$  as the xor of  $x_{i+1}$ ,  $x_{i+2}$  (using  $xor(t_i, x_{i+1}, x_{i+2})$ ) and  $t_{i+1}$  as the xor of  $t_i$  and  $t_{i-1}$  (using  $xor(t_{i+1}, t_i, t_{i-1})$ ). See Figure 2 for an example and notice how we change the topology of the tree.

In  $\lfloor \frac{n}{2} \rfloor$  many swaps we can change our linear depth tree into a tree that consists of a two linear branches of depth at most  $\lceil \frac{n}{2} \rceil$  joined at the top by an xor. This means that using a divide and conquer approach, we can turn this tree in a balanced binary tree of  $\lceil \log_2 n \rceil$  depth in  $\mathcal{O}(n \log n)$  many steps.

The purpose of a log depth tree structure is to allow leaf-to-leaf swapping from both ends of the tree without having to do a linear number of swaps, in fact we can do arbitrary leaf swaps in  $\mathcal{O}(\lceil \log n \rceil)$  many individual steps. This is done by pushing a variable up its branch to the source node of the tree and pushing it back down another branch to its destination as in Figure 3. Then we can reverse the steps with the variable being swapped out. The resulting tree even retains the position of all other nodes.

Note that we also have the variables  $x_n$  and  $x_{n-1}$  that only appear in the clauses of  $xor(\bar{t}_{n-3}, x_{n-1}, x_n)$ . Suppose the two children of  $t_{n-3}$  in its definition circuit are a and b, in other words  $xor(t_{n-3}, a, b)$  are the clauses currently defining  $t_{n-3}$ . Without loss of generality suppose we want to swap  $x_{n-1}$  with a.

The clauses of  $\operatorname{xor}(\overline{t}_{n-3}, x_{n-1}, x_n)$  are exactly the same as the clauses of  $\operatorname{xor}(t_{n-3}, x_{n-1}, \overline{x}_n)$ . Using Lemma 1 we can eliminate  $t_{n-3}$  and gain eight clauses that represent that  $\overline{x}_n$  is the ternary xor of a, b and  $x_{n-1}$ . Then we can reverse the steps but instead swap the positions of  $x_{n-1}$  and a.

In this way we can introduce  $x_{n-1}$  or  $x_n$  into the tree and swap it with any leaf. Once again we only require  $\mathcal{O}(\log n)$  many applications of Lemma 1 to completely swap the position of  $x_{n-1}$  or  $x_n$  with any leaf.

Arriving at the empty clause. The total number of leaf-to-leaf swaps we are required to perform is bounded above linearly so we stay within  $\mathcal{O}(n \log n)$  many steps. We can now undo the balanced tree into a linear tree in (we reverse what we did to balance it) keeping within an  $\mathcal{O}(n \log n)$  upper bound.

Recall that we performed a sort on the variables in PARITY(X, T', e) thereby transforming it into PARITY $(X, T', \sigma')$  with  $var(\sigma'(x)) = var(\sigma(x))$ , resulting in the formula PARITY $(X, T, \sigma) \land$  PARITY $(X, T', \sigma')$ . Thus the final part of the proof now involves refuting a formula equivalent to one of the **Dubois** formulas.

We create a proof that inductively shows equivalence or non-equivalence between variables  $t_j \in T$  and the  $t'_j \in T'$  starting from j = 1 to j = n - 3. If there is an even number of instances  $i, 1 \leq i \leq j + 1$  where  $\sigma'(x_i) \neq \sigma(x_i)$  we derive  $(t'_j \vee \bar{t}_j)$  and  $(\bar{t'}_j \vee t_j)$ . If there are an odd number of instances  $i, 1 \leq i \leq j + 1$ where  $\sigma'(x_i) \neq \sigma(x_i)$  we instead derive  $(\bar{t'}_j \vee \bar{t}_j)$  and  $(t'_j \vee t_j)$ .

Whichever case, we can increase j with the addition (ATA) of six clauses. We can think of this as working via DP resolution in a careful order:  $\sigma(x_{j+1})$ ,  $t_{j-1}$ ,  $t'_j$  from j = 1 to n-3 in increasing j (and treat  $\sigma(x_1)$  as  $t_0$ ).

Finally, when j = n - 3, we have either already exceeded the single value i such that  $\sigma'(x_i) \neq \sigma(x_i)$ , or it appears in n - 1 or n. Either way, we can add the four clauses  $(\sigma(x_{n-1}) \lor \sigma(x_n)), (\neg \sigma(x_{n-1}) \lor \sigma(x_n)), (\sigma(x_{n-1}) \lor \neg \sigma(x_n)), (\neg \sigma(x_{n-1}) \lor \neg \sigma(x_n))$  then the two unit clauses  $(\sigma(x_n))$  and  $(\neg \sigma(x_n))$  and finally the empty clause. This final part of the refutation uses  $\mathcal{O}(n)$  many ATA steps.

### 4 Evaluation

The formulas we ran experiments on are labelled  $\operatorname{rpar}(n,g)$ . Which represent  $\operatorname{PARITY}(X,T,\sigma_{(n,g)}) \wedge \operatorname{PARITY}(X,T',e)$  using the DIMACS format. The parameter n is the number of input variables and a random number generator g. The CNF uses variables  $X = \{1,\ldots,n\}, T = \{n+1,\ldots,2n-3\}, T' = \{2n-2,\ldots,3n-6\}, e$  is the identity permutation, and  $\sigma_{(n,g)}$  is a random permutation based on g, where one random literal  $i_{n,g}$  is flipped by  $\sigma$ .

We ran a program rParSort that generated an instance  $rpar(n, rnd_s)$  based on a seed s and also generated a DRAT proof based on Theorem 1. We compare the size of our proofs by ones produced by the state-of-the-art SAT solver CaDiCaL [1] (version 1.2.1) and the tool EBDDRES [17] (version 1.1). The latter solves the instance using binary decision diagrams and turns the construction into an ER proof. These ER proofs can easily be transformed into the DRAT format as DRAT generalizes ER. Proof sizes (in the number of DRAT steps, i.e. lines in the proof) are presented and compared in Figure 4.

rParSort proofs remained feasible for values as large as n = 4000 with proofs only being 150MB due to the  $\mathcal{O}(n \log n)$  upper bound in proof lines. We believe



**Fig. 4.** rParSort proof sizes for rpar $(n, \text{rnd}_{53})$  formulas (left). Comparisons of average (of 10) proof sizes on  $n \in \{35, \ldots, 45\}$  (right).

leading coefficient is also kept small by number of factors such as the proof lines being width 4 and only 16 being needed per swap step.

CaDiCaL showed difficulty for modest values of n. While proofs with less than  $10^6$  lines are common for n = 35, the size and running time grows exponentially and by n = 41 proofs are larger than  $10^7$  lines. CaDiCaL times out using a 5000 seconds limit on some instances with n = 46 and on most instances with  $n \ge 50$ .

The size of proofs produced by EBDDRES appears to grow slower compared to CDCL, which is not surprising as BDDs can solve the formulas in polynomial time. However, as can be observed in Figure 4, the ER proofs are actually bigger for small n. The extracted DRAT proofs (converted from the ER proofs) are large: the average proof with  $n \ge 35$  had more than  $10^7$  lines. This means that this BDD-based approach is not practical to express parity reasoning in DRAT.

## 5 Conclusion

We have shown that through manipulating existing encoding variables DRAT can take advantage of the commutativity of xor definitions via Lemma 1. Our proof generator is capable of producing reasonable-sized proofs for instances with tens of thousands of variables, while state-of-the-art SAT solvers without xor detection and Gaussian elimination, such as CaDiCaL, can only solve instances up to about 60 variables. Although these formulas are also doable for BDD-based approaches, the resulting proofs are too big for practical purposes.

The DRAT proofs are in the fragment of DRAT<sup>-</sup>, where the number of variables stays fixed, which is of potential benefit to the checker. If we are not concerned with the introduction of new variables, our DRAT proofs can easily be made into ER proofs with only a 50% increase in addition steps (and the introduction of new variables). This is an alternative approach that may prove useful in other settings where elimination of a variable is not so easy.

Acknowledgements. The authors thank Armin Biere for his useful comments on an earlier draft. This work has been support by the National Science Foundation (NSF) under grant CCF-1618574.

# References

- 1. Biere, A.: CaDiCaL at the SAT Race 2019 (2019)
- Buss, S., Thapen, N.: DRAT proofs, propagation redundancy, and extended resolution. In: International Conference on Theory and Applications of Satisfiability Testing. pp. 71–89. Springer (2019)
- 3. Crawford, J.M., Kearns, M.J., Schapire, R.E.: The minimal disagreement parity problem as a hard satisfiability problem (1994)
- Davis, M., Putnam, H.: A computing procedure for quantification theory. Journal of the ACM 7, 210–215 (1960)
- Han, C.S., Jiang, J.H.R.: When Boolean satisfiability meets Gaussian elimination in a simplex way. In: Madhusudan, P., Seshia, S.A. (eds.) Computer Aided Verification. pp. 410–426. Springer, Berlin, Heidelberg (2012)
- Heule, M., van Maaren, H.: Aligning CNF- and equivalence-reasoning. In: Hoos, H.H., Mitchell, D.G. (eds.) Theory and Applications of Satisfiability Testing. pp. 145–156. Springer, Berlin, Heidelberg (2005)
- Järvisalo, M., Heule, M.J.H., Biere, A.: Inprocessing rules. In: Gramlich, B., Miller, D., Sattler, U. (eds.) Automated Reasoning. pp. 355–370. Springer, Berlin, Heidelberg (2012)
- Kiesl, B., Rebola-Pardo, A., Heule, M.J.H.: Extended resolution simulates DRAT. In: Galmiche, D., Schulz, S., Sebastiani, R. (eds.) Automated Reasoning - 9th International Joint Conference, IJCAR 2018, Held as Part of the Federated Logic Conference, FloC 2018, Oxford, UK, July 14–17, 2018, Proceedings. Lecture Notes in Computer Science, vol. 10900, pp. 516–531. Springer (2018)
- Laitinen, T., Junttila, T., Niemelä, I.: Extending clause learning DPLL with parity reasoning. In: Proceedings of the 2010 Conference on ECAI 2010: 19th European Conference on Artificial Intelligence. pp. 21–26. IOS Press, NLD (2010)
- Laitinen, T., Junttila, T., Niemela, I.: Equivalence class based parity reasoning with DPLL(XOR). In: Proceedings of the 2011 IEEE 23rd International Conference on Tools with Artificial Intelligence. pp. 649–658. ICTAI '11, IEEE Computer Society, USA (2011)
- 11. Li, C.M.: Equivalent literal propagation in the DLL procedure. Discrete Applied Mathematics **130**(2), 251–276 (2003), the Renesse Issue on Satisfiability
- Marques Silva, J.P., Lynce, I., Malik, S.: Conflict-driven clause learning SAT solvers. In: Handbook of Satisfiability. IOS Press (2009)
- Ostrowski, R., Grégoire, É., Mazure, B., Saïs, L.: Recovering and exploiting structural knowledge from CNF formulas. In: Van Hentenryck, P. (ed.) Principles and Practice of Constraint Programming - CP 2002. pp. 185–199. Springer, Berlin, Heidelberg (2002)
- Philipp, T., Rebola-Pardo, A.: DRAT proofs for XOR reasoning. In: Michael, L., Kakas, A. (eds.) Logics in Artificial Intelligence. pp. 415–429. Springer International Publishing, Cham (2016)
- 15. Pipatsrisawat, K., Darwiche, A.: On the power of clause-learning SAT solvers as resolution engines. Artificial Intelligence **175**(2), 512–525 (2011)

- Robinson, J.A.: Theorem-proving on the computer. Journal of the ACM 10(2), 163–174 (1963)
- Sinz, C., Biere, A.: Extended resolution proofs for conjoining BDDs. In: Grigoriev, D., Harrison, J., Hirsch, E.A. (eds.) Computer Science – Theory and Applications. pp. 600–611. Springer, Berlin, Heidelberg (2006)
- Soos, M.: Enhanced Gaussian elimination in DPLL-based SAT solvers. In: Berre, D.L. (ed.) POS-10. Pragmatics of SAT. EPiC Series in Computing, vol. 8, pp. 2–14. EasyChair (2012)
- Soos, M., Nohl, K., Castelluccia, C.: Extending SAT solvers to cryptographic problems. In: Kullmann, O. (ed.) Theory and Applications of Satisfiability Testing -SAT 2009. pp. 244–257. Springer, Berlin, Heidelberg (2009)
- Tseitin, G.C.: On the complexity of derivations in propositional calculus. In: Slisenko, A.O. (ed.) Studies in Mathematics and Mathematical Logic, Part II, pp. 115–125 (1968)
- Urquhart, A.: Hard examples for resolution. Journal of the ACM 34(1), 209–219 (1987)
- Warners, J.P., van Maaren, H.: A two-phase algorithm for solving a class of hard satisfiability problems. Operations Research Letters 23(3), 81–88 (1998). ISSN 0167-6377