feat(library/blast): add basic assumption action
This commit is contained in:
parent
6340b1ae5b
commit
78f1679b03
6 changed files with 49 additions and 3 deletions
|
@ -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)
|
||||||
|
|
23
src/library/blast/assumption.cpp
Normal file
23
src/library/blast/assumption.cpp
Normal 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());
|
||||||
|
}
|
||||||
|
}}
|
12
src/library/blast/assumption.h
Normal file
12
src/library/blast/assumption.h
Normal 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();
|
||||||
|
}}
|
|
@ -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());
|
||||||
|
|
|
@ -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();
|
||||||
|
|
||||||
|
|
2
tests/lean/run/blast1.lean
Normal file
2
tests/lean/run/blast1.lean
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
example (a b : Prop) (Ha : a) (Hb : b) : a :=
|
||||||
|
by blast
|
Loading…
Reference in a new issue