diff options
author | Alan Mishchenko <alanmi@berkeley.edu> | 2017-10-01 19:49:28 +0300 |
---|---|---|
committer | Alan Mishchenko <alanmi@berkeley.edu> | 2017-10-01 19:49:28 +0300 |
commit | c272188946b1142c7853c0820c2f034bf8edf86a (patch) | |
tree | 87c9aef0eec92f18e4959c1fe6cb3094d077ba8a /src/sat | |
parent | ce8dbc4ac6b1e40e4d209d23c95e014417378f38 (diff) | |
download | abc-c272188946b1142c7853c0820c2f034bf8edf86a.tar.gz abc-c272188946b1142c7853c0820c2f034bf8edf86a.tar.bz2 abc-c272188946b1142c7853c0820c2f034bf8edf86a.zip |
Exact synthesis of majority gates.
Diffstat (limited to 'src/sat')
-rw-r--r-- | src/sat/bmc/bmcMaj.c | 24 |
1 files changed, 17 insertions, 7 deletions
diff --git a/src/sat/bmc/bmcMaj.c b/src/sat/bmc/bmcMaj.c index 749be285..31460b0e 100644 --- a/src/sat/bmc/bmcMaj.c +++ b/src/sat/bmc/bmcMaj.c @@ -41,6 +41,7 @@ struct Maj_Man_t_ int nWords; // the truth table size in 64-bit words int iVar; // the next available SAT variable int fUseConst; // use constant fanins + int fUseLine; // use cascade topology Vec_Wrd_t * vInfo; // Const0 + Const1 + nVars + nNodes + Maj(nVars) int VarMarks[MAJ_NOBJS][3][MAJ_NOBJS]; // variable marks int VarVals[MAJ_NOBJS+2]; // values of the first 2 + nVars variables @@ -103,6 +104,13 @@ int Maj_ManMarkup( Maj_Man_t * p ) { for ( k = 0; k < 3; k++ ) { + if ( p->fUseLine && k == 0 ) + { + j = i-1; + Vec_WecPush( p->vOutLits, j, Abc_Var2Lit(p->iVar, 0) ); + p->VarMarks[i][k][j] = p->iVar++; + continue; + } for ( j = (p->fUseConst && k == 2) ? 0 : 2; j < i - k; j++ ) { Vec_WecPush( p->vOutLits, j, Abc_Var2Lit(p->iVar, 0) ); @@ -119,19 +127,20 @@ int Maj_ManMarkup( Maj_Man_t * p ) for ( j = 0; j < p->nObjs; j++ ) { for ( k = 0; k < 3; k++ ) - printf( "%2d ", p->VarMarks[i][k][j] ); + printf( "%3d ", p->VarMarks[i][k][j] ); printf( "\n" ); } } return p->iVar; } -Maj_Man_t * Maj_ManAlloc( int nVars, int nNodes, int fUseConst ) +Maj_Man_t * Maj_ManAlloc( int nVars, int nNodes, int fUseConst, int fUseLine ) { Maj_Man_t * p = ABC_CALLOC( Maj_Man_t, 1 ); p->nVars = nVars; p->nNodes = nNodes; p->nObjs = 2 + nVars + nNodes; p->fUseConst = fUseConst; + p->fUseLine = fUseLine; p->nWords = Abc_TtWordNum(nVars); p->vOutLits = Vec_WecStart( p->nObjs ); p->iVar = Maj_ManMarkup( p ); @@ -207,10 +216,11 @@ void Maj_ManPrintSolution( Maj_Man_t * p ) { int i, k, iVar; printf( "Realization of %d-input majority using %d MAJ3 gates:\n", p->nVars, p->nNodes ); - for ( i = p->nVars + 2; i < p->nObjs; i++ ) +// for ( i = p->nVars + 2; i < p->nObjs; i++ ) + for ( i = p->nObjs - 1; i >= p->nVars + 2; i-- ) { printf( "%02d = MAJ(", i-2 ); - for ( k = 0; k < 3; k++ ) + for ( k = 2; k >= 0; k-- ) { iVar = Maj_ManFindFanin( p, i, k ); if ( iVar >= 2 && iVar < p->nVars + 2 ) @@ -335,11 +345,11 @@ int Maj_ManAddCnf( Maj_Man_t * p, int iMint ) p->iVar += 4*p->nNodes; return 1; } -void Maj_ManExactSynthesis( int nVars, int nNodes, int fUseConst, int fVerbose ) +void Maj_ManExactSynthesis( int nVars, int nNodes, int fUseConst, int fUseLine, int fVerbose ) { int i, iMint = 0; abctime clkTotal = Abc_Clock(); - Maj_Man_t * p = Maj_ManAlloc( nVars, nNodes, fUseConst ); + Maj_Man_t * p = Maj_ManAlloc( nVars, nNodes, fUseConst, fUseLine ); int status = Maj_ManAddCnfStart( p ); assert( status ); printf( "Running exact synthesis for %d-input majority with %d MAJ3 gates...\n", p->nVars, p->nNodes ); @@ -355,7 +365,7 @@ void Maj_ManExactSynthesis( int nVars, int nNodes, int fUseConst, int fVerbose ) Extra_PrintBinary( stdout, (unsigned *)&iMint, p->nVars ); printf( " Var =%5d ", p->iVar ); printf( "Cla =%6d ", bmcg_sat_solver_clausenum(p->pSat) ); - printf( "Conf =%8d ", bmcg_sat_solver_conflictnum(p->pSat) ); + printf( "Conf =%9d ", bmcg_sat_solver_conflictnum(p->pSat) ); Abc_PrintTime( 1, "Time", Abc_Clock() - clk ); } if ( status == GLUCOSE_UNSAT ) |