⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cuddint.h

📁 主要进行大规模的电路综合
💻 H
📖 第 1 页 / 共 3 页
字号:
/**Macro***********************************************************************  Synopsis    [Returns 1 if the absolute value of the difference of the two  arguments x and y is less than e.]  Description []  SideEffects [none]  SeeAlso     []******************************************************************************/#define ddEqualVal(x,y,e) (ddAbs((x)-(y))<(e))/**Macro***********************************************************************  Synopsis    [Saturating increment operator.]  Description []  SideEffects [none]  SeeAlso     [cuddSatDec]******************************************************************************/#if SIZEOF_VOID_P == 8 && SIZEOF_INT == 4#define cuddSatInc(x) ((x)++)#else#define cuddSatInc(x) ((x) += (x) != (DdHalfWord)DD_MAXREF)#endif/**Macro***********************************************************************  Synopsis    [Saturating decrement operator.]  Description []  SideEffects [none]  SeeAlso     [cuddSatInc]******************************************************************************/#if SIZEOF_VOID_P == 8 && SIZEOF_INT == 4#define cuddSatDec(x) ((x)--)#else#define cuddSatDec(x) ((x) -= (x) != (DdHalfWord)DD_MAXREF)#endif/**Macro***********************************************************************  Synopsis    [Returns the constant 1 node.]  Description []  SideEffects [none]  SeeAlso     [DD_ZERO DD_PLUS_INFINITY DD_MINUS_INFINITY]******************************************************************************/#define DD_ONE(dd)		((dd)->one)/**Macro***********************************************************************  Synopsis    [Returns the arithmetic 0 constant node.]  Description [Returns the arithmetic 0 constant node. This is different  from the logical zero. The latter is obtained by  Cudd_Not(DD_ONE(dd)).]  SideEffects [none]  SeeAlso     [DD_ONE Cudd_Not DD_PLUS_INFINITY DD_MINUS_INFINITY]******************************************************************************/#define DD_ZERO(dd) ((dd)->zero)/**Macro***********************************************************************  Synopsis    [Returns the plus infinity constant node.]  Description []  SideEffects [none]  SeeAlso     [DD_ONE DD_ZERO DD_MINUS_INFINITY]******************************************************************************/#define DD_PLUS_INFINITY(dd) ((dd)->plusinfinity)/**Macro***********************************************************************  Synopsis    [Returns the minus infinity constant node.]  Description []  SideEffects [none]  SeeAlso     [DD_ONE DD_ZERO DD_PLUS_INFINITY]******************************************************************************/#define DD_MINUS_INFINITY(dd) ((dd)->minusinfinity)/**Macro***********************************************************************  Synopsis    [Enforces DD_MINUS_INF_VAL <= x <= DD_PLUS_INF_VAL.]  Description [Enforces DD_MINUS_INF_VAL <= x <= DD_PLUS_INF_VAL.  Furthermore, if x <= DD_MINUS_INF_VAL/2, x is set to  DD_MINUS_INF_VAL. Similarly, if DD_PLUS_INF_VAL/2 <= x, x is set to  DD_PLUS_INF_VAL.  Normally this macro is a NOOP. However, if  HAVE_IEEE_754 is not defined, it makes sure that a value does not  get larger than infinity in absolute value, and once it gets to  infinity, stays there.  If the value overflows before this macro is  applied, no recovery is possible.]  SideEffects [none]  SeeAlso     []******************************************************************************/#ifdef HAVE_IEEE_754#define cuddAdjust(x)#else#define cuddAdjust(x)		((x) = ((x) >= DD_CRI_HI_MARK) ? DD_PLUS_INF_VAL : (((x) <= DD_CRI_LO_MARK) ? DD_MINUS_INF_VAL : (x)))#endif/**Macro***********************************************************************  Synopsis    [Extract the least significant digit of a double digit.]  Description [Extract the least significant digit of a double digit. Used  in the manipulation of arbitrary precision integers.]  SideEffects [None]  SeeAlso     [DD_MSDIGIT]******************************************************************************/#define DD_LSDIGIT(x)	((x) & DD_APA_MASK)/**Macro***********************************************************************  Synopsis    [Extract the most significant digit of a double digit.]  Description [Extract the most significant digit of a double digit. Used  in the manipulation of arbitrary precision integers.]  SideEffects [None]  SeeAlso     [DD_LSDIGIT]******************************************************************************/#define DD_MSDIGIT(x)	((x) >> DD_APA_BITS)/**Macro***********************************************************************  Synopsis    [Outputs a line of stats.]  Description [Outputs a line of stats if DD_COUNT and DD_STATS are  defined. Increments the number of recursive calls if DD_COUNT is  defined.]  SideEffects [None]  SeeAlso     []******************************************************************************/#ifdef DD_COUNT#ifdef DD_STATS#define statLine(dd) dd->recursiveCalls++; \if (dd->recursiveCalls == dd->nextSample) {(void) fprintf(dd->err, \"@%.0f: %u nodes %u live %.0f dropped %.0f reclaimed\n", dd->recursiveCalls, \dd->keys, dd->keys - dd->dead, dd->nodesDropped, dd->reclaimed); \dd->nextSample += 250000;}#else#define statLine(dd) dd->recursiveCalls++;#endif#else#define statLine(dd)#endif/**AutomaticStart*************************************************************//*---------------------------------------------------------------------------*//* Function prototypes                                                       *//*---------------------------------------------------------------------------*/EXTERN DdNode * cuddAddExistAbstractRecur ARGS((DdManager *manager, DdNode *f, DdNode *cube));EXTERN DdNode * cuddAddUnivAbstractRecur ARGS((DdManager *manager, DdNode *f, DdNode *cube));EXTERN DdNode * cuddAddOrAbstractRecur ARGS((DdManager *manager, DdNode *f, DdNode *cube));EXTERN DdNode * cuddAddApplyRecur ARGS((DdManager *dd, DdNode * (*)(DdManager *, DdNode **, DdNode **), DdNode *f, DdNode *g));EXTERN DdNode * cuddAddMonadicApplyRecur ARGS((DdManager * dd, DdNode * (*op)(DdManager *, DdNode *), DdNode * f));EXTERN DdNode * cuddAddScalarInverseRecur ARGS((DdManager *dd, DdNode *f, DdNode *epsilon));EXTERN DdNode * cuddAddIteRecur ARGS((DdManager *dd, DdNode *f, DdNode *g, DdNode *h));EXTERN DdNode * cuddAddCmplRecur ARGS((DdManager *dd, DdNode *f));EXTERN DdNode * cuddAddNegateRecur ARGS((DdManager *dd, DdNode *f));EXTERN DdNode * cuddAddRoundOffRecur ARGS((DdManager *dd, DdNode *f, double trunc));EXTERN DdNode * cuddUnderApprox ARGS((DdManager *dd, DdNode *f, int numVars, int threshold, int safe, double quality));EXTERN DdNode * cuddRemapUnderApprox ARGS((DdManager *dd, DdNode *f, int numVars, int threshold, double quality));EXTERN DdNode * cuddBiasedUnderApprox ARGS((DdManager *dd, DdNode *f, DdNode *b, int numVars, int threshold, double quality1, double quality0));EXTERN DdNode * cuddBddAndAbstractRecur ARGS((DdManager *manager, DdNode *f, DdNode *g, DdNode *cube));EXTERN int cuddAnnealing ARGS((DdManager *table, int lower, int upper));EXTERN DdNode * cuddBddExistAbstractRecur ARGS((DdManager *manager, DdNode *f, DdNode *cube));EXTERN DdNode * cuddBddXorExistAbstractRecur ARGS((DdManager *manager, DdNode *f, DdNode *g, DdNode *cube));EXTERN DdNode * cuddBddBooleanDiffRecur ARGS((DdManager *manager, DdNode *f, DdNode *var));EXTERN DdNode * cuddBddIteRecur ARGS((DdManager *dd, DdNode *f, DdNode *g, DdNode *h));EXTERN DdNode * cuddBddIntersectRecur ARGS((DdManager *dd, DdNode *f, DdNode *g));EXTERN DdNode * cuddBddAndRecur ARGS((DdManager *manager, DdNode *f, DdNode *g));EXTERN DdNode * cuddBddXorRecur ARGS((DdManager *manager, DdNode *f, DdNode *g));EXTERN DdNode * cuddBddTransfer ARGS((DdManager *ddS, DdManager *ddD, DdNode *f));EXTERN DdNode * cuddAddBddDoPattern ARGS((DdManager *dd, DdNode *f));EXTERN int cuddInitCache ARGS((DdManager *unique, unsigned int cacheSize, unsigned int maxCacheSize));EXTERN void cuddCacheInsert ARGS((DdManager *table, ptruint op, DdNode *f, DdNode *g, DdNode *h, DdNode *data));EXTERN void cuddCacheInsert2 ARGS((DdManager *table, DdNode * (*)(DdManager *, DdNode *, DdNode *), DdNode *f, DdNode *g, DdNode *data));EXTERN void cuddCacheInsert1 ARGS((DdManager *table, DdNode * (*)(DdManager *, DdNode *), DdNode *f, DdNode *data));EXTERN DdNode * cuddCacheLookup ARGS((DdManager *table, ptruint op, DdNode *f, DdNode *g, DdNode *h));EXTERN DdNode * cuddCacheLookupZdd ARGS((DdManager *table, ptruint op, DdNode *f, DdNode *g, DdNode *h));EXTERN DdNode * cuddCacheLookup2 ARGS((DdManager *table, DdNode * (*)(DdManager *, DdNode *, DdNode *), DdNode *f, DdNode *g));EXTERN DdNode * cuddCacheLookup1 ARGS((DdManager *table, DdNode * (*)(DdManager *, DdNode *), DdNode *f));EXTERN DdNode * cuddCacheLookup2Zdd ARGS((DdManager *table, DdNode * (*)(DdManager *, DdNode *, DdNode *), DdNode *f, DdNode *g));EXTERN DdNode * cuddCacheLookup1Zdd ARGS((DdManager *table, DdNode * (*)(DdManager *, DdNode *), DdNode *f));EXTERN DdNode * cuddConstantLookup ARGS((DdManager *table, ptruint op, DdNode *f, DdNode *g, DdNode *h));EXTERN int cuddCacheProfile ARGS((DdManager *table, FILE *fp));EXTERN void cuddCacheResize ARGS((DdManager *table));EXTERN void cuddCacheFlush ARGS((DdManager *table));EXTERN int cuddComputeFloorLog2 ARGS((unsigned int value));EXTERN int cuddHeapProfile ARGS((DdManager *dd));EXTERN void cuddPrintNode ARGS((DdNode *f, FILE *fp));EXTERN void cuddPrintVarGroups ARGS((DdManager * dd, MtrNode * root, int zdd, int silent));EXTERN DdNode * cuddBddClippingAnd ARGS((DdManager *dd, DdNode *f, DdNode *g, int maxDepth, int direction));EXTERN DdNode * cuddBddClippingAndAbstract ARGS((DdManager *dd, DdNode *f, DdNode *g, DdNode *cube, int maxDepth, int direction));EXTERN void cuddGetBranches ARGS((DdNode *g, DdNode **g1, DdNode **g0));EXTERN int cuddCheckCube ARGS((DdManager *dd, DdNode *g));EXTERN DdNode * cuddCofactorRecur ARGS((DdManager *dd, DdNode *f, DdNode *g));EXTERN DdNode * cuddBddComposeRecur ARGS((DdManager *dd, DdNode *f, DdNode *g, DdNode *proj));EXTERN DdNode * cuddAddComposeRecur ARGS((DdManager *dd, DdNode *f, DdNode *g, DdNode *proj));EXTERN int cuddExact ARGS((DdManager *table, int lower, int upper));EXTERN DdNode * cuddBddConstrainRecur ARGS((DdManager *dd, DdNode *f, DdNode *c));EXTERN DdNode * cuddBddRestrictRecur ARGS((DdManager *dd, DdNode *f, DdNode *c));EXTERN DdNode * cuddAddConstrainRecur ARGS((DdManager *dd, DdNode *f, DdNode *c));EXTERN DdNode * cuddAddRestrictRecur ARGS((DdManager *dd, DdNode *f, DdNode *c));EXTERN DdNode * cuddBddLICompaction ARGS((DdManager *dd, DdNode *f, DdNode *c));EXTERN int cuddGa ARGS((DdManager *table, int lower, int upper));EXTERN int cuddTreeSifting ARGS((DdManager *table, Cudd_ReorderingType method));EXTERN int cuddZddInitUniv ARGS((DdManager *zdd));EXTERN void cuddZddFreeUniv ARGS((DdManager *zdd));EXTERN void cuddSetInteract ARGS((DdManager *table, int x, int y));EXTERN int cuddTestInteract ARGS((DdManager *table, int x, int y));EXTERN int cuddInitInteract ARGS((DdManager *table));EXTERN DdLocalCache * cuddLocalCacheInit ARGS((DdManager *manager, unsigned int keySize, unsigned int cacheSize, unsigned int maxCacheSize));EXTERN void cuddLocalCacheQuit ARGS((DdLocalCache *cache));EXTERN void cuddLocalCacheInsert ARGS((DdLocalCache *cache, DdNodePtr *key, DdNode *value));EXTERN DdNode * cuddLocalCacheLookup ARGS((DdLocalCache *cache, DdNodePtr *key));EXTERN void cuddLocalCacheClearDead ARGS((DdManager *manager));EXTERN int cuddIsInDeathRow ARGS((DdManager *dd, DdNode *f));EXTERN int cuddTimesInDeathRow ARGS((DdManager *dd, DdNode *f));EXTERN void cuddLocalCacheClearAll ARGS((DdManager *manager));#ifdef DD_CACHE_PROFILEEXTERN int cuddLocalCacheProfile ARGS((DdLocalCache *cache));#endifEXTERN DdHashTable * cuddHashTableInit ARGS((DdManager *manager, unsigned int keySize, unsigned int initSize));EXTERN void cuddHashTableQuit ARGS((DdHashTable *hash));EXTERN int cuddHashTableInsert ARGS((DdHashTable *hash, DdNodePtr *key, DdNode *value, ptrint count));EXTERN DdNode * cuddHashTableLookup ARGS((DdHashTable *hash, DdNodePtr *key));EXTERN int cuddHashTableInsert1 ARGS((DdHashTable *hash, DdNode *f, DdNode *value, ptrint count));EXTERN DdNode * cuddHashTableLookup1 ARGS((DdHashTable *hash, DdNode *f));EXTERN int cuddHashTableInsert2 ARGS((DdHashTable *hash, DdNode *f, DdNode *g, DdNode *value, ptrint count));EXTERN DdNode * cuddHashTableLookup2 ARGS((DdHashTable *hash, DdNode *f, DdNode *g));EXTERN int cuddHashTableInsert3 ARGS((DdHashTable *hash, DdNode *f, DdNode *g, DdNode *h, DdNode *value, ptrint count));EXTERN DdNode * cuddHashTableLookup3 ARGS((DdHashTable *hash, DdNode *f, DdNode *g, DdNode *h));EXTERN DdLevelQueue * cuddLevelQueueInit ARGS((int levels, int itemSize, int numBuckets));EXTERN void cuddLevelQueueQuit ARGS((DdLevelQueue *queue));EXTERN void * cuddLevelQueueEnqueue ARGS((DdLevelQueue *queue, void *key, int level));EXTERN void cuddLevelQueueDequeue ARGS((DdLevelQueue *queue, int level));EXTERN int cuddLinearAndSifting ARGS((DdManager *table, int lower, int upper));EXTERN DdNode * cuddBddLiteralSetIntersectionRecur ARGS((DdManager *dd, DdNode *f, DdNode *g));EXTERN DdNode * cuddCProjectionRecur ARGS((DdManager *dd, DdNode *R, DdNode *Y, DdNode *Ysupp));EXTERN DdNode * cuddBddClosestCube ARGS((DdManager *dd, DdNode *f, DdNode *g, CUDD_VALUE_TYPE bound));EXTERN void cuddReclaim ARGS((DdManager *table, DdNode *n));EXTERN void cuddReclaimZdd ARGS((DdManager *table, DdNode *n));EXTERN void cuddClearDeathRow ARGS((DdManager *table));EXTERN void cuddShrinkDeathRow ARGS((DdManager *table));EXTERN DdNode * cuddDynamicAllocNode ARGS((DdManager *table));EXTERN int cuddSifting ARGS((DdManager *table, int lower, int upper));EXTERN int cuddSwapping ARGS((DdManager *table, int lower, int upper, Cudd_ReorderingType heuristic));EXTERN int cuddNextHigh ARGS((DdManager *table, int x));EXTERN int cuddNextLow ARGS((DdManager *table, int x));EXTERN int cuddSwapInPlace ARGS((DdManager *table, int x, int y));EXTERN int cuddBddAlignToZdd ARGS((DdManager *table));EXTERN DdNode * cuddBddMakePrime ARGS((DdManager *dd, DdNode *cube, DdNode *f));EXTERN DdNode * cuddSolveEqnRecur ARGS((DdManager *bdd, DdNode *F, DdNode *Y, DdNode **G, int n, int *yIndex, int i));EXTERN DdNode * cuddVerifySol ARGS((DdManager *bdd, DdNode *F, DdNode **G, int *yIndex, int n));#ifdef ST_INCLUDEDEXTERN DdNode* cuddSplitSetRecur ARGS((DdManager *manager, st_table *mtable, int *varSeen, DdNode *p, double n, double max, int index));#endifEXTERN DdNode * cuddSubsetHeavyBranch ARGS((DdManager *dd, DdNode *f, int numVars, int threshold));EXTERN DdNode * cuddSubsetShortPaths ARGS((DdManager *dd, DdNode *f, int numVars, int threshold, int hardlimit));EXTERN int cuddSymmCheck ARGS((DdManager *table, int x, int y));EXTERN int cuddSymmSifting ARGS((DdManager *table, int lower, int upper));EXTERN int cuddSymmSiftingConv ARGS((DdManager *table, int lower, int upper));EXTERN DdNode * cuddAllocNode ARGS((DdManager *unique));EXTERN DdManager * cuddInitTable ARGS((unsigned int numVars, unsigned int numVarsZ, unsigned int numSlots, unsigned int looseUpTo));EXTERN void cuddFreeTable ARGS((DdManager *unique));EXTERN int cuddGarbageCollect ARGS((DdManager *unique, int clearCache));EXTERN int cuddGarbageCollectZdd ARGS((DdManager *unique, int clearCache));EXTERN DdNode * cuddZddGetNode ARGS((DdManager *zdd, int id, DdNode *T, DdNode *E));EXTERN DdNode * cuddZddGetNodeIVO ARGS((DdManager *dd, int index, DdNode *g, DdNode *h));EXTERN DdNode * cuddUniqueInter ARGS((DdManager *unique, int index, DdNode *T, DdNode *E));EXTERN DdNode * cuddUniqueInterIVO ARGS((DdManager *unique, int index, DdNode *T, DdNode *E));EXTERN DdNode * cuddUniqueInterZdd ARGS((DdManager *unique, int index, DdNode *T, DdNode *E));EXTERN DdNode * cuddUniqueConst ARGS((DdManager *unique, CUDD_VALUE_TYPE value));EXTERN void cuddRehash ARGS((DdManager *unique, int i));EXTERN void cuddShrinkSubtable ARGS((DdManager *unique, int i));EXTERN int cuddInsertSubtables ARGS((DdManager *unique, int n, int level));EXTERN int cuddDestroySubtables ARGS((DdManager *unique, int n));EXTERN int cuddResizeTableZdd ARGS((DdManager *unique, int index));EXTERN void cuddSlowTableGrowth ARGS((DdManager *unique));EXTERN int cuddP ARGS((DdManager *dd, DdNode *f));#ifdef ST_INCLUDEDEXTERN enum st_retval cuddStCountfree ARGS((char *key, char *value, char *arg));EXTERN int cuddCollectNodes ARGS((DdNode *f, st_table *visited));#endifEXTERN int cuddWindowReorder ARGS((DdManager *table, int low, int high, Cudd_ReorderingType submethod));EXTERN DdNode	* cuddZddProduct ARGS((DdManager *dd, DdNode *f, DdNode *g));EXTERN DdNode	* cuddZddUnateProduct ARGS((DdManager *dd, DdNode *f, DdNode *g));EXTERN DdNode	* cuddZddWeakDiv ARGS((DdManager *dd, DdNode *f, DdNode *g));EXTERN DdNode	* cuddZddWeakDivF ARGS((DdManager *dd, DdNode *f, DdNode *g));EXTERN DdNode	* cuddZddDivide ARGS((DdManager *dd, DdNode *f, DdNode *g));EXTERN DdNode	* cuddZddDivideF ARGS((DdManager *dd, DdNode *f, DdNode *g));EXTERN int cuddZddGetCofactors3 ARGS((DdManager *dd, DdNode *f, int v, DdNode **f1, DdNode **f0, DdNode **fd));EXTERN int cuddZddGetCofactors2 ARGS((DdManager *dd, DdNode *f, int v, DdNode **f1, DdNode **f0));EXTERN DdNode	* cuddZddComplement ARGS((DdManager *dd, DdNode *node));EXTERN int cuddZddGetPosVarIndex(DdManager * dd, int index);EXTERN int cuddZddGetNegVarIndex(DdManager * dd, int index);EXTERN int cuddZddGetPosVarLevel(DdManager * dd, int index);EXTERN int cuddZddGetNegVarLevel(DdManager * dd, int index);EXTERN int cuddZddTreeSifting ARGS((DdManager *table, Cudd_ReorderingType method));EXTERN DdNode	* cuddZddIsop ARGS((DdManager *dd, DdNode *L, DdNode *U, DdNode **zdd_I));EXTERN DdNode	* cuddBddIsop ARGS((DdManager *dd, DdNode *L, DdNode *U));EXTERN DdNode	* cuddMakeBddFromZddCover ARGS((DdManager *dd, DdNode *node));EXTERN int cuddZddLinearSifting ARGS((DdManager *table, int lower, int upper));EXTERN int cuddZddAlignToBdd ARGS((DdManager *table));EXTERN int cuddZddNextHigh ARGS((DdManager *table, int x));EXTERN int cuddZddNextLow ARGS((DdManager *table, int x));EXTERN int cuddZddUniqueCompare ARGS((int *ptr_x, int *ptr_y));EXTERN int cuddZddSwapInPlace ARGS((DdManager *table, int x, int y));EXTERN int cuddZddSwapping ARGS((DdManager *table, int lower, int upper, Cudd_ReorderingType heuristic));EXTERN int cuddZddSifting ARGS((DdManager *table, int lower, int upper));EXTERN DdNode * cuddZddIte ARGS((DdManager *dd, DdNode *f, DdNode *g, DdNode *h));EXTERN DdNode * cuddZddUnion ARGS((DdManager *zdd, DdNode *P, DdNode *Q));EXTERN DdNode * cuddZddIntersect ARGS((DdManager *zdd, DdNode *P, DdNode *Q));EXTERN DdNode * cuddZddDiff ARGS((DdManager *zdd, DdNode *P, DdNode *Q));EXTERN DdNode * cuddZddChangeAux ARGS((DdManager *zdd, DdNode *P, DdNode *zvar));EXTERN DdNode * cuddZddSubset1 ARGS((DdManager *dd, DdNode *P, int var));EXTERN DdNode * cuddZddSubset0 ARGS((DdManager *dd, DdNode *P, int var));EXTERN DdNode * cuddZddChange ARGS((DdManager *dd, DdNode *P, int var));EXTERN int cuddZddSymmCheck ARGS((DdManager *table, int x, int y));EXTERN int cuddZddSymmSifting ARGS((DdManager *table, int lower, int upper));EXTERN int cuddZddSymmSiftingConv ARGS((DdManager *table, int lower, int upper));EXTERN int cuddZddP ARGS((DdManager *zdd, DdNode *f));/**AutomaticEnd***************************************************************/#endif /* _CUDDINT */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -