summaryrefslogtreecommitdiffstats
path: root/src/base/abci/abcMfs.c
diff options
context:
space:
mode:
authorAlan Mishchenko <alanmi@berkeley.edu>2013-05-26 16:12:44 -0700
committerAlan Mishchenko <alanmi@berkeley.edu>2013-05-26 16:12:44 -0700
commitfb6eaaf5d9e26d7b0ac326fa17a8c7379b24df68 (patch)
tree4fa94aa0db2667caf76bd9fb605b5aedcf0d4aa8 /src/base/abci/abcMfs.c
parented3d3dfc8ea16ac226bbce6cabbb207ee89ce474 (diff)
downloadabc-fb6eaaf5d9e26d7b0ac326fa17a8c7379b24df68.tar.gz
abc-fb6eaaf5d9e26d7b0ac326fa17a8c7379b24df68.tar.bz2
abc-fb6eaaf5d9e26d7b0ac326fa17a8c7379b24df68.zip
New MFS package.
Diffstat (limited to 'src/base/abci/abcMfs.c')
-rw-r--r--src/base/abci/abcMfs.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/src/base/abci/abcMfs.c b/src/base/abci/abcMfs.c
index c87c1a75..2371e49a 100644
--- a/src/base/abci/abcMfs.c
+++ b/src/base/abci/abcMfs.c
@@ -111,9 +111,9 @@ Sfm_Ntk_t * Abc_NtkExtractMfs( Abc_Ntk_t * pNtk, int nFirstFixed )
{
word uTruth = Abc_SopToTruth((char *)pObj->pData, Abc_ObjFaninNum(pObj));
Vec_WrdWriteEntry( vTruths, pObj->iTemp, uTruth );
- vArray = Vec_WecEntry( vFanins, pObj->iTemp );
if ( uTruth == 0 || ~uTruth == 0 )
continue;
+ vArray = Vec_WecEntry( vFanins, pObj->iTemp );
Vec_IntGrow( vArray, Abc_ObjFaninNum(pObj) );
Abc_ObjForEachFanin( pObj, pFanin, k )
Vec_IntPush( vArray, pFanin->iTemp );
@@ -146,11 +146,10 @@ Sfm_Ntk_t * Abc_NtkExtractMfs( Abc_Ntk_t * pNtk, int nFirstFixed )
***********************************************************************/
void Abc_NtkInsertMfs( Abc_Ntk_t * pNtk, Sfm_Ntk_t * p )
{
- Vec_Int_t * vCover = Sfm_NodeReadCover(p);
- Vec_Int_t * vMap, * vArray;
+ Vec_Int_t * vCover, * vMap, * vArray;
Abc_Obj_t * pNode;
- int i, k, Fanin;
word * pTruth;
+ int i, k, Fanin;
// map new IDs into old nodes
vMap = Vec_IntStart( Abc_NtkObjNumMax(pNtk) );
Abc_NtkForEachCi( pNtk, pNode, i )
@@ -162,6 +161,7 @@ void Abc_NtkInsertMfs( Abc_Ntk_t * pNtk, Sfm_Ntk_t * p )
Abc_NtkForEachNode( pNtk, pNode, i )
Abc_ObjRemoveFanins( pNode );
// create new fanins
+ vCover = Vec_IntAlloc( 1 << 16 );
Abc_NtkForEachNode( pNtk, pNode, i )
{
if ( pNode->iTemp == 0 || Sfm_NodeReadFixed(p, pNode->iTemp) )
@@ -192,6 +192,7 @@ void Abc_NtkInsertMfs( Abc_Ntk_t * pNtk, Sfm_Ntk_t * p )
}
assert( Abc_SopGetVarNum((char *)pNode->pData) == Vec_IntSize(vArray) );
}
+ Vec_IntFree( vCover );
Vec_IntFree( vMap );
}