diff options
author | Alan Mishchenko <alanmi@berkeley.edu> | 2012-03-26 12:55:20 -0700 |
---|---|---|
committer | Alan Mishchenko <alanmi@berkeley.edu> | 2012-03-26 12:55:20 -0700 |
commit | 16cf6bf1cae3b5525dd05931aa119439e4aea15a (patch) | |
tree | b77a1f12bd91e073d00b687c59baf2c4076cf7c7 /src/base/abci/abcExtract.c | |
parent | 45f07795ef18d66d74f67f939d0998bed06cf703 (diff) | |
download | abc-16cf6bf1cae3b5525dd05931aa119439e4aea15a.tar.gz abc-16cf6bf1cae3b5525dd05931aa119439e4aea15a.tar.bz2 abc-16cf6bf1cae3b5525dd05931aa119439e4aea15a.zip |
Logic sharing for multi-input gates.
Diffstat (limited to 'src/base/abci/abcExtract.c')
-rw-r--r-- | src/base/abci/abcExtract.c | 15 |
1 files changed, 10 insertions, 5 deletions
diff --git a/src/base/abci/abcExtract.c b/src/base/abci/abcExtract.c index 1a543eaa..c0d4d70c 100644 --- a/src/base/abci/abcExtract.c +++ b/src/base/abci/abcExtract.c @@ -315,17 +315,19 @@ void Abc_NtkTraverseSupers( Abc_ShaMan_t * p, int fAnd ) int i, nOnesMax; // create mapping of nodes into their column vectors - vInputs = Vec_PtrStart( Abc_NtkObjNumMax(p->pNtk) ); + vInputs = Vec_PtrStart( Abc_NtkObjNumMax(p->pNtk) * (1 + fAnd) ); Abc_NtkIncrementTravId( p->pNtk ); if ( fAnd ) { Abc_NtkForEachCo( p->pNtk, pObj, i ) - Abc_NtkTraverseSupersAnd_rec( p, Abc_ObjFanin0(pObj), vInputs ); + if ( Abc_ObjIsNode(Abc_ObjFanin0(pObj)) ) + Abc_NtkTraverseSupersAnd_rec( p, Abc_ObjFanin0(pObj), vInputs ); } else { Abc_NtkForEachCo( p->pNtk, pObj, i ) - Abc_NtkTraverseSupersXor_rec( p, Abc_ObjFanin0(pObj), vInputs ); + if ( Abc_ObjIsNode(Abc_ObjFanin0(pObj)) ) + Abc_NtkTraverseSupersXor_rec( p, Abc_ObjFanin0(pObj), vInputs ); } p->nStartCols = Vec_IntSize(p->vObj2Lit); @@ -646,7 +648,10 @@ Abc_Ntk_t * Abc_NtkUpdateNetwork( Abc_ShaMan_t * p, int fAnd ) // create map of originals vMap2Repl = Vec_IntStartFull( Abc_NtkObjNumMax(p->pNtk) ); Vec_PtrForEachEntry( Abc_Obj_t *, vOrig, pObj, i ) + { +// printf( "Replacing %d by %d.\n", Abc_ObjId(pObj), Abc_ObjToLit((Abc_Obj_t *)Vec_PtrEntry(vRepl, i)) ); Vec_IntWriteEntry( vMap2Repl, Abc_ObjId(pObj), Abc_ObjToLit((Abc_Obj_t *)Vec_PtrEntry(vRepl, i)) ); + } Vec_PtrFree( vOrig ); Vec_PtrFree( vRepl ); @@ -660,7 +665,7 @@ Abc_Ntk_t * Abc_NtkUpdateNetwork( Abc_ShaMan_t * p, int fAnd ) { if ( iLit == iLitConst1 && fAnd ) { - pObj->fCompl0 = 1; + pObj->fCompl0 ^= 1; Vec_IntWriteEntry( &pObj->vFanins, 0, Abc_Lit2Var(iLitConst1) ); } else @@ -677,7 +682,7 @@ Abc_Ntk_t * Abc_NtkUpdateNetwork( Abc_ShaMan_t * p, int fAnd ) { if ( iLit == iLitConst1 && fAnd ) { - pObj->fCompl1 = 1; + pObj->fCompl1 ^= 1; Vec_IntWriteEntry( &pObj->vFanins, 1, Abc_Lit2Var(iLitConst1) ); } else |