mirror of
https://github.com/Z3Prover/z3
synced 2025-04-06 17:44:08 +00:00
fix #7493
This commit is contained in:
parent
99cbfa715c
commit
17d47ca8c7
|
@ -241,6 +241,7 @@ namespace opt {
|
|||
smt::theory_var v = m_objective_vars[i];
|
||||
bool has_shared = false;
|
||||
m_last_model = nullptr;
|
||||
blocker = nullptr;
|
||||
//
|
||||
// compute an optimization hint.
|
||||
// The hint is valid if there are no shared symbols (a pure LP).
|
||||
|
@ -256,6 +257,7 @@ namespace opt {
|
|||
if (!m_models[i])
|
||||
m_models.set(i, m_last_model.get());
|
||||
|
||||
TRACE("opt", tout << "maximize " << i << " " << val << " " << m_objective_values[i] << " " << blocker << "\n";);
|
||||
if (val > m_objective_values[i]) {
|
||||
m_objective_values[i] = val;
|
||||
}
|
||||
|
|
|
@ -202,9 +202,6 @@ namespace opt {
|
|||
for (unsigned i = 0; i < obj_index; ++i)
|
||||
commit_assignment(i);
|
||||
|
||||
// m_s->maximize_objective(obj_index, bound);
|
||||
// m_s->assert_expr(bound);
|
||||
|
||||
unsigned steps = 0;
|
||||
unsigned step_incs = 0;
|
||||
rational delta_per_step(1);
|
||||
|
@ -216,9 +213,10 @@ namespace opt {
|
|||
SASSERT(delta_per_step.is_pos());
|
||||
is_sat = m_s->check_sat(0, nullptr);
|
||||
TRACE("opt", tout << "check " << is_sat << "\n";
|
||||
tout << "last bound: " << last_bound << "\n";
|
||||
tout << "last bound: " << last_bound << " bound " << bound << "\n";
|
||||
tout << "lower: " << m_lower[obj_index] << "\n";
|
||||
tout << "upper: " << m_upper[obj_index] << "\n";
|
||||
if (is_sat == l_true) m_s->display(tout);
|
||||
);
|
||||
if (is_sat == l_true) {
|
||||
m_s->maximize_objective(obj_index, bound);
|
||||
|
|
|
@ -3858,12 +3858,21 @@ public:
|
|||
vi = get_lpvar(v);
|
||||
|
||||
st = lp().maximize_term(vi, term_max);
|
||||
|
||||
if (has_int() && lp().has_inf_int()) {
|
||||
st = lp::lp_status::FEASIBLE;
|
||||
lp().restore_x();
|
||||
}
|
||||
if (m_nla && (st == lp::lp_status::OPTIMAL || st == lp::lp_status::UNBOUNDED)) {
|
||||
switch (check_nla()) {
|
||||
case FC_DONE:
|
||||
st = lp::lp_status::FEASIBLE;
|
||||
break;
|
||||
case FC_GIVEUP:
|
||||
case FC_CONTINUE:
|
||||
st = lp::lp_status::UNBOUNDED;
|
||||
break;
|
||||
}
|
||||
lp().restore_x();
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue