summaryrefslogtreecommitdiffstats
path: root/src/sat
diff options
context:
space:
mode:
authorAlan Mishchenko <alanmi@berkeley.edu>2014-04-01 11:53:08 -0700
committerAlan Mishchenko <alanmi@berkeley.edu>2014-04-01 11:53:08 -0700
commit7b8863466eacfd6b63159600e62816f830acece6 (patch)
tree121788940097c38fa8b7530835c38be46f5e9a2a /src/sat
parent41e94c474a26ac18cbe75572066411dd9ece81d0 (diff)
downloadabc-7b8863466eacfd6b63159600e62816f830acece6.tar.gz
abc-7b8863466eacfd6b63159600e62816f830acece6.tar.bz2
abc-7b8863466eacfd6b63159600e62816f830acece6.zip
Adding switch to handle only single faults.
Diffstat (limited to 'src/sat')
-rw-r--r--src/sat/bmc/bmcFault.c96
-rw-r--r--src/sat/bsat/satSolver.h8
2 files changed, 90 insertions, 14 deletions
diff --git a/src/sat/bmc/bmcFault.c b/src/sat/bmc/bmcFault.c
index b4a540a4..8f7d8c9b 100644
--- a/src/sat/bmc/bmcFault.c
+++ b/src/sat/bmc/bmcFault.c
@@ -36,6 +36,67 @@ ABC_NAMESPACE_IMPL_START
/**Function*************************************************************
+ Synopsis [Add constraint that no more than 1 variable is 1.]
+
+ Description []
+
+ SideEffects []
+
+ SeeAlso []
+
+***********************************************************************/
+static inline int Cnf_AddCardinConstr( sat_solver * p, Vec_Int_t * vVars )
+{
+ int i, k, pLits[2], iVar, nVars = sat_solver_nvars(p);
+ Vec_IntForEachEntry( vVars, iVar, i )
+ assert( iVar >= 0 && iVar < nVars );
+ iVar = nVars;
+ sat_solver_setnvars( p, nVars + Vec_IntSize(vVars) - 1 );
+ while ( Vec_IntSize(vVars) > 1 )
+ {
+ for ( k = i = 0; i < Vec_IntSize(vVars)/2; i++ )
+ {
+ pLits[0] = Abc_Var2Lit( Vec_IntEntry(vVars, 2*i), 1 );
+ pLits[1] = Abc_Var2Lit( Vec_IntEntry(vVars, 2*i+1), 1 );
+ sat_solver_addclause( p, pLits, pLits + 2 );
+ sat_solver_add_and( p, iVar, Vec_IntEntry(vVars, 2*i), Vec_IntEntry(vVars, 2*i+1), 1, 1, 1 );
+ Vec_IntWriteEntry( vVars, k++, iVar++ );
+ }
+ if ( Vec_IntSize(vVars) & 1 )
+ Vec_IntWriteEntry( vVars, k++, Vec_IntEntryLast(vVars) );
+ Vec_IntShrink( vVars, k );
+ }
+ return iVar;
+}
+void Cnf_AddCardinConstrTest()
+{
+ int i, status, nVars = 7;
+ Vec_Int_t * vVars = Vec_IntStartNatural( nVars );
+ sat_solver * pSat = sat_solver_new();
+ sat_solver_setnvars( pSat, nVars );
+ Cnf_AddCardinConstr( pSat, vVars );
+ while ( 1 )
+ {
+ status = sat_solver_solve( pSat, NULL, NULL, 0, 0, 0, 0 );
+ if ( status != l_True )
+ break;
+ Vec_IntClear( vVars );
+ for ( i = 0; i < nVars; i++ )
+ {
+ Vec_IntPush( vVars, Abc_Var2Lit(i, sat_solver_var_value(pSat, i)) );
+ printf( "%d", sat_solver_var_value(pSat, i) );
+ }
+ printf( "\n" );
+ status = sat_solver_addclause( pSat, Vec_IntArray(vVars), Vec_IntArray(vVars) + Vec_IntSize(vVars) );
+ if ( status == 0 )
+ break;
+ }
+ sat_solver_delete( pSat );
+ Vec_IntFree( vVars );
+}
+
+/**Function*************************************************************
+
Synopsis []
Description []
@@ -503,7 +564,7 @@ Vec_Int_t * Gia_ManGetTestPatterns( char * pFileName )
SeeAlso []
***********************************************************************/
-void Gia_ManFaultTest( Gia_Man_t * p, char * pFileName, int Algo, int fComplVars, int fStartPats, int nTimeOut, int fDump, int fDumpUntest, int fVerbose )
+void Gia_ManFaultTest( Gia_Man_t * p, char * pFileName, int Algo, int fComplVars, int fStartPats, int nTimeOut, int fBasic, int fDump, int fDumpUntest, int fVerbose )
{
int nIterMax = 1000000;
int i, Iter, LitRoot, status, nFuncVars = -1;
@@ -516,19 +577,29 @@ void Gia_ManFaultTest( Gia_Man_t * p, char * pFileName, int Algo, int fComplVars
// select algorithm
if ( Algo == 1 )
- nFuncVars = Gia_ManRegNum(p) + 2 * Gia_ManPiNum(p);
+ printf( "FFTEST is computing test patterns for %sdelay faults...\n", fBasic ? "single " : "" );
else if ( Algo == 2 )
- nFuncVars = Gia_ManCiNum(p);
+ printf( "FFTEST is computing test patterns for %sstuck-at faults...\n", fBasic ? "single " : "" );
else if ( Algo == 3 )
- nFuncVars = Gia_ManCiNum(p);
+ printf( "FFTEST is computing test patterns for %scomplement faults...\n", fBasic ? "single " : "" );
else if ( Algo == 4 )
- nFuncVars = Gia_ManCiNum(p);
+ printf( "FFTEST is computing test patterns for %sfunctionally observable faults...\n", fBasic ? "single " : "" );
else
{
printf( "Unregnized algorithm (%d).\n", Algo );
return;
}
+ // select algorithm
+ if ( Algo == 1 )
+ nFuncVars = Gia_ManRegNum(p) + 2 * Gia_ManPiNum(p);
+ else if ( Algo == 2 )
+ nFuncVars = Gia_ManCiNum(p);
+ else if ( Algo == 3 )
+ nFuncVars = Gia_ManCiNum(p);
+ else if ( Algo == 4 )
+ nFuncVars = Gia_ManCiNum(p);
+
// collect test patterns from file
if ( pFileName )
vTests = Gia_ManGetTestPatterns( pFileName );
@@ -565,11 +636,6 @@ void Gia_ManFaultTest( Gia_Man_t * p, char * pFileName, int Algo, int fComplVars
p0 = Gia_ManFOFUnfold( p, 0, fComplVars );
p1 = Gia_ManFOFUnfold( p, 1, fComplVars );
}
- else
- {
- printf( "Unregnized algorithm (%d).\n", Algo );
- return;
- }
// create miter
pM = Gia_ManMiter( p0, p1, 0, 0, 0, 0, 0 );
@@ -595,6 +661,16 @@ void Gia_ManFaultTest( Gia_Man_t * p, char * pFileName, int Algo, int fComplVars
Vec_IntPush( vLits, Abc_Var2Lit(pCnf->pVarNums[Gia_ObjId(pM, pObj)], 0) );
sat_solver_addclause( pSat, Vec_IntArray(vLits), Vec_IntArray(vLits) + Vec_IntSize(vLits) );
+ // add cadinality constraint
+ if ( fBasic )
+ {
+ Vec_IntClear( vLits );
+ Gia_ManForEachPi( pM, pObj, i )
+ if ( i >= nFuncVars )
+ Vec_IntPush( vLits, pCnf->pVarNums[Gia_ObjId(pM, pObj)] );
+ Cnf_AddCardinConstr( pSat, vLits );
+ }
+
// add available test-patterns
if ( Vec_IntSize(vTests) > 0 )
{
diff --git a/src/sat/bsat/satSolver.h b/src/sat/bsat/satSolver.h
index 1003d54a..fb19490c 100644
--- a/src/sat/bsat/satSolver.h
+++ b/src/sat/bsat/satSolver.h
@@ -315,22 +315,22 @@ static inline int sat_solver_add_buffer_enable( sat_solver * pSat, int iVarA, in
assert( Cid );
return 2;
}
-static inline int sat_solver_add_and( sat_solver * pSat, int iVar, int iVar0, int iVar1, int fCompl0, int fCompl1 )
+static inline int sat_solver_add_and( sat_solver * pSat, int iVar, int iVar0, int iVar1, int fCompl0, int fCompl1, int fCompl )
{
lit Lits[3];
int Cid;
- Lits[0] = toLitCond( iVar, 1 );
+ Lits[0] = toLitCond( iVar, !fCompl );
Lits[1] = toLitCond( iVar0, fCompl0 );
Cid = sat_solver_addclause( pSat, Lits, Lits + 2 );
assert( Cid );
- Lits[0] = toLitCond( iVar, 1 );
+ Lits[0] = toLitCond( iVar, !fCompl );
Lits[1] = toLitCond( iVar1, fCompl1 );
Cid = sat_solver_addclause( pSat, Lits, Lits + 2 );
assert( Cid );
- Lits[0] = toLitCond( iVar, 0 );
+ Lits[0] = toLitCond( iVar, fCompl );
Lits[1] = toLitCond( iVar0, !fCompl0 );
Lits[2] = toLitCond( iVar1, !fCompl1 );
Cid = sat_solver_addclause( pSat, Lits, Lits + 3 );