mirror of
https://github.com/Z3Prover/z3
synced 2025-04-06 01:24:08 +00:00
81 lines
2.2 KiB
C++
81 lines
2.2 KiB
C++
/*++
|
|
Copyright (c) 2011 Microsoft Corporation
|
|
|
|
Module Name:
|
|
|
|
th_rewriter.h
|
|
|
|
Abstract:
|
|
|
|
Rewriter for applying all builtin (cheap) theory rewrite rules.
|
|
|
|
Author:
|
|
|
|
Leonardo (leonardo) 2011-04-07
|
|
|
|
Notes:
|
|
|
|
--*/
|
|
#pragma once
|
|
|
|
#include "ast/ast.h"
|
|
#include "ast/rewriter/rewriter_types.h"
|
|
#include "util/params.h"
|
|
|
|
class expr_substitution;
|
|
|
|
class expr_solver;
|
|
|
|
class th_rewriter {
|
|
struct imp;
|
|
imp * m_imp;
|
|
params_ref m_params;
|
|
public:
|
|
th_rewriter(ast_manager & m, params_ref const & p = params_ref());
|
|
~th_rewriter();
|
|
|
|
ast_manager & m () const;
|
|
|
|
void updt_params(params_ref const & p);
|
|
static void get_param_descrs(param_descrs & r);
|
|
|
|
void set_flat_and_or(bool f);
|
|
void set_order_eq(bool f);
|
|
|
|
unsigned get_cache_size() const;
|
|
unsigned get_num_steps() const;
|
|
|
|
void operator()(expr_ref& term);
|
|
void operator()(expr * t, expr_ref & result);
|
|
void operator()(expr * t, expr_ref & result, proof_ref & result_pr);
|
|
expr_ref operator()(expr * n, unsigned num_bindings, expr * const * bindings);
|
|
|
|
expr_ref mk_app(func_decl* f, unsigned num_args, expr* const* args);
|
|
expr_ref mk_app(func_decl* f, ptr_vector<expr> const& args) { return mk_app(f, args.size(), args.data()); }
|
|
expr_ref mk_app(func_decl* f, expr_ref_vector const& args) { return mk_app(f, args.size(), args.data()); }
|
|
expr_ref mk_eq(expr* a, expr* b);
|
|
|
|
bool reduce_quantifier(quantifier * old_q,
|
|
expr * new_body,
|
|
expr * const * new_patterns,
|
|
expr * const * new_no_patterns,
|
|
expr_ref & result,
|
|
proof_ref & result_pr);
|
|
|
|
void cleanup();
|
|
void reset();
|
|
|
|
void set_substitution(expr_substitution * s);
|
|
|
|
// Dependency tracking is very coarse.
|
|
// The rewriter just keeps accumulating the dependencies of the used substitutions.
|
|
// The following methods are used to recover and reset them.
|
|
// Remark: reset_used_dependecies will reset the internal cache if get_used_dependencies() != 0
|
|
expr_dependency * get_used_dependencies();
|
|
void reset_used_dependencies();
|
|
|
|
void set_solver(expr_solver* solver);
|
|
|
|
};
|
|
|