From e7ff907e7c340f8dd59d47b6ec2922b854d5f5b8 Mon Sep 17 00:00:00 2001 From: Hamed Gorjiara Date: Thu, 13 Jun 2019 20:06:42 -0700 Subject: [PATCH] Adding support for reading wrong assumptions --- glucose-syrup/core/Solver.h | 2 ++ glucose-syrup/incremental/Main.cc | 21 +++++++++++++++++++++ glucose-syrup/simp/SimpSolver.h | 2 +- 3 files changed, 24 insertions(+), 1 deletion(-) diff --git a/glucose-syrup/core/Solver.h b/glucose-syrup/core/Solver.h index 63d5316..b0cd3b0 100644 --- a/glucose-syrup/core/Solver.h +++ b/glucose-syrup/core/Solver.h @@ -135,6 +135,7 @@ public: int nClauses () const; // The current number of original clauses. int nLearnts () const; // The current number of learnt clauses. int nVars () const; // The current number of variables. + int assumptionsSize () const; // The current number of variables. int nFreeVars () const; inline char valuePhase(Var v) {return polarity[v];} @@ -477,6 +478,7 @@ inline int Solver::nAssigns () const { return trail.size(); } inline int Solver::nClauses () const { return clauses.size(); } inline int Solver::nLearnts () const { return learnts.size(); } inline int Solver::nVars () const { return vardata.size(); } +inline int Solver::assumptionsSize () const { return assumptions.size(); } inline int Solver::nFreeVars () const { return (int)dec_vars - (trail_lim.size() == 0 ? trail.size() : trail_lim[0]); } inline void Solver::setPolarity (Var v, bool b) { polarity[v] = b; } inline void Solver::setDecisionVar(Var v, bool b) diff --git a/glucose-syrup/incremental/Main.cc b/glucose-syrup/incremental/Main.cc index 9183e8e..b973afb 100644 --- a/glucose-syrup/incremental/Main.cc +++ b/glucose-syrup/incremental/Main.cc @@ -113,9 +113,11 @@ void readClauses(Solver *solver) { vec clause; int numvars = solver->nVars(); bool haveClause = false; + fprintf(stderr,"Let's read clauses ...\n"); while(true) { int lit=getInt(); if (lit!=0) { +// fprintf(stderr,"%d ", lit); int var = abs(lit) - 1; while (var >= numvars) { numvars++; @@ -124,11 +126,13 @@ void readClauses(Solver *solver) { clause.push( (lit>0) ? mkLit(var) : ~mkLit(var)); haveClause = true; } else { +// fprintf(stderr, "\n"); if (haveClause) { solver->addClause_(clause); haveClause = false; clause.clear(); } else { +// fprintf(stderr, "****************************************************************\n"); //done with clauses return; } @@ -142,12 +146,20 @@ void processCommands(SimpSolver *solver) { switch(command) { case IS_FREEZE: { int var=getInt()-1; +// fprintf(stderr, "Freezing %d\n", var); solver->setFrozen(var, true); break; } case IS_RUNSOLVER: { vec dummy; +// SimpSolver* solver2 = (SimpSolver*)solver->clone(); + double time1 = cpuTime(); lbool ret = solver->solveLimited(dummy); +// double time2 = cpuTime(); +// vec dummy2; +// lbool ret2 = solver2->solveLimited(dummy2); +// double time3 = cpuTime(); +// fprintf( stderr, "First execution time: %f\t second execution time: %f\n", time2 - time1, time3-time2); if (ret == l_True) { putInt(IS_SAT); putInt(solver->nVars()); @@ -156,6 +168,15 @@ void processCommands(SimpSolver *solver) { } } else if (ret == l_False) { putInt(IS_UNSAT); + putInt(solver->assumptionsSize()); + fprintf(stderr, "assumption size = %d\nConflict Array: ",solver->assumptionsSize()); + for(int i=0;iconflict.size();i++) { + fprintf(stderr, "%d = %d, ", i, sign(solver->conflict[i])==true); + } + fprintf(stderr, "\n***********************\n"); + for(int i=0;iassumptionsSize();i++) { + putInt(sign(solver->conflict[i])==true); + } } else { putInt(IS_INDETER); } diff --git a/glucose-syrup/simp/SimpSolver.h b/glucose-syrup/simp/SimpSolver.h index 5f457a8..c7dcff7 100644 --- a/glucose-syrup/simp/SimpSolver.h +++ b/glucose-syrup/simp/SimpSolver.h @@ -193,7 +193,7 @@ class SimpSolver : public Solver { bool backwardSubsumptionCheck (bool verbose = false); bool eliminateVar (Var v); void extendModel (); - + void unsatExplanation(); void removeClause (CRef cr,bool inPurgatory=false); bool strengthenClause (CRef cr, Lit l); void cleanUpClauses (); -- 2.34.1