3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2025-04-29 11:55:51 +00:00

working on mam

This commit is contained in:
Nikolaj Bjorner 2021-01-25 17:54:53 -08:00
parent f33d6f89b9
commit 4b6d7ca097
15 changed files with 807 additions and 209 deletions

71
src/sat/smt/q_mam.h Normal file
View file

@ -0,0 +1,71 @@
/*++
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 solver;
};
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() {}
public:
static mam * mk(euf::solver& ctx, ematch& em);
virtual ~mam() {}
virtual void add_pattern(quantifier * q, app * mp) = 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 reset() = 0;
virtual std::ostream& display(std::ostream& out) = 0;
virtual bool check_missing_instances() = 0;
virtual void on_match(quantifier * qa, app * pat, unsigned num_bindings, enode * const * bindings, unsigned max_generation) = 0;
static void ground_subterms(expr* e, ptr_vector<app>& ground);
};
};