mirror of
https://github.com/Z3Prover/z3
synced 2025-04-06 17:44:08 +00:00
* Fixed bug in UP * Put decrement at the right position * Fixed replaying in UP * Set UP persist clauses to false
This commit is contained in:
parent
c2b7b58c78
commit
acd48b6a30
|
@ -103,7 +103,7 @@ def_module_params(module_name='smt',
|
|||
('arith.print_ext_var_names', BOOL, False, 'print external variable names'),
|
||||
('pb.conflict_frequency', UINT, 1000, 'conflict frequency for Pseudo-Boolean theory'),
|
||||
('pb.learn_complements', BOOL, True, 'learn complement literals for Pseudo-Boolean theory'),
|
||||
('up.persist_clauses', BOOL, True, 'replay propagated clauses below the levels they are asserted'),
|
||||
('up.persist_clauses', BOOL, False, 'replay propagated clauses below the levels they are asserted'),
|
||||
('array.weak', BOOL, False, 'weak array theory'),
|
||||
('array.extensional', BOOL, True, 'extensional array theory'),
|
||||
('clause_proof', BOOL, False, 'record a clausal proof'),
|
||||
|
|
|
@ -1142,10 +1142,13 @@ namespace smt {
|
|||
for (unsigned i = 0; i < num_lits; i++) {
|
||||
literal curr = lits[i];
|
||||
lbool val = get_assignment(curr);
|
||||
switch(val) {
|
||||
switch (val) {
|
||||
case l_false:
|
||||
TRACE("simplify_aux_clause_literals", display_literal_verbose(tout << get_assign_level(curr) << " " << get_scope_level() << " " << curr << ":", curr); tout << "\n"; );
|
||||
if (curr != prev) {
|
||||
prev = curr;
|
||||
simp_lits.push_back(~curr);
|
||||
}
|
||||
break; // ignore literal
|
||||
// fall through
|
||||
case l_undef:
|
||||
|
|
|
@ -339,22 +339,20 @@ void theory_user_propagator::propagate_consequence(prop_info const& prop) {
|
|||
ctx.mark_as_relevant(lit);
|
||||
|
||||
m_lits.push_back(lit);
|
||||
if (ctx.get_fparams().m_up_persist_clauses)
|
||||
ctx.mk_th_axiom(get_id(), m_lits);
|
||||
else
|
||||
ctx.mk_th_lemma(get_id(), m_lits);
|
||||
|
||||
if (ctx.get_fparams().m_up_persist_clauses) {
|
||||
ctx.mk_th_axiom(get_id(), m_lits);
|
||||
expr_ref_vector clause(m);
|
||||
for (auto lit : m_lits)
|
||||
clause.push_back(ctx.literal2expr(lit));
|
||||
for (auto l : m_lits)
|
||||
clause.push_back(ctx.literal2expr(l));
|
||||
m_clauses_to_replay.push_back(clause);
|
||||
if (m_replay_qhead + 1 < m_clauses_to_replay.size())
|
||||
std::swap(m_clauses_to_replay[m_replay_qhead], m_clauses_to_replay[m_clauses_to_replay.size()-1]);
|
||||
ctx.push_trail(value_trail<unsigned>(m_replay_qhead));
|
||||
++m_replay_qhead;
|
||||
ctx.mk_th_axiom(get_id(), m_lits);
|
||||
}
|
||||
else
|
||||
ctx.mk_th_lemma(get_id(), m_lits);
|
||||
}
|
||||
TRACE("user_propagate", ctx.display(tout););
|
||||
|
||||
|
|
Loading…
Reference in a new issue