/** @file @ingroup cplusplus @brief Functions for the C++ object-oriented encapsulation of CUDD. @author Fabio Somenzi @copyright@parblock Copyright (c) 1995-2015, Regents of the University of Colorado All rights reserved. Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. Neither the name of the University of Colorado nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. @endparblock */ #include #include #include #include #include #include #include #include "epdInt.h" #include "cuddInt.h" #include "cuddObj.hh" using std::cout; using std::cerr; using std::ostream; using std::endl; using std::hex; using std::dec; using std::string; using std::vector; using std::sort; namespace cudd { // --------------------------------------------------------------------------- // Variable declarations // --------------------------------------------------------------------------- // --------------------------------------------------------------------------- // Members of class Capsule // --------------------------------------------------------------------------- /** @brief Class for reference counting of CUDD managers. @see Cudd DD ABDD ADD BDD ZDD */ class Capsule { public: Capsule(unsigned int numVars, unsigned int numVarsZ, unsigned int numSlots, unsigned int cacheSize, unsigned long maxMemory, PFC defaultHandler); ~Capsule(); #if HAVE_MODERN_CXX == 1 Capsule(Capsule const &) = delete; Capsule & operator=(Capsule const &) = delete; #else private: Capsule(Capsule const &); // not defined Capsule & operator=(Capsule const &); // not defined public: #endif DdManager *manager; PFC errorHandler; PFC timeoutHandler; PFC terminationHandler; std::vector varnames; int ref; bool verbose; }; Capsule::Capsule( unsigned int numVars, unsigned int numVarsZ, unsigned int numSlots, unsigned int cacheSize, unsigned long maxMemory, PFC defaultHandler) { errorHandler = defaultHandler; timeoutHandler = defaultHandler; terminationHandler = defaultHandler; manager = Cudd_Init(numVars, numVarsZ, numSlots, cacheSize, maxMemory); if (!manager) errorHandler("Out of memory"); verbose = 0; // initially terse ref = 1; } // Capsule::Capsule Capsule::~Capsule() { #ifdef DD_DEBUG if (manager) { int retval = Cudd_CheckZeroRef(manager); if (retval != 0) { cerr << retval << " unexpected non-zero reference counts" << endl; } else if (verbose) { cerr << "All went well" << endl; } } #endif for (vector::iterator it = varnames.begin(); it != varnames.end(); ++it) { delete [] *it; } Cudd_Quit(manager); } // Capsule::~Capsule // --------------------------------------------------------------------------- // Members of class DD // --------------------------------------------------------------------------- DD::DD() : p(0), node(0) {} DD::DD(Capsule *cap, DdNode *ddNode) : p(cap), node(ddNode) { if (node) Cudd_Ref(node); if (p->verbose) { cout << "Standard DD constructor for node " << hex << node << dec << " ref = " << Cudd_Regular(node)->ref << "\n"; } } // DD::DD DD::DD(Cudd const & manager, DdNode *ddNode) : p(manager.p), node(ddNode) { checkReturnValue(ddNode); if (node) Cudd_Ref(node); if (p->verbose) { cout << "Standard DD constructor for node " << hex << node << dec << " ref = " << Cudd_Regular(node)->ref << "\n"; } } // DD::DD DD::DD(const DD &from) { p = from.p; node = from.node; if (node) { Cudd_Ref(node); if (p->verbose) { cout << "Copy DD constructor for node " << hex << node << dec << " ref = " << Cudd_Regular(node)->ref << "\n"; } } } // DD::DD DD::~DD() {} inline DdManager * DD::checkSameManager( const DD &other) const { DdManager *mgr = p->manager; if (mgr != other.p->manager) { p->errorHandler("Operands come from different manager."); } return mgr; } // DD::checkSameManager inline void DD::checkReturnValue( const void *result) const { if (result == 0) { DdManager *mgr = p->manager; Cudd_ErrorType errType = Cudd_ReadErrorCode(mgr); switch (errType) { case CUDD_MEMORY_OUT: p->errorHandler("Out of memory."); break; case CUDD_TOO_MANY_NODES: break; case CUDD_MAX_MEM_EXCEEDED: p->errorHandler("Maximum memory exceeded."); break; case CUDD_TIMEOUT_EXPIRED: { std::ostringstream msg; unsigned long lag = Cudd_ReadElapsedTime(mgr) - Cudd_ReadTimeLimit(mgr); msg << "Timeout expired. Lag = " << lag << " ms."; p->timeoutHandler(msg.str()); } break; case CUDD_TERMINATION: { std::ostringstream msg; msg << "Terminated.\n"; p->terminationHandler(msg.str()); } break; case CUDD_INVALID_ARG: p->errorHandler("Invalid argument."); break; case CUDD_INTERNAL_ERROR: p->errorHandler("Internal error."); break; case CUDD_NO_ERROR: p->errorHandler("Unexpected error."); break; } } } // DD::checkReturnValue inline void DD::checkReturnValue( int result, int expected) const { if (result != expected) { DdManager *mgr = p->manager; Cudd_ErrorType errType = Cudd_ReadErrorCode(mgr); switch (errType) { case CUDD_MEMORY_OUT: p->errorHandler("Out of memory."); break; case CUDD_TOO_MANY_NODES: break; case CUDD_MAX_MEM_EXCEEDED: p->errorHandler("Maximum memory exceeded."); break; case CUDD_TIMEOUT_EXPIRED: { std::ostringstream msg; unsigned long lag = Cudd_ReadElapsedTime(mgr) - Cudd_ReadTimeLimit(mgr); msg << "Timeout expired. Lag = " << lag << " ms.\n"; p->timeoutHandler(msg.str()); } break; case CUDD_TERMINATION: { std::ostringstream msg; msg << "Terminated.\n"; p->terminationHandler(msg.str()); } break; case CUDD_INVALID_ARG: p->errorHandler("Invalid argument."); break; case CUDD_INTERNAL_ERROR: p->errorHandler("Internal error."); break; case CUDD_NO_ERROR: p->errorHandler("Unexpected error."); break; } } } // DD::checkReturnValue DdManager * DD::manager() const { return p->manager; } // DD::manager DdNode * DD::getNode() const { return node; } // DD::getNode DdNode * DD::getRegularNode() const { return Cudd_Regular(node); } // DD::getRegularNode int DD::nodeCount() const { return Cudd_DagSize(node); } // DD::nodeCount unsigned int DD::NodeReadIndex() const { return Cudd_NodeReadIndex(node); } // DD::NodeReadIndex // --------------------------------------------------------------------------- // Members of class ABDD // --------------------------------------------------------------------------- ABDD::ABDD() : DD() {} ABDD::ABDD(Capsule *cap, DdNode *bddNode) : DD(cap,bddNode) {} ABDD::ABDD(Cudd const & manager, DdNode *bddNode) : DD(manager,bddNode) {} ABDD::ABDD(const ABDD &from) : DD(from) {} ABDD::~ABDD() { if (node) { Cudd_RecursiveDeref(p->manager,node); if (p->verbose) { cout << "ADD/BDD destructor called for node " << hex << dec << node << " ref = " << Cudd_Regular(node)->ref << "\n"; } } } // ABDD::~ABDD bool ABDD::operator==( const ABDD& other) const { checkSameManager(other); return node == other.node; } // ABDD::operator== bool ABDD::operator!=( const ABDD& other) const { checkSameManager(other); return node != other.node; } // ABDD::operator!= bool ABDD::IsOne() const { return node == Cudd_ReadOne(p->manager); } // ABDD::IsOne void ABDD::print( int nvars, int verbosity) const { cout.flush(); if (!node) defaultError("empty DD."); int retval = Cudd_PrintDebug(p->manager,node,nvars,verbosity); fflush(Cudd_ReadStdout(p->manager)); checkReturnValue(retval); //if (retval == 0) p->errorHandler("print failed"); } // ABDD::print void ABDD::summary( int nvars, int mode) const { cout.flush(); if (!node) defaultError("empty DD."); int retval = Cudd_PrintSummary(p->manager,node,nvars,mode); fflush(Cudd_ReadStdout(p->manager)); checkReturnValue(retval); } // ABDD::summary // --------------------------------------------------------------------------- // Members of class BDD // --------------------------------------------------------------------------- BDD::BDD() : ABDD() {} BDD::BDD(Capsule *cap, DdNode *bddNode) : ABDD(cap,bddNode) {} BDD::BDD(Cudd const & manager, DdNode *bddNode) : ABDD(manager,bddNode) {} BDD::BDD(const BDD &from) : ABDD(from) {} BDD BDD::operator=( const BDD& right) { if (this == &right) return *this; if (right.node) Cudd_Ref(right.node); if (node) { Cudd_RecursiveDeref(p->manager,node); if (p->verbose) { cout << "BDD dereferencing for node " << hex << node << dec << " ref = " << Cudd_Regular(node)->ref << "\n"; } } node = right.node; p = right.p; if (node && p->verbose) { cout << "BDD assignment for node " << hex << node << dec << " ref = " << Cudd_Regular(node)->ref << "\n"; } return *this; } // BDD::operator= bool BDD::operator<=( const BDD& other) const { DdManager *mgr = checkSameManager(other); return Cudd_bddLeq(mgr,node,other.node); } // BDD::operator<= bool BDD::operator>=( const BDD& other) const { DdManager *mgr = checkSameManager(other); return Cudd_bddLeq(mgr,other.node,node); } // BDD::operator>= bool BDD::operator<( const BDD& other) const { DdManager *mgr = checkSameManager(other); return node != other.node && Cudd_bddLeq(mgr,node,other.node); } // BDD::operator< bool BDD::operator>( const BDD& other) const { DdManager *mgr = checkSameManager(other); return node != other.node && Cudd_bddLeq(mgr,other.node,node); } // BDD::operator> BDD BDD::operator!() const { return BDD(p, Cudd_Not(node)); } // BDD::operator! BDD BDD::operator~() const { return BDD(p, Cudd_Not(node)); } // BDD::operator~ BDD BDD::operator*( const BDD& other) const { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_bddAnd(mgr,node,other.node); checkReturnValue(result); return BDD(p, result); } // BDD::operator* BDD BDD::operator*=( const BDD& other) { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_bddAnd(mgr,node,other.node); checkReturnValue(result); Cudd_Ref(result); Cudd_RecursiveDeref(mgr,node); node = result; return *this; } // BDD::operator*= BDD BDD::operator&( const BDD& other) const { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_bddAnd(mgr,node,other.node); checkReturnValue(result); return BDD(p, result); } // BDD::operator& BDD BDD::operator&=( const BDD& other) { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_bddAnd(mgr,node,other.node); checkReturnValue(result); Cudd_Ref(result); Cudd_RecursiveDeref(mgr,node); node = result; return *this; } // BDD::operator&= BDD BDD::operator+( const BDD& other) const { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_bddOr(mgr,node,other.node); checkReturnValue(result); return BDD(p, result); } // BDD::operator+ BDD BDD::operator+=( const BDD& other) { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_bddOr(mgr,node,other.node); checkReturnValue(result); Cudd_Ref(result); Cudd_RecursiveDeref(mgr,node); node = result; return *this; } // BDD::operator+= BDD BDD::operator|( const BDD& other) const { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_bddOr(mgr,node,other.node); checkReturnValue(result); return BDD(p, result); } // BDD::operator| BDD BDD::operator|=( const BDD& other) { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_bddOr(mgr,node,other.node); checkReturnValue(result); Cudd_Ref(result); Cudd_RecursiveDeref(mgr,node); node = result; return *this; } // BDD::operator|= BDD BDD::operator^( const BDD& other) const { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_bddXor(mgr,node,other.node); checkReturnValue(result); return BDD(p, result); } // BDD::operator^ BDD BDD::operator^=( const BDD& other) { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_bddXor(mgr,node,other.node); checkReturnValue(result); Cudd_Ref(result); Cudd_RecursiveDeref(mgr,node); node = result; return *this; } // BDD::operator^= BDD BDD::operator-( const BDD& other) const { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_bddAnd(mgr,node,Cudd_Not(other.node)); checkReturnValue(result); return BDD(p, result); } // BDD::operator- BDD BDD::operator-=( const BDD& other) { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_bddAnd(mgr,node,Cudd_Not(other.node)); checkReturnValue(result); Cudd_Ref(result); Cudd_RecursiveDeref(mgr,node); node = result; return *this; } // BDD::operator-= ostream & operator<<(ostream & os, BDD const & f) { if (!f.node) defaultError("empty DD."); DdManager *mgr = f.p->manager; vector const & vn = f.p->varnames; char const * const *inames = vn.size() == (size_t) Cudd_ReadSize(mgr) ? &vn[0] : 0; char * str = Cudd_FactoredFormString(mgr, f.node, inames); f.checkReturnValue(str); os << string(str); free(str); return os; } // operator<< bool BDD::IsZero() const { return node == Cudd_ReadLogicZero(p->manager); } // BDD::IsZero bool BDD::IsVar() const { return Cudd_bddIsVar(p->manager, node); } // BDD::IsVar // --------------------------------------------------------------------------- // Members of class ADD // --------------------------------------------------------------------------- ADD::ADD() : ABDD() {} ADD::ADD(Capsule *cap, DdNode *bddNode) : ABDD(cap,bddNode) {} ADD::ADD(Cudd const & manager, DdNode *bddNode) : ABDD(manager,bddNode) {} ADD::ADD(const ADD &from) : ABDD(from) {} ADD ADD::operator=( const ADD& right) { if (this == &right) return *this; if (right.node) Cudd_Ref(right.node); if (node) { Cudd_RecursiveDeref(p->manager,node); } node = right.node; p = right.p; return *this; } // ADD::operator= bool ADD::operator<=( const ADD& other) const { DdManager *mgr = checkSameManager(other); return Cudd_addLeq(mgr,node,other.node); } // ADD::operator<= bool ADD::operator>=( const ADD& other) const { DdManager *mgr = checkSameManager(other); return Cudd_addLeq(mgr,other.node,node); } // ADD::operator>= bool ADD::operator<( const ADD& other) const { DdManager *mgr = checkSameManager(other); return node != other.node && Cudd_addLeq(mgr,node,other.node); } // ADD::operator< bool ADD::operator>( const ADD& other) const { DdManager *mgr = checkSameManager(other); return node != other.node && Cudd_addLeq(mgr,other.node,node); } // ADD::operator> ADD ADD::operator-() const { return ADD(p, Cudd_addNegate(p->manager,node)); } // ADD::operator- ADD ADD::operator*( const ADD& other) const { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_addApply(mgr,Cudd_addTimes,node,other.node); checkReturnValue(result); return ADD(p, result); } // ADD::operator* ADD ADD::operator*=( const ADD& other) { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_addApply(mgr,Cudd_addTimes,node,other.node); checkReturnValue(result); Cudd_Ref(result); Cudd_RecursiveDeref(mgr,node); node = result; return *this; } // ADD::operator*= ADD ADD::operator+( const ADD& other) const { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_addApply(mgr,Cudd_addPlus,node,other.node); checkReturnValue(result); return ADD(p, result); } // ADD::operator+ ADD ADD::operator+=( const ADD& other) { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_addApply(mgr,Cudd_addPlus,node,other.node); checkReturnValue(result); Cudd_Ref(result); Cudd_RecursiveDeref(mgr,node); node = result; return *this; } // ADD::operator+= ADD ADD::operator-( const ADD& other) const { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_addApply(mgr,Cudd_addMinus,node,other.node); checkReturnValue(result); return ADD(p, result); } // ADD::operator- ADD ADD::operator-=( const ADD& other) { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_addApply(mgr,Cudd_addMinus,node,other.node); checkReturnValue(result); Cudd_Ref(result); Cudd_RecursiveDeref(mgr,node); node = result; return *this; } // ADD::operator-= ADD ADD::operator~() const { return ADD(p, Cudd_addCmpl(p->manager,node)); } // ADD::operator~ ADD ADD::operator&( const ADD& other) const { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_addApply(mgr,Cudd_addTimes,node,other.node); checkReturnValue(result); return ADD(p, result); } // ADD::operator& ADD ADD::operator&=( const ADD& other) { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_addApply(mgr,Cudd_addTimes,node,other.node); checkReturnValue(result); Cudd_Ref(result); Cudd_RecursiveDeref(mgr,node); node = result; return *this; } // ADD::operator&= ADD ADD::operator|( const ADD& other) const { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_addApply(mgr,Cudd_addOr,node,other.node); checkReturnValue(result); return ADD(p, result); } // ADD::operator| ADD ADD::operator|=( const ADD& other) { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_addApply(mgr,Cudd_addOr,node,other.node); checkReturnValue(result); Cudd_Ref(result); Cudd_RecursiveDeref(mgr,node); node = result; return *this; } // ADD::operator|= bool ADD::IsZero() const { return node == Cudd_ReadZero(p->manager); } // ADD::IsZero // --------------------------------------------------------------------------- // Members of class ZDD // --------------------------------------------------------------------------- ZDD::ZDD(Capsule *cap, DdNode *bddNode) : DD(cap,bddNode) {} ZDD::ZDD() : DD() {} ZDD::ZDD(const ZDD &from) : DD(from) {} ZDD::~ZDD() { if (node) { Cudd_RecursiveDerefZdd(p->manager,node); if (p->verbose) { cout << "ZDD destructor called for node " << hex << node << dec << " ref = " << Cudd_Regular(node)->ref << "\n"; } } } // ZDD::~ZDD ZDD ZDD::operator=( const ZDD& right) { if (this == &right) return *this; if (right.node) Cudd_Ref(right.node); if (node) { Cudd_RecursiveDerefZdd(p->manager,node); if (p->verbose) { cout << "ZDD dereferencing for node " << hex << node << dec << " ref = " << node->ref << "\n"; } } node = right.node; p = right.p; if (node && p->verbose) { cout << "ZDD assignment for node " << hex << node << dec << " ref = " << node->ref << "\n"; } return *this; } // ZDD::operator= bool ZDD::operator==( const ZDD& other) const { checkSameManager(other); return node == other.node; } // ZDD::operator== bool ZDD::operator!=( const ZDD& other) const { checkSameManager(other); return node != other.node; } // ZDD::operator!= bool ZDD::operator<=( const ZDD& other) const { DdManager *mgr = checkSameManager(other); return Cudd_zddDiffConst(mgr,node,other.node) == Cudd_ReadZero(mgr); } // ZDD::operator<= bool ZDD::operator>=( const ZDD& other) const { DdManager *mgr = checkSameManager(other); return Cudd_zddDiffConst(mgr,other.node,node) == Cudd_ReadZero(mgr); } // ZDD::operator>= bool ZDD::operator<( const ZDD& other) const { DdManager *mgr = checkSameManager(other); return node != other.node && Cudd_zddDiffConst(mgr,node,other.node) == Cudd_ReadZero(mgr); } // ZDD::operator< bool ZDD::operator>( const ZDD& other) const { DdManager *mgr = checkSameManager(other); return node != other.node && Cudd_zddDiffConst(mgr,other.node,node) == Cudd_ReadZero(mgr); } // ZDD::operator> void ZDD::print( int nvars, int verbosity) const { cout.flush(); int retval = Cudd_zddPrintDebug(p->manager,node,nvars,verbosity); fflush(Cudd_ReadStdout(p->manager)); if (retval == 0) p->errorHandler("print failed"); } // ZDD::print ZDD ZDD::operator*( const ZDD& other) const { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_zddIntersect(mgr,node,other.node); checkReturnValue(result); return ZDD(p, result); } // ZDD::operator* ZDD ZDD::operator*=( const ZDD& other) { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_zddIntersect(mgr,node,other.node); checkReturnValue(result); Cudd_Ref(result); Cudd_RecursiveDerefZdd(mgr,node); node = result; return *this; } // ZDD::operator*= ZDD ZDD::operator&( const ZDD& other) const { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_zddIntersect(mgr,node,other.node); checkReturnValue(result); return ZDD(p, result); } // ZDD::operator& ZDD ZDD::operator&=( const ZDD& other) { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_zddIntersect(mgr,node,other.node); checkReturnValue(result); Cudd_Ref(result); Cudd_RecursiveDerefZdd(mgr,node); node = result; return *this; } // ZDD::operator&= ZDD ZDD::operator+( const ZDD& other) const { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_zddUnion(mgr,node,other.node); checkReturnValue(result); return ZDD(p, result); } // ZDD::operator+ ZDD ZDD::operator+=( const ZDD& other) { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_zddUnion(mgr,node,other.node); checkReturnValue(result); Cudd_Ref(result); Cudd_RecursiveDerefZdd(mgr,node); node = result; return *this; } // ZDD::operator+= ZDD ZDD::operator|( const ZDD& other) const { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_zddUnion(mgr,node,other.node); checkReturnValue(result); return ZDD(p, result); } // ZDD::operator| ZDD ZDD::operator|=( const ZDD& other) { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_zddUnion(mgr,node,other.node); checkReturnValue(result); Cudd_Ref(result); Cudd_RecursiveDerefZdd(mgr,node); node = result; return *this; } // ZDD::operator|= ZDD ZDD::operator-( const ZDD& other) const { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_zddDiff(mgr,node,other.node); checkReturnValue(result); return ZDD(p, result); } // ZDD::operator- ZDD ZDD::operator-=( const ZDD& other) { DdManager *mgr = checkSameManager(other); DdNode *result = Cudd_zddDiff(mgr,node,other.node); checkReturnValue(result); Cudd_Ref(result); Cudd_RecursiveDerefZdd(mgr,node); node = result; return *this; } // ZDD::operator-= // --------------------------------------------------------------------------- // Members of class Cudd // --------------------------------------------------------------------------- Cudd::Cudd( unsigned int numVars, unsigned int numVarsZ, unsigned int numSlots, unsigned int cacheSize, unsigned long maxMemory, PFC defaultHandler) { p = new Capsule(numVars,numVarsZ,numSlots,cacheSize,maxMemory,defaultHandler); } // Cudd::Cudd Cudd::Cudd( const Cudd& x) { p = x.p; x.p->ref++; if (p->verbose) cout << "Cudd Copy Constructor" << endl; } // Cudd::Cudd Cudd::~Cudd() { if (--p->ref == 0) { delete p; } } // Cudd::~Cudd DdManager * Cudd::getManager(void) const { return p->manager; } // Cudd::getManager void Cudd::makeVerbose(void) const { p->verbose = 1; } // Cudd::makeVerbose void Cudd::makeTerse(void) const { p->verbose = 0; } // Cudd::makeTerse bool Cudd::isVerbose(void) const { return p->verbose; } // Cudd::isVerbose Cudd& Cudd::operator=( const Cudd& right) { right.p->ref++; if (--p->ref == 0) { // disconnect self delete p; } p = right.p; return *this; } // Cudd::operator= PFC Cudd::setHandler( PFC newHandler) const { PFC oldHandler = p->errorHandler; p->errorHandler = newHandler; return oldHandler; } // Cudd::setHandler PFC Cudd::getHandler() const { return p->errorHandler; } // Cudd::getHandler PFC Cudd::setTimeoutHandler( PFC newHandler) const { PFC oldHandler = p->timeoutHandler; p->timeoutHandler = newHandler; return oldHandler; } // Cudd::setTimeoutHandler PFC Cudd::getTimeoutHandler() const { return p->timeoutHandler; } // Cudd::getTimeourHandler PFC Cudd::setTerminationHandler( PFC newHandler) const { PFC oldHandler = p->terminationHandler; p->terminationHandler = newHandler; return oldHandler; } // Cudd::setTerminationHandler PFC Cudd::getTerminationHandler() const { return p->terminationHandler; } // Cudd::getTerminationHandler void Cudd::pushVariableName(std::string s) const { char * cstr = new char[s.length() + 1]; strcpy(cstr, s.c_str()); p->varnames.push_back(cstr); } void Cudd::clearVariableNames(void) const { for (vector::iterator it = p->varnames.begin(); it != p->varnames.end(); ++it) { delete [] *it; } p->varnames.clear(); } std::string Cudd::getVariableName(size_t i) const { return std::string(p->varnames.at(i)); } inline void Cudd::checkReturnValue( const void *result) const { if (result == 0) { if (Cudd_ReadErrorCode(p->manager) == CUDD_MEMORY_OUT) { p->errorHandler("Out of memory."); } else if (Cudd_ReadErrorCode(p->manager) == CUDD_TOO_MANY_NODES) { p->errorHandler("Too many nodes."); } else if (Cudd_ReadErrorCode(p->manager) == CUDD_MAX_MEM_EXCEEDED) { p->errorHandler("Maximum memory exceeded."); } else if (Cudd_ReadErrorCode(p->manager) == CUDD_TIMEOUT_EXPIRED) { std::ostringstream msg; DdManager *mgr = p->manager; unsigned long lag = Cudd_ReadElapsedTime(mgr) - Cudd_ReadTimeLimit(mgr); msg << "Timeout expired. Lag = " << lag << " ms.\n"; p->timeoutHandler(msg.str()); } else if (Cudd_ReadErrorCode(p->manager) == CUDD_TERMINATION) { std::ostringstream msg; msg << "Terminated.\n"; p->terminationHandler(msg.str()); } else if (Cudd_ReadErrorCode(p->manager) == CUDD_INVALID_ARG) { p->errorHandler("Invalid argument."); } else if (Cudd_ReadErrorCode(p->manager) == CUDD_INTERNAL_ERROR) { p->errorHandler("Internal error."); } else { p->errorHandler("Unexpected error."); } } } // Cudd::checkReturnValue inline void Cudd::checkReturnValue( const int result) const { if (result == 0) { if (Cudd_ReadErrorCode(p->manager) == CUDD_MEMORY_OUT) { p->errorHandler("Out of memory."); } else if (Cudd_ReadErrorCode(p->manager) == CUDD_TOO_MANY_NODES) { p->errorHandler("Too many nodes."); } else if (Cudd_ReadErrorCode(p->manager) == CUDD_MAX_MEM_EXCEEDED) { p->errorHandler("Maximum memory exceeded."); } else if (Cudd_ReadErrorCode(p->manager) == CUDD_TIMEOUT_EXPIRED) { std::ostringstream msg; DdManager *mgr = p->manager; unsigned long lag = Cudd_ReadElapsedTime(mgr) - Cudd_ReadTimeLimit(mgr); msg << "Timeout expired. Lag = " << lag << " ms.\n"; p->timeoutHandler(msg.str()); } else if (Cudd_ReadErrorCode(p->manager) == CUDD_TERMINATION) { std::ostringstream msg; msg << "Terminated.\n"; p->terminationHandler(msg.str()); } else if (Cudd_ReadErrorCode(p->manager) == CUDD_INVALID_ARG) { p->errorHandler("Invalid argument."); } else if (Cudd_ReadErrorCode(p->manager) == CUDD_INTERNAL_ERROR) { p->errorHandler("Internal error."); } else { p->errorHandler("Unexpected error."); } } } // Cudd::checkReturnValue void Cudd::info() const { cout.flush(); int retval = Cudd_PrintInfo(p->manager,stdout); checkReturnValue(retval); } // Cudd::info BDD Cudd::bddVar() const { DdNode *result = Cudd_bddNewVar(p->manager); checkReturnValue(result); return BDD(p, result); } // Cudd::bddVar BDD Cudd::bddVar( int index) const { DdNode *result = Cudd_bddIthVar(p->manager,index); checkReturnValue(result); return BDD(p, result); } // Cudd::bddVar BDD Cudd::bddOne() const { DdNode *result = Cudd_ReadOne(p->manager); checkReturnValue(result); return BDD(p, result); } // Cudd::bddOne BDD Cudd::bddZero() const { DdNode *result = Cudd_ReadLogicZero(p->manager); checkReturnValue(result); return BDD(p, result); } // Cudd::bddZero ADD Cudd::addVar() const { DdNode *result = Cudd_addNewVar(p->manager); checkReturnValue(result); return ADD(p, result); } // Cudd::addVar ADD Cudd::addVar( int index) const { DdNode *result = Cudd_addIthVar(p->manager,index); checkReturnValue(result); return ADD(p, result); } // Cudd::addVar ADD Cudd::addOne() const { DdNode *result = Cudd_ReadOne(p->manager); checkReturnValue(result); return ADD(p, result); } // Cudd::addOne ADD Cudd::addZero() const { DdNode *result = Cudd_ReadZero(p->manager); checkReturnValue(result); return ADD(p, result); } // Cudd::addZero ADD Cudd::constant( CUDD_VALUE_TYPE c) const { DdNode *result = Cudd_addConst(p->manager, c); checkReturnValue(result); return ADD(p, result); } // Cudd::constant ADD Cudd::plusInfinity() const { DdNode *result = Cudd_ReadPlusInfinity(p->manager); checkReturnValue(result); return ADD(p, result); } // Cudd::plusInfinity ADD Cudd::minusInfinity() const { DdNode *result = Cudd_ReadMinusInfinity(p->manager); checkReturnValue(result); return ADD(p, result); } // Cudd::minusInfinity ZDD Cudd::zddVar( int index) const { DdNode *result = Cudd_zddIthVar(p->manager,index); checkReturnValue(result); return ZDD(p, result); } // Cudd::zddVar ZDD Cudd::zddOne( int i) const { DdNode *result = Cudd_ReadZddOne(p->manager,i); checkReturnValue(result); return ZDD(p, result); } // Cudd::zddOne ZDD Cudd::zddZero() const { DdNode *result = Cudd_ReadZero(p->manager); checkReturnValue(result); return ZDD(p, result); } // Cudd::zddZero void defaultError( string message) { throw std::logic_error(message); } // defaultError // --------------------------------------------------------------------------- // All the rest // --------------------------------------------------------------------------- ADD Cudd::addNewVarAtLevel( int level) const { DdNode *result = Cudd_addNewVarAtLevel(p->manager, level); checkReturnValue(result); return ADD(p, result); } // Cudd::addNewVarAtLevel BDD Cudd::bddNewVarAtLevel( int level) const { DdNode *result = Cudd_bddNewVarAtLevel(p->manager, level); checkReturnValue(result); return BDD(p, result); } // Cudd::bddNewVarAtLevel void Cudd::zddVarsFromBddVars( int multiplicity) const { int result = Cudd_zddVarsFromBddVars(p->manager, multiplicity); checkReturnValue(result); } // Cudd::zddVarsFromBddVars unsigned long Cudd::ReadStartTime() const { return Cudd_ReadStartTime(p->manager); } // Cudd::ReadStartTime unsigned long Cudd::ReadElapsedTime() const { return Cudd_ReadElapsedTime(p->manager); } // Cudd::ReadElapsedTime void Cudd::SetStartTime( unsigned long st) const { Cudd_SetStartTime(p->manager, st); } // Cudd::SetStartTime void Cudd::ResetStartTime() const { Cudd_ResetStartTime(p->manager); } // Cudd::ResetStartTime unsigned long Cudd::ReadTimeLimit() const { return Cudd_ReadTimeLimit(p->manager); } // Cudd::ReadTimeLimit unsigned long Cudd::SetTimeLimit( unsigned long tl) const { return Cudd_SetTimeLimit(p->manager, tl); } // Cudd::SetTimeLimit void Cudd::UpdateTimeLimit() const { Cudd_UpdateTimeLimit(p->manager); } // Cudd::UpdateTimeLimit void Cudd::IncreaseTimeLimit( unsigned long increase) const { Cudd_IncreaseTimeLimit(p->manager, increase); } // Cudd::IncreaseTimeLimit void Cudd::UnsetTimeLimit() const { Cudd_UnsetTimeLimit(p->manager); } // Cudd::UnsetTimeLimit bool Cudd::TimeLimited() const { return Cudd_TimeLimited(p->manager); } // Cudd::TimeLimited void Cudd::RegisterTerminationCallback( DD_THFP callback, void * callback_arg) const { Cudd_RegisterTerminationCallback(p->manager, callback, callback_arg); } // Cudd::RegisterTerminationCallback void Cudd::UnregisterTerminationCallback() const { Cudd_UnregisterTerminationCallback(p->manager); } // Cudd::UnregisterTerminationCallback DD_OOMFP Cudd::RegisterOutOfMemoryCallback( DD_OOMFP callback) const { return Cudd_RegisterOutOfMemoryCallback(p->manager, callback); } // Cudd::RegisterOutOfMemoryCallback void Cudd::UnregisterOutOfMemoryCallback() const { Cudd_UnregisterOutOfMemoryCallback(p->manager); } // Cudd::UnregisterOutOfMemoryCallback void Cudd::AutodynEnable( Cudd_ReorderingType method) const { Cudd_AutodynEnable(p->manager, method); } // Cudd::AutodynEnable void Cudd::AutodynDisable() const { Cudd_AutodynDisable(p->manager); } // Cudd::AutodynDisable bool Cudd::ReorderingStatus( Cudd_ReorderingType * method) const { return Cudd_ReorderingStatus(p->manager, method); } // Cudd::ReorderingStatus void Cudd::AutodynEnableZdd( Cudd_ReorderingType method) const { Cudd_AutodynEnableZdd(p->manager, method); } // Cudd::AutodynEnableZdd void Cudd::AutodynDisableZdd() const { Cudd_AutodynDisableZdd(p->manager); } // Cudd::AutodynDisableZdd bool Cudd::ReorderingStatusZdd( Cudd_ReorderingType * method) const { return Cudd_ReorderingStatusZdd(p->manager, method); } // Cudd::ReorderingStatusZdd bool Cudd::zddRealignmentEnabled() const { return Cudd_zddRealignmentEnabled(p->manager); } // Cudd::zddRealignmentEnabled void Cudd::zddRealignEnable() const { Cudd_zddRealignEnable(p->manager); } // Cudd::zddRealignEnable void Cudd::zddRealignDisable() const { Cudd_zddRealignDisable(p->manager); } // Cudd::zddRealignDisable bool Cudd::bddRealignmentEnabled() const { return Cudd_bddRealignmentEnabled(p->manager); } // Cudd::bddRealignmentEnabled void Cudd::bddRealignEnable() const { Cudd_bddRealignEnable(p->manager); } // Cudd::bddRealignEnable void Cudd::bddRealignDisable() const { Cudd_bddRealignDisable(p->manager); } // Cudd::bddRealignDisable ADD Cudd::background() const { DdNode *result = Cudd_ReadBackground(p->manager); checkReturnValue(result); return ADD(p, result); } // Cudd::background void Cudd::SetBackground( ADD bg) const { DdManager *mgr = p->manager; if (mgr != bg.manager()) { p->errorHandler("Background comes from different manager."); } Cudd_SetBackground(mgr, bg.getNode()); } // Cudd::SetBackground unsigned int Cudd::ReadCacheSlots() const { return Cudd_ReadCacheSlots(p->manager); } // Cudd::ReadCacheSlots double Cudd::ReadCacheLookUps() const { return Cudd_ReadCacheLookUps(p->manager); } // Cudd::ReadCacheLookUps double Cudd::ReadCacheUsedSlots() const { return Cudd_ReadCacheUsedSlots(p->manager); } // Cudd::ReadCacheUsedSlots double Cudd::ReadCacheHits() const { return Cudd_ReadCacheHits(p->manager); } // Cudd::ReadCacheHits unsigned int Cudd::ReadMinHit() const { return Cudd_ReadMinHit(p->manager); } // Cudd::ReadMinHit void Cudd::SetMinHit( unsigned int hr) const { Cudd_SetMinHit(p->manager, hr); } // Cudd::SetMinHit unsigned int Cudd::ReadLooseUpTo() const { return Cudd_ReadLooseUpTo(p->manager); } // Cudd::ReadLooseUpTo void Cudd::SetLooseUpTo( unsigned int lut) const { Cudd_SetLooseUpTo(p->manager, lut); } // Cudd::SetLooseUpTo unsigned int Cudd::ReadMaxCache() const { return Cudd_ReadMaxCache(p->manager); } // Cudd::ReadMaxCache unsigned int Cudd::ReadMaxCacheHard() const { return Cudd_ReadMaxCacheHard(p->manager); } // Cudd::ReadMaxCacheHard void Cudd::SetMaxCacheHard( unsigned int mc) const { Cudd_SetMaxCacheHard(p->manager, mc); } // Cudd::SetMaxCacheHard int Cudd::ReadSize() const { return Cudd_ReadSize(p->manager); } // Cudd::ReadSize int Cudd::ReadZddSize() const { return Cudd_ReadZddSize(p->manager); } // Cudd::ReadZddSize unsigned int Cudd::ReadSlots() const { return Cudd_ReadSlots(p->manager); } // Cudd::ReadSlots unsigned int Cudd::ReadKeys() const { return Cudd_ReadKeys(p->manager); } // Cudd::ReadKeys unsigned int Cudd::ReadDead() const { return Cudd_ReadDead(p->manager); } // Cudd::ReadDead unsigned int Cudd::ReadMinDead() const { return Cudd_ReadMinDead(p->manager); } // Cudd::ReadMinDead unsigned int Cudd::ReadReorderings() const { return Cudd_ReadReorderings(p->manager); } // Cudd::ReadReorderings unsigned int Cudd::ReadMaxReorderings() const { return Cudd_ReadMaxReorderings(p->manager); } // Cudd::ReadMaxReorderings void Cudd::SetMaxReorderings( unsigned int mr) const { Cudd_SetMaxReorderings(p->manager, mr); } // Cudd::SetMaxReorderings long Cudd::ReadReorderingTime() const { return Cudd_ReadReorderingTime(p->manager); } // Cudd::ReadReorderingTime int Cudd::ReadGarbageCollections() const { return Cudd_ReadGarbageCollections(p->manager); } // Cudd::ReadGarbageCollections long Cudd::ReadGarbageCollectionTime() const { return Cudd_ReadGarbageCollectionTime(p->manager); } // Cudd::ReadGarbageCollectionTime int Cudd::ReadSiftMaxVar() const { return Cudd_ReadSiftMaxVar(p->manager); } // Cudd::ReadSiftMaxVar void Cudd::SetSiftMaxVar( int smv) const { Cudd_SetSiftMaxVar(p->manager, smv); } // Cudd::SetSiftMaxVar int Cudd::ReadSiftMaxSwap() const { return Cudd_ReadSiftMaxSwap(p->manager); } // Cudd::ReadSiftMaxSwap void Cudd::SetSiftMaxSwap( int sms) const { Cudd_SetSiftMaxSwap(p->manager, sms); } // Cudd::SetSiftMaxSwap double Cudd::ReadMaxGrowth() const { return Cudd_ReadMaxGrowth(p->manager); } // Cudd::ReadMaxGrowth void Cudd::SetMaxGrowth( double mg) const { Cudd_SetMaxGrowth(p->manager, mg); } // Cudd::SetMaxGrowth MtrNode * Cudd::ReadTree() const { return Cudd_ReadTree(p->manager); } // Cudd::ReadTree void Cudd::SetTree( MtrNode * tree) const { Cudd_SetTree(p->manager, tree); } // Cudd::SetTree void Cudd::FreeTree() const { Cudd_FreeTree(p->manager); } // Cudd::FreeTree MtrNode * Cudd::ReadZddTree() const { return Cudd_ReadZddTree(p->manager); } // Cudd::ReadZddTree void Cudd::SetZddTree( MtrNode * tree) const { Cudd_SetZddTree(p->manager, tree); } // Cudd::SetZddTree void Cudd::FreeZddTree() const { Cudd_FreeZddTree(p->manager); } // Cudd::FreeZddTree int Cudd::ReadPerm( int i) const { return Cudd_ReadPerm(p->manager, i); } // Cudd::ReadPerm int Cudd::ReadPermZdd( int i) const { return Cudd_ReadPermZdd(p->manager, i); } // Cudd::ReadPermZdd int Cudd::ReadInvPerm( int i) const { return Cudd_ReadInvPerm(p->manager, i); } // Cudd::ReadInvPerm int Cudd::ReadInvPermZdd( int i) const { return Cudd_ReadInvPermZdd(p->manager, i); } // Cudd::ReadInvPermZdd BDD Cudd::ReadVars( int i) const { DdNode *result = Cudd_ReadVars(p->manager, i); checkReturnValue(result); return BDD(p, result); } // Cudd::ReadVars CUDD_VALUE_TYPE Cudd::ReadEpsilon() const { return Cudd_ReadEpsilon(p->manager); } // Cudd::ReadEpsilon void Cudd::SetEpsilon( CUDD_VALUE_TYPE ep) const { Cudd_SetEpsilon(p->manager, ep); } // Cudd::SetEpsilon Cudd_AggregationType Cudd::ReadGroupcheck() const { return Cudd_ReadGroupcheck(p->manager); } // Cudd::ReadGroupcheck void Cudd::SetGroupcheck( Cudd_AggregationType gc) const { Cudd_SetGroupcheck(p->manager, gc); } // Cudd::SetGroupcheck bool Cudd::GarbageCollectionEnabled() const { return Cudd_GarbageCollectionEnabled(p->manager); } // Cudd::GarbageCollectionEnabled void Cudd::EnableGarbageCollection() const { Cudd_EnableGarbageCollection(p->manager); } // Cudd::EnableGarbageCollection void Cudd::DisableGarbageCollection() const { Cudd_DisableGarbageCollection(p->manager); } // Cudd::DisableGarbageCollection bool Cudd::DeadAreCounted() const { return Cudd_DeadAreCounted(p->manager); } // Cudd::DeadAreCounted void Cudd::TurnOnCountDead() const { Cudd_TurnOnCountDead(p->manager); } // Cudd::TurnOnCountDead void Cudd::TurnOffCountDead() const { Cudd_TurnOffCountDead(p->manager); } // Cudd::TurnOffCountDead int Cudd::ReadRecomb() const { return Cudd_ReadRecomb(p->manager); } // Cudd::ReadRecomb void Cudd::SetRecomb( int recomb) const { Cudd_SetRecomb(p->manager, recomb); } // Cudd::SetRecomb int Cudd::ReadSymmviolation() const { return Cudd_ReadSymmviolation(p->manager); } // Cudd::ReadSymmviolation void Cudd::SetSymmviolation( int symmviolation) const { Cudd_SetSymmviolation(p->manager, symmviolation); } // Cudd::SetSymmviolation int Cudd::ReadArcviolation() const { return Cudd_ReadArcviolation(p->manager); } // Cudd::ReadArcviolation void Cudd::SetArcviolation( int arcviolation) const { Cudd_SetArcviolation(p->manager, arcviolation); } // Cudd::SetArcviolation int Cudd::ReadPopulationSize() const { return Cudd_ReadPopulationSize(p->manager); } // Cudd::ReadPopulationSize void Cudd::SetPopulationSize( int populationSize) const { Cudd_SetPopulationSize(p->manager, populationSize); } // Cudd::SetPopulationSize int Cudd::ReadNumberXovers() const { return Cudd_ReadNumberXovers(p->manager); } // Cudd::ReadNumberXovers void Cudd::SetNumberXovers( int numberXovers) const { Cudd_SetNumberXovers(p->manager, numberXovers); } // Cudd::SetNumberXovers unsigned int Cudd::ReadOrderRandomization() const { return Cudd_ReadOrderRandomization(p->manager); } // Cudd::ReadOrderRandomization void Cudd::SetOrderRandomization( unsigned int factor) const { Cudd_SetOrderRandomization(p->manager, factor); } // Cudd::SetOrderRandomization unsigned long Cudd::ReadMemoryInUse() const { return Cudd_ReadMemoryInUse(p->manager); } // Cudd::ReadMemoryInUse long Cudd::ReadPeakNodeCount() const { return Cudd_ReadPeakNodeCount(p->manager); } // Cudd::ReadPeakNodeCount long Cudd::ReadNodeCount() const { return Cudd_ReadNodeCount(p->manager); } // Cudd::ReadNodeCount long Cudd::zddReadNodeCount() const { return Cudd_zddReadNodeCount(p->manager); } // Cudd::zddReadNodeCount void Cudd::AddHook( DD_HFP f, Cudd_HookType where) const { int result = Cudd_AddHook(p->manager, f, where); checkReturnValue(result); } // Cudd::AddHook void Cudd::RemoveHook( DD_HFP f, Cudd_HookType where) const { int result = Cudd_RemoveHook(p->manager, f, where); checkReturnValue(result); } // Cudd::RemoveHook bool Cudd::IsInHook( DD_HFP f, Cudd_HookType where) const { return Cudd_IsInHook(p->manager, f, where); } // Cudd::IsInHook void Cudd::EnableReorderingReporting() const { int result = Cudd_EnableReorderingReporting(p->manager); checkReturnValue(result); } // Cudd::EnableReorderingReporting void Cudd::DisableReorderingReporting() const { int result = Cudd_DisableReorderingReporting(p->manager); checkReturnValue(result); } // Cudd::DisableReorderingReporting bool Cudd::ReorderingReporting() const { return Cudd_ReorderingReporting(p->manager); } // Cudd::ReorderingReporting int Cudd::ReadErrorCode() const { return Cudd_ReadErrorCode(p->manager); } // Cudd::ReadErrorCode void Cudd::ClearErrorCode() const { Cudd_ClearErrorCode(p->manager); } // Cudd::ClearErrorCode DD_OOMFP Cudd::InstallOutOfMemoryHandler(DD_OOMFP newHandler) const { return Cudd_InstallOutOfMemoryHandler(newHandler); } // Cudd::InstallOutOfMemoryHandler FILE * Cudd::ReadStdout() const { return Cudd_ReadStdout(p->manager); } // Cudd::ReadStdout void Cudd::SetStdout(FILE *fp) const { Cudd_SetStdout(p->manager, fp); } // Cudd::SetStdout FILE * Cudd::ReadStderr() const { return Cudd_ReadStderr(p->manager); } // Cudd::ReadStderr void Cudd::SetStderr(FILE *fp) const { Cudd_SetStderr(p->manager, fp); } // Cudd::SetStderr unsigned int Cudd::ReadNextReordering() const { return Cudd_ReadNextReordering(p->manager); } // Cudd::ReadNextReordering void Cudd::SetNextReordering( unsigned int next) const { Cudd_SetNextReordering(p->manager, next); } // Cudd::SetNextReordering double Cudd::ReadSwapSteps() const { return Cudd_ReadSwapSteps(p->manager); } // Cudd::ReadSwapSteps unsigned int Cudd::ReadMaxLive() const { return Cudd_ReadMaxLive(p->manager); } // Cudd::ReadMaxLive void Cudd::SetMaxLive(unsigned int maxLive) const { Cudd_SetMaxLive(p->manager, maxLive); } // Cudd::SetMaxLive size_t Cudd::ReadMaxMemory() const { return Cudd_ReadMaxMemory(p->manager); } // Cudd::ReadMaxMemory size_t Cudd::SetMaxMemory(size_t maxMem) const { return Cudd_SetMaxMemory(p->manager, maxMem); } // Cudd::SetMaxMemory int Cudd::bddBindVar(int index) const { return Cudd_bddBindVar(p->manager, index); } // Cudd::bddBindVar int Cudd::bddUnbindVar(int index) const { return Cudd_bddUnbindVar(p->manager, index); } // Cudd::bddUnbindVar bool Cudd::bddVarIsBound(int index) const { return Cudd_bddVarIsBound(p->manager, index); } // Cudd::bddVarIsBound ADD ADD::ExistAbstract( const ADD& cube) const { DdManager *mgr = checkSameManager(cube); DdNode *result = Cudd_addExistAbstract(mgr, node, cube.node); checkReturnValue(result); return ADD(p, result); } // ADD::ExistAbstract ADD ADD::UnivAbstract( const ADD& cube) const { DdManager *mgr = checkSameManager(cube); DdNode *result = Cudd_addUnivAbstract(mgr, node, cube.node); checkReturnValue(result); return ADD(p, result); } // ADD::UnivAbstract ADD ADD::OrAbstract( const ADD& cube) const { DdManager *mgr = checkSameManager(cube); DdNode *result = Cudd_addOrAbstract(mgr, node, cube.node); checkReturnValue(result); return ADD(p, result); } // ADD::OrAbstract ADD ADD::MinAbstract(const ADD& cube) const { DdManager *mgr = checkSameManager(cube); DdNode *result = Cudd_addMinAbstract(mgr, node, cube.node); checkReturnValue(result); return ADD(p, result); } // ADD::MinAbstract ADD ADD::MaxAbstract(const ADD& cube) const { DdManager *mgr = checkSameManager(cube); DdNode *result = Cudd_addMaxAbstract(mgr, node, cube.node); checkReturnValue(result); return ADD(p, result); } // ADD::MaxAbstract ADD ADD::MinAbstractRepresentative(const ADD& cube) const { DdManager *mgr = checkSameManager(cube); DdNode *result = Cudd_addMinAbstractRepresentative(mgr, node, cube.node); checkReturnValue(result); return ADD(p, result); } // ADD::MinRepresentative ADD ADD::MaxAbstractRepresentative(const ADD& cube) const { DdManager *mgr = checkSameManager(cube); DdNode *result = Cudd_addMaxAbstractRepresentative(mgr, node, cube.node); checkReturnValue(result); return ADD(p, result); } // ADD::MaxRepresentative ADD ADD::Plus( const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addPlus, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::Plus ADD ADD::Times( const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addTimes, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::Times ADD ADD::Threshold( const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addThreshold, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::Threshold ADD ADD::SetNZ( const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addSetNZ, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::SetNZ ADD ADD::Divide( const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addDivide, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::Divide ADD ADD::Minus( const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addMinus, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::Minus ADD ADD::Minimum( const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addMinimum, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::Minimum ADD ADD::Maximum( const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addMaximum, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::Maximum ADD ADD::OneZeroMaximum( const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addOneZeroMaximum, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::OneZeroMaximum ADD ADD::Diff( const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addDiff, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::Diff ADD ADD::Agreement( const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addAgreement, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::Agreement ADD ADD::Or( const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addOr, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::Or ADD ADD::Nand( const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addNand, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::Nand ADD ADD::Nor( const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addNor, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::Nor ADD ADD::Xor( const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addXor, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::Xor ADD ADD::Xnor( const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addXnor, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::Xnor ADD ADD::Pow( const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addPow, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::Pow ADD ADD::Mod( const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addMod, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::Mod ADD ADD::LogXY( const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addLogXY, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::LogXY ADD ADD::Log() const { DdManager *mgr = p->manager; DdNode *result = Cudd_addMonadicApply(mgr, Cudd_addLog, node); checkReturnValue(result); return ADD(p, result); } // ADD::Log ADD ADD::Floor() const { DdManager *mgr = p->manager; DdNode *result = Cudd_addMonadicApply(mgr, Cudd_addFloor, node); checkReturnValue(result); return ADD(p, result); } // ADD::Floor ADD ADD::Ceil() const { DdManager *mgr = p->manager; DdNode *result = Cudd_addMonadicApply(mgr, Cudd_addCeil, node); checkReturnValue(result); return ADD(p, result); } // ADD::Ceil ADD ADD::FindMax() const { DdManager *mgr = p->manager; DdNode *result = Cudd_addFindMax(mgr, node); checkReturnValue(result); return ADD(p, result); } // ADD::FindMax ADD ADD::FindMin() const { DdManager *mgr = p->manager; DdNode *result = Cudd_addFindMin(mgr, node); checkReturnValue(result); return ADD(p, result); } // ADD::FindMin ADD ADD::IthBit( int bit) const { DdManager *mgr = p->manager; DdNode *result = Cudd_addIthBit(mgr, node, bit); checkReturnValue(result); return ADD(p, result); } // ADD::IthBit ADD ADD::ScalarInverse( const ADD& epsilon) const { DdManager *mgr = checkSameManager(epsilon); DdNode *result = Cudd_addScalarInverse(mgr, node, epsilon.node); checkReturnValue(result); return ADD(p, result); } // ADD::ScalarInverse ADD ADD::Ite( const ADD& g, const ADD& h) const { DdManager *mgr = checkSameManager(g); checkSameManager(h); DdNode *result = Cudd_addIte(mgr, node, g.node, h.node); checkReturnValue(result); return ADD(p, result); } // ADD::Ite ADD ADD::IteConstant( const ADD& g, const ADD& h) const { DdManager *mgr = checkSameManager(g); checkSameManager(h); DdNode *result = Cudd_addIteConstant(mgr, node, g.node, h.node); checkReturnValue(result); return ADD(p, result); } // ADD::IteConstant ADD ADD::EvalConst( const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addEvalConst(mgr, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::EvalConst bool ADD::Leq( const ADD& g) const { DdManager *mgr = checkSameManager(g); return Cudd_addLeq(mgr, node, g.node); } // ADD::Leq ADD ADD::Cmpl() const { DdManager *mgr = p->manager; DdNode *result = Cudd_addCmpl(mgr, node); checkReturnValue(result); return ADD(p, result); } // ADD::Cmpl ADD ADD::Negate() const { DdManager *mgr = p->manager; DdNode *result = Cudd_addNegate(mgr, node); checkReturnValue(result); return ADD(p, result); } // ADD::Negate ADD ADD::RoundOff( int N) const { DdManager *mgr = p->manager; DdNode *result = Cudd_addRoundOff(mgr, node, N); checkReturnValue(result); return ADD(p, result); } // ADD::RoundOff ADD Cudd::Walsh( std::vector x, std::vector y) const { size_t n = x.size(); DdNode **X = new DdNode *[n]; DdNode **Y = new DdNode *[n]; for (size_t i = 0; i < n; i++) { X[i] = x[i].getNode(); Y[i] = y[i].getNode(); } DdNode *result = Cudd_addWalsh(p->manager, X, Y, (int) n); delete [] X; delete [] Y; checkReturnValue(result); return ADD(p, result); } // ADD::Walsh ADD Cudd::addResidue( int n, int m, int options, int top) const { DdNode *result = Cudd_addResidue(p->manager, n, m, options, top); checkReturnValue(result); return ADD(p, result); } // Cudd::addResidue ADD ADD::Equals(const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addEquals, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::Equals ADD ADD::NotEquals(const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addNotEquals, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::NotEquals ADD ADD::LessThan(const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addLessThan, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::LessThan ADD ADD::LessThanOrEqual(const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addLessThanEquals, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::LessThanOrEqual ADD ADD::GreaterThan(const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addGreaterThan, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::GreaterThan ADD ADD::GreaterThanOrEqual(const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addApply(mgr, Cudd_addGreaterThanEquals, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::GreaterThanOrEqual BDD BDD::AndAbstract( const BDD& g, const BDD& cube, unsigned int limit) const { DdManager *mgr = checkSameManager(g); checkSameManager(cube); DdNode *result; if (limit == 0) result = Cudd_bddAndAbstract(mgr, node, g.node, cube.node); else result = Cudd_bddAndAbstractLimit(mgr, node, g.node, cube.node, limit); checkReturnValue(result); return BDD(p, result); } // BDD::AndAbstract int Cudd::ApaNumberOfDigits( int binaryDigits) const { return Cudd_ApaNumberOfDigits(binaryDigits); } // Cudd::ApaNumberOfDigits DdApaNumber Cudd::NewApaNumber( int digits) const { return Cudd_NewApaNumber(digits); } // Cudd::NewApaNumber void Cudd::ApaCopy( int digits, DdApaNumber source, DdApaNumber dest) const { Cudd_ApaCopy(digits, source, dest); } // Cudd::ApaCopy DdApaDigit Cudd::ApaAdd( int digits, DdApaNumber a, DdApaNumber b, DdApaNumber sum) const { return Cudd_ApaAdd(digits, a, b, sum); } // Cudd::ApaAdd DdApaDigit Cudd::ApaSubtract( int digits, DdApaNumber a, DdApaNumber b, DdApaNumber diff) const { return Cudd_ApaSubtract(digits, a, b, diff); } // Cudd::ApaSubtract DdApaDigit Cudd::ApaShortDivision( int digits, DdApaNumber dividend, DdApaDigit divisor, DdApaNumber quotient) const { return Cudd_ApaShortDivision(digits, dividend, divisor, quotient); } // Cudd::ApaShortDivision void Cudd::ApaShiftRight( int digits, DdApaDigit in, DdApaNumber a, DdApaNumber b) const { Cudd_ApaShiftRight(digits, in, a, b); } // Cudd::ApaShiftRight void Cudd::ApaSetToLiteral( int digits, DdApaNumber number, DdApaDigit literal) const { Cudd_ApaSetToLiteral(digits, number, literal); } // Cudd::ApaSetToLiteral void Cudd::ApaPowerOfTwo( int digits, DdApaNumber number, int power) const { Cudd_ApaPowerOfTwo(digits, number, power); } // Cudd::ApaPowerOfTwo void Cudd::ApaPrintHex( int digits, DdApaNumber number, FILE * fp) const { cout.flush(); int result = Cudd_ApaPrintHex(fp, digits, number); checkReturnValue(result); } // Cudd::ApaPrintHex void Cudd::ApaPrintDecimal( int digits, DdApaNumber number, FILE * fp) const { cout.flush(); int result = Cudd_ApaPrintDecimal(fp, digits, number); checkReturnValue(result); } // Cudd::ApaPrintDecimal std::string Cudd::ApaStringDecimal( int digits, DdApaNumber number) const { char * result = Cudd_ApaStringDecimal(digits, number); checkReturnValue(result); std::string ret = std::string(result); free(result); return ret; } // Cudd::ApaStringDecimal void Cudd::ApaPrintExponential( int digits, DdApaNumber number, int precision, FILE * fp) const { cout.flush(); int result = Cudd_ApaPrintExponential(fp, digits, number, precision); checkReturnValue(result); } // Cudd::ApaPrintExponential DdApaNumber ABDD::ApaCountMinterm( int nvars, int * digits) const { DdManager *mgr = p->manager; return Cudd_ApaCountMinterm(mgr, node, nvars, digits); } // ABDD::ApaCountMinterm void ABDD::ApaPrintMinterm( int nvars, FILE * fp) const { cout.flush(); DdManager *mgr = p->manager; int result = Cudd_ApaPrintMinterm(fp, mgr, node, nvars); checkReturnValue(result); } // ABDD::ApaPrintMinterm void ABDD::ApaPrintMintermExp( int nvars, int precision, FILE * fp) const { cout.flush(); DdManager *mgr = p->manager; int result = Cudd_ApaPrintMintermExp(fp, mgr, node, nvars, precision); checkReturnValue(result); } // ABDD::ApaPrintMintermExp void ABDD::EpdPrintMinterm( int nvars, FILE * fp) const { EpDouble count; char str[24]; cout.flush(); DdManager *mgr = p->manager; int result = Cudd_EpdCountMinterm(mgr, node, nvars, &count); checkReturnValue(result,0); EpdGetString(&count, str); fprintf(fp, "%s", str); } // ABDD::EpdPrintMinterm long double ABDD::LdblCountMinterm( int nvars) const { cout.flush(); DdManager *mgr = p->manager; long double result = Cudd_LdblCountMinterm(mgr, node, nvars); checkReturnValue(result != (long double) CUDD_OUT_OF_MEM); return result; } // ABDD::LdblCountMinterm BDD BDD::UnderApprox( int numVars, int threshold, bool safe, double quality) const { DdManager *mgr = p->manager; DdNode *result = Cudd_UnderApprox(mgr, node, numVars, threshold, safe, quality); checkReturnValue(result); return BDD(p, result); } // BDD::UnderApprox BDD BDD::OverApprox( int numVars, int threshold, bool safe, double quality) const { DdManager *mgr = p->manager; DdNode *result = Cudd_OverApprox(mgr, node, numVars, threshold, safe, quality); checkReturnValue(result); return BDD(p, result); } // BDD::OverApprox BDD BDD::RemapUnderApprox( int numVars, int threshold, double quality) const { DdManager *mgr = p->manager; DdNode *result = Cudd_RemapUnderApprox(mgr, node, numVars, threshold, quality); checkReturnValue(result); return BDD(p, result); } // BDD::RemapUnderApprox BDD BDD::RemapOverApprox( int numVars, int threshold, double quality) const { DdManager *mgr = p->manager; DdNode *result = Cudd_RemapOverApprox(mgr, node, numVars, threshold, quality); checkReturnValue(result); return BDD(p, result); } // BDD::RemapOverApprox BDD BDD::BiasedUnderApprox( const BDD& bias, int numVars, int threshold, double quality1, double quality0) const { DdManager *mgr = p->manager; DdNode *result = Cudd_BiasedUnderApprox(mgr, node, bias.node, numVars, threshold, quality1, quality0); checkReturnValue(result); return BDD(p, result); } // BDD::BiasedUnderApprox BDD BDD::BiasedOverApprox( const BDD& bias, int numVars, int threshold, double quality1, double quality0) const { DdManager *mgr = p->manager; DdNode *result = Cudd_BiasedOverApprox(mgr, node, bias.node, numVars, threshold, quality1, quality0); checkReturnValue(result); return BDD(p, result); } // BDD::BiasedOverApprox BDD BDD::ExistAbstract( const BDD& cube, unsigned int limit) const { DdManager *mgr = checkSameManager(cube); DdNode *result; if (limit == 0) result = Cudd_bddExistAbstract(mgr, node, cube.node); else result = Cudd_bddExistAbstractLimit(mgr, node, cube.node, limit); checkReturnValue(result); return BDD(p, result); } // BDD::ExistAbstract BDD BDD::ExistAbstractRepresentative(const BDD& cube) const { DdManager *mgr = checkSameManager(cube); DdNode *result; result = Cudd_bddExistAbstractRepresentative(mgr, node, cube.node); checkReturnValue(result); return BDD(p, result); } // BDD::ExistAbstractRepresentative BDD BDD::XorExistAbstract( const BDD& g, const BDD& cube) const { DdManager *mgr = checkSameManager(g); checkSameManager(cube); DdNode *result = Cudd_bddXorExistAbstract(mgr, node, g.node, cube.node); checkReturnValue(result); return BDD(p, result); } // BDD::XorExistAbstract BDD BDD::UnivAbstract( const BDD& cube) const { DdManager *mgr = checkSameManager(cube); DdNode *result = Cudd_bddUnivAbstract(mgr, node, cube.node); checkReturnValue(result); return BDD(p, result); } // BDD::UnivAbstract BDD BDD::BooleanDiff( int x) const { DdManager *mgr = p->manager; DdNode *result = Cudd_bddBooleanDiff(mgr, node, x); checkReturnValue(result); return BDD(p, result); } // BDD::BooleanDiff bool BDD::VarIsDependent( const BDD& var) const { DdManager *mgr = p->manager; return Cudd_bddVarIsDependent(mgr, node, var.node); } // BDD::VarIsDependent double BDD::Correlation( const BDD& g) const { DdManager *mgr = checkSameManager(g); return Cudd_bddCorrelation(mgr, node, g.node); } // BDD::Correlation double BDD::CorrelationWeights( const BDD& g, double * prob) const { DdManager *mgr = checkSameManager(g); return Cudd_bddCorrelationWeights(mgr, node, g.node, prob); } // BDD::CorrelationWeights BDD BDD::Ite( const BDD& g, const BDD& h, unsigned int limit) const { DdManager *mgr = checkSameManager(g); checkSameManager(h); DdNode *result; if (limit == 0) result = Cudd_bddIte(mgr, node, g.node, h.node); else result = Cudd_bddIteLimit(mgr, node, g.node, h.node, limit); checkReturnValue(result); return BDD(p, result); } // BDD::Ite BDD BDD::IteConstant( const BDD& g, const BDD& h) const { DdManager *mgr = checkSameManager(g); checkSameManager(h); DdNode *result = Cudd_bddIteConstant(mgr, node, g.node, h.node); checkReturnValue(result); return BDD(p, result); } // BDD::IteConstant BDD BDD::Intersect( const BDD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_bddIntersect(mgr, node, g.node); checkReturnValue(result); return BDD(p, result); } // BDD::Intersect BDD BDD::And( const BDD& g, unsigned int limit) const { DdManager *mgr = checkSameManager(g); DdNode *result; if (limit == 0) result = Cudd_bddAnd(mgr, node, g.node); else result = Cudd_bddAndLimit(mgr, node, g.node, limit); checkReturnValue(result); return BDD(p, result); } // BDD::And BDD BDD::Or( const BDD& g, unsigned int limit) const { DdManager *mgr = checkSameManager(g); DdNode *result; if (limit == 0) result = Cudd_bddOr(mgr, node, g.node); else result = Cudd_bddOrLimit(mgr, node, g.node, limit); checkReturnValue(result); return BDD(p, result); } // BDD::Or BDD BDD::Nand( const BDD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_bddNand(mgr, node, g.node); checkReturnValue(result); return BDD(p, result); } // BDD::Nand BDD BDD::Nor( const BDD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_bddNor(mgr, node, g.node); checkReturnValue(result); return BDD(p, result); } // BDD::Nor BDD BDD::Xor( const BDD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_bddXor(mgr, node, g.node); checkReturnValue(result); return BDD(p, result); } // BDD::Xor BDD BDD::Xnor( const BDD& g, unsigned int limit) const { DdManager *mgr = checkSameManager(g); DdNode *result; if (limit == 0) result = Cudd_bddXnor(mgr, node, g.node); else result = Cudd_bddXnorLimit(mgr, node, g.node, limit); checkReturnValue(result); return BDD(p, result); } // BDD::Xnor bool BDD::Leq( const BDD& g) const { DdManager *mgr = checkSameManager(g); return Cudd_bddLeq(mgr, node, g.node); } // BDD::Leq BDD ADD::BddThreshold( CUDD_VALUE_TYPE value) const { DdManager *mgr = p->manager; DdNode *result = Cudd_addBddThreshold(mgr, node, value); checkReturnValue(result); return BDD(p, result); } // ADD::BddThreshold BDD ADD::BddStrictThreshold( CUDD_VALUE_TYPE value) const { DdManager *mgr = p->manager; DdNode *result = Cudd_addBddStrictThreshold(mgr, node, value); checkReturnValue(result); return BDD(p, result); } // ADD::BddStrictThreshold BDD ADD::BddInterval( CUDD_VALUE_TYPE lower, CUDD_VALUE_TYPE upper) const { DdManager *mgr = p->manager; DdNode *result = Cudd_addBddInterval(mgr, node, lower, upper); checkReturnValue(result); return BDD(p, result); } // ADD::BddInterval BDD ADD::BddIthBit( int bit) const { DdManager *mgr = p->manager; DdNode *result = Cudd_addBddIthBit(mgr, node, bit); checkReturnValue(result); return BDD(p, result); } // ADD::BddIthBit ADD BDD::Add() const { DdManager *mgr = p->manager; DdNode *result = Cudd_BddToAdd(mgr, node); checkReturnValue(result); return ADD(p, result); } // BDD::Add BDD ADD::BddPattern() const { DdManager *mgr = p->manager; DdNode *result = Cudd_addBddPattern(mgr, node); checkReturnValue(result); return BDD(p, result); } // ADD::BddPattern BDD BDD::Transfer( Cudd& destination) const { DdManager *mgr = p->manager; DdNode *result = Cudd_bddTransfer(mgr, destination.p->manager, node); checkReturnValue(result); return BDD(destination.p, result); } // BDD::Transfer void Cudd::DebugCheck() const { int result = Cudd_DebugCheck(p->manager); checkReturnValue(result == 0); } // Cudd::DebugCheck void Cudd::CheckKeys() const { int result = Cudd_CheckKeys(p->manager); checkReturnValue(result == 0); } // Cudd::CheckKeys BDD BDD::ClippingAnd( const BDD& g, int maxDepth, int direction) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_bddClippingAnd(mgr, node, g.node, maxDepth, direction); checkReturnValue(result); return BDD(p, result); } // BDD::ClippingAnd BDD BDD::ClippingAndAbstract( const BDD& g, const BDD& cube, int maxDepth, int direction) const { DdManager *mgr = checkSameManager(g); checkSameManager(cube); DdNode *result = Cudd_bddClippingAndAbstract(mgr, node, g.node, cube.node, maxDepth, direction); checkReturnValue(result); return BDD(p, result); } // BDD::ClippingAndAbstract ADD ADD::Cofactor( const ADD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_Cofactor(mgr, node, g.node); checkReturnValue(result); return ADD(p, result); } // ADD::Cofactor BDD BDD::Cofactor( const BDD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_Cofactor(mgr, node, g.node); checkReturnValue(result); return BDD(p, result); } // BDD::Cofactor bool BDD::VarAreSymmetric(int index1, int index2) const { return Cudd_VarsAreSymmetric(p->manager, node, index1, index2); } // BDD::VarAreSymmetric BDD BDD::Compose( const BDD& g, int v) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_bddCompose(mgr, node, g.node, v); checkReturnValue(result); return BDD(p, result); } // BDD::Compose ADD ADD::Compose( const ADD& g, int v) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_addCompose(mgr, node, g.node, v); checkReturnValue(result); return ADD(p, result); } // ADD::Compose ADD ADD::Permute( int * permut) const { DdManager *mgr = p->manager; DdNode *result = Cudd_addPermute(mgr, node, permut); checkReturnValue(result); return ADD(p, result); } // ADD::Permute ADD ADD::SwapVariables( std::vector x, std::vector y) const { size_t n = x.size(); DdManager *mgr = p->manager; DdNode **X = new DdNode *[n]; DdNode **Y = new DdNode *[n]; for (size_t i = 0; i < n; i++) { X[i] = x[i].node; Y[i] = y[i].node; } DdNode *result = Cudd_addSwapVariables(mgr, node, X, Y, (int) n); delete [] X; delete [] Y; checkReturnValue(result); return ADD(p, result); } // ADD::SwapVariables BDD BDD::Permute( int * permut) const { DdManager *mgr = p->manager; DdNode *result = Cudd_bddPermute(mgr, node, permut); checkReturnValue(result); return BDD(p, result); } // BDD::Permute BDD BDD::SwapVariables( std::vector x, std::vector y) const { size_t n = x.size(); DdManager *mgr = p->manager; DdNode **X = new DdNode *[n]; DdNode **Y = new DdNode *[n]; for (size_t i = 0; i < n; i++) { X[i] = x[i].node; Y[i] = y[i].node; } DdNode *result = Cudd_bddSwapVariables(mgr, node, X, Y, (int) n); delete [] X; delete [] Y; checkReturnValue(result); return BDD(p, result); } // BDD::SwapVariables BDD BDD::AdjPermuteX( std::vector x) const { size_t n = x.size(); DdManager *mgr = p->manager; DdNode **X = new DdNode *[n]; for (size_t i = 0; i < n; i++) { X[i] = x[i].node; } DdNode *result = Cudd_bddAdjPermuteX(mgr, node, X, (int) n); delete [] X; checkReturnValue(result); return BDD(p, result); } // BDD::AdjPermuteX ADD ADD::VectorCompose( std::vector vect) const { DdManager *mgr = p->manager; size_t n = (size_t) Cudd_ReadSize(mgr); DdNode **X = new DdNode *[n]; for (size_t i = 0; i < n; i++) { X[i] = vect[i].node; } DdNode *result = Cudd_addVectorCompose(mgr, node, X); delete [] X; checkReturnValue(result); return ADD(p, result); } // ADD::VectorCompose ADD ADD::NonSimCompose( std::vector vect) const { DdManager *mgr = p->manager; size_t n = (size_t) Cudd_ReadSize(mgr); DdNode **X = new DdNode *[n]; for (size_t i = 0; i < n; i++) { X[i] = vect[i].node; } DdNode *result = Cudd_addNonSimCompose(mgr, node, X); delete [] X; checkReturnValue(result); return ADD(p, result); } // ADD::NonSimCompose BDD BDD::VectorCompose( std::vector vect) const { DdManager *mgr = p->manager; size_t n = (size_t) Cudd_ReadSize(mgr); DdNode **X = new DdNode *[n]; for (size_t i = 0; i < n; i++) { X[i] = vect[i].node; } DdNode *result = Cudd_bddVectorCompose(mgr, node, X); delete [] X; checkReturnValue(result); return BDD(p, result); } // BDD::VectorCompose void BDD::ApproxConjDecomp( BDD* g, BDD* h) const { DdManager *mgr = p->manager; DdNode **pieces; int result = Cudd_bddApproxConjDecomp(mgr, node, &pieces); checkReturnValue(result == 2); *g = BDD(p, pieces[0]); *h = BDD(p, pieces[1]); Cudd_RecursiveDeref(mgr,pieces[0]); Cudd_RecursiveDeref(mgr,pieces[1]); free(pieces); } // BDD::ApproxConjDecomp void BDD::ApproxDisjDecomp( BDD* g, BDD* h) const { DdManager *mgr = p->manager; DdNode **pieces; int result = Cudd_bddApproxDisjDecomp(mgr, node, &pieces); checkReturnValue(result == 2); *g = BDD(p, pieces[0]); *h = BDD(p, pieces[1]); Cudd_RecursiveDeref(mgr,pieces[0]); Cudd_RecursiveDeref(mgr,pieces[1]); free(pieces); } // BDD::ApproxDisjDecomp void BDD::IterConjDecomp( BDD* g, BDD* h) const { DdManager *mgr = p->manager; DdNode **pieces; int result = Cudd_bddIterConjDecomp(mgr, node, &pieces); checkReturnValue(result == 2); *g = BDD(p, pieces[0]); *h = BDD(p, pieces[1]); Cudd_RecursiveDeref(mgr,pieces[0]); Cudd_RecursiveDeref(mgr,pieces[1]); free(pieces); } // BDD::IterConjDecomp void BDD::IterDisjDecomp( BDD* g, BDD* h) const { DdManager *mgr = p->manager; DdNode **pieces; int result = Cudd_bddIterDisjDecomp(mgr, node, &pieces); checkReturnValue(result == 2); *g = BDD(p, pieces[0]); *h = BDD(p, pieces[1]); Cudd_RecursiveDeref(mgr,pieces[0]); Cudd_RecursiveDeref(mgr,pieces[1]); free(pieces); } // BDD::IterDisjDecomp void BDD::GenConjDecomp( BDD* g, BDD* h) const { DdManager *mgr = p->manager; DdNode **pieces; int result = Cudd_bddGenConjDecomp(mgr, node, &pieces); checkReturnValue(result == 2); *g = BDD(p, pieces[0]); *h = BDD(p, pieces[1]); Cudd_RecursiveDeref(mgr,pieces[0]); Cudd_RecursiveDeref(mgr,pieces[1]); free(pieces); } // BDD::GenConjDecomp void BDD::GenDisjDecomp( BDD* g, BDD* h) const { DdManager *mgr = p->manager; DdNode **pieces; int result = Cudd_bddGenDisjDecomp(mgr, node, &pieces); checkReturnValue(result == 2); *g = BDD(p, pieces[0]); *h = BDD(p, pieces[1]); Cudd_RecursiveDeref(mgr,pieces[0]); Cudd_RecursiveDeref(mgr,pieces[1]); free(pieces); } // BDD::GenDisjDecomp void BDD::VarConjDecomp( BDD* g, BDD* h) const { DdManager *mgr = p->manager; DdNode **pieces; int result = Cudd_bddVarConjDecomp(mgr, node, &pieces); checkReturnValue(result == 2); *g = BDD(p, pieces[0]); *h = BDD(p, pieces[1]); Cudd_RecursiveDeref(mgr,pieces[0]); Cudd_RecursiveDeref(mgr,pieces[1]); free(pieces); } // BDD::VarConjDecomp void BDD::VarDisjDecomp( BDD* g, BDD* h) const { DdManager *mgr = p->manager; DdNode **pieces; int result = Cudd_bddVarDisjDecomp(mgr, node, &pieces); checkReturnValue(result == 2); *g = BDD(p, pieces[0]); *h = BDD(p, pieces[1]); Cudd_RecursiveDeref(mgr,pieces[0]); Cudd_RecursiveDeref(mgr,pieces[1]); free(pieces); } // BDD::VarDisjDecomp bool ABDD::IsCube() const { DdManager *mgr = p->manager; return Cudd_CheckCube(mgr, node); } // ABDD::IsCube BDD ABDD::FindEssential() const { DdManager *mgr = p->manager; DdNode *result = Cudd_FindEssential(mgr, node); checkReturnValue(result); return BDD(p, result); } // ABDD::FindEssential bool BDD::IsVarEssential( int id, int phase) const { DdManager *mgr = p->manager; return Cudd_bddIsVarEssential(mgr, node, id, phase); } // BDD::IsVarEssential void ABDD::PrintTwoLiteralClauses( char **names, FILE *fp) const { DdManager *mgr = p->manager; int result = Cudd_PrintTwoLiteralClauses(mgr, node, names, fp); checkReturnValue(result); } // ABDD::PrintTwoLiteralClauses void Cudd::DumpBlif( const std::vector& nodes, char const * const * inames, char const * const * onames, char * mname, FILE * fp, int mv) const { DdManager *mgr = p->manager; size_t n = nodes.size(); DdNode **F = new DdNode *[n]; for (size_t i = 0; i < n; i ++) { F[i] = nodes[i].getNode(); } int result = Cudd_DumpBlif(mgr, (int) n, F, inames, onames, mname, fp, mv); delete [] F; checkReturnValue(result); } // Cudd::DumpBlif void Cudd::DumpDot( const std::vector& nodes, char const * const * inames, char const * const * onames, FILE * fp) const { DdManager *mgr = p->manager; size_t n = nodes.size(); DdNode **F = new DdNode *[n]; for (size_t i = 0; i < n; i ++) { F[i] = nodes[i].getNode(); } int result = Cudd_DumpDot(mgr, (int) n, F, inames, onames, fp); delete [] F; checkReturnValue(result); } // Cudd::DumpDot void Cudd::DumpDot( const std::vector& nodes, char const * const * inames, char const * const * onames, FILE * fp) const { DdManager *mgr = p->manager; size_t n = nodes.size(); DdNode **F = new DdNode *[n]; for (size_t i = 0; i < n; i ++) { F[i] = nodes[i].getNode(); } int result = Cudd_DumpDot(mgr, (int) n, F, inames, onames, fp); delete [] F; checkReturnValue(result); } // Cudd::DumpDot void Cudd::DumpDaVinci( const std::vector& nodes, char const * const * inames, char const * const * onames, FILE * fp) const { DdManager *mgr = p->manager; size_t n = nodes.size(); DdNode **F = new DdNode *[n]; for (size_t i = 0; i < n; i ++) { F[i] = nodes[i].getNode(); } int result = Cudd_DumpDaVinci(mgr, (int) n, F, inames, onames, fp); delete [] F; checkReturnValue(result); } // Cudd::DumpDaVinci void Cudd::DumpDaVinci( const std::vector& nodes, char const * const * inames, char const * const * onames, FILE * fp) const { DdManager *mgr = p->manager; size_t n = nodes.size(); DdNode **F = new DdNode *[n]; for (size_t i = 0; i < n; i ++) { F[i] = nodes[i].getNode(); } int result = Cudd_DumpDaVinci(mgr, (int) n, F, inames, onames, fp); delete [] F; checkReturnValue(result); } // Cudd::DumpDaVinci void Cudd::DumpDDcal( const std::vector& nodes, char const * const * inames, char const * const * onames, FILE * fp) const { DdManager *mgr = p->manager; size_t n = nodes.size(); DdNode **F = new DdNode *[n]; for (size_t i = 0; i < n; i ++) { F[i] = nodes[i].getNode(); } int result = Cudd_DumpDDcal(mgr, (int) n, F, inames, onames, fp); delete [] F; checkReturnValue(result); } // Cudd::DumpDDcal void Cudd::DumpFactoredForm( const std::vector& nodes, char const * const * inames, char const * const * onames, FILE * fp) const { DdManager *mgr = p->manager; size_t n = nodes.size(); DdNode **F = new DdNode *[n]; for (size_t i = 0; i < n; i ++) { F[i] = nodes[i].getNode(); } int result = Cudd_DumpFactoredForm(mgr, (int) n, F, inames, onames, fp); delete [] F; checkReturnValue(result); } // Cudd::DumpFactoredForm void BDD::PrintFactoredForm( char const * const * inames, FILE * fp) const { DdManager *mgr = p->manager; DdNode *f = node; int result = Cudd_DumpFactoredForm(mgr, 0, &f, inames, 0, fp); checkReturnValue(result); } // BDD::PrintFactoredForm string BDD::FactoredFormString(char const * const * inames) const { DdManager *mgr = p->manager; DdNode *f = node; char *cstr = Cudd_FactoredFormString(mgr, f, inames); checkReturnValue(cstr); string str(cstr); free(cstr); return str; } // BDD::FactoredFormString BDD BDD::Constrain( const BDD& c) const { DdManager *mgr = checkSameManager(c); DdNode *result = Cudd_bddConstrain(mgr, node, c.node); checkReturnValue(result); return BDD(p, result); } // BDD::Constrain BDD BDD::Restrict( const BDD& c) const { DdManager *mgr = checkSameManager(c); DdNode *result = Cudd_bddRestrict(mgr, node, c.node); checkReturnValue(result); return BDD(p, result); } // BDD::Restrict BDD BDD::NPAnd( const BDD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_bddNPAnd(mgr, node, g.node); checkReturnValue(result); return BDD(p, result); } // BDD::NPAnd ADD ADD::Constrain( const ADD& c) const { DdManager *mgr = checkSameManager(c); DdNode *result = Cudd_addConstrain(mgr, node, c.node); checkReturnValue(result); return ADD(p, result); } // ADD::Constrain std::vector BDD::ConstrainDecomp() const { DdManager *mgr = p->manager; DdNode **result = Cudd_bddConstrainDecomp(mgr, node); checkReturnValue(result); int size = Cudd_ReadSize(mgr); vector vect; for (int i = 0; i < size; i++) { Cudd_Deref(result[i]); vect.push_back(BDD(p, result[i])); } free(result); return vect; } // BDD::ConstrainDecomp ADD ADD::Restrict( const ADD& c) const { DdManager *mgr = checkSameManager(c); DdNode *result = Cudd_addRestrict(mgr, node, c.node); checkReturnValue(result); return ADD(p, result); } // ADD::Restrict std::vector BDD::CharToVect() const { DdManager *mgr = p->manager; DdNode **result = Cudd_bddCharToVect(mgr, node); checkReturnValue(result); int size = Cudd_ReadSize(mgr); vector vect; for (int i = 0; i < size; i++) { Cudd_Deref(result[i]); vect.push_back(BDD(p, result[i])); } free(result); return vect; } // BDD::CharToVect BDD BDD::LICompaction( const BDD& c) const { DdManager *mgr = checkSameManager(c); DdNode *result = Cudd_bddLICompaction(mgr, node, c.node); checkReturnValue(result); return BDD(p, result); } // BDD::LICompaction BDD BDD::Squeeze( const BDD& u) const { DdManager *mgr = checkSameManager(u); DdNode *result = Cudd_bddSqueeze(mgr, node, u.node); checkReturnValue(result); return BDD(p, result); } // BDD::Squeeze BDD BDD::Interpolate( const BDD& u) const { DdManager *mgr = checkSameManager(u); DdNode *result = Cudd_bddInterpolate(mgr, node, u.node); checkReturnValue(result); return BDD(p, result); } // BDD::Interpolate BDD BDD::Minimize( const BDD& c) const { DdManager *mgr = checkSameManager(c); DdNode *result = Cudd_bddMinimize(mgr, node, c.node); checkReturnValue(result); return BDD(p, result); } // BDD::Minimize BDD BDD::SubsetCompress( int nvars, int threshold) const { DdManager *mgr = p->manager; DdNode *result = Cudd_SubsetCompress(mgr, node, nvars, threshold); checkReturnValue(result); return BDD(p, result); } // BDD::SubsetCompress BDD BDD::SupersetCompress( int nvars, int threshold) const { DdManager *mgr = p->manager; DdNode *result = Cudd_SupersetCompress(mgr, node, nvars, threshold); checkReturnValue(result); return BDD(p, result); } // BDD::SupersetCompress MtrNode * Cudd::MakeTreeNode( unsigned int low, unsigned int size, unsigned int type) const { return Cudd_MakeTreeNode(p->manager, low, size, type); } // Cudd::MakeTreeNode ADD Cudd::Harwell( FILE * fp, std::vector& x, std::vector& y, std::vector& xn, std::vector& yn_, int * m, int * n, int bx, int sx, int by, int sy, int pr) const { DdManager *mgr = p->manager; DdNode *E; DdNode **xa = 0, **ya = 0, **xna = 0, **yna = 0; int nx = x.size(), ny = y.size(); if (nx > 0) { xa = (DdNode **) malloc(nx * sizeof(DdNode *)); if (!xa) { p->errorHandler("Out of memory."); } xna = (DdNode **) malloc(nx * sizeof(DdNode *)); if (!xna) { free(xa); p->errorHandler("Out of memory."); } for (int i = 0; i < nx; ++i) { xa[i] = x.at(i).node; xna[i] = xn.at(i).node; } } if (ny > 0) { ya = (DdNode **) malloc(ny * sizeof(DdNode *)); if (!ya) { free(xa); free(xna); p->errorHandler("Out of memory."); } yna = (DdNode **) malloc(ny * sizeof(DdNode *)); if (!yna) { free(xa); free(xna); free(ya); p->errorHandler("Out of memory."); } for (int j = 0; j < ny; ++j) { ya[j] = y.at(j).node; yna[j] = yn_.at(j).node; } } int result = Cudd_addHarwell(fp, mgr, &E, &xa, &ya, &xna, &yna, &nx, &ny, m, n, bx, sx, by, sy, pr); checkReturnValue(result); for (int i = x.size(); i < nx; ++i) { x.push_back(ADD(p, xa[i])); xn.push_back(ADD(p, xna[i])); } free(xa); free(xna); for (int j = y.size(); j < ny; ++j) { y.push_back(ADD(p, ya[j])); yn_.push_back(ADD(p, yna[j])); } free(ya); free(yna); Cudd_Deref(E); return ADD(p, E); } // Cudd::Harwell void Cudd::PrintLinear(void) const { cout.flush(); int result = Cudd_PrintLinear(p->manager); checkReturnValue(result); } // Cudd::PrintLinear int Cudd::ReadLinear( int x, int y) const { return Cudd_ReadLinear(p->manager, x, y); } // Cudd::ReadLinear BDD BDD::LiteralSetIntersection( const BDD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_bddLiteralSetIntersection(mgr, node, g.node); checkReturnValue(result); return BDD(p, result); } // BDD::LiteralSetIntersection ADD ADD::MatrixMultiply( const ADD& B, std::vector z) const { size_t nz = z.size(); DdManager *mgr = checkSameManager(B); DdNode **Z = new DdNode *[nz]; for (size_t i = 0; i < nz; i++) { Z[i] = z[i].node; } DdNode *result = Cudd_addMatrixMultiply(mgr, node, B.node, Z, (int) nz); delete [] Z; checkReturnValue(result); return ADD(p, result); } // ADD::MatrixMultiply ADD ADD::TimesPlus( const ADD& B, std::vector z) const { size_t nz = z.size(); DdManager *mgr = checkSameManager(B); DdNode **Z = new DdNode *[nz]; for (size_t i = 0; i < nz; i++) { Z[i] = z[i].node; } DdNode *result = Cudd_addTimesPlus(mgr, node, B.node, Z, (int) nz); delete [] Z; checkReturnValue(result); return ADD(p, result); } // ADD::TimesPlus ADD ADD::Triangle( const ADD& g, std::vector z) const { size_t nz = z.size(); DdManager *mgr = checkSameManager(g); DdNode **Z = new DdNode *[nz]; for (size_t i = 0; i < nz; i++) { Z[i] = z[i].node; } DdNode *result = Cudd_addTriangle(mgr, node, g.node, Z, (int) nz); delete [] Z; checkReturnValue(result); return ADD(p, result); } // ADD::Triangle BDD BDD::PrioritySelect( std::vector x, std::vector y, std::vector z, const BDD& Pi, DD_PRFP Pifunc) const { size_t n = x.size(); DdManager *mgr = p->manager; DdNode **X = new DdNode *[n]; DdNode **Y = new DdNode *[n]; DdNode **Z = new DdNode *[n]; for (size_t i = 0; i < n; i++) { X[i] = x[i].node; Y[i] = y[i].node; Z[i] = z[i].node; } DdNode *result = Cudd_PrioritySelect(mgr, node, X, Y, Z, Pi.node, (int) n, Pifunc); delete [] X; delete [] Y; delete [] Z; checkReturnValue(result); return BDD(p, result); } // BDD::PrioritySelect BDD Cudd::Xgty( std::vector z, std::vector x, std::vector y) const { size_t N = z.size(); DdManager *mgr = p->manager; DdNode **X = new DdNode *[N]; DdNode **Y = new DdNode *[N]; DdNode **Z = new DdNode *[N]; for (size_t i = 0; i < N; i++) { X[i] = x[i].getNode(); Y[i] = y[i].getNode(); Z[i] = z[i].getNode(); } DdNode *result = Cudd_Xgty(mgr, (int) N, Z, X, Y); delete [] X; delete [] Y; delete [] Z; checkReturnValue(result); return BDD(p, result); } // Cudd::Xgty BDD Cudd::Xeqy( std::vector x, std::vector y) const { size_t N = x.size(); DdManager *mgr = p->manager; DdNode **X = new DdNode *[N]; DdNode **Y = new DdNode *[N]; for (size_t i = 0; i < N; i++) { X[i] = x[i].getNode(); Y[i] = y[i].getNode(); } DdNode *result = Cudd_Xeqy(mgr, (int) N, X, Y); delete [] X; delete [] Y; checkReturnValue(result); return BDD(p, result); } // BDD::Xeqy ADD Cudd::Xeqy( std::vector x, std::vector y) const { size_t N = x.size(); DdManager *mgr = p->manager; DdNode **X = new DdNode *[N]; DdNode **Y = new DdNode *[N]; for (size_t i = 0; i < N; i++) { X[i] = x[i].getNode(); Y[i] = y[i].getNode(); } DdNode *result = Cudd_addXeqy(mgr, (int) N, X, X); delete [] X; delete [] Y; checkReturnValue(result); return ADD(p, result); } // ADD::Xeqy BDD Cudd::Dxygtdxz( std::vector x, std::vector y, std::vector z) const { size_t N = x.size(); DdManager *mgr = p->manager; DdNode **X = new DdNode *[N]; DdNode **Y = new DdNode *[N]; DdNode **Z = new DdNode *[N]; for (size_t i = 0; i < N; i++) { X[i] = x[i].getNode(); Y[i] = y[i].getNode(); Z[i] = z[i].getNode(); } DdNode *result = Cudd_Dxygtdxz(mgr, (int) N, X, Y, Z); delete [] X; delete [] Y; delete [] Z; checkReturnValue(result); return BDD(p, result); } // Cudd::Dxygtdxz BDD Cudd::Dxygtdyz( std::vector x, std::vector y, std::vector z) const { size_t N = x.size(); DdManager *mgr = p->manager; DdNode **X = new DdNode *[N]; DdNode **Y = new DdNode *[N]; DdNode **Z = new DdNode *[N]; for (size_t i = 0; i < N; i++) { X[i] = x[i].getNode(); Y[i] = y[i].getNode(); Z[i] = z[i].getNode(); } DdNode *result = Cudd_Dxygtdyz(mgr, (int) N, X, Y, Z); delete [] X; delete [] Y; delete [] Z; checkReturnValue(result); return BDD(p, result); } // Cudd::Dxygtdyz BDD Cudd::Inequality( int c, std::vector x, std::vector y) const { size_t N = x.size(); DdManager *mgr = p->manager; DdNode **X = new DdNode *[N]; DdNode **Y = new DdNode *[N]; for (size_t i = 0; i < N; i++) { X[i] = x[i].getNode(); Y[i] = y[i].getNode(); } DdNode *result = Cudd_Inequality(mgr, (int) N, c, X, Y); delete [] X; delete [] Y; checkReturnValue(result); return BDD(p, result); } // Cudd::Inequality BDD Cudd::Disequality( int c, std::vector x, std::vector y) const { size_t N = x.size(); DdManager *mgr = p->manager; DdNode **X = new DdNode *[N]; DdNode **Y = new DdNode *[N]; for (size_t i = 0; i < N; i++) { X[i] = x[i].getNode(); Y[i] = y[i].getNode(); } DdNode *result = Cudd_Disequality(mgr, (int) N, c, X, Y); delete [] X; delete [] Y; checkReturnValue(result); return BDD(p, result); } // Cudd::Disequality BDD Cudd::Interval( std::vector x, unsigned int lowerB, unsigned int upperB) const { size_t N = x.size(); DdManager *mgr = p->manager; DdNode **X = new DdNode *[N]; for (size_t i = 0; i < N; i++) { X[i] = x[i].getNode(); } DdNode *result = Cudd_bddInterval(mgr, (int) N, X, lowerB, upperB); delete [] X; checkReturnValue(result); return BDD(p, result); } // Cudd::Interval BDD BDD::CProjection( const BDD& Y) const { DdManager *mgr = checkSameManager(Y); DdNode *result = Cudd_CProjection(mgr, node, Y.node); checkReturnValue(result); return BDD(p, result); } // BDD::CProjection int BDD::MinHammingDist( int *minterm, int upperBound) const { DdManager *mgr = p->manager; int result = Cudd_MinHammingDist(mgr, node, minterm, upperBound); return result; } // BDD::MinHammingDist ADD Cudd::Hamming( std::vector xVars, std::vector yVars) const { size_t nVars = xVars.size(); DdManager *mgr = p->manager; DdNode **X = new DdNode *[nVars]; DdNode **Y = new DdNode *[nVars]; for (size_t i = 0; i < nVars; i++) { X[i] = xVars[i].getNode(); Y[i] = yVars[i].getNode(); } DdNode *result = Cudd_addHamming(mgr, X, Y, (int) nVars); delete [] X; delete [] Y; checkReturnValue(result); return ADD(p, result); } // Cudd::Hamming ADD Cudd::Read( FILE * fp, std::vector& x, std::vector& y, std::vector& xn, std::vector& yn_, int * m, int * n, int bx, int sx, int by, int sy) const { DdManager *mgr = p->manager; DdNode *E; DdNode **xa = 0, **ya = 0, **xna = 0, **yna = 0; int nx = x.size(), ny = y.size(); if (nx > 0) { xa = (DdNode **) malloc(nx * sizeof(DdNode *)); if (!xa) { p->errorHandler("Out of memory."); } xna = (DdNode **) malloc(nx * sizeof(DdNode *)); if (!xna) { free(xa); p->errorHandler("Out of memory."); } for (int i = 0; i < nx; ++i) { xa[i] = x.at(i).node; xna[i] = xn.at(i).node; } } if (ny > 0) { ya = (DdNode **) malloc(ny * sizeof(DdNode *)); if (!ya) { free(xa); free(xna); p->errorHandler("Out of memory."); } yna = (DdNode **) malloc(ny * sizeof(DdNode *)); if (!yna) { free(xa); free(xna); free(ya); p->errorHandler("Out of memory."); } for (int j = 0; j < ny; ++j) { ya[j] = y.at(j).node; yna[j] = yn_.at(j).node; } } int result = Cudd_addRead(fp, mgr, &E, &xa, &ya, &xna, &yna, &nx, &ny, m, n, bx, sx, by, sy); checkReturnValue(result); for (int i = x.size(); i < nx; ++i) { x.push_back(ADD(p, xa[i])); xn.push_back(ADD(p, xna[i])); } free(xa); free(xna); for (int j = y.size(); j < ny; ++j) { y.push_back(ADD(p, ya[j])); yn_.push_back(ADD(p, yna[j])); } free(ya); free(yna); Cudd_Deref(E); return ADD(p, E); } // Cudd::Read BDD Cudd::Read( FILE * fp, std::vector& x, std::vector& y, int * m, int * n, int bx, int sx, int by, int sy) const { DdManager *mgr = p->manager; DdNode *E; DdNode **xa = 0, **ya = 0; int nx = x.size(), ny = y.size(); if (nx > 0) { xa = (DdNode **) malloc(nx * sizeof(DdNode *)); if (!xa) { p->errorHandler("Out of memory."); } for (int i = 0; i < nx; ++i) { xa[i] = x.at(i).node; } } if (ny > 0) { ya = (DdNode **) malloc(ny * sizeof(DdNode *)); if (!ya) { free(xa); p->errorHandler("Out of memory."); } for (int j = 0; j < nx; ++j) { ya[j] = y.at(j).node; } } int result = Cudd_bddRead(fp, mgr, &E, &xa, &ya, &nx, &ny, m, n, bx, sx, by, sy); checkReturnValue(result); for (int i = x.size(); i < nx; ++i) { x.push_back(BDD(p, xa[i])); } free(xa); for (int j = y.size(); j < ny; ++j) { y.push_back(BDD(p, ya[j])); } free(ya); Cudd_Deref(E); return BDD(p, E); } // Cudd::Read void Cudd::ReduceHeap( Cudd_ReorderingType heuristic, int minsize) const { int result = Cudd_ReduceHeap(p->manager, heuristic, minsize); checkReturnValue(result); } // Cudd::ReduceHeap void Cudd::ShuffleHeap( int * permutation) const { int result = Cudd_ShuffleHeap(p->manager, permutation); checkReturnValue(result); } // Cudd::ShuffleHeap ADD ADD::Eval( int * inputs) const { DdManager *mgr = p->manager; DdNode *result = Cudd_Eval(mgr, node, inputs); checkReturnValue(result); return ADD(p, result); } // ADD::Eval BDD BDD::Eval( int * inputs) const { DdManager *mgr = p->manager; DdNode *result = Cudd_Eval(mgr, node, inputs); checkReturnValue(result); return BDD(p, result); } // BDD::Eval BDD ABDD::ShortestPath( int * weight, int * support, int * length) const { DdManager *mgr = p->manager; DdNode *result = Cudd_ShortestPath(mgr, node, weight, support, length); checkReturnValue(result); return BDD(p, result); } // ABDD::ShortestPath BDD ABDD::LargestCube( int * length) const { DdManager *mgr = p->manager; DdNode *result = Cudd_LargestCube(mgr, node, length); checkReturnValue(result); return BDD(p, result); } // ABDD::LargestCube int ABDD::ShortestLength( int * weight) const { DdManager *mgr = p->manager; int result = Cudd_ShortestLength(mgr, node, weight); checkReturnValue(result != CUDD_OUT_OF_MEM); return result; } // ABDD::ShortestLength BDD BDD::Decreasing( int i) const { DdManager *mgr = p->manager; DdNode *result = Cudd_Decreasing(mgr, node, i); checkReturnValue(result); return BDD(p, result); } // BDD::Decreasing BDD BDD::Increasing( int i) const { DdManager *mgr = p->manager; DdNode *result = Cudd_Increasing(mgr, node, i); checkReturnValue(result); return BDD(p, result); } // BDD::Increasing bool ABDD::EquivDC( const ABDD& G, const ABDD& D) const { DdManager *mgr = checkSameManager(G); checkSameManager(D); return Cudd_EquivDC(mgr, node, G.node, D.node); } // ABDD::EquivDC bool BDD::LeqUnless( const BDD& G, const BDD& D) const { DdManager *mgr = checkSameManager(G); checkSameManager(D); int res = Cudd_bddLeqUnless(mgr, node, G.node, D.node); return res; } // BDD::LeqUnless bool ADD::EqualSupNorm( const ADD& g, CUDD_VALUE_TYPE tolerance, int pr) const { DdManager *mgr = checkSameManager(g); return Cudd_EqualSupNorm(mgr, node, g.node, tolerance, pr); } // ADD::EqualSupNorm bool ADD::EqualSupNormRel( const ADD& g, CUDD_VALUE_TYPE tolerance, int pr) const { DdManager *mgr = checkSameManager(g); return Cudd_EqualSupNormRel(mgr, node, g.node, tolerance, pr) != 0; } // ADD::EqualSupNormRel BDD BDD::MakePrime( const BDD& F) const { DdManager *mgr = checkSameManager(F); if (!Cudd_CheckCube(mgr, node)) { p->errorHandler("Invalid argument."); } DdNode *result = Cudd_bddMakePrime(mgr, node, F.node); checkReturnValue(result); return BDD(p, result); } // BDD:MakePrime BDD BDD::MaximallyExpand( const BDD& ub, const BDD& f) { DdManager *mgr = checkSameManager(ub); checkSameManager(f); DdNode *result = Cudd_bddMaximallyExpand(mgr, node, ub.node, f.node); checkReturnValue(result); return BDD(p, result); } // BDD::MaximallyExpand BDD BDD::LargestPrimeUnate( const BDD& phases) { DdManager *mgr = checkSameManager(phases); DdNode *result = Cudd_bddLargestPrimeUnate(mgr, node, phases.node); checkReturnValue(result); return BDD(p, result); } // BDD::LargestPrimeUnate double * ABDD::CofMinterm() const { DdManager *mgr = p->manager; double *result = Cudd_CofMinterm(mgr, node); checkReturnValue(result); return result; } // ABDD::CofMinterm BDD BDD::SolveEqn( const BDD& Y, std::vector & G, int ** yIndex, int n) const { DdManager *mgr = checkSameManager(Y); DdNode **g = new DdNode *[n]; DdNode *result = Cudd_SolveEqn(mgr, node, Y.node, g, yIndex, n); checkReturnValue(result); for (int i = 0; i < n; i++) { G.push_back(BDD(p, g[i])); Cudd_RecursiveDeref(mgr,g[i]); } delete [] g; return BDD(p, result); } // BDD::SolveEqn BDD BDD::VerifySol( std::vector const & G, int * yIndex) const { size_t n = G.size(); DdManager *mgr = p->manager; DdNode **g = new DdNode *[n]; for (size_t i = 0; i < n; i++) { g[i] = G[i].node; } DdNode *result = Cudd_VerifySol(mgr, node, g, yIndex, (int) n); delete [] g; checkReturnValue(result); return BDD(p, result); } // BDD::VerifySol BDD BDD::SplitSet( std::vector xVars, double m) const { size_t n = xVars.size(); DdManager *mgr = p->manager; DdNode **X = new DdNode *[n]; for (size_t i = 0; i < n; i++) { X[i] = xVars[i].node; } DdNode *result = Cudd_SplitSet(mgr, node, X, (int) n, m); delete [] X; checkReturnValue(result); return BDD(p, result); } // BDD::SplitSet BDD BDD::SubsetHeavyBranch( int numVars, int threshold) const { DdManager *mgr = p->manager; DdNode *result = Cudd_SubsetHeavyBranch(mgr, node, numVars, threshold); checkReturnValue(result); return BDD(p, result); } // BDD::SubsetHeavyBranch BDD BDD::SupersetHeavyBranch( int numVars, int threshold) const { DdManager *mgr = p->manager; DdNode *result = Cudd_SupersetHeavyBranch(mgr, node, numVars, threshold); checkReturnValue(result); return BDD(p, result); } // BDD::SupersetHeavyBranch BDD BDD::SubsetShortPaths( int numVars, int threshold, bool hardlimit) const { DdManager *mgr = p->manager; DdNode *result = Cudd_SubsetShortPaths(mgr, node, numVars, threshold, hardlimit); checkReturnValue(result); return BDD(p, result); } // BDD::SubsetShortPaths BDD BDD::SupersetShortPaths( int numVars, int threshold, bool hardlimit) const { DdManager *mgr = p->manager; DdNode *result = Cudd_SupersetShortPaths(mgr, node, numVars, threshold, hardlimit); checkReturnValue(result); return BDD(p, result); } // BDD::SupersetShortPaths void Cudd::SymmProfile( int lower, int upper) const { Cudd_SymmProfile(p->manager, lower, upper); } // Cudd::SymmProfile unsigned int Cudd::Prime( unsigned int pr) const { return Cudd_Prime(pr); } // Cudd::Prime void Cudd::Reserve( int amount) const { int result = Cudd_Reserve(p->manager, amount); checkReturnValue(result); } // Cudd::Reserve void ABDD::PrintMinterm() const { cout.flush(); DdManager *mgr = p->manager; int result = Cudd_PrintMinterm(mgr, node); checkReturnValue(result); } // ABDD::PrintMinterm void BDD::PrintCover() const { cout.flush(); DdManager *mgr = p->manager; int result = Cudd_bddPrintCover(mgr, node, node); checkReturnValue(result); } // BDD::PrintCover void BDD::PrintCover( const BDD& u) const { checkSameManager(u); cout.flush(); DdManager *mgr = p->manager; int result = Cudd_bddPrintCover(mgr, node, u.node); checkReturnValue(result); } // BDD::PrintCover int BDD::EstimateCofactor( int i, int phase) const { DdManager *mgr = p->manager; int result = Cudd_EstimateCofactor(mgr, node, i, phase); checkReturnValue(result != CUDD_OUT_OF_MEM); return result; } // BDD::EstimateCofactor int BDD::EstimateCofactorSimple( int i) const { int result = Cudd_EstimateCofactorSimple(node, i); return result; } // BDD::EstimateCofactorSimple int Cudd::SharingSize( DD* nodes, int n) const { DdNode **nodeArray = new DdNode *[n]; for (int i = 0; i < n; i++) { nodeArray[i] = nodes[i].getNode(); } int result = Cudd_SharingSize(nodeArray, n); delete [] nodeArray; checkReturnValue(n == 0 || result > 0); return result; } // Cudd::SharingSize int Cudd::SharingSize( const std::vector& v) const { vector::size_type n = v.size(); DdNode **nodeArray = new DdNode *[n]; for (vector::size_type i = 0; i != n; ++i) { nodeArray[i] = v[i].getNode(); } int result = Cudd_SharingSize(nodeArray, (int) n); delete [] nodeArray; checkReturnValue(n == 0 || result > 0); return result; } // Cudd::SharingSize double ABDD::CountMinterm( int nvars) const { DdManager *mgr = p->manager; double result = Cudd_CountMinterm(mgr, node, nvars); checkReturnValue(result != (double) CUDD_OUT_OF_MEM); return result; } // ABDD::CountMinterm double ABDD::CountPath() const { double result = Cudd_CountPath(node); checkReturnValue(result != (double) CUDD_OUT_OF_MEM); return result; } // ABDD::CountPath BDD ABDD::Support() const { DdManager *mgr = p->manager; DdNode *result = Cudd_Support(mgr, node); checkReturnValue(result); return BDD(p, result); } // ABDD::Support int ABDD::SupportSize() const { DdManager *mgr = p->manager; int result = Cudd_SupportSize(mgr, node); checkReturnValue(result != CUDD_OUT_OF_MEM); return result; } // ABDD::SupportSize BDD Cudd::VectorSupport(const std::vector& roots) const { size_t n = roots.size(); DdManager *mgr = p->manager; DdNode **F = new DdNode *[n]; for (size_t i = 0; i < n; i++) { F[i] = roots[i].getNode(); } DdNode *result = Cudd_VectorSupport(mgr, F, (int) n); delete [] F; checkReturnValue(result); return BDD(p, result); } // Cudd::VectorSupport std::vector ABDD::SupportIndices() const { unsigned int *support; DdManager *mgr = p->manager; int size = Cudd_SupportIndices(mgr, node, (int **)&support); checkReturnValue(size >= 0); // size could be 0, in which case support is 0 too! vector indices(support, support+size); if (support) free(support); return indices; } // ABDD::SupportIndices std::vector Cudd::SupportIndices(const std::vector& roots) const { unsigned int *support; size_t n = roots.size(); DdManager *mgr = p->manager; DdNode **F = new DdNode *[n]; for (size_t i = 0; i < n; i++) { F[i] = roots[i].getNode(); } int size = Cudd_VectorSupportIndices(mgr, F, (int) n, (int **)&support); delete [] F; checkReturnValue(size >= 0); // size could be 0, in which case support is 0 too! vector indices(support, support+size); if (support) free(support); return indices; } // Cudd::SupportIndices std::vector Cudd::SupportIndices(const std::vector& roots) const { unsigned int *support; size_t n = roots.size(); DdManager *mgr = p->manager; DdNode **F = new DdNode *[n]; for (size_t i = 0; i < n; i++) { F[i] = roots[i].getNode(); } int size = Cudd_VectorSupportIndices(mgr, F, (int) n, (int **)&support); delete [] F; checkReturnValue(size >= 0); // size could be 0, in which case support is 0 too! vector indices(support, support+size); if (support) free(support); return indices; } // Cudd::SupportIndices int Cudd::nodeCount(const std::vector& roots) const { size_t n = roots.size(); DdNode **nodeArray = new DdNode *[n]; for (size_t i = 0; i < n; i++) { nodeArray[i] = roots[i].getNode(); } int result = Cudd_SharingSize(nodeArray, (int) n); delete [] nodeArray; checkReturnValue(result > 0); return result; } // Cudd::nodeCount BDD Cudd::VectorSupport(const std::vector& roots) const { size_t n = roots.size(); DdManager *mgr = p->manager; DdNode **F = new DdNode *[n]; for (size_t i = 0; i < n; i++) { F[i] = roots[i].getNode(); } DdNode *result = Cudd_VectorSupport(mgr, F, (int) n); delete [] F; checkReturnValue(result); return BDD(p, result); } // Cudd::VectorSupport int Cudd::VectorSupportSize(const std::vector& roots) const { size_t n = roots.size(); DdManager *mgr = p->manager; DdNode **F = new DdNode *[n]; for (size_t i = 0; i < n; i++) { F[i] = roots[i].getNode(); } int result = Cudd_VectorSupportSize(mgr, F, (int) n); delete [] F; checkReturnValue(result != CUDD_OUT_OF_MEM); return result; } // Cudd::VectorSupportSize int Cudd::VectorSupportSize(const std::vector& roots) const { size_t n = roots.size(); DdManager *mgr = p->manager; DdNode **F = new DdNode *[n]; for (size_t i = 0; i < n; i++) { F[i] = roots[i].getNode(); } int result = Cudd_VectorSupportSize(mgr, F, (int) n); delete [] F; checkReturnValue(result != CUDD_OUT_OF_MEM); return result; } // Cudd::VectorSupportSize void ABDD::ClassifySupport( const ABDD& g, BDD* common, BDD* onlyF, BDD* onlyG) const { DdManager *mgr = checkSameManager(g); DdNode *C, *F, *G; int result = Cudd_ClassifySupport(mgr, node, g.node, &C, &F, &G); checkReturnValue(result); *common = BDD(p, C); *onlyF = BDD(p, F); *onlyG = BDD(p, G); } // ABDD::ClassifySupport int ABDD::CountLeaves() const { return Cudd_CountLeaves(node); } // ABDD::CountLeaves DdGen * ABDD::FirstCube( int ** cube, CUDD_VALUE_TYPE * value) const { DdManager *mgr = p->manager; DdGen *result = Cudd_FirstCube(mgr, node, cube, value); checkReturnValue((DdNode *)result); return result; } // ABDD::FirstCube int ABDD::NextCube( DdGen * gen, int ** cube, CUDD_VALUE_TYPE * value) { return Cudd_NextCube(gen, cube, value); } // ABDD::NextCube void BDD::PickOneCube( char * string) const { DdManager *mgr = p->manager; int result = Cudd_bddPickOneCube(mgr, node, string); checkReturnValue(result); } // BDD::PickOneCube BDD BDD::PickOneMinterm( std::vector vars) const { size_t n = vars.size(); DdManager *mgr = p->manager; DdNode **V = new DdNode *[n]; for (size_t i = 0; i < n; i++) { V[i] = vars[i].node; } DdNode *result = Cudd_bddPickOneMinterm(mgr, node, V, (int) n); delete [] V; checkReturnValue(result); return BDD(p, result); } // BDD::PickOneMinterm BDD Cudd::bddComputeCube( BDD * vars, int * phase, int n) const { DdManager *mgr = p->manager; DdNode **V = new DdNode *[n]; for (int i = 0; i < n; i++) { V[i] = vars[i].getNode(); } DdNode *result = Cudd_bddComputeCube(mgr, V, phase, n); delete [] V; checkReturnValue(result); return BDD(p, result); } // Cudd::bddComputeCube BDD Cudd::computeCube( std::vector const & vars) const { DdManager *mgr = p->manager; size_t n = vars.size(); DdNode **V = new DdNode *[n]; for (size_t i = 0; i < n; i++) { V[i] = vars[i].getNode(); } DdNode *result = Cudd_bddComputeCube(mgr, V, 0, n); delete [] V; checkReturnValue(result); return BDD(p, result); } // Cudd::computeCube ADD Cudd::addComputeCube( ADD * vars, int * phase, int n) const { DdManager *mgr = p->manager; DdNode **V = new DdNode *[n]; for (int i = 0; i < n; i++) { V[i] = vars[i].getNode(); } DdNode *result = Cudd_addComputeCube(mgr, V, phase, n); delete [] V; checkReturnValue(result); return ADD(p, result); } // Cudd::addComputeCube ADD Cudd::computeCube( std::vector const & vars) const { DdManager *mgr = p->manager; size_t n = vars.size(); DdNode **V = new DdNode *[n]; for (size_t i = 0; i < n; i++) { V[i] = vars[i].getNode(); } DdNode *result = Cudd_addComputeCube(mgr, V, 0, n); delete [] V; checkReturnValue(result); return ADD(p, result); } // Cudd::computeCube BDD Cudd::IndicesToCube( int * array, int n) const { DdNode *result = Cudd_IndicesToCube(p->manager, array, n); checkReturnValue(result); return BDD(p, result); } // Cudd::IndicesToCube void Cudd::PrintVersion( FILE * fp) const { cout.flush(); Cudd_PrintVersion(fp); } // Cudd::PrintVersion double Cudd::AverageDistance() const { return Cudd_AverageDistance(p->manager); } // Cudd::AverageDistance int32_t Cudd::Random() const { return Cudd_Random(p->manager); } // Cudd::Random void Cudd::Srandom( int32_t seed) const { Cudd_Srandom(p->manager,seed); } // Cudd::Srandom double ABDD::Density( int nvars) const { DdManager *mgr = p->manager; double result = Cudd_Density(mgr, node, nvars); checkReturnValue(result != (double) CUDD_OUT_OF_MEM); return result; } // ABDD::Density int ZDD::Count() const { DdManager *mgr = p->manager; int result = Cudd_zddCount(mgr, node); checkReturnValue(result != CUDD_OUT_OF_MEM); return result; } // ZDD::Count double ZDD::CountDouble() const { DdManager *mgr = p->manager; double result = Cudd_zddCountDouble(mgr, node); checkReturnValue(result != (double) CUDD_OUT_OF_MEM); return result; } // ZDD::CountDouble ZDD ZDD::Product( const ZDD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_zddProduct(mgr, node, g.node); checkReturnValue(result); return ZDD(p, result); } // ZDD::Product ZDD ZDD::UnateProduct( const ZDD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_zddUnateProduct(mgr, node, g.node); checkReturnValue(result); return ZDD(p, result); } // ZDD::UnateProduct ZDD ZDD::WeakDiv( const ZDD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_zddWeakDiv(mgr, node, g.node); checkReturnValue(result); return ZDD(p, result); } // ZDD::WeakDiv ZDD ZDD::Divide( const ZDD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_zddDivide(mgr, node, g.node); checkReturnValue(result); return ZDD(p, result); } // ZDD::Divide ZDD ZDD::WeakDivF( const ZDD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_zddWeakDivF(mgr, node, g.node); checkReturnValue(result); return ZDD(p, result); } // ZDD::WeakDivF ZDD ZDD::DivideF( const ZDD& g) const { DdManager *mgr = checkSameManager(g); DdNode *result = Cudd_zddDivideF(mgr, node, g.node); checkReturnValue(result); return ZDD(p, result); } // ZDD::DivideF MtrNode * Cudd::MakeZddTreeNode( unsigned int low, unsigned int size, unsigned int type) const { return Cudd_MakeZddTreeNode(p->manager, low, size, type); } // Cudd::MakeZddTreeNode BDD BDD::zddIsop( const BDD& U, ZDD* zdd_I) const { DdManager *mgr = checkSameManager(U); DdNode *Z; DdNode *result = Cudd_zddIsop(mgr, node, U.node, &Z); checkReturnValue(result); *zdd_I = ZDD(p, Z); return BDD(p, result); } // BDD::Isop BDD BDD::Isop( const BDD& U) const { DdManager *mgr = checkSameManager(U); DdNode *result = Cudd_bddIsop(mgr, node, U.node); checkReturnValue(result); return BDD(p, result); } // BDD::Isop double ZDD::CountMinterm( int path) const { DdManager *mgr = p->manager; double result = Cudd_zddCountMinterm(mgr, node, path); checkReturnValue(result != (double) CUDD_OUT_OF_MEM); return result; } // ZDD::CountMinterm void Cudd::zddPrintSubtable() const { cout.flush(); Cudd_zddPrintSubtable(p->manager); } // Cudd::zddPrintSubtable ZDD BDD::PortToZdd() const { DdManager *mgr = p->manager; DdNode *result = Cudd_zddPortFromBdd(mgr, node); checkReturnValue(result); return ZDD(p, result); } // BDD::PortToZdd BDD ZDD::PortToBdd() const { DdManager *mgr = p->manager; DdNode *result = Cudd_zddPortToBdd(mgr, node); checkReturnValue(result); return BDD(p, result); } // ZDD::PortToBdd void Cudd::zddReduceHeap( Cudd_ReorderingType heuristic, int minsize) const { int result = Cudd_zddReduceHeap(p->manager, heuristic, minsize); checkReturnValue(result); } // Cudd::zddReduceHeap void Cudd::zddShuffleHeap( int * permutation) const { int result = Cudd_zddShuffleHeap(p->manager, permutation); checkReturnValue(result); } // Cudd::zddShuffleHeap ZDD ZDD::Ite( const ZDD& g, const ZDD& h) const { DdManager *mgr = checkSameManager(g); checkSameManager(h); DdNode *result = Cudd_zddIte(mgr, node, g.node, h.node); checkReturnValue(result); return ZDD(p, result); } // ZDD::Ite ZDD ZDD::Union( const ZDD& Q) const { DdManager *mgr = checkSameManager(Q); DdNode *result = Cudd_zddUnion(mgr, node, Q.node); checkReturnValue(result); return ZDD(p, result); } // ZDD::Union ZDD ZDD::Intersect( const ZDD& Q) const { DdManager *mgr = checkSameManager(Q); DdNode *result = Cudd_zddIntersect(mgr, node, Q.node); checkReturnValue(result); return ZDD(p, result); } // ZDD::Intersect ZDD ZDD::Diff( const ZDD& Q) const { DdManager *mgr = checkSameManager(Q); DdNode *result = Cudd_zddDiff(mgr, node, Q.node); checkReturnValue(result); return ZDD(p, result); } // ZDD::Diff ZDD ZDD::DiffConst( const ZDD& Q) const { DdManager *mgr = checkSameManager(Q); DdNode *result = Cudd_zddDiffConst(mgr, node, Q.node); checkReturnValue(result); return ZDD(p, result); } // ZDD::DiffConst ZDD ZDD::Subset1( int var) const { DdManager *mgr = p->manager; DdNode *result = Cudd_zddSubset1(mgr, node, var); checkReturnValue(result); return ZDD(p, result); } // ZDD::Subset1 ZDD ZDD::Subset0( int var) const { DdManager *mgr = p->manager; DdNode *result = Cudd_zddSubset0(mgr, node, var); checkReturnValue(result); return ZDD(p, result); } // ZDD::Subset0 ZDD ZDD::Change( int var) const { DdManager *mgr = p->manager; DdNode *result = Cudd_zddChange(mgr, node, var); checkReturnValue(result); return ZDD(p, result); } // ZDD::Change void Cudd::zddSymmProfile( int lower, int upper) const { Cudd_zddSymmProfile(p->manager, lower, upper); } // Cudd::zddSymmProfile void ZDD::PrintMinterm() const { cout.flush(); DdManager *mgr = p->manager; int result = Cudd_zddPrintMinterm(mgr, node); checkReturnValue(result); } // ZDD::PrintMinterm void ZDD::PrintCover() const { cout.flush(); DdManager *mgr = p->manager; int result = Cudd_zddPrintCover(mgr, node); checkReturnValue(result); } // ZDD::PrintCover BDD ZDD::Support() const { DdManager *mgr = p->manager; DdNode *result = Cudd_zddSupport(mgr, node); checkReturnValue(result); return BDD(p, result); } // ZDD::Support void Cudd::DumpDot( const std::vector& nodes, char const * const * inames, char const * const * onames, FILE * fp) const { DdManager *mgr = p->manager; size_t n = nodes.size(); DdNode **F = new DdNode *[n]; for (size_t i = 0; i < n; i++) { F[i] = nodes[i].getNode(); } int result = Cudd_zddDumpDot(mgr, (int) n, F, inames, onames, fp); delete [] F; checkReturnValue(result); } // vector::DumpDot std::string Cudd::OrderString(void) const { DdManager * mgr = p->manager; int nvars = Cudd_ReadSize(mgr); bool hasNames = p->varnames.size() == (size_t) nvars; std::ostringstream oss; std::string separ = ""; for (int level = 0; level != nvars; ++level) { oss << separ; separ = " "; int index = Cudd_ReadInvPerm(mgr, level); if (hasNames) { oss << p->varnames.at(index); } else { oss << "x" << index; } } return oss.str(); } // Cudd::OrderString } // end namespace storm