All Downloads are FREE. Search and download functionalities are using the official Maven repository.

z3-z3-4.13.0.src.ast.simplifiers.elim_unconstrained.h Maven / Gradle / Ivy

The newest version!
/*++
Copyright (c) 2022 Microsoft Corporation

Module Name:

    elim_unconstrained.h

Author:

    Nikolaj Bjorner (nbjorner) 2022-11-2.

--*/


#pragma once

#include "util/heap.h"
#include "ast/simplifiers/dependent_expr_state.h"
#include "ast/rewriter/th_rewriter.h"
#include "ast/converters/expr_inverter.h"


class elim_unconstrained : public dependent_expr_simplifier {

    friend class seq_simplifier;
    
    struct node {
        unsigned         m_refcount = 0;
        expr*            m_term = nullptr;
        expr*            m_orig = nullptr;
        proof*           m_proof = nullptr;
        bool             m_dirty = false;
        ptr_vector m_parents;
    };
    struct var_lt {
        elim_unconstrained& s;
        var_lt(elim_unconstrained& s) : s(s) {}
        bool operator()(int v1, int v2) const {
            return s.is_var_lt(v1, v2);
        }
    };
    struct stats {
        unsigned m_num_eliminated = 0;
        void reset() { m_num_eliminated = 0; }
    };
    expr_inverter            m_inverter;
    vector             m_nodes;
    var_lt                   m_lt;
    heap             m_heap;
    expr_ref_vector          m_trail;
    expr_ref_vector          m_args;
    stats                    m_stats;
    unsigned_vector          m_root;
    bool                     m_created_compound = false;
    bool                     m_enable_proofs = false;

    bool is_var_lt(int v1, int v2) const;
    bool is_node(unsigned n) const { return m_nodes.size() > n; }
    bool is_node(expr* t) const { return is_node(t->get_id()); }
    node& get_node(unsigned n) { return m_nodes[n]; }
    node const& get_node(unsigned n) const { return m_nodes[n]; }
    node& get_node(expr* t) { return m_nodes[root(t)]; }
    unsigned root(expr* t) const { return m_root[t->get_id()]; }
    node const& get_node(expr* t) const { return m_nodes[root(t)]; }
    unsigned get_refcount(expr* t) const { return get_node(t).m_refcount; }
    void inc_ref(expr* t) { ++get_node(t).m_refcount; if (is_uninterp_const(t)) m_heap.increased(root(t)); }
    void dec_ref(expr* t) { --get_node(t).m_refcount; if (is_uninterp_const(t)) m_heap.decreased(root(t)); }
    void freeze(expr* t);
    void freeze_rec(expr* r);
    void gc(expr* t);
    expr* get_parent(unsigned n) const;
    void init_terms(expr_ref_vector const& terms);
    void init_nodes();
    void eliminate();
    void reconstruct_terms();
    expr_ref reconstruct_term(node& n);
    void assert_normalized(vector& old_fmls);
    void update_model_trail(generic_model_converter& mc, vector const& old_fmls);
    void invalidate_parents(expr* e);
    
    
public:

    elim_unconstrained(ast_manager& m, dependent_expr_state& fmls);

    char const* name() const override { return "elim-unconstrained"; }

    void reduce() override;

    void collect_statistics(statistics& st) const override { st.update("elim-unconstrained", m_stats.m_num_eliminated); }

    void reset_statistics() override { m_stats.reset(); }
};




© 2015 - 2024 Weber Informatics LLC | Privacy Policy