feat(library/blast): add basic assumption action

This commit is contained in:
Leonardo de Moura 2015-11-08 18:09:31 -08:00
parent 6340b1ae5b
commit 78f1679b03
6 changed files with 49 additions and 3 deletions

View file

@ -1,2 +1,2 @@
add_library(blast OBJECT expr.cpp branch.cpp state.cpp blast.cpp add_library(blast OBJECT expr.cpp branch.cpp state.cpp blast.cpp
blast_tactic.cpp init_module.cpp simplifier.cpp) blast_tactic.cpp init_module.cpp simplifier.cpp assumption.cpp)

View file

@ -0,0 +1,23 @@
/*
Copyright (c) 2015 Microsoft Corporation. All rights reserved.
Released under Apache 2.0 license as described in the file LICENSE.
Author: Leonardo de Moura
*/
#include "library/blast/blast.h"
namespace lean {
namespace blast {
optional<expr> assumption_action() {
// TODO(Leo): this is a very naive implementation that just traverses the set of
// active hypothesis
branch const & b = main_branch();
expr const & target = b.get_target();
auto hidx = b.find_active_hypothesis([&](unsigned, hypothesis const & h) {
return is_def_eq(h.get_type(), target);
});
if (!hidx)
return none_expr();
return some_expr(b.get(*hidx)->get_value());
}
}}

View file

@ -0,0 +1,12 @@
/*
Copyright (c) 2015 Microsoft Corporation. All rights reserved.
Released under Apache 2.0 license as described in the file LICENSE.
Author: Leonardo de Moura
*/
#pragma once
#include "kernel/expr.h"
namespace lean {
namespace blast {
optional<expr> assumption_action();
}}

View file

@ -21,6 +21,7 @@ Author: Leonardo de Moura
#include "library/blast/expr.h" #include "library/blast/expr.h"
#include "library/blast/state.h" #include "library/blast/state.h"
#include "library/blast/blast.h" #include "library/blast/blast.h"
#include "library/blast/assumption.h"
#include "library/blast/blast_exception.h" #include "library/blast/blast_exception.h"
#ifndef LEAN_DEFAULT_BLAST_MAX_DEPTH #ifndef LEAN_DEFAULT_BLAST_MAX_DEPTH
@ -434,6 +435,8 @@ class blastenv {
if (activate_hypothesis()) { if (activate_hypothesis()) {
// TODO(Leo): we should probably eagerly simplify the activated hypothesis. // TODO(Leo): we should probably eagerly simplify the activated hypothesis.
return mk_pair(Continue, expr()); return mk_pair(Continue, expr());
} else if (auto pr = assumption_action()) {
return mk_pair(ClosedBranch, *pr);
} else { } else {
// TODO(Leo): add more actions... // TODO(Leo): add more actions...
return mk_pair(NoAction, expr()); return mk_pair(NoAction, expr());

View file

@ -21,7 +21,7 @@ class branch {
typedef hypothesis_idx_map<hypothesis_idx_set> forward_deps; typedef hypothesis_idx_map<hypothesis_idx_set> forward_deps;
typedef rb_map<double, unsigned, double_cmp> todo_queue; typedef rb_map<double, unsigned, double_cmp> todo_queue;
friend class state; friend class state;
unsigned m_next; unsigned m_next{0};
context m_context; context m_context;
// We break the set of hypotheses in m_context in 3 sets that are not necessarily disjoint: // We break the set of hypotheses in m_context in 3 sets that are not necessarily disjoint:
// - assumption // - assumption
@ -60,7 +60,7 @@ class branch {
void update_indices(unsigned hidx); void update_indices(unsigned hidx);
public: public:
branch():m_next(0) {} branch() {}
expr add_hypothesis(name const & n, expr const & type, expr const & value); expr add_hypothesis(name const & n, expr const & type, expr const & value);
expr add_hypothesis(expr const & type, expr const & value); expr add_hypothesis(expr const & type, expr const & value);
@ -75,6 +75,12 @@ public:
return get(href_index(h)); return get(href_index(h));
} }
void for_each_hypothesis(std::function<void(unsigned, hypothesis const &)> const & fn) const { m_context.for_each(fn); } void for_each_hypothesis(std::function<void(unsigned, hypothesis const &)> const & fn) const { m_context.for_each(fn); }
optional<unsigned> find_active_hypothesis(std::function<bool(unsigned, hypothesis const &)> const & fn) const { // NOLINT
return m_active.find_if([&](unsigned hidx) {
return fn(hidx, *get(hidx));
});
}
/** \brief Activate the next hypothesis in the TODO queue, return none if the TODO queue is empty. */ /** \brief Activate the next hypothesis in the TODO queue, return none if the TODO queue is empty. */
optional<unsigned> activate_hypothesis(); optional<unsigned> activate_hypothesis();

View file

@ -0,0 +1,2 @@
example (a b : Prop) (Ha : a) (Hb : b) : a :=
by blast