Painless
A framework to ease parallelization of sequential CDCL SAT solvers
Loading...
Searching...
No Matches
KissatMABSolver.hpp
1#pragma once
2
3#include "containers/ClauseBuffer.hpp"
4#include "containers/ClauseDatabase.hpp"
5#include "containers/ClauseUtils.hpp"
6#include "utils/Threading.hpp"
7#include <fstream>
8#include <iostream>
9#include <unordered_map>
10
11#include "KissatFamily.hpp"
12#include "SolverCdclInterface.hpp"
13
14#define KISSAT_MAB_
15
16// KissatMABSolver includes
17extern "C"
18{
19#include "kissat_mab/src/kissat.h"
20}
21
22// Wrapping struct
23typedef struct kissat kissat_mab;
24
28{
29 public:
30 void setBumpVar(int v);
31
33 void loadFormula(const char* filename);
34
36 unsigned int getVariablesCount();
37
40
42 void setPhase(const unsigned int var, const bool phase);
43
45 void bumpVariableActivity(const int var, const int times);
46
49
52
54 SatResult solve(const std::vector<int>& cube);
55
57 void addClause(ClauseExchangePtr clause);
58
60 void addClauses(const std::vector<ClauseExchangePtr>& clauses);
61
63 void addInitialClauses(const std::vector<simpleClause>& clauses, unsigned int nbVars) override;
64
66 bool importClause(const ClauseExchangePtr& clause) override;
67
69 void importClauses(const std::vector<ClauseExchangePtr>& clauses) override;
70
73
74 void printWinningLog() override;
75
77 void setFamily(KissatFamily family) { this->family = family; };
78
79 void computeFamily();
80
82 std::vector<int> getModel();
83
85 void diversify(const SeedGenerator& getSeed) override;
86
89
91 KissatMABSolver(int id, const std::shared_ptr<ClauseDatabase>& clauseDB);
92
95
96 std::vector<int> getFinalAnalysis();
97
98 std::vector<int> getSatAssumptions();
99
101 std::unordered_map<std::string, int> kissatMABOptions;
102
103 protected:
104 int bump_var;
105
107 kissat_mab* solver;
108
110
113
115 std::atomic<bool> stopSolver;
116
117 KissatFamily family;
118
120 /* Decided to not use pointers to move because of c++ stl (cannot move an array into a vector,
121 * sharedPtr destruction) */
122 friend char KissatMabImportUnit(void*, kissat*);
123 /* With KissatMabImportClause(void *painless_interface, int *kclause, unsigned int *size): need to not
124 * use sharedPtr*/
125 friend char KissatMabImportClause(void*, kissat*);
126 friend char KissatMabExportClause(void*, kissat*);
127};
Wrapper for boost::lockfree::queue to manage ClauseExchange objects.
Definition ClauseBuffer.hpp:26
Instance of a KissatMABSolver solver.
Definition KissatMABSolver.hpp:28
int getDivisionVariable()
Get a variable suitable for search splitting.
void loadFormula(const char *filename)
Load formula from a given dimacs file, return false if failed.
void bumpVariableActivity(const int var, const int times)
Bump activity of a given variable.
unsigned int getVariablesCount()
Get the number of variables of the current resolution.
void addClause(ClauseExchangePtr clause)
Add a permanent clause to the formula.
void diversify(const SeedGenerator &getSeed) override
Native diversification.
virtual ~KissatMABSolver()
Destructor.
void printStatistics()
Get solver statistics.
std::vector< int > getModel()
Return the model in case of SAT result.
void setSolverInterrupt()
Interrupt resolution, solving cannot continue until interrupt is unset.
void setPhase(const unsigned int var, const bool phase)
Set initial phase for a given variable.
KissatMABSolver(int id, const std::shared_ptr< ClauseDatabase > &clauseDB)
Constructor.
void printWinningLog() override
Print the winning log.
void setFamily(KissatFamily family)
Set family from working strategy.
Definition KissatMABSolver.hpp:77
void initkissatMABOptions()
Initializes the map kissatOptions with the default configuration.
friend char KissatMabImportUnit(void *, kissat *)
Callback to export/import clauses used by real kissat.
SatResult solve(const std::vector< int > &cube)
Solve the formula with a given cube.
void unsetSolverInterrupt()
Remove the SAT solving interrupt request.
void addClauses(const std::vector< ClauseExchangePtr > &clauses)
Add a list of permanent clauses to the formula.
void importClauses(const std::vector< ClauseExchangePtr > &clauses) override
Add a list of learned clauses to the formula.
bool importClause(const ClauseExchangePtr &clause) override
Add a learned clause to the formula.
ClauseBuffer clausesToAdd
Buffer used to import clauses (units included).
Definition KissatMABSolver.hpp:112
void addInitialClauses(const std::vector< simpleClause > &clauses, unsigned int nbVars) override
Add a list of initial clauses to the formula.
kissat_mab * solver
Pointer to a KissatMABSolver solver.
Definition KissatMABSolver.hpp:107
std::vector< int > getFinalAnalysis()
Get the final analysis in case of UNSAT result.
std::atomic< bool > stopSolver
Used to stop or continue the resolution.
Definition KissatMABSolver.hpp:115
std::unordered_map< std::string, int > kissatMABOptions
A map mapping a kissat option name to its value.
Definition KissatMABSolver.hpp:101
std::vector< int > getSatAssumptions()
Get current assumptions.
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