Painless
A framework to ease parallelization of sequential CDCL SAT solvers
Loading...
Searching...
No Matches
MiniSat.hpp
1#pragma once
2
3#include "containers/ClauseBuffer.hpp"
4#include "containers/ClauseDatabase.hpp"
5#include "solvers/CDCL/SolverCdclInterface.hpp"
6#include "utils/Threading.hpp"
7
8#define MINISAT_
9
10// Some forward declatarations for Minisat
11namespace Minisat {
12class SimpSolver;
13class Lit;
14template<class T, class _Size>
15class vec;
16}
17
21{
22 public:
24 void loadFormula(const char* filename);
25
27 unsigned int getVariablesCount();
28
31
33 void setPhase(const unsigned int var, const bool phase);
34
36 void bumpVariableActivity(const int var, const int times);
37
40
43
45 SatResult solve(const std::vector<int>& cube);
46
48 void addClause(ClauseExchangePtr clause);
49
51 void addClauses(const std::vector<ClauseExchangePtr>& clauses);
52
54 void addInitialClauses(const std::vector<simpleClause>& clauses, unsigned int nbVars) override;
55
57 bool importClause(const ClauseExchangePtr& clause);
58
60 void importClauses(const std::vector<ClauseExchangePtr>& clauses);
61
64
65 void printWinningLog() override;
66
68 std::vector<int> getModel();
69
71 void diversify(const SeedGenerator& getSeed) override;
72
73 std::vector<int> getFinalAnalysis();
74
75 std::vector<int> getSatAssumptions();
76
78 MiniSat(int id, const std::shared_ptr<ClauseDatabase>& clauseDB);
79
81 virtual ~MiniSat();
82
83 protected:
85 Minisat::SimpSolver* solver;
86
88 std::unique_ptr<ClauseDatabase> unitsToImport;
89
92
94 std::atomic<int> sizeLimit;
95
98 friend Minisat::Lit minisatImportUnit(void*);
99 friend bool minisatImportClause(void*, Minisat::vec<Minisat::Lit, int>&);
100};
Wrapper for boost::lockfree::queue to manage ClauseExchange objects.
Definition ClauseBuffer.hpp:26
Instance of a Minisat solver.
Definition MiniSat.hpp:21
void loadFormula(const char *filename)
Load formula from a given dimacs file, return false if failed.
std::vector< int > getFinalAnalysis()
Get the final analysis in case of UNSAT result.
friend void minisatExportClause(void *, Minisat::vec< Minisat::Lit, int > &)
Callback to export/import clauses.
ClauseBuffer clausesToAdd
Buffer used to add permanent clauses.
Definition MiniSat.hpp:91
void bumpVariableActivity(const int var, const int times)
Bump activity of a given variable.
SatResult solve(const std::vector< int > &cube)
Solve the formula with a given cube.
std::vector< int > getModel()
Return the model in case of SAT result.
Minisat::SimpSolver * solver
Pointer to a Minisat solver.
Definition MiniSat.hpp:85
void setSolverInterrupt()
Interrupt resolution, solving cannot continue until interrupt is unset.
void addInitialClauses(const std::vector< simpleClause > &clauses, unsigned int nbVars) override
Add a list of initial clauses to the formula.
void unsetSolverInterrupt()
Remove the SAT solving interrupt request.
std::unique_ptr< ClauseDatabase > unitsToImport
Database used to import units.
Definition MiniSat.hpp:88
void setPhase(const unsigned int var, const bool phase)
Set initial phase for a given variable.
void printWinningLog() override
Print the winning log.
void addClause(ClauseExchangePtr clause)
Add a permanent clause to the formula.
std::atomic< int > sizeLimit
Size limit used to share clauses.
Definition MiniSat.hpp:94
void addClauses(const std::vector< ClauseExchangePtr > &clauses)
Add a list of permanent clauses to the formula.
unsigned int getVariablesCount()
Get the number of variables of the current resolution.
bool importClause(const ClauseExchangePtr &clause)
Add a learned clause to the formula.
virtual ~MiniSat()
Destructor.
int getDivisionVariable()
Get a variable suitable for search splitting.
MiniSat(int id, const std::shared_ptr< ClauseDatabase > &clauseDB)
Constructor.
void diversify(const SeedGenerator &getSeed) override
Native diversification.
void importClauses(const std::vector< ClauseExchangePtr > &clauses)
Add a list of learned clauses to the formula.
void printStatistics()
Get solver statistics.
std::vector< int > getSatAssumptions()
Get current assumptions.
Definition MiniSat.hpp:15
Interface for CDCL (Conflict-Driven Clause Learning) solvers This class provides a common interface f...
Definition SolverCdclInterface.hpp:58
SatResult
Enumeration for SAT solver results.
Definition SolverInterface.hpp:39