summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorAlan Mishchenko <alanmi@berkeley.edu>2011-02-03 13:05:01 -0800
committerAlan Mishchenko <alanmi@berkeley.edu>2011-02-03 13:05:01 -0800
commit59d7455cf16cc2be722b5f224801bcd1b600134e (patch)
tree69cf5dd67598837d80b9b291f001995047edffee /src
parent1d54983bc4f7e96c0bb826138066cd926ab73b9d (diff)
downloadabc-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.c2
-rw-r--r--src/aig/llb/llb3Nonlin.c125
-rw-r--r--src/bdd/cudd/cuddAndAbs.c5
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;