diff options
author | Alan Mishchenko <alanmi@berkeley.edu> | 2014-09-18 22:26:54 -0700 |
---|---|---|
committer | Alan Mishchenko <alanmi@berkeley.edu> | 2014-09-18 22:26:54 -0700 |
commit | ee727912938fdba38f08570e4ab961c0fd503dcf (patch) | |
tree | 762850b27b429eb1d6b6f43cd3e97b5ddb41f0a0 /src | |
parent | 69699da9125fdce50c586d2c13954fb3285ccc2f (diff) | |
download | abc-ee727912938fdba38f08570e4ab961c0fd503dcf.tar.gz abc-ee727912938fdba38f08570e4ab961c0fd503dcf.tar.bz2 abc-ee727912938fdba38f08570e4ab961c0fd503dcf.zip |
Improvements to Boolean matching.
Diffstat (limited to 'src')
-rw-r--r-- | src/base/abci/abc.c | 8 | ||||
-rw-r--r-- | src/map/if/ifDsd.c | 26 | ||||
-rw-r--r-- | src/map/if/ifTune.c | 2 |
3 files changed, 26 insertions, 10 deletions
diff --git a/src/base/abci/abc.c b/src/base/abci/abc.c index 23983869..b99c1049 100644 --- a/src/base/abci/abc.c +++ b/src/base/abci/abc.c @@ -15409,9 +15409,9 @@ int Abc_CommandIf( Abc_Frame_t * pAbc, int argc, char ** argv ) Abc_Print( -1, "DSD manager is not available.\n" ); return 1; } - if ( pPars->nLutSize > If_DsdManLutSize(pDsdMan) ) + if ( pPars->nLutSize > If_DsdManVarNum(pDsdMan) ) { - Abc_Print( -1, "LUT size (%d) is more than the number of variables in the DSD manager (%d).\n", pPars->nLutSize, If_DsdManLutSize(pDsdMan) ); + Abc_Print( -1, "LUT size (%d) is more than the number of variables in the DSD manager (%d).\n", pPars->nLutSize, If_DsdManVarNum(pDsdMan) ); return 1; } pPars->fCutMin = 1; @@ -31280,9 +31280,9 @@ int Abc_CommandAbc9If( Abc_Frame_t * pAbc, int argc, char ** argv ) Abc_Print( -1, "DSD manager is not available.\n" ); return 1; } - if ( pPars->nLutSize > If_DsdManLutSize(pDsdMan) ) + if ( pPars->nLutSize > If_DsdManVarNum(pDsdMan) ) { - Abc_Print( -1, "LUT size (%d) is more than the number of variables in the DSD manager (%d).\n", pPars->nLutSize, If_DsdManLutSize(pDsdMan) ); + Abc_Print( -1, "LUT size (%d) is more than the number of variables in the DSD manager (%d).\n", pPars->nLutSize, If_DsdManVarNum(pDsdMan) ); return 1; } pPars->fCutMin = 1; diff --git a/src/map/if/ifDsd.c b/src/map/if/ifDsd.c index 27e260d5..5525678b 100644 --- a/src/map/if/ifDsd.c +++ b/src/map/if/ifDsd.c @@ -89,6 +89,7 @@ struct If_DsdMan_t_ Gia_Man_t * pTtGia; // GIA to represent truth tables Vec_Int_t * vCover; // temporary memory void * pSat; // SAT solver + int nObjsPrev; // previous number of objects int fNewAsUseless; // set new as useless int nUniqueHits; // statistics int nUniqueMisses; // statistics @@ -127,13 +128,15 @@ static inline void If_DsdVecObjClearMark( Vec_Ptr_t * p, int iObj ) #define If_DsdVecForEachObj( vVec, pObj, i ) \ Vec_PtrForEachEntry( If_DsdObj_t *, vVec, pObj, i ) -#define If_DsdVecForEachObjVec( vNodes, vVec, pObj, i ) \ +#define If_DsdVecForEachObjStart( vVec, pObj, i, Start ) \ + Vec_PtrForEachEntryStart( If_DsdObj_t *, vVec, pObj, i, Start ) +#define If_DsdVecForEachObjVec( vNodes, vVec, pObj, i ) \ for ( i = 0; (i < Vec_IntSize(vNodes)) && ((pObj) = If_DsdVecObj(vVec, Vec_IntEntry(vNodes,i))); i++ ) #define If_DsdVecForEachNode( vVec, pObj, i ) \ Vec_PtrForEachEntryStart( If_DsdObj_t *, vVec, pObj, i, 2 ) #define If_DsdObjForEachFanin( vVec, pObj, pFanin, i ) \ for ( i = 0; (i < If_DsdObjFaninNum(pObj)) && ((pFanin) = If_DsdObjFanin(vVec, pObj, i)); i++ ) -#define If_DsdObjForEachFaninLit( vVec, pObj, iLit, i ) \ +#define If_DsdObjForEachFaninLit( vVec, pObj, iLit, i ) \ for ( i = 0; (i < If_DsdObjFaninNum(pObj)) && ((iLit) = If_DsdObjFaninLit(pObj, i)); i++ ) extern int Kit_TruthToGia( Gia_Man_t * pMan, unsigned * pTruth, int nVars, Vec_Int_t * vMemory, Vec_Int_t * vLeaves, int fHash ); @@ -183,6 +186,7 @@ int If_DsdManReadMark( If_DsdMan_t * p, int iDsd ) } void If_DsdManSetNewAsUseless( If_DsdMan_t * p ) { + p->nObjsPrev = If_DsdManObjNum(p); p->fNewAsUseless = 1; } @@ -2379,6 +2383,8 @@ void Id_DsdManTuneStr1( If_DsdMan_t * p, char * pStruct, int nConfls, int fVerbo abctime clk = Abc_Clock(); // parse the structure Ifn_Ntk_t * pNtk = Ifn_NtkParse( pStruct ); + if ( pNtk == NULL ) + return; if ( If_DsdManVarNum(p) > Ifn_NtkInputNum(pNtk) ) { printf( "The support of DSD manager (%d) exceeds the support of the structure (%d).\n", If_DsdManVarNum(p), Ifn_NtkInputNum(pNtk) ); @@ -2395,11 +2401,14 @@ void Id_DsdManTuneStr1( If_DsdMan_t * p, char * pStruct, int nConfls, int fVerbo Ifn_NtkPrint( pNtk ); printf( "Largest LUT size = %d.\n", LutSize ); } + if ( p->nObjsPrev > 0 ) + printf( "Starting the tuning process from object %d (out of %d).\n", p->nObjsPrev, Vec_PtrSize(&p->vObjs) ); // clean the attributes If_DsdVecForEachObj( &p->vObjs, pObj, i ) - pObj->fMark = 0; + if ( i >= p->nObjsPrev ) + pObj->fMark = 0; pProgress = Extra_ProgressBarStart( stdout, Vec_PtrSize(&p->vObjs) ); - If_DsdVecForEachObj( &p->vObjs, pObj, i ) + If_DsdVecForEachObjStart( &p->vObjs, pObj, i, p->nObjsPrev ) { Extra_ProgressBarUpdate( pProgress, i, NULL ); nVars = If_DsdObjSuppSize(pObj); @@ -2416,6 +2425,7 @@ void Id_DsdManTuneStr1( If_DsdMan_t * p, char * pStruct, int nConfls, int fVerbo if ( Value == 0 ) If_DsdVecObjSetMark( &p->vObjs, i ); } + p->nObjsPrev = 0; Extra_ProgressBarStop( pProgress ); printf( "Finished matching %d functions. ", Vec_PtrSize(&p->vObjs) ); Abc_PrintTime( 1, "Time", Abc_Clock() - clk ); @@ -2519,9 +2529,12 @@ void Id_DsdManTuneStr( If_DsdMan_t * p, char * pStruct, int nConfls, int nProcs, printf( "Largest LUT size = %d.\n", LutSize ); } ABC_FREE( pNtk ); + if ( p->nObjsPrev > 0 ) + printf( "Starting the tuning process from object %d (out of %d).\n", p->nObjsPrev, Vec_PtrSize(&p->vObjs) ); // clean the attributes If_DsdVecForEachObj( &p->vObjs, pObj, i ) - pObj->fMark = 0; + if ( i >= p->nObjsPrev ) + pObj->fMark = 0; pProgress = Extra_ProgressBarStart( stdout, Vec_PtrSize(&p->vObjs) ); // perform concurrent solving @@ -2529,7 +2542,7 @@ void Id_DsdManTuneStr( If_DsdMan_t * p, char * pStruct, int nConfls, int nProcs, pthread_t WorkerThread[PAR_THR_MAX]; Ifn_ThData_t ThData[PAR_THR_MAX]; abctime clk, clkUsed = 0; - int status, fRunning = 1, iCurrentObj = 0; + int status, fRunning = 1, iCurrentObj = p->nObjsPrev; // start the threads for ( i = 0; i < nProcs; i++ ) { @@ -2605,6 +2618,7 @@ void Id_DsdManTuneStr( If_DsdMan_t * p, char * pStruct, int nConfls, int nProcs, } } + p->nObjsPrev = 0; Extra_ProgressBarStop( pProgress ); printf( "Finished matching %d functions. ", Vec_PtrSize(&p->vObjs) ); Abc_PrintTime( 1, "Time", Abc_Clock() - clk ); diff --git a/src/map/if/ifTune.c b/src/map/if/ifTune.c index 95f598fd..7b3adfec 100644 --- a/src/map/if/ifTune.c +++ b/src/map/if/ifTune.c @@ -807,6 +807,8 @@ void Ifn_NtkRead() // char * pStr = "g=<abc>;h=<ade>;i={fgh};"; char * pStr = "i=<abc>;j=(def);k=[gh];l={ijk};"; Ifn_Ntk_t * p = Ifn_NtkParse( pStr ); + if ( p == NULL ) + return; Ifn_NtkPrint( p ); Dau_DsdPrintFromTruth( pTruth, nVars ); // get the given function |