summaryrefslogtreecommitdiffstats
path: root/src/sat/bsat/satSolver.c
diff options
context:
space:
mode:
authorAlan Mishchenko <alanmi@berkeley.edu>2017-02-16 13:57:36 -0800
committerAlan Mishchenko <alanmi@berkeley.edu>2017-02-16 13:57:36 -0800
commit6d6bf8740d246b1478b636a1d300ede371bffabe (patch)
tree0b8adf3dc10d80c2596a70ffd21bcf11ef83e1a1 /src/sat/bsat/satSolver.c
parent632ca7ed11be3bd57ac1a730a9775658c17d9b53 (diff)
downloadabc-6d6bf8740d246b1478b636a1d300ede371bffabe.tar.gz
abc-6d6bf8740d246b1478b636a1d300ede371bffabe.tar.bz2
abc-6d6bf8740d246b1478b636a1d300ede371bffabe.zip
Fixing missing sat_solver APIs in 'iprove'.
Diffstat (limited to 'src/sat/bsat/satSolver.c')
-rw-r--r--src/sat/bsat/satSolver.c30
1 files changed, 24 insertions, 6 deletions
diff --git a/src/sat/bsat/satSolver.c b/src/sat/bsat/satSolver.c
index f753e0a5..df9ada8e 100644
--- a/src/sat/bsat/satSolver.c
+++ b/src/sat/bsat/satSolver.c
@@ -328,11 +328,11 @@ static inline void act_var_bump(sat_solver* s, int v)
}
static inline void act_var_bump_global(sat_solver* s, int v)
{
- if ( !s->pGlobalVars )
+ if ( !s->pGlobalVars || !s->pGlobalVars[v] )
return;
if ( s->VarActType == 0 )
{
- s->activity[v] += (int)((unsigned)s->var_inc * 3 * s->pGlobalVars[v]);
+ s->activity[v] += (int)((unsigned)s->var_inc * 3);
if (s->activity[v] & 0x80000000)
act_var_rescale(s);
if (s->orderpos[v] != -1)
@@ -340,8 +340,17 @@ static inline void act_var_bump_global(sat_solver* s, int v)
}
else if ( s->VarActType == 1 )
{
- s->activity[v] += (unsigned)(Abc_Word2Dbl(s->var_inc) * 3.0 * s->pGlobalVars[v]);
- if (Abc_Word2Dbl(s->activity[v]) > 1e100)
+ double act = Abc_Word2Dbl(s->activity[v]) + Abc_Word2Dbl(s->var_inc) * 3.0;
+ s->activity[v] = Abc_Dbl2Word(act);
+ if ( act > 1e100)
+ act_var_rescale(s);
+ if (s->orderpos[v] != -1)
+ order_update(s,v);
+ }
+ else if ( s->VarActType == 2 )
+ {
+ s->activity[v] = Xdbl_Add( s->activity[v], Xdbl_Mul(s->var_inc, Xdbl_FromDouble(3.0)) );
+ if (s->activity[v] > ABC_CONST(0x014c924d692ca61b))
act_var_rescale(s);
if (s->orderpos[v] != -1)
order_update(s,v);
@@ -362,8 +371,17 @@ static inline void act_var_bump_factor(sat_solver* s, int v)
}
else if ( s->VarActType == 1 )
{
- s->activity[v] += (unsigned)(Abc_Word2Dbl(s->var_inc) * s->factors[v]);
- if (Abc_Word2Dbl(s->activity[v]) > 1e100)
+ double act = Abc_Word2Dbl(s->activity[v]) + Abc_Word2Dbl(s->var_inc) * s->factors[v];
+ s->activity[v] = Abc_Dbl2Word(act);
+ if ( act > 1e100)
+ act_var_rescale(s);
+ if (s->orderpos[v] != -1)
+ order_update(s,v);
+ }
+ else if ( s->VarActType == 2 )
+ {
+ s->activity[v] = Xdbl_Add( s->activity[v], Xdbl_Mul(s->var_inc, Xdbl_FromDouble(s->factors[v])) );
+ if (s->activity[v] > ABC_CONST(0x014c924d692ca61b))
act_var_rescale(s);
if (s->orderpos[v] != -1)
order_update(s,v);