1 #include "sattranslator.h"
4 #include "satencoder.h"
6 uint64_t getElementValueBinaryIndexSATTranslator(CSolver* This, ElementEncoding* elemEnc){
8 for(int i=elemEnc->numVars-1;i>=0;i--) {
10 if (This->satEncoder->cnf->solver->solution[ getEdgeVar( elemEnc->variables[i] ) ])
13 ASSERT(elemEnc->encArraySize >index && isinUseElement(elemEnc, index));
14 return elemEnc->encodingArray[index];
17 uint64_t getElementValueBinaryValueSATTranslator(CSolver* This, ElementEncoding* elemEnc){
18 //THIS WILL PROBABLY BE WRONG SINCE THE VALUES CAN BE OFFSET
20 for(int i=elemEnc->numVars-1;i>=0;i--) {
22 if (This->satEncoder->cnf->solver->solution[ getEdgeVar( elemEnc->variables[i] ) ])
28 uint64_t getElementValueOneHotSATTranslator(CSolver* This, ElementEncoding* elemEnc){
30 for(int i=elemEnc->numVars-1;i>=0;i--) {
31 if (This->satEncoder->cnf->solver->solution[ getEdgeVar( elemEnc->variables[i] ) ])
34 ASSERT(elemEnc->encArraySize >index && isinUseElement(elemEnc, index));
35 return elemEnc->encodingArray[index];
38 uint64_t getElementValueUnarySATTranslator(CSolver* This, ElementEncoding* elemEnc){
40 for(i=0;i<elemEnc->numVars;i++) {
41 if (!This->satEncoder->cnf->solver->solution[ getEdgeVar( elemEnc->variables[i] ) ]) {
46 return elemEnc->encodingArray[i];
49 uint64_t getElementValueSATTranslator(CSolver* This, Element* element){
50 ElementEncoding* elemEnc = getElementEncoding(element);
51 switch(elemEnc->type){
53 getElementValueOneHotSATTranslator(This, elemEnc);
56 getElementValueUnarySATTranslator(This, elemEnc);
59 return getElementValueBinaryIndexSATTranslator(This, elemEnc);
73 bool getBooleanVariableValueSATTranslator( CSolver* This , Boolean* boolean){
74 int index = getEdgeVar( ((BooleanVar*) boolean)->var );
75 return This->satEncoder->cnf->solver->solution[index] == true;