f2db838c409b7aa0557b941847a9c56421570cd0
[satune.git] / src / csolver.h
1 #ifndef CSOLVER_H
2 #define CSOLVER_H
3 #include "classlist.h"
4 #include "ops.h"
5 #include "structs.h"
6
7 struct CSolver {
8         VectorBoolean * constraint;
9         uint64_t uniqSec;
10 };
11         
12 CSolver * allocCSolver();
13 Set * createSet(CSolver *, VarType type, uint64_t * elements, uint num);
14 Set * createRangeSet(CSolver *, VarType type, uint64_t lowrange, uint64_t highrange);
15 MutableSet * createMutableSet(CSolver *, VarType type);
16
17 void addItem(CSolver *, MutableSet * set, uint64_t element);
18 int64_t createUniqueItem(CSolver *, MutableSet * set);
19
20 Element * getElementVar(CSolver *, Set * set);
21 Boolean * getBooleanVar(CSolver *);
22
23 Function * createFunctionOperator(CSolver *, enum ArithOp op, Set ** domain, Set * range, enum OverFlowBehavior overflowbehavior, Boolean * overflowstatus);
24 //Does Not Overflow
25 Function * createFunctionOperatorPure(CSolver *, enum ArithOp op);
26 Predicate * createPredicateOperator(CSolver *, enum CompOp op, Set ** domain);
27
28 Table * createTable(CSolver *, Set **domains, Set * range);
29 void addTableEntry(CSolver *, Element ** inputs, Element *result);
30 Function * completeTable(CSolver *, struct Table *);
31
32 Element * applyFunction(CSolver *, Function * function, Element ** array);
33 Boolean * applyPredicate(CSolver *, Predicate * predicate, Element ** inputs);
34 Boolean * applyLogicalOperation(CSolver *, enum LogicOp op, Boolean ** array);
35
36 void addBoolean(CSolver *, Boolean * constraint);
37
38 Order * createOrder(CSolver *, enum OrderType type, Set * set);
39 Boolean * orderConstraint(CSolver *, Order * order, uint64_t first, uint64_t second);
40 #endif