Merge branch 'master' of ssh://plrg.eecs.uci.edu/home/git/constraint_compiler
[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 * constraints;
9         VectorSet * sets;
10         VectorElement * elements;
11 };
12
13 CSolver * allocCSolver();
14 Set * createSet(CSolver *, VarType type, uint64_t * elements, uint num);
15 Set * createRangeSet(CSolver *, VarType type, uint64_t lowrange, uint64_t highrange);
16 MutableSet * createMutableSet(CSolver *, VarType type);
17
18 void addItem(CSolver *, MutableSet * set, uint64_t element);
19 uint64_t createUniqueItem(CSolver *, MutableSet * set);
20
21 Element * getElementVar(CSolver *, Set * set);
22 Boolean * getBooleanVar(CSolver *, VarType type);
23
24 Function * createFunctionOperator(CSolver *solver, enum ArithOp op, Set ** domain, uint numDomain, Set * range,
25         enum OverFlowBehavior overflowbehavior, Boolean * overflowstatus);
26 //Does Not Overflow
27 //Function * createFunctionOperatorPure(CSolver *, enum ArithOp op);
28 Predicate * createPredicateOperator(CSolver *solver, enum CompOp op, Set ** domain, uint numDomain);
29
30 Table * createTable(CSolver *solver, Set **domains, uint numDomain, Set * range);
31 void addTableEntry(CSolver *solver, uint64_t* inputs, uint inputSize, uint64_t result);
32 Function * completeTable(CSolver *, Table *);
33
34 Element * applyFunction(CSolver *, Function * function, Element ** array);
35 Boolean * applyPredicate(CSolver *, Predicate * predicate, Element ** inputs);
36 Boolean * applyLogicalOperation(CSolver *, enum LogicOp op, Boolean ** array);
37
38 void addBoolean(CSolver *, Boolean * constraint);
39
40 Order * createOrder(CSolver *, enum OrderType type, Set * set);
41 Boolean * orderConstraint(CSolver *, Order * order, uint64_t first, uint64_t second);
42 #endif