560 likes | 808 Views
Satisfiability and Unsatisfiability: Proof Complexity and Algorithms. Paul Beame University of Washington. Outline. Intro to proof complexity Proof complexity and complete SAT algs Review Resolution/DPLL connection Application to random k-SAT Proof complexity and DPLL extensions
E N D
Satisfiability and Unsatisfiability: Proof Complexity and Algorithms Paul Beame University of Washington
Outline • Intro to proof complexity • Proof complexity and complete SAT algs • Review Resolution/DPLL connection • Application to random k-SAT • Proof complexity and DPLL extensions • Clause learning • Caching • Proof system survey
Proof Complexity • Study of the number of symbols required for proofs of unsatisfiability (or tautology) in propositional logic • Does not address algorithmic issue • How would you find short proofs if they existed? • Existence of short proofs for every unsatisfiable formula is equivalent to NP = co-NP (and is implied by P=NP) • Generally believed that such proofs don’t exist
Propositional proof systems • A propositional proof system is a polynomial time algorithmV s.t. for all formulas F • Fis unsatisfiable there exists a stringP s.t. V accepts input(P,F) • Note: • direction is usually called soundness • direction is usually called completeness • Proof complexity is size ofPas a function of the size ofF
Sample propositional proof systems • Truth tables • proof is a fully filled out truth table • easy to verify that it is filled out correctly and all truth assignments yield T • Frege systems • inference rules:e.g. modus ponens A,(A B) |B • axioms: e.g. excluded middle| (A A) • axioms & inference rules are schemas • can make consistent substitution of arbitrary formulas for variables in schema • e.g. excluded middle yields ((xy) (xy))
F5 F1 F2 F7 F6 F3 F8 F10 F11 F4 F9 F12 F13 The graph of a proof Axioms/inputs are sources Inference rule associated with each node Sink labelled by tautology (orLfor refutation)
Resolution • Start with clauses of CNF formula F • Resolution rule • Given (A x), (B x) derive (A B) • The empty clause is derivable F is unsatisfiable • Proof size = # of clauses used
Restricted forms of Resolution • Resolution • In general, graph of inferences is a directed acyclic graph • Tree Resolution • Graph of inferences forms a binary tree • i.e., if you want to use a clause more than once you need to re-derive it • Regular Resolution • Once a variable is resolved out of a clause you can’t add it back later • More general than Tree Resolution
Satisfiability Algorithms • Incomplete Algorithms • Local search GSAT [Selman,Levesque,Mitchell 92] Walksat [Kautz,Selman 96] • Belief Propagation SP [Braunstein, Mezard, Zecchina 02] • Complete Algorithms • Backtracking search DPLL [Davis,Putnam 60][Davis,Logeman,Loveland 62] DPLL + clause learning GRASP, SATO, zchaff, berkmin • etc
Proof Complexity and SAT Algorithms • Proof Complexity • Unsatisfiable formulas • Nondeterministic algorithms • SAT Algorithms • Satisfiable formulas • Deterministic or randomized algorithms
Proof complexity and complete satisfiability algorithms • In general • The transcript of the run of a complete satisfiability algorithm on an unsatisfiable formula is a proof of its unsatisfiability • For backtracking style algorithms • Even runs on satisfiable formulas yield proofs of unsatisfiability of related formulas
Backtracking search/DPLL DPLL(F) whileFcontains a 1-clause x F F|x=1 if F is empty return 1 if F has an empty clause return 0 else selecta literal x to branch on return DPLL(F|x=1) DPLL(F|x=0) Residual formula
Resolution and DPLL • DPLL tree with any variable selection rule on an unsatisfiable formula F generates a Resolution refutation of F • # of clauses running time • Note: Regular resolution corresponds to a similar DAG (read-once branching program) rather than a tree but general resolution has no such analogue
a a a b b b b b b c 3 d 3 c c b b d d 1 2 4 5 ab c d b ac a d DPLL Refutation Clauses 1.ab c 2.ab 3.c 4.a d 5.d b
a:L b: a b: a c: ab 3 d:a b 3 b b 1 4 5 2 ab c d b ac a d DPLL Refutation= Tree-like Resolution Proof Clauses 1.ab c 2.ac 3.b 4.a d 5.a b
Random k-CNF formulas • Randomly choose m clauses over n variables independently each of size k • Each size k clause is equally likely • Key parameter r=m/n, the ratio of clauses to variables: • Threshold value rk* of r • Below, almost certainly satisfiable • Above, almost certainly unsatisfiable • Hardest problems near threshold
probability satisfiable 1 0 4.267 DPLL on random 3-CNF* Proof complexity shows 2Q(n/r)time is required for unsatisfiable formulas for r r3* [B,Karp,Saks,Pitassi 98] [Ben-Sasson 02] # of DPLL backtracks What about satisfiable formulas below threshold? ratio of clauses to variables [Mitchell,Selman,Levesque 92] r * n = 50 variables
Some simple select choices for DPLL algorithms • UC: Unit Clause/Ordered DLL • Choose variables in a fixed order • Always set True first • UCwm: Unit Clause with majority • Choose variables in a fixed order • Apply a majority vote among 3-clauses for assigning each value • GUC: Generalized Unit Clause • Choose a variable v in a shortest clause C • Set v to satisfy C
Parameters of residual formulas follow trajectories 1 [Chao,Franco 88] [Frieze,Suen 95] [Achlioptas00] 2-clause ratio [Achlioptas,Sorkin 00] UC [Kaporis et al 03] GUC 2/3 8/3 3.52 0 3-clause ratio
Satisfiability for mixed random formulas: proven properties [Achlioptas et al 96] 1 [Kaporis et al 03] ? ? [Dubois 01] ? ? ? ? UNSAT 2-clause ratio ? ? ? ? SAT ? ? 3.52 2/3 2.28 4.501 3-clause ratio
Resolution proof complexity of mixed random formulas Theorem: [Achlioptas, B, Molloy 01]For any constants r21 and r3 0 random formulas with r2n2-clauses andr3n 3-clauses need exponential-size resolution proofs almost surely Extends [Chvatal-Szemeredi 88]
Long-running DPLL Executions and Proof Complexity Residual formula at each node is a mix of 2- and 3-clauses Residual formula at is unsatisfiable 2rn Every resolution Algorithm’s proof of unsatisfiability is exponentially long
Trajectory on 3-CNF UC Algorithm Trajectory 1 Provably UNSAT & Hard 2-clause ratio Provably SAT & Easy 0 4.51 3.81 3.52 4.267 3-clause ratio
Exponential lower bounds for 3-CNF formulas below ratio 4.267 Corollary For almost all 3-CNF formulas, above ratio • 3.81 UC takes exponential time • 3.83 UCwm takes exponential time • 4.01 GUC takes exponential time
Exponential lower bound below the proven k-CNF threshold • [Achlioptas, Peres 02]rk* 2k ln 2 – (k+4)/2 • [Achlioptas, B, Molloy 04] For k 4, for almost all k-CNF formulas UC takes exponential time above ratio c 2k/k Note These formulas have huge numbers of satisfying assignments (more than 2 (1-) n out of a possible 2n) but still are hard
Open Problem • Closing gap for unsatisfiability of mixed formulas would yield sharp threshold behavior for each algorithm A • Below rAalgorithm runs in linear time • Above rA algorithm requires exponential time • Conjecture: no polynomial time selection heuristicwill work up to the threshold • rA r3* for all algorithms A • Backtracking algorithms for other random problems with phase transitions? • e.g. k-colorability on random graphs G(n,r/n) • Unsatisfiable phase exp(cn/rak)[B, Culberson, Mitchell, Moore 03]
Outline • Intro to proof complexity • Proof complexity and complete SAT algs • Review Resolution/DPLL connection • Application to random k-SAT • Proof Complexity and DPLL extensions • Clause learning • Caching • Proof system survey
Clause Learning • At each backtrack point in DPLL search add new clauses to the input formula that correspond to known causes of failure of the search • Critical to the good behavior of the best current algorithms • What is the power of clause learning? • Intuitively: it makes DPLL trees DAG-like • regular resolution? general resolution?
x1 Conflict Graph y x2 false y x3 1-UIP scheme (t) p q a b t Decision scheme (p q b) Known Clauses (p q a) ( a b t) (t x1) (t x2) (t x3) (x1 x2 x3 y) (x2 y) Current decisions p false q false b true
Proof complexity and clause learning • Clause learning is no stronger than Resolution • Implication graph yields resolution derivation of each learned clause • There are examples where clause learning works in polynomial time but any Regular Resolution proof is exponential [Sabharwal, B, Kautz 04] • Clause learning can sometimes be much stronger than Regular Resolution
Proof complexity and clause learning • Separation is true for any proper subsystem R of Resolution for which refuting F|x is no harder than F • Clause learning does not have this property unless it is as powerful as resolution • Idea: Take formula F easy for Resolution but hard for R and create new formula F’ that is F plus clauses for (CpC) for each C in Resolution proof of F where each pC is a new propositional variable • Setting each pCto true yields original F but branching on sequence of pC allows sequence of clauses C to be learned
Still Open • Can clause learning do everything regular resolution can?* • Is clause learning as powerful as general resolution? * Note: Alan Van Gelder has pointed out that if one returns learned clauses up the tree and resolves them while backtracking then clause learning does efficiently simulate regular resolution
Proof Complexity and Formula Caching • Formula Caching: Memoization • Cache residual formulas that have been already found to be unsatisfiable • Do not make recursive call if the current residual formula is already cached
DPLL(F) if F is empty report satisfiable and halt if F contains the empty clause L backtrack else select a literal x DPLL(F|x) DPLL(F|x) DPLL
FC(F,L) if F is empty report satisfiable and halt if F contains the empty clause Lor FL return else choose a literal x FC(F|x,L) FC(F|x,L) add F to L Basic Formula Caching Start with FC(F,)
Proof Complexity of Formula Caching [B, Impagliazzo, Pitassi, Segerlind 03] • Basic Formula Caching can exponentially improve DPLL • Basic Formula Caching is not as powerful as regular resolution • but some of its natural extensions are • These natural extensions can be exponentially more powerful than general resolution or even Res(k) for any k! • Res(k) is like resolution but uses k-DNFs instead of clauses
Extensions of Formula Caching • Don’t just check membership in the cache • F is trivially unsatisfiable given G iff every clause of G contains some clause of F • Record the reasons why residual formulas are known to be unsatisfiable and check the reasons rather than the formulas
FC*(F,L) if F is empty report satisfiable and halt if F is trivially unsatisfiable given L add F to L return else choose a literal x FC*(F|x,L) FC*(F|x,L) add F to L More General Formula Caching
FCreason(F,L) if F is empty report satisfiable and halt if F is trivially unsatisfiable based on GL add F to L return(G) else choose a literal x GFCreason(F|x,L) HFCreason(F|x,L) J(xG) (xH) add F,J to L return(J) Adding Reasons
Combining Clause Learning and Formula Caching • Cachet system used to count # of satisfying assignments [Sang, Bacchus, B., Kautz, Pitassi 04] • Built on zchaff’s clause learning • Uses decomposition of residual formula into components • Caches components rather than the whole formula • Subtle interactions
Outline • Intro to proof complexity • Proof complexity and complete SAT algs • Resolution/DPLL review • Application to random k-SAT • DPLL extensions • Clause learning • Caching • Proof system survey
Proof Systems Hierarchy ZFC Ext-Frege Frege LS AC0-Frege Cutting Planes PCR Res(k) Polynomial Calculus Resolution DPLL Nullstellensatz Truth Tables
AC0-Frege • Constant-depth Frege (AC0-Frege) • Like Frege but formulas in proof only have constant # of alternations between and • Resolution is depth-1 Frege
Some Known Hard Problems for Resolution • Exact/Modular Counting • Pigeonhole principle: n+1 pigeons can’t fit into n pigeonholes without getting cosy with each other • Parity Principle: e.g. can’t pair up an odd number of people • Tseitin Tautologies • These problems are also hard for AC0-Frege • Random Unsatisfiable • k-CNF • Graph k-colorability • Existence of k-cliques in graphs
Cutting Planes/PseudoBoolean • Introduced to relate integer and linear programming [Gomory 59, Chvatal 73]: • Objects are linear integer inequalities • Clause(x1x2 x3)becomes inequality x1+(1-x2)+x31 • Addinequalitiesxi 0and 1-xi 0 • Goal: derive0 1
a1x1 + ... + anxn A b1x1 + ... + bnxn B (a1+b1)x1+...+(an+bn)xn A+B a1x1 + ... + anxn A ca1x1 + ... + canxn cA ca1x+ ... + canxn B a1x1 + ... + anxnB/c Cutting Planes rules • addition: • multiplication by positive integer: • Division by positive integer:
Limitations of Cutting Planes • At least as good as resolution • Can also handle • pigeonhole principle • parity principle • But can’t handle counting when it is a derived property • Clique-Coloring • A graph can’t have a k-clique and be k-1-colorable • Tseitin tautologies still open
Proof Systems Hierarchy ZFC Ext-Frege Frege LS AC0-Frege Cutting Planes PCR Res(k) Polynomial Calculus Resolution DPLL Nullstellensatz Truth Tables
Hilbert’s Nullstellensatz • System of polynomials Q1(x1,…,xn)=0,…,Qm(x1,…,xn)=0 over field Khas no solution in any extension field ofKthere exist polynomialsP1(x1,…,xn),…,Pm(x1,…,xn)inK[x1,…,xn] s.t.
Nullstellensatz proof system C • Clause (x1x2 x3)becomes equation (1-x1)x2(1-x3)=0 • Add equations xi2-xi =0for each variable • Guarantees only 0-1 solutions • A proof is polynomials P1,…, Pm+nproving unsatisfiability: i.e. such that QC