summaryrefslogtreecommitdiffstats
path: root/src/sat
diff options
context:
space:
mode:
authorAlan Mishchenko <alanmi@berkeley.edu>2017-12-06 12:31:24 -0800
committerAlan Mishchenko <alanmi@berkeley.edu>2017-12-06 12:31:24 -0800
commit9e515ae3631ab8e4e263a24392c1c74896122035 (patch)
tree0c873f5ce35b5615e3a9fae8b20bf9c3c6d3b5ea /src/sat
parent67181d0446de9f0b0b5df685701ceb420373790f (diff)
downloadabc-9e515ae3631ab8e4e263a24392c1c74896122035.tar.gz
abc-9e515ae3631ab8e4e263a24392c1c74896122035.tar.bz2
abc-9e515ae3631ab8e4e263a24392c1c74896122035.zip
An improvement to 'twoexact' and 'lutexact'.
Diffstat (limited to 'src/sat')
-rw-r--r--src/sat/bmc/bmcMaj2.c51
1 files changed, 50 insertions, 1 deletions
diff --git a/src/sat/bmc/bmcMaj2.c b/src/sat/bmc/bmcMaj2.c
index aed84474..25f1b1cc 100644
--- a/src/sat/bmc/bmcMaj2.c
+++ b/src/sat/bmc/bmcMaj2.c
@@ -939,7 +939,7 @@ static int Exa3_ManMarkup( Exa3_Man_t * p )
}
}
printf( "The number of parameter variables = %d.\n", p->iVar );
- return p->iVar;
+ //return p->iVar;
// printout
// for ( i = p->nVars; i < p->nObjs; i++ )
for ( i = p->nObjs - 1; i >= p->nVars; i-- )
@@ -955,6 +955,54 @@ static int Exa3_ManMarkup( Exa3_Man_t * p )
}
return p->iVar;
}
+static int Exa3_ManInitPolarityFindVar( Exa3_Man_t * p, int i, int k, int * pIndex )
+{
+ int iVar;
+ do {
+ iVar = p->VarMarks[i][k][*pIndex];
+ *pIndex = (*pIndex + 1) % p->nVars;
+ } while ( iVar <= 0 );
+ //intf( "Setting var %d.\n", iVar );
+ return iVar;
+}
+static void Exa3_ManInitPolarity( Exa3_Man_t * p )
+{
+ int i, k, iVar, nInputs = 0;
+ for ( i = p->nVars; i < p->nObjs; i++ )
+ {
+ // create AND-gate
+ int iVarStart = 1 + p->LutMask*(i - p->nVars);
+ iVar = iVarStart + p->LutMask-1;
+ p->pSat->polarity[iVar] = 1;
+ //printf( "Setting var %d.\n", iVar );
+ }
+ for ( i = p->nVars; i < p->nObjs; i++ )
+ {
+ // connect first fanin to previous
+ if ( i == p->nVars )
+ {
+ for ( k = p->nLutSize - 1; k >= 0; k-- )
+ {
+ iVar = Exa3_ManInitPolarityFindVar( p, i, k, &nInputs );
+ p->pSat->polarity[iVar] = 1;
+ }
+ }
+ else
+ {
+ for ( k = p->nLutSize - 1; k > 0; k-- )
+ {
+ iVar = Exa3_ManInitPolarityFindVar( p, i, k, &nInputs );
+ p->pSat->polarity[iVar] = 1;
+ }
+ iVar = p->VarMarks[i][0][i-1];
+ if ( iVar <= 0 ) printf( "Variable mapping error.\n" ), fflush(stdout);
+ assert( iVar > 0 );
+ p->pSat->polarity[iVar] = 1;
+ //intf( "Setting var %d.\n", iVar );
+ }
+ //intf( "\n" );
+ }
+}
static Exa3_Man_t * Exa3_ManAlloc( int nVars, int nNodes, int nLutSize, word * pTruth )
{
Exa3_Man_t * p = ABC_CALLOC( Exa3_Man_t, 1 );
@@ -970,6 +1018,7 @@ static Exa3_Man_t * Exa3_ManAlloc( int nVars, int nNodes, int nLutSize, word * p
p->vInfo = Exa3_ManTruthTables( p );
p->pSat = sat_solver_new();
sat_solver_setnvars( p->pSat, p->iVar );
+ Exa3_ManInitPolarity( p );
return p;
}
static void Exa3_ManFree( Exa3_Man_t * p )