Commit f80841a5 by Alan Mishchenko

Variable timeframe abstraction.

parent d0713831
...@@ -149,7 +149,7 @@ void Gia_VtaSetDefaultParams( Gia_ParVta_t * p ) ...@@ -149,7 +149,7 @@ void Gia_VtaSetDefaultParams( Gia_ParVta_t * p )
p->nFramesStart = 5; // starting frame p->nFramesStart = 5; // starting frame
p->nFramesPast = 4; // overlap frames p->nFramesPast = 4; // overlap frames
p->nConfLimit = 0; // conflict limit p->nConfLimit = 0; // conflict limit
p->nLearntMax = 10000; // max number of learned clauses p->nLearntMax = 0; // max number of learned clauses
p->nTimeOut = 0; // timeout in seconds p->nTimeOut = 0; // timeout in seconds
p->nRatioMin = 10; // stop when less than this % of object is abstracted p->nRatioMin = 10; // stop when less than this % of object is abstracted
p->fUseTermVars = 1; // use terminal variables p->fUseTermVars = 1; // use terminal variables
...@@ -1415,7 +1415,7 @@ int Gia_VtaPerform( Gia_Man_t * pAig, Gia_ParVta_t * pPars ) ...@@ -1415,7 +1415,7 @@ int Gia_VtaPerform( Gia_Man_t * pAig, Gia_ParVta_t * pPars )
p->pPars->nConfLimit, p->pPars->nTimeOut, pPars->nRatioMin ); p->pPars->nConfLimit, p->pPars->nTimeOut, pPars->nRatioMin );
printf( "Frame Abs Confl Cex Core F0 F1 F2 F3 ...\n" ); printf( "Frame Abs Confl Cex Core F0 F1 F2 F3 ...\n" );
} }
for ( f = 0; !p->pPars->nFramesMax || f < p->pPars->nFramesMax; f++ ) for ( f = i = 0; !p->pPars->nFramesMax || f < p->pPars->nFramesMax; f++ )
{ {
int nConflsBeg = sat_solver2_nconflicts(p->pSat); int nConflsBeg = sat_solver2_nconflicts(p->pSat);
p->pPars->iFrame = f; p->pPars->iFrame = f;
...@@ -1423,10 +1423,8 @@ int Gia_VtaPerform( Gia_Man_t * pAig, Gia_ParVta_t * pPars ) ...@@ -1423,10 +1423,8 @@ int Gia_VtaPerform( Gia_Man_t * pAig, Gia_ParVta_t * pPars )
if ( f == p->nWords * 32 ) if ( f == p->nWords * 32 )
p->nWords = Vec_IntDoubleWidth( p->vSeens, p->nWords ); p->nWords = Vec_IntDoubleWidth( p->vSeens, p->nWords );
// check this timeframe // check this timeframe
i = 0;
if ( f < p->pPars->nFramesStart ) if ( f < p->pPars->nFramesStart )
{ {
// printf( " Adding %8d ", Vec_IntSize(Vec_PtrEntry(p->vFrames, f)) );
Vga_ManAddClausesOne( p, 0, f ); Vga_ManAddClausesOne( p, 0, f );
Vga_ManLoadSlice( p, (Vec_Int_t *)Vec_PtrEntry(p->vFrames, f), 0 ); Vga_ManLoadSlice( p, (Vec_Int_t *)Vec_PtrEntry(p->vFrames, f), 0 );
} }
......
...@@ -1037,7 +1037,6 @@ static lbool solver2_search(sat_solver2* s, ABC_INT64_T nof_conflicts) ...@@ -1037,7 +1037,6 @@ static lbool solver2_search(sat_solver2* s, ABC_INT64_T nof_conflicts)
if (solver2_dlevel(s) <= s->root_level){ if (solver2_dlevel(s) <= s->root_level){
proof_id = solver2_analyze_final(s, confl, 0); proof_id = solver2_analyze_final(s, confl, 0);
assert( proof_id > 0 ); assert( proof_id > 0 );
// solver2_record(s,&s->conf_final, proof_id);
s->hProofLast = proof_id; s->hProofLast = proof_id;
veci_delete(&learnt_clause); veci_delete(&learnt_clause);
return l_False; return l_False;
...@@ -1093,8 +1092,11 @@ static lbool solver2_search(sat_solver2* s, ABC_INT64_T nof_conflicts) ...@@ -1093,8 +1092,11 @@ static lbool solver2_search(sat_solver2* s, ABC_INT64_T nof_conflicts)
if (next == var_Undef){ if (next == var_Undef){
// Model found: // Model found:
int i; int i;
for (i = 0; i < s->size; i++) for (i = 0; i < s->size; i++)
{
assert( var_value(s,i) != varX );
s->model[i] = (var_value(s,i)==var1 ? l_True : l_False); s->model[i] = (var_value(s,i)==var1 ? l_True : l_False);
}
solver2_canceluntil(s,s->root_level); solver2_canceluntil(s,s->root_level);
veci_delete(&learnt_clause); veci_delete(&learnt_clause);
return l_True; return l_True;
...@@ -1493,14 +1495,16 @@ void sat_solver2_reducedb(sat_solver2* s) ...@@ -1493,14 +1495,16 @@ void sat_solver2_reducedb(sat_solver2* s)
void sat_solver2_rollback( sat_solver2* s ) void sat_solver2_rollback( sat_solver2* s )
{ {
int i, k, j; int i, k, j;
assert( s->qhead == s->qtail ); assert( s->iVarPivot >= 0 && s->iVarPivot <= s->size );
assert( s->iSimpPivot >= 0 && s->iSimpPivot <= s->qtail );
assert( s->hClausePivot >= 1 && s->hClausePivot <= veci_size(&s->clauses) ); assert( s->hClausePivot >= 1 && s->hClausePivot <= veci_size(&s->clauses) );
assert( s->hLearntPivot >= 1 && s->hLearntPivot <= veci_size(&s->learnts) ); assert( s->hLearntPivot >= 1 && s->hLearntPivot <= veci_size(&s->learnts) );
assert( s->iVarPivot >= 0 && s->iVarPivot <= s->size ); // reset implication queue
veci_resize(&s->order, 0); solver2_canceluntil_rollback( s, s->iSimpPivot );
if ( s->hClausePivot > 1 || s->hLearntPivot > 1 ) // update order
if ( s->iVarPivot < s->size )
{ {
// update order veci_resize(&s->order, 0);
for ( i = 0; i < s->iVarPivot; i++ ) for ( i = 0; i < s->iVarPivot; i++ )
{ {
if ( var_value(s, i) != varX ) if ( var_value(s, i) != varX )
...@@ -1509,7 +1513,10 @@ void sat_solver2_rollback( sat_solver2* s ) ...@@ -1509,7 +1513,10 @@ void sat_solver2_rollback( sat_solver2* s )
veci_push(&s->order,i); veci_push(&s->order,i);
order_update(s, i); order_update(s, i);
} }
// compact watches }
// compact watches
if ( s->hClausePivot > 1 || s->hLearntPivot > 1 )
{
for ( i = 0; i < s->size*2; i++ ) for ( i = 0; i < s->size*2; i++ )
{ {
cla* pArray = veci_begin(&s->wlists[i]); cla* pArray = veci_begin(&s->wlists[i]);
...@@ -1519,9 +1526,6 @@ void sat_solver2_rollback( sat_solver2* s ) ...@@ -1519,9 +1526,6 @@ void sat_solver2_rollback( sat_solver2* s )
veci_resize(&s->wlists[i],j); veci_resize(&s->wlists[i],j);
} }
} }
// reset implication queue
assert( solver2_dlevel(s) == 0 );
solver2_canceluntil_rollback( s, s->iSimpPivot );
// reset problem clauses // reset problem clauses
if ( s->hClausePivot < veci_size(&s->clauses) ) if ( s->hClausePivot < veci_size(&s->clauses) )
{ {
...@@ -1557,6 +1561,7 @@ void sat_solver2_rollback( sat_solver2* s ) ...@@ -1557,6 +1561,7 @@ void sat_solver2_rollback( sat_solver2* s )
s->activity[i] = (1<<10); s->activity[i] = (1<<10);
#endif #endif
s->model [i] = 0; s->model [i] = 0;
s->orderpos[i] = -1;
} }
s->size = s->iVarPivot; s->size = s->iVarPivot;
// initialize other vars // initialize other vars
...@@ -1613,7 +1618,7 @@ int sat_solver2_find_clause( sat_solver2* s, int Hand, int fVerbose ) ...@@ -1613,7 +1618,7 @@ int sat_solver2_find_clause( sat_solver2* s, int Hand, int fVerbose )
if ( (pArray[k] >> 1) == Hand ) if ( (pArray[k] >> 1) == Hand )
{ {
if ( fVerbose ) if ( fVerbose )
printf( "Clause found in list %d.\n", k ); printf( "Clause found in list %d at position.\n", i, k );
Found = 1; Found = 1;
break; break;
} }
...@@ -1621,12 +1626,12 @@ int sat_solver2_find_clause( sat_solver2* s, int Hand, int fVerbose ) ...@@ -1621,12 +1626,12 @@ int sat_solver2_find_clause( sat_solver2* s, int Hand, int fVerbose )
if ( Found == 0 ) if ( Found == 0 )
{ {
if ( fVerbose ) if ( fVerbose )
printf( "Clause with hand %d is not found.\n", Hand ); printf( "Clause with handle %d is not found.\n", Hand );
} }
return Found; return Found;
} }
// verify that all clauses are satisfied // verify that all problem clauses are satisfied
void sat_solver2_verify( sat_solver2* s ) void sat_solver2_verify( sat_solver2* s )
{ {
satset * c; satset * c;
...@@ -1738,7 +1743,6 @@ int sat_solver2_solve(sat_solver2* s, lit* begin, lit* end, ABC_INT64_T nConfLim ...@@ -1738,7 +1743,6 @@ int sat_solver2_solve(sat_solver2* s, lit* begin, lit* end, ABC_INT64_T nConfLim
if (var_level(s, lit_var(p)) > 0) if (var_level(s, lit_var(p)) > 0)
veci_push(&s->conf_final, p); veci_push(&s->conf_final, p);
} }
// solver2_record(s, &s->conf_final, proof_id, 1);
s->hProofLast = proof_id; s->hProofLast = proof_id;
solver2_canceluntil(s, 0); solver2_canceluntil(s, 0);
return l_False; return l_False;
...@@ -1749,7 +1753,6 @@ int sat_solver2_solve(sat_solver2* s, lit* begin, lit* end, ABC_INT64_T nConfLim ...@@ -1749,7 +1753,6 @@ int sat_solver2_solve(sat_solver2* s, lit* begin, lit* end, ABC_INT64_T nConfLim
if (confl != NULL){ if (confl != NULL){
proof_id = solver2_analyze_final(s, confl, 0); proof_id = solver2_analyze_final(s, confl, 0);
assert(s->conf_final.size > 0); assert(s->conf_final.size > 0);
// solver2_record(s,&s->conf_final, proof_id, 1);
s->hProofLast = proof_id; s->hProofLast = proof_id;
solver2_canceluntil(s, 0); solver2_canceluntil(s, 0);
return l_False; return l_False;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment