/*++ Copyright (c) 2006 Microsoft Corporation Module Name: asserted_formulas.h Abstract: Author: Leonardo de Moura (leonardo) 2008-06-11. Revision History: --*/ #ifndef ASSERTED_FORMULAS_H_ #define ASSERTED_FORMULAS_H_ #include "util/statistics.h" #include "ast/static_features.h" #include "ast/simplifier/simplifier.h" #include "ast/simplifier/basic_simplifier_plugin.h" #include "ast/simplifier/maximise_ac_sharing.h" #include "ast/simplifier/bit2int.h" #include "ast/macros/macro_manager.h" #include "ast/macros/macro_finder.h" #include "ast/normal_forms/defined_names.h" #include "ast/pattern/pattern_inference.h" #include "smt/params/smt_params.h" class arith_simplifier_plugin; class bv_simplifier_plugin; class asserted_formulas { ast_manager & m; smt_params & m_params; simplifier m_pre_simplifier; simplifier m_simplifier; basic_simplifier_plugin * m_bsimp; bv_simplifier_plugin * m_bvsimp; defined_names m_defined_names; static_features m_static_features; expr_ref_vector m_asserted_formulas; // formulas asserted by user proof_ref_vector m_asserted_formula_prs; // proofs for the asserted formulas. unsigned m_asserted_qhead; macro_manager m_macro_manager; scoped_ptr m_macro_finder; bit2int m_bit2int; maximise_bv_sharing m_bv_sharing; bool m_inconsistent; bool m_has_quantifiers; struct scope { unsigned m_asserted_formulas_lim; bool m_inconsistent_old; }; svector m_scopes; void setup_simplifier_plugins(simplifier & s, basic_simplifier_plugin * & bsimp, arith_simplifier_plugin * & asimp, bv_simplifier_plugin * & bvsimp); void reduce_asserted_formulas(); void swap_asserted_formulas(expr_ref_vector & new_exprs, proof_ref_vector & new_prs); void find_macros_core(); void find_macros(); void expand_macros(); void apply_quasi_macros(); void nnf_cnf(); void infer_patterns(); void eliminate_term_ite(); void reduce_and_solve(); void flush_cache() { m_pre_simplifier.reset(); m_simplifier.reset(); } void set_eliminate_and(bool flag); void propagate_values(); void propagate_booleans(); bool pull_cheap_ite_trees(); bool pull_nested_quantifiers(); void push_assertion(expr * e, proof * pr, expr_ref_vector & result, proof_ref_vector & result_prs); void eliminate_and(); void refine_inj_axiom(); bool cheap_quant_fourier_motzkin(); void apply_distribute_forall(); bool apply_bit2int(); void lift_ite(); bool elim_bvs_from_quantifiers(); void ng_lift_ite(); #ifdef Z3DEBUG bool check_well_sorted() const; #endif unsigned get_total_size() const; bool has_bv() const; void max_bv_sharing(); bool canceled() { return m.canceled(); } public: asserted_formulas(ast_manager & m, smt_params & p); ~asserted_formulas(); void setup(); void assert_expr(expr * e, proof * in_pr); void assert_expr(expr * e); void reset(); void push_scope(); void pop_scope(unsigned num_scopes); bool inconsistent() const { return m_inconsistent; } proof * get_inconsistency_proof() const; void reduce(); unsigned get_num_formulas() const { return m_asserted_formulas.size(); } unsigned get_formulas_last_level() const; unsigned get_qhead() const { return m_asserted_qhead; } void commit(); void commit(unsigned new_qhead); expr * get_formula(unsigned idx) const { return m_asserted_formulas.get(idx); } proof * get_formula_proof(unsigned idx) const { return m.proofs_enabled() ? m_asserted_formula_prs.get(idx) : 0; } expr * const * get_formulas() const { return m_asserted_formulas.c_ptr(); } proof * const * get_formula_proofs() const { return m_asserted_formula_prs.c_ptr(); } void init(unsigned num_formulas, expr * const * formulas, proof * const * prs); void register_simplifier_plugin(simplifier_plugin * p) { m_simplifier.register_plugin(p); } simplifier & get_simplifier() { return m_simplifier; } void get_assertions(ptr_vector & result); bool empty() const { return m_asserted_formulas.empty(); } void collect_static_features(); void display(std::ostream & out) const; void display_ll(std::ostream & out, ast_mark & pp_visited) const; void collect_statistics(statistics & st) const; // TODO: improve precision of the following method. bool has_quantifiers() const { return m_has_quantifiers; } // ----------------------------------- // // Macros // // ----------------------------------- unsigned get_num_macros() const { return m_macro_manager.get_num_macros(); } unsigned get_first_macro_last_level() const { return m_macro_manager.get_first_macro_last_level(); } func_decl * get_macro_func_decl(unsigned i) const { return m_macro_manager.get_macro_func_decl(i); } func_decl * get_macro_interpretation(unsigned i, expr_ref & interp) const { return m_macro_manager.get_macro_interpretation(i, interp); } quantifier * get_macro_quantifier(func_decl * f) const { return m_macro_manager.get_macro_quantifier(f); } // auxiliary function used to create a logic context based on a model. void insert_macro(func_decl * f, quantifier * m, proof * pr) { m_macro_manager.insert(f, m, pr); } }; #endif /* ASSERTED_FORMULAS_H_ */