mirror of
https://github.com/Z3Prover/z3
synced 2025-04-24 01:25:31 +00:00
add rewriter and seq simplifiers
This commit is contained in:
parent
a152f9cfd6
commit
4e9f21c2a1
6 changed files with 140 additions and 14 deletions
|
@ -15,4 +15,5 @@ z3_add_component(simplifiers
|
|||
COMPONENT_DEPENDENCIES
|
||||
euf
|
||||
rewriter
|
||||
bit_blaster
|
||||
)
|
||||
|
|
|
@ -49,7 +49,7 @@ void card2bv::reduce() {
|
|||
for (func_decl* f : fns)
|
||||
m_fmls.model_trail().hide(f);
|
||||
|
||||
advance_qhead(m_fmls.size());
|
||||
advance_qhead(m_fmls.size());
|
||||
}
|
||||
|
||||
void card2bv::collect_statistics(statistics& st) const {
|
||||
|
|
53
src/ast/simplifiers/rewriter_simplifier.h
Normal file
53
src/ast/simplifiers/rewriter_simplifier.h
Normal file
|
@ -0,0 +1,53 @@
|
|||
/*++
|
||||
Copyright (c) 2022 Microsoft Corporation
|
||||
|
||||
Module Name:
|
||||
|
||||
rewriter_simplifier.h
|
||||
|
||||
Abstract:
|
||||
|
||||
rewriter simplifier
|
||||
|
||||
Author:
|
||||
|
||||
Nikolaj Bjorner (nbjorner) 2022-11-24
|
||||
|
||||
--*/
|
||||
|
||||
#pragma once
|
||||
|
||||
#include "ast/simplifiers/dependent_expr_state.h"
|
||||
#include "ast/rewriter/th_rewriter.h"
|
||||
|
||||
|
||||
class rewriter_simplifier : public dependent_expr_simplifier {
|
||||
|
||||
unsigned m_num_steps = 0;
|
||||
params_ref m_params;
|
||||
|
||||
public:
|
||||
rewriter_simplifier(ast_manager& m, params_ref const& p, dependent_expr_state& fmls):
|
||||
dependent_expr_simplifier(m, fmls) {
|
||||
updt_params(p);
|
||||
}
|
||||
|
||||
void reduce() override {
|
||||
m_num_steps = 0;
|
||||
expr_ref new_curr(m);
|
||||
proof_ref new_pr(m);
|
||||
for (unsigned idx = m_qhead; idx < m_fmls.size(); idx++) {
|
||||
if (m_fmls.inconsistent())
|
||||
break;
|
||||
auto [f, d] = m_fmls[i]();
|
||||
m_rewriter(f, new_curr, new_pr);
|
||||
m_num_steps += m_rewriter.get_num_steps();
|
||||
m_fmls.update(idx, dependent_expr(m, new_curr, d));
|
||||
}
|
||||
advance_qhead(m_fmls.size());
|
||||
}
|
||||
void collect_statistics(statistics& st) const override { st.update("simplifier", m_num_steps); }
|
||||
void reset_statistics() override { m_stats.reset(); }
|
||||
void updt_params(params_ref const& p) override { m_params.append(p); m_rewriter.updt_params(m_params); }
|
||||
void collect_param_descrs(param_descrs& r) override { th_rewriter::get_param_descrs(r); }
|
||||
};
|
72
src/ast/simplifiers/seq_simplifier.h
Normal file
72
src/ast/simplifiers/seq_simplifier.h
Normal file
|
@ -0,0 +1,72 @@
|
|||
/*++
|
||||
Copyright (c) 2022 Microsoft Corporation
|
||||
|
||||
Module Name:
|
||||
|
||||
seq_simplifier.h
|
||||
|
||||
Abstract:
|
||||
|
||||
create a simplifier from a sequence of simplifiers
|
||||
|
||||
Author:
|
||||
|
||||
Nikolaj Bjorner (nbjorner) 2022-11-24
|
||||
|
||||
--*/
|
||||
|
||||
#pragma once
|
||||
|
||||
#include "ast/simplifiers/dependent_expr_state.h"
|
||||
|
||||
|
||||
class seq_simplifier : public dependent_expr_simplifier {
|
||||
scoped_ptr_vector<dependent_expr_simplifier> m_simplifiers;
|
||||
|
||||
public:
|
||||
seq_simplifier(ast_manager& m, params_ref const& p, dependent_expr_state& fmls):
|
||||
dependent_expr_simplifier(m, fmls) {
|
||||
}
|
||||
|
||||
void add_simplifier(dependent_expr_simplifier* s) {
|
||||
m_simplifiers.push_back(s);
|
||||
}
|
||||
|
||||
void reduce() override {
|
||||
for (auto* s : m_simplifiers) {
|
||||
if (m_fmls.inconsistent())
|
||||
break;
|
||||
s->reduce();
|
||||
}
|
||||
}
|
||||
|
||||
void collect_statistics(statistics& st) const override {
|
||||
for (auto* s : m_simplifiers)
|
||||
s->collect_statistics(st);
|
||||
}
|
||||
|
||||
void reset_statistics() override {
|
||||
for (auto* s : m_simplifiers)
|
||||
s->reset_statistics(st);
|
||||
}
|
||||
|
||||
void updt_params(params_ref const& p) override {
|
||||
for (auto* s : m_simplifiers)
|
||||
s->updt_params(p);
|
||||
}
|
||||
|
||||
void collect_param_descrs(param_descrs& r) override {
|
||||
for (auto* s : m_simplifiers)
|
||||
s->collect_param_descrs(r);
|
||||
}
|
||||
|
||||
void push() override {
|
||||
for (auto* s : m_simplifiers)
|
||||
s->push();
|
||||
}
|
||||
|
||||
void pop(unsigned n) override {
|
||||
for (auto* s : m_simplifiers)
|
||||
s->pop(n);
|
||||
}
|
||||
};
|
Loading…
Add table
Add a link
Reference in a new issue