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

z3-z3-4.12.6.src.ast.pattern.expr_pattern_match.h Maven / Gradle / Ivy

There is a newer version: 4.13.0.1
Show newest version
/*++
Copyright (c) 2007 Microsoft Corporation

Module Name:

    expr_pattern_match.h

Abstract:

    Search for opportune pattern matching utilities.

Author:

    Nikolaj Bjorner (nbjorner) 2007-04-10
    Leonardo (leonardo)

Notes:

--*/
#pragma once

#include "ast/ast.h"
#include "util/map.h"

class expr_pattern_match {

    enum instr_kind {
        BACKTRACK,
        BIND,
        BIND_AC,
        BIND_C,
        CHOOSE_AC,
        CHOOSE_C,
        SET_VAR,
        CHECK_VAR,
        CHECK_TERM,
        SET_BOUND,
        CHECK_BOUND,        
        YIELD
    };

    struct instr {
        instr(instr_kind k) : m_kind(k) {}
        instr(instr_kind k, unsigned o, unsigned next, app* app, unsigned count):
            m_kind(k), m_offset(o), m_next(next), m_app(app), m_count(count) {}

        instr_kind      m_kind;
        unsigned        m_offset{ 0 };
        unsigned        m_next{ 0 };
        app*            m_app{ nullptr };
        expr*           m_pat{ nullptr };
        unsigned        m_reg{ 0 };
        unsigned        m_other_reg{ 0 };
        unsigned        m_count{ 0 };
        unsigned        m_num_bound{ 0 };
    };

    typedef obj_map subst;
    typedef obj_map bound;

    struct inst_proc {
        ast_manager&    m_manager;
        expr_ref_vector m_pinned;
        subst&          m_subst;
        bound&          m_bound;
        obj_map m_memoize;
        ptr_vector& m_regs;
        
        
        inst_proc(ast_manager& m, subst& s, bound& b, ptr_vector& regs) : 
            m_manager(m), m_pinned(m), m_subst(s), m_bound(b), m_regs(regs) {}
                

        void operator()(ast* a) {
        }

        void operator()(expr* a) {
            m_memoize.insert(a, a);
        }

        void operator()(var* v) {
            m_memoize.insert(v, m_bound[v]);
        }
                
        void operator()(app * n) {  
            unsigned r;
            ptr_vector args;
            unsigned num_args     = n->get_num_args();
            func_decl * decl = n->get_decl();
            expr* result;
            if (m_subst.find(decl, r)) {
                decl = to_app(m_regs[r])->get_decl();
            }
            for (expr* arg : *n) {
                arg = m_memoize[arg];
                args.push_back(arg);
            }
            if (m_manager.is_pattern(n)) {
                result = m_manager.mk_pattern(num_args, reinterpret_cast(args.data()));
            }
            else {
                result = m_manager.mk_app(decl, num_args, args.data());
            }
            m_pinned.push_back(result);
            m_memoize.insert(n, result);
        }
    };

    ast_manager &                 m_manager;
    quantifier_ref_vector         m_precompiled;
    unsigned_vector               m_first_instrs;
    svector                m_instrs;
    ptr_vector              m_regs;
    ptr_vector               m_bound_dom;
    ptr_vector               m_bound_rng;

 public:
    expr_pattern_match(ast_manager & manager);
    ~expr_pattern_match();
    bool match_quantifier(quantifier * qf, app_ref_vector & patterns, unsigned & weight);
    bool match_quantifier_index(quantifier* qf, app_ref_vector & patterns, unsigned& index);
    unsigned initialize(quantifier* qf);
    void initialize(char const * database);
    void display(std::ostream& out) const;

 private:
    bool match_quantifier(unsigned i, quantifier * qf, app_ref_vector & patterns, unsigned & weight);
    void instantiate(expr* a, unsigned num_bound, subst& s, expr_ref& result);
    void compile(expr* q);
    bool match(expr* a, unsigned init, subst& s);
    bool match_decl(func_decl const * pat, func_decl const * d) const;
    bool is_var(func_decl* d);
    void display(std::ostream& out, instr const& pc) const;
};





© 2015 - 2024 Weber Informatics LLC | Privacy Policy