Skip to content

Commit

Permalink
The demodulator doesn't produce proofs so remove code path that depen…
Browse files Browse the repository at this point in the history
…ds it does.
  • Loading branch information
NikolajBjorner committed Dec 4, 2022
1 parent 7fe6787 commit d218083
Show file tree
Hide file tree
Showing 3 changed files with 9 additions and 14 deletions.
11 changes: 2 additions & 9 deletions src/ast/rewriter/demodulator_rewriter.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -616,15 +616,8 @@ void demodulator_rewriter::reschedule_demodulators(func_decl * f, expr * lhs) {
}
}

void demodulator_rewriter::operator()(unsigned n, expr * const * exprs, proof * const * prs,
expr_ref_vector & new_exprs, proof_ref_vector & new_prs) {
if (m.proofs_enabled()) {
TRACE("tactic", tout << "PRE_DEMODULATOR=true is not supported when proofs are enabled.";);
// Let us not waste time with proof production
new_exprs.append(n, exprs);
new_prs.append(n, prs);
return;
}
void demodulator_rewriter::operator()(unsigned n, expr * const * exprs,
expr_ref_vector & new_exprs) {

TRACE("demodulator", tout << "before demodulator:\n";
for ( unsigned i = 0 ; i < n ; i++ )
Expand Down
2 changes: 1 addition & 1 deletion src/ast/rewriter/demodulator_rewriter.h
Original file line number Diff line number Diff line change
Expand Up @@ -197,7 +197,7 @@ class demodulator_rewriter final {
demodulator_rewriter(ast_manager & m);
~demodulator_rewriter();

void operator()(unsigned n, expr * const * exprs, proof * const * prs, expr_ref_vector & new_exprs, proof_ref_vector & new_prs);
void operator()(unsigned n, expr * const * exprs, expr_ref_vector & new_exprs);

/**
Given a demodulator (aka rewrite rule) of the form
Expand Down
10 changes: 6 additions & 4 deletions src/tactic/ufbv/ufbv_rewriter_tactic.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -41,14 +41,16 @@ class demodulator_rewriter_tactic : public tactic {
void collect_param_descrs(param_descrs & r) override {
insert_max_memory(r);
insert_produce_models(r);
insert_produce_proofs(r);
}

void operator()(goal_ref const & g, goal_ref_buffer & result) override {
tactic_report report("ufbv-rewriter", *g);
fail_if_unsat_core_generation("ufbv-rewriter", g);

bool produce_proofs = g->proofs_enabled();
if (g->proofs_enabled()) {
result.push_back(g.get());
return;
}

demodulator_rewriter dem(m_manager);

Expand All @@ -61,11 +63,11 @@ class demodulator_rewriter_tactic : public tactic {
proofs.push_back(g->pr(i));
}

dem(forms.size(), forms.data(), proofs.data(), new_forms, new_proofs);
dem(forms.size(), forms.data(), new_forms);

g->reset();
for (unsigned i = 0; i < new_forms.size(); i++)
g->assert_expr(new_forms.get(i), produce_proofs ? new_proofs.get(i) : nullptr, nullptr);
g->assert_expr(new_forms.get(i), nullptr, nullptr);

// CMW: Remark: The demodulator could potentially
// remove all references to a variable.
Expand Down

0 comments on commit d218083

Please sign in to comment.