diff options
author | Alan Mishchenko <alanmi@berkeley.edu> | 2011-02-03 13:05:01 -0800 |
---|---|---|
committer | Alan Mishchenko <alanmi@berkeley.edu> | 2011-02-03 13:05:01 -0800 |
commit | 59d7455cf16cc2be722b5f224801bcd1b600134e (patch) | |
tree | 69cf5dd67598837d80b9b291f001995047edffee /src | |
parent | 1d54983bc4f7e96c0bb826138066cd926ab73b9d (diff) | |
download | abc-59d7455cf16cc2be722b5f224801bcd1b600134e.tar.gz abc-59d7455cf16cc2be722b5f224801bcd1b600134e.tar.bz2 abc-59d7455cf16cc2be722b5f224801bcd1b600134e.zip |
Minor changes while improving BDD-based reachability.
Diffstat (limited to 'src')
-rw-r--r-- | src/aig/llb/llb3Image.c | 2 | ||||
-rw-r--r-- | src/aig/llb/llb3Nonlin.c | 125 | ||||
-rw-r--r-- | src/bdd/cudd/cuddAndAbs.c | 5 |
3 files changed, 84 insertions, 48 deletions
diff --git a/src/aig/llb/llb3Image.c b/src/aig/llb/llb3Image.c index d040b342..1866a87c 100644 --- a/src/aig/llb/llb3Image.c +++ b/src/aig/llb/llb3Image.c @@ -355,7 +355,7 @@ Llb_NonlinPrint( p ); printf( "Conjoining partitions %d and %d.\n", pPart1->iPart, pPart2->iPart ); Extra_bddPrintSupport( p->dd, bCube ); printf( "\n" ); } - + // derive new function // bFunc = Cudd_bddAndAbstract( p->dd, pPart1->bFunc, pPart2->bFunc, bCube ); Cudd_Ref( bFunc ); bFunc = Cudd_bddAndAbstractLimit( p->dd, pPart1->bFunc, pPart2->bFunc, bCube, Limit ); diff --git a/src/aig/llb/llb3Nonlin.c b/src/aig/llb/llb3Nonlin.c index 88bee63e..c22f5a0c 100644 --- a/src/aig/llb/llb3Nonlin.c +++ b/src/aig/llb/llb3Nonlin.c @@ -21,7 +21,7 @@ #include "llbInt.h" ABC_NAMESPACE_IMPL_START - + //////////////////////////////////////////////////////////////////////// /// DECLARATIONS /// @@ -82,7 +82,7 @@ int Llb_NonlinFindBestVar( DdManager * dd, DdNode * bFunc, Aig_Man_t * pAig ) { int fVerbose = 0; Aig_Obj_t * pObj; - DdNode * bCof, * bVar, * bTemp; + DdNode * bCof, * bVar; int i, iVar, iVarBest = -1, iValue, iValueBest = ABC_INFINITY, Size0Best = -1; int Size, Size0, Size1; int clk = clock(); @@ -93,46 +93,42 @@ int Llb_NonlinFindBestVar( DdManager * dd, DdNode * bFunc, Aig_Man_t * pAig ) { iVar = Aig_ObjId(pObj); - if ( fVerbose ) - printf( "Var =%3d : ", iVar ); +if ( fVerbose ) +printf( "Var =%3d : ", iVar ); bVar = Cudd_bddIthVar(dd, iVar); - bCof = Cudd_Cofactor( dd, bFunc, Cudd_Not(bVar) ); Cudd_Ref( bCof ); - bCof = Cudd_bddAnd( dd, bTemp = bCof, Cudd_Not(bVar) ); Cudd_Ref( bCof ); - Cudd_RecursiveDeref( dd, bTemp ); + bCof = Cudd_bddAnd( dd, bFunc, Cudd_Not(bVar) ); Cudd_Ref( bCof ); Size0 = Cudd_DagSize(bCof); - if ( fVerbose ) - printf( "Supp0 =%3d ", Cudd_SupportSize(dd, bCof) ); - if ( fVerbose ) - printf( "Size0 =%6d ", Size0 ); +if ( fVerbose ) +printf( "Supp0 =%3d ", Cudd_SupportSize(dd, bCof) ); +if ( fVerbose ) +printf( "Size0 =%6d ", Size0 ); Cudd_RecursiveDeref( dd, bCof ); - bCof = Cudd_Cofactor( dd, bFunc, bVar ); Cudd_Ref( bCof ); - bCof = Cudd_bddAnd( dd, bTemp = bCof, bVar ); Cudd_Ref( bCof ); - Cudd_RecursiveDeref( dd, bTemp ); + bCof = Cudd_bddAnd( dd, bFunc, bVar ); Cudd_Ref( bCof ); Size1 = Cudd_DagSize(bCof); - if ( fVerbose ) - printf( "Supp1 =%3d ", Cudd_SupportSize(dd, bCof) ); - if ( fVerbose ) - printf( "Size1 =%6d ", Size1 ); +if ( fVerbose ) +printf( "Supp1 =%3d ", Cudd_SupportSize(dd, bCof) ); +if ( fVerbose ) +printf( "Size1 =%6d ", Size1 ); Cudd_RecursiveDeref( dd, bCof ); iValue = ABC_MAX(Size0, Size1) - ABC_MIN(Size0, Size1) + Size0 + Size1 - Size; - if ( fVerbose ) - printf( "D =%6d ", Size0 + Size1 - Size ); - if ( fVerbose ) - printf( "B =%6d ", ABC_MAX(Size0, Size1) - ABC_MIN(Size0, Size1) ); - if ( fVerbose ) - printf( "S =%6d\n", iValue ); - - if ( iValueBest > iValue ) +if ( fVerbose ) +printf( "D =%6d ", Size0 + Size1 - Size ); +if ( fVerbose ) +printf( "B =%6d ", ABC_MAX(Size0, Size1) - ABC_MIN(Size0, Size1) ); +if ( fVerbose ) +printf( "S =%6d\n", iValue ); + if ( Size0 > 1 && Size1 > 1 && iValueBest > iValue ) { iValueBest = iValue; - iVarBest = iVar; + iVarBest = i; Size0Best = Size0; } } - printf( "BestVar = %4d. Value =%6d. Orig =%6d. Size0 =%6d. ", iVarBest, iValueBest, Size, Size0Best ); + printf( "BestVar = %4d/%4d. Value =%6d. Orig =%6d. Size0 =%6d. ", + iVarBest, Aig_ObjId(Saig_ManLo(pAig,iVarBest)), iValueBest, Size, Size0Best ); Abc_PrintTime( 1, "Time", clock() - clk ); return iVarBest; } @@ -259,7 +255,14 @@ Abc_Cex_t * Llb_NonlinDeriveCex( Llb_Mnn_t * p ) p->pVars2Q[Aig_ObjId(pObj)] = 1; Vec_IntPush( vVarsNs, Aig_ObjId(pObj) ); } - +/* + Saig_ManForEachLo( p->pAig, pObj, i ) + printf( "%d ", pObj->Id ); + printf( "\n" ); + Saig_ManForEachLi( p->pAig, pObj, i ) + printf( "%d(%d) ", pObj->Id, Aig_ObjFaninId0(pObj) ); + printf( "\n" ); +*/ // allocate room for the counter-example pCex = Ssw_SmlAllocCounterExample( Saig_ManRegNum(p->pAig), Saig_ManPiNum(p->pAig), Vec_PtrSize(p->vRings) ); pCex->iFrame = Vec_PtrSize(p->vRings) - 1; @@ -287,12 +290,14 @@ Abc_Cex_t * Llb_NonlinDeriveCex( Llb_Mnn_t * p ) { if ( v == Vec_PtrSize(p->vRings) - 1 ) continue; +//Extra_bddPrintSupport( p->dd, bState ); printf( "\n" ); +//Extra_bddPrintSupport( p->dd, bRing ); printf( "\n" ); // compute the next states bImage = Llb_NonlinImage( p->pAig, p->vLeaves, p->vRoots, p->pVars2Q, p->dd, bState, p->pPars->fReorder, p->pPars->fVeryVerbose, p->pOrder, ABC_INFINITY ); // consumed reference assert( bImage != NULL ); Cudd_Ref( bImage ); -//Extra_bddPrintSupport( p->dd, bImage ); printf( "\n" ); +//Extra_bddPrintSupport( p->dd, bImage ); printf( "\n" ); // move reached states into ring manager bImage = Extra_TransferPermute( p->dd, p->ddR, bTemp = bImage, Vec_IntArray(p->vCs2Glo) ); Cudd_Ref( bImage ); @@ -349,7 +354,7 @@ Abc_Cex_t * Llb_NonlinDeriveCex( Llb_Mnn_t * p ) int Llb_NonlinReachability( Llb_Mnn_t * p ) { DdNode * bCurrent, * bNext, * bTemp; - int nIters, nBddSize0, nBddSize; + int iVar, nIters, nBddSize0, nBddSize, Limit = p->pPars->nBddMax; int clk2, clk3, clk = clock(); assert( Aig_ManRegNum(p->pAig) > 0 ); @@ -400,37 +405,66 @@ int Llb_NonlinReachability( Llb_Mnn_t * p ) return 0; } + // check the size + if ( Cudd_DagSize(bCurrent) > p->pPars->nBddMax ) + { + DdNode * bVar, * bVarG; + + // find the best variable + iVar = Llb_NonlinFindBestVar( p->dd, bCurrent, p->pAig ); + + // get cofactor in the working manager + bVar = Cudd_bddIthVar( p->dd, Aig_ObjId(Saig_ManLo(p->pAig,iVar)) ); + bCurrent = Cudd_bddAnd( p->dd, bTemp = bCurrent, Cudd_Not(bVar) ); Cudd_Ref( bCurrent ); + Cudd_RecursiveDeref( p->dd, bTemp ); + + // get cofactor in the global manager + bVarG = Cudd_bddIthVar(p->ddG, iVar); + p->ddG->bFunc2 = Cudd_bddAnd( p->ddG, bTemp = p->ddG->bFunc2, Cudd_Not(bVarG) ); Cudd_Ref( p->ddG->bFunc2 ); + Cudd_RecursiveDeref( p->ddG, bTemp ); + } + // compute the next states clk3 = clock(); nBddSize0 = Cudd_DagSize( bCurrent ); bNext = Llb_NonlinImage( p->pAig, p->vLeaves, p->vRoots, p->pVars2Q, p->dd, bCurrent, - p->pPars->fReorder, p->pPars->fVeryVerbose, p->pOrder, p->pPars->nBddMax ); +// p->pPars->fReorder, p->pPars->fVeryVerbose, p->pOrder, nIters ? p->pPars->nBddMax : ABC_INFINITY ); + p->pPars->fReorder, p->pPars->fVeryVerbose, p->pOrder, ABC_INFINITY ); +// Abc_PrintTime( 1, "Image time", clock() - clk3 ); if ( bNext == NULL ) // Llb_NonlimImage() consumes reference of bCurrent!!! { - int iVar; - DdNode * bVar; - int nDagSize; + DdNode * bVar, * bVarG; // if ( !p->pPars->fSilent ) // printf( "Reached timeout during image computation (%d seconds).\n", p->pPars->TimeLimit ); // p->pPars->iFrame = nIters - 1; // return -1; + printf( "Should never happen!\n" ); + + // get the frontier in the working manager bCurrent = Extra_TransferPermute( p->ddG, p->dd, p->ddG->bFunc2, Vec_IntArray(p->vGlo2Cs) ); Cudd_Ref( bCurrent ); - nDagSize = Cudd_DagSize(bCurrent); + // find the best variable iVar = Llb_NonlinFindBestVar( p->dd, bCurrent, p->pAig ); - bVar = Cudd_bddIthVar(p->dd, iVar); - bCurrent = Cudd_Cofactor( p->dd, bTemp = bCurrent, Cudd_Not(bVar) ); Cudd_Ref( bCurrent ); - Cudd_RecursiveDeref( p->dd, bTemp ); - bCurrent = Cudd_bddAnd( p->dd, bTemp = bCurrent, Cudd_Not(bVar) ); Cudd_Ref( bCurrent ); + // get cofactor in the working manager + bVar = Cudd_bddIthVar( p->dd, Aig_ObjId(Saig_ManLo(p->pAig,iVar)) ); + bCurrent = Cudd_bddAnd( p->dd, bTemp = bCurrent, Cudd_Not(bVar) ); Cudd_Ref( bCurrent ); Cudd_RecursiveDeref( p->dd, bTemp ); -// printf( "Before = %6d. After = %6d.\n", nDagSize, Cudd_DagSize(bCurrent) ); + // get cofactor in the global manager + bVarG = Cudd_bddIthVar(p->dd, iVar); + p->ddG->bFunc2 = Cudd_bddAnd( p->ddG, bTemp = p->ddG->bFunc2, Cudd_Not(bVarG) ); Cudd_Ref( p->ddG->bFunc2 ); + Cudd_RecursiveDeref( p->ddG, bTemp ); - p->pPars->nBddMax = 3 * p->pPars->nBddMax / 2; +// Cudd_ReduceHeap( p->dd, CUDD_REORDER_SIFT, 1 ); + p->pPars->nBddMax = ABC_INFINITY; + nIters--; continue; } + else + p->pPars->nBddMax = Limit; + Cudd_Ref( bNext ); nBddSize = Cudd_DagSize( bNext ); p->timeImage += clock() - clk3; @@ -603,12 +637,15 @@ void Llb_MnnStop( Llb_Mnn_t * p ) Vec_PtrForEachEntry( DdNode *, p->vRings, bTemp, i ) Cudd_RecursiveDeref( p->ddR, bTemp ); Vec_PtrFree( p->vRings ); - if ( p->ddR->bFunc ) + if ( p->ddG->bFunc ) Cudd_RecursiveDeref( p->ddG, p->ddG->bFunc ); - if ( p->ddR->bFunc2 ) + if ( p->ddG->bFunc2 ) Cudd_RecursiveDeref( p->ddG, p->ddG->bFunc2 ); +// printf( "manager1\n" ); Extra_StopManager( p->dd ); +// printf( "manager2\n" ); Extra_StopManager( p->ddG ); +// printf( "manager3\n" ); Extra_StopManager( p->ddR ); Vec_IntFreeP( &p->vCs2Glo ); Vec_IntFreeP( &p->vNs2Glo ); diff --git a/src/bdd/cudd/cuddAndAbs.c b/src/bdd/cudd/cuddAndAbs.c index cd928e80..10b057ac 100644 --- a/src/bdd/cudd/cuddAndAbs.c +++ b/src/bdd/cudd/cuddAndAbs.c @@ -135,11 +135,10 @@ Cudd_bddAndAbstractLimit( { DdNode *res; unsigned int saveLimit = manager->maxLive; - - manager->maxLive = (manager->keys - manager->dead) + - (manager->keysZ - manager->deadZ) + limit; do { manager->reordered = 0; + manager->maxLive = (manager->keys - manager->dead) + + (manager->keysZ - manager->deadZ) + limit; res = cuddBddAndAbstractRecur(manager, f, g, cube); } while (manager->reordered == 1); manager->maxLive = saveLimit; |