diff options
author | Alan Mishchenko <alanmi@berkeley.edu> | 2013-06-25 11:49:25 -0700 |
---|---|---|
committer | Alan Mishchenko <alanmi@berkeley.edu> | 2013-06-25 11:49:25 -0700 |
commit | 94b26fe5a21199ddbd5c564331e7ee2848c8d498 (patch) | |
tree | 3c59199ce64e9fe8e840e322dd9ddf6b149248e1 /src/proof | |
parent | b255c7693e0264974128de2b00e1a386fba0b239 (diff) | |
download | abc-94b26fe5a21199ddbd5c564331e7ee2848c8d498.tar.gz abc-94b26fe5a21199ddbd5c564331e7ee2848c8d498.tar.bz2 abc-94b26fe5a21199ddbd5c564331e7ee2848c8d498.zip |
Improving CEC (command 'dcec') by integrating XOR balancing.
Diffstat (limited to 'src/proof')
-rw-r--r-- | src/proof/fra/fraCec.c | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/src/proof/fra/fraCec.c b/src/proof/fra/fraCec.c index 662a1d9e..aa95b992 100644 --- a/src/proof/fra/fraCec.c +++ b/src/proof/fra/fraCec.c @@ -274,6 +274,28 @@ int Fra_FraigSat( Aig_Man_t * pMan, ABC_INT64_T nConfLimit, ABC_INT64_T nInsLimi /**Function************************************************************* + Synopsis [Recognizes what nodes are inputs of the EXOR.] + + Description [] + + SideEffects [] + + SeeAlso [] + +***********************************************************************/ +int Aig_ManCountXors( Aig_Man_t * p ) +{ + Aig_Obj_t * pObj, * pFan0, * pFan1; + int i, Counter = 0; + Aig_ManForEachNode( p, pObj, i ) + if ( Aig_ObjIsMuxType(pObj) && Aig_ObjRecognizeExor(pObj, &pFan0, &pFan1) ) + Counter++; + return Counter; + +} + +/**Function************************************************************* + Synopsis [] Description [] @@ -338,6 +360,19 @@ ABC_PRT( "Time", Abc_Clock() - clk ); for ( i = 0; i < 6; i++ ) { //printf( "Running fraiging with %d BTnode and %d BTmiter.\n", pParams->nBTLimitNode, pParams->nBTLimitMiter ); + // try XOR balancing + if ( Aig_ManCountXors(pAig) * 30 > Aig_ManNodeNum(pAig) + 300 ) + { +clk = Abc_Clock(); + pAig = Dar_ManBalanceXor( pTemp = pAig, 1, 0, 0 ); + Aig_ManStop( pTemp ); + if ( fVerbose ) + { + printf( "Balance-X: Nodes = %6d. ", Aig_ManNodeNum(pAig) ); +ABC_PRT( "Time", Abc_Clock() - clk ); + } + } + // run fraiging clk = Abc_Clock(); pAig = Fra_FraigPerform( pTemp = pAig, pParams ); |