mirror of
https://github.com/Z3Prover/z3
synced 2025-07-19 10:52:02 +00:00
mbp (#4741)
* adding dt-solver Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com> * dt Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com> * move mbp to self-contained module Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com> * files Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com> * Create CMakeLists.txt * dt Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com> * rename to bool_var2expr to indicate type class * mbp * na * add projection * na * na * na * na * na Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com> * deps Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com> * testing arith/q * na * newline for model printing Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com>
This commit is contained in:
parent
e5cc613bf1
commit
72d407a49f
51 changed files with 903 additions and 618 deletions
|
@ -23,8 +23,11 @@ Author:
|
|||
namespace euf {
|
||||
|
||||
void solver::update_model(model_ref& mdl) {
|
||||
for (auto* mb : m_solvers)
|
||||
mb->init_model();
|
||||
deps_t deps;
|
||||
m_values.reset();
|
||||
m_values2root.reset();
|
||||
collect_dependencies(deps);
|
||||
deps.topological_sort();
|
||||
dependencies2values(deps, mdl);
|
||||
|
@ -117,7 +120,7 @@ namespace euf {
|
|||
}
|
||||
if (is_app(e) && to_app(e)->get_family_id() == m.get_basic_family_id())
|
||||
continue;
|
||||
sat::bool_var v = si.to_bool_var(e);
|
||||
sat::bool_var v = get_enode(e)->bool_var();
|
||||
SASSERT(v != sat::null_bool_var);
|
||||
switch (s().value(v)) {
|
||||
case l_true:
|
||||
|
@ -131,7 +134,6 @@ namespace euf {
|
|||
}
|
||||
continue;
|
||||
}
|
||||
TRACE("euf", tout << "value for " << mk_bounded_pp(e, m) << "\n";);
|
||||
sort* srt = m.get_sort(e);
|
||||
if (m.is_uninterp(srt))
|
||||
user_sort.add(id, srt);
|
||||
|
@ -186,11 +188,12 @@ namespace euf {
|
|||
// TODO
|
||||
}
|
||||
|
||||
obj_map<expr,enode*> const& solver::values2root() {
|
||||
m_values2root.reset();
|
||||
obj_map<expr,enode*> const& solver::values2root() {
|
||||
if (!m_values2root.empty())
|
||||
return m_values2root;
|
||||
for (enode* n : m_egraph.nodes())
|
||||
if (n->is_root())
|
||||
m_values2root.insert(m_values.get(n->get_root_id()), n);
|
||||
if (n->is_root() && m_values.get(n->get_expr_id()))
|
||||
m_values2root.insert(m_values.get(n->get_expr_id()), n);
|
||||
return m_values2root;
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue