summaryrefslogtreecommitdiffstats
path: root/src/proof
diff options
context:
space:
mode:
authorAlan Mishchenko <alanmi@berkeley.edu>2013-06-25 11:49:25 -0700
committerAlan Mishchenko <alanmi@berkeley.edu>2013-06-25 11:49:25 -0700
commit94b26fe5a21199ddbd5c564331e7ee2848c8d498 (patch)
tree3c59199ce64e9fe8e840e322dd9ddf6b149248e1 /src/proof
parentb255c7693e0264974128de2b00e1a386fba0b239 (diff)
downloadabc-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.c35
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 );