mirror of
https://github.com/Z3Prover/z3
synced 2025-08-04 02:10:23 +00:00
move mam to euf
This commit is contained in:
parent
0e4c033e30
commit
9a299eb9ff
6 changed files with 72 additions and 56 deletions
3915
src/ast/euf/euf_mam.cpp
Normal file
3915
src/ast/euf/euf_mam.cpp
Normal file
File diff suppressed because it is too large
Load diff
90
src/ast/euf/euf_mam.h
Normal file
90
src/ast/euf/euf_mam.h
Normal file
|
@ -0,0 +1,90 @@
|
|||
/*++
|
||||
Copyright (c) 2006 Microsoft Corporation
|
||||
|
||||
Module Name:
|
||||
|
||||
euf_mam.h
|
||||
|
||||
Abstract:
|
||||
|
||||
Matching Abstract Machine
|
||||
|
||||
Author:
|
||||
|
||||
Leonardo de Moura (leonardo) 2007-02-13.
|
||||
Nikolaj Bjorner (nbjorner) 2021-01-22.
|
||||
|
||||
--*/
|
||||
#pragma once
|
||||
|
||||
#include "ast/ast.h"
|
||||
#include "ast/euf/euf_egraph.h"
|
||||
#include <functional>
|
||||
|
||||
namespace euf {
|
||||
|
||||
class mam_solver {
|
||||
public:
|
||||
virtual ~mam_solver() = default;
|
||||
virtual trail_stack& get_trail() = 0;
|
||||
virtual region& get_region() = 0;
|
||||
virtual ast_manager& get_manager() = 0;
|
||||
virtual egraph& get_egraph() = 0;
|
||||
virtual bool is_relevant(euf::enode* n) const = 0;
|
||||
virtual bool resource_limits_exceeded() const = 0;
|
||||
};
|
||||
|
||||
class on_binding_callback {
|
||||
public:
|
||||
virtual ~on_binding_callback() = default;
|
||||
virtual void on_binding(quantifier* q, app* pat, euf::enode* const* binding, unsigned max_generation, unsigned min_gen, unsigned max_gen) = 0;
|
||||
};
|
||||
};
|
||||
|
||||
namespace q {
|
||||
|
||||
typedef euf::enode enode;
|
||||
typedef euf::egraph egraph;
|
||||
typedef euf::enode_vector enode_vector;
|
||||
|
||||
class ematch;
|
||||
|
||||
/**
|
||||
\brief Matching Abstract Machine (MAM)
|
||||
*/
|
||||
class mam {
|
||||
friend class mam_impl;
|
||||
|
||||
mam() = default;
|
||||
|
||||
public:
|
||||
|
||||
static mam * mk(euf::mam_solver& ctx, euf::on_binding_callback& em);
|
||||
|
||||
virtual ~mam() = default;
|
||||
|
||||
virtual void add_pattern(quantifier * q, app * mp) = 0;
|
||||
|
||||
virtual void add_node(enode * n, bool lazy) = 0;
|
||||
|
||||
virtual void propagate() = 0;
|
||||
|
||||
virtual bool can_propagate() const = 0;
|
||||
|
||||
virtual void rematch(bool use_irrelevant = false) = 0;
|
||||
|
||||
virtual void on_merge(enode * root, enode * other) = 0;
|
||||
|
||||
virtual void on_match(quantifier * qa, app * pat, unsigned num_bindings, enode * const * bindings, unsigned max_generation) = 0;
|
||||
|
||||
virtual void reset() = 0;
|
||||
|
||||
virtual std::ostream& display(std::ostream& out) = 0;
|
||||
|
||||
virtual bool check_missing_instances() = 0;
|
||||
|
||||
static void ground_subterms(expr* e, ptr_vector<app>& ground);
|
||||
|
||||
};
|
||||
};
|
||||
|
Loading…
Add table
Add a link
Reference in a new issue