File: cpr_dpll.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 (72 lines) | stat: -rw-r--r-- 2,233 bytes parent folder | download | duplicates (2)
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
/*-----------------------------------------------------------------------

File  : cpr_dpll.h

Author: Stephan Schulz

Contents

  Definitions for the main DPLL algorithm.

  Copyright 2003 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

<1> Tue May  6 02:04:46 CEST 2003
    New

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

#ifndef CPR_DPLL

#define CPR_DPLL

#include <cpr_varset.h>
#include <cpr_dpllformula.h>


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

typedef struct dpll_state_cell
{
   DPLLFormula_p form;
   PStack_p      assignment; /* Current assignment, atom code
                                represents positive assignment, -atom
                                code represents negative assignment */
   PStack_p      deactivated; /* Clauses that have been deactivated,
             each initiated by a NULL pointer */
   PStack_p      unproc_units; /* Known unprocessed unit clauses */
   AtomSet_p     open_atoms;  /* List of unassigned variables */
}DPLLStateCell, *DPLLState_p;



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

#define DPLLStateCellAlloc() (DPLLStateCell*)SizeMalloc(sizeof(DPLLStateCell))
#define DPLLStateCellFree(junk)            SizeFree(junk, sizeof(DPLLStateCell))

DPLLState_p DPLLStateAlloc(DPLLFormula_p form);
void        DPLLStateFree(DPLLState_p junk);

bool      DPLLAssignVar(DPLLState_p state, PLiteralCode assignment);
void      DPLLRetractLastAss(DPLLState_p state);

#endif

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