File: ccl_satinterface.h

package info (click to toggle)
eprover 2.6%2Bds-3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 21,288 kB
  • sloc: ansic: 331,111; csh: 12,026; python: 10,178; awk: 5,825; makefile: 461; sh: 389
file content (130 lines) | stat: -rw-r--r-- 4,730 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
/*-----------------------------------------------------------------------

  File  : ccl_satinterface.h

  Author: Stephan Schulz

  Contents

  Datatypes and declarations for efficient conversion of the proof
  state to propositional clauses and submission to a SAT solver.

  Copyright 2017 by the author.
  This code is released under the GNU General Public Licence and
  the GNU Lesser General Public License.
  See the file COPYING in the main E directory for details..
  Run "eprover -h" for contact information.

  Changes

  Created: Fri Sep 15 20:29:49 CEST 2017

  -----------------------------------------------------------------------*/

#ifndef CCL_SATINTERFACE

#define CCL_SATINTERFACE

#include <ccl_proofstate.h>
#include <cio_tempfile.h>
#include <picosat.h>

/*---------------------------------------------------------------------*/
/*                    Data type declarations                           */
/*---------------------------------------------------------------------*/



typedef struct satclausecell
{
   bool       has_pure_lit;
   int        lit_no;   // lit_no is actual number of literals
   int *      literals; // null-terminated (PicoSAT requirement),
                        // length(literals) = lit_no+1 !
   Clause_p   source;
}SatClauseCell, *SatClause_p;

typedef struct satclausesetcell
{
   PDRangeArr_p renumber_index; // Used to map term->id to [0...max_lit]
   int          max_lit;
   PStack_p     set;            // Actual set (clauses must be freed)
   PStack_p     exported;       // Subset of clauses exported to the solver state
   long         core_size;      // Size of the unsat core, if any
   long         set_size_limit; // Limit after which insertions will fail
                                // if -1 no limit is set.
}SatClauseSetCell, *SatClauseSet_p;


typedef enum
{
   GMNoGrounding,
   GMPseudoVar,
   GMFirstConst,
   GMConjMinMinFreq, /* Rarest conjecture constant */
   GMConjMaxMinFreq,
   GMConjMinMaxFreq, /* Rarest in conjectures, most frequent overall */
   GMConjMaxMaxFreq,
   GMGlobalMax,
   GMGlobalMin
}GroundingStrategy;

typedef bool (*SatClauseFilter)(SatClause_p);
typedef PicoSAT* SatSolver_p;

/*---------------------------------------------------------------------*/
/*                Exported Functions and Variables                     */
/*---------------------------------------------------------------------*/

extern char* GroundingStratNames[];

#define SatClauseCellAlloc()    (SatClauseCell*)SizeMalloc(sizeof(SatClauseCell))
#define SatClauseCellFree(junk) SizeFree(junk, sizeof(SatClauseCell))

SatClause_p SatClauseAlloc(int lit_no);
void        SatClauseFree(SatClause_p junk);

#define SatClauseSetCellAlloc()    (SatClauseSetCell*)SizeMalloc(sizeof(SatClauseSetCell))
#define SatClauseSetCellFree(junk) SizeFree(junk, sizeof(SatClauseSetCell))

#define SatClauseSetMaxClausesSet(set, l) ((set)->set_size_limit = (l))
#define SatClauseSetLimitReached(s) ((s)->set_size_limit ==\
                                       (PStackGetSP((s)->set))) 


SatClauseSet_p SatClauseSetAlloc(void);
void           SatClauseSetFree(SatClauseSet_p junk);

#define SatClauseSetCardinality(satset) PStackGetSP((satset)->set)
#define SatClauseSetNonPureCardinality(satset) PStackGetSP((satset)->exported)
#define SatClauseSetCoreSize(satset) (satset)->core_size


SatClause_p SatClauseCreateAndStore(Clause_p clause, SatClauseSet_p set);
void        SatClausePrint(FILE* out, SatClause_p satclause);

void        SatClauseSetPrint(FILE* out, SatClauseSet_p set);

void        SatClauseSetExportToSolver(SatSolver_p solver, SatClauseSet_p set);
void        SatClauseSetExportToSolverNonPure(SatSolver_p solver, SatClauseSet_p set);

Subst_p     SubstPseudoGroundVarBank(VarBank_p vars);
Subst_p     SubstGroundVarBankFirstConst(TB_p terms, bool norm_const);
Subst_p     SubstGroundFreqBased(TB_p terms, ClauseSet_p clauses,
                                 FunConstCmpFunType is_better, bool norm_const);

long        SatClauseSetImportClauseSet(SatClauseSet_p satset, ClauseSet_p set);
long        SatClauseSetImportProofState(SatClauseSet_p satset, ProofState_p state,
                                         GroundingStrategy strat, bool norm_const);
long        SatClauseSetMarkPure(SatClauseSet_p satset);
ProverResult SatClauseSetCheckUnsat(SatClauseSet_p satset, Clause_p *empty,
                                    SatSolver_p solver,
                                    int sat_check_decision_level);



#endif

/*---------------------------------------------------------------------*/
/*                        End of File                                  */
/*---------------------------------------------------------------------*/