CBMC
satcheck_picosat.h
Go to the documentation of this file.
1 /*******************************************************************\
2 
3 Module:
4 
5 Author: Michael Tautschnig, michael.tautschnig@cs.ox.ac.uk
6 
7 \*******************************************************************/
8 
9 
10 #ifndef CPROVER_SOLVERS_SAT_SATCHECK_PICOSAT_H
11 #define CPROVER_SOLVERS_SAT_SATCHECK_PICOSAT_H
12 
13 #include "cnf.h"
14 
15 // NOLINTNEXTLINE(readability/identifiers)
16 struct PicoSAT;
17 
19 {
20 public:
23 
24  const std::string solver_text() override;
25  tvt l_get(literalt a) const override;
26 
27  void lcnf(const bvt &bv) override;
28  void set_assignment(literalt a, bool value) override;
29 
30  bool is_in_conflict(literalt a) const override;
31  void set_assumptions(const bvt &_assumptions) override;
32  bool has_set_assumptions() const override
33  {
34  return true;
35  }
36  bool has_is_in_conflict() const override
37  {
38  return true;
39  }
40 
41 protected:
42  resultt do_prop_solve() override;
43 
45 
46 private:
47  PicoSAT *picosat;
48 };
49 
50 #endif // CPROVER_SOLVERS_SAT_SATCHECK_PICOSAT_H
satcheck_picosatt::set_assumptions
void set_assumptions(const bvt &_assumptions) override
Definition: satcheck_picosat.cpp:127
resultt
resultt
The result of goto verifying.
Definition: properties.h:44
bvt
std::vector< literalt > bvt
Definition: literal.h:201
satcheck_picosatt::set_assignment
void set_assignment(literalt a, bool value) override
Definition: satcheck_picosat.cpp:105
cnf_solvert
Definition: cnf.h:72
satcheck_picosatt::l_get
tvt l_get(literalt a) const override
Definition: satcheck_picosat.cpp:25
satcheck_picosatt::picosat
PicoSAT * picosat
Definition: satcheck_picosat.h:47
tvt
Definition: threeval.h:19
satcheck_picosatt::has_set_assumptions
bool has_set_assumptions() const override
Definition: satcheck_picosat.h:32
satcheck_picosatt::assumptions
bvt assumptions
Definition: satcheck_picosat.h:44
satcheck_picosatt::solver_text
const std::string solver_text() override
Definition: satcheck_picosat.cpp:46
satcheck_picosatt::is_in_conflict
bool is_in_conflict(literalt a) const override
Returns true if an assumption is in the final conflict.
Definition: satcheck_picosat.cpp:120
literalt
Definition: literal.h:25
satcheck_picosatt::lcnf
void lcnf(const bvt &bv) override
Definition: satcheck_picosat.cpp:51
satcheck_picosatt
Definition: satcheck_picosat.h:18
satcheck_picosatt::has_is_in_conflict
bool has_is_in_conflict() const override
Definition: satcheck_picosat.h:36
satcheck_picosatt::~satcheck_picosatt
~satcheck_picosatt()
Definition: satcheck_picosat.cpp:115
satcheck_picosatt::do_prop_solve
resultt do_prop_solve() override
Definition: satcheck_picosat.cpp:68
cnf.h
satcheck_picosatt::satcheck_picosatt
satcheck_picosatt()
Definition: satcheck_picosat.cpp:110