feat(library/blast): improve trace messages

This commit is contained in:
Leonardo de Moura 2015-12-09 11:38:39 -08:00
parent a7f5d6603a
commit 6bbbc3d50e
7 changed files with 29 additions and 20 deletions

View file

@ -290,7 +290,7 @@ action_result recursor_action(hypothesis_idx hidx, name const & R) {
return action_result::failed(); // ill-formed recursor return action_result::failed(); // ill-formed recursor
save_state.commit(); save_state.commit();
lean_trace(name({"blast", "action"}), tout() << "recursor " << R << "\n";); lean_trace_action(tout() << "recursor " << R << "\n";);
if (new_goals.empty()) { if (new_goals.empty()) {
return action_result::solved(rec); return action_result::solved(rec);
} }

View file

@ -18,14 +18,14 @@ action_result assumption_action() {
for (hypothesis_idx hidx : s.get_head_related()) { for (hypothesis_idx hidx : s.get_head_related()) {
hypothesis const & h = s.get_hypothesis_decl(hidx); hypothesis const & h = s.get_hypothesis_decl(hidx);
if (is_def_eq(h.get_type(), target)) { if (is_def_eq(h.get_type(), target)) {
trace_action("assumption"); lean_trace_action(tout() << "assumption " << h << "\n";);
return action_result(h.get_self()); return action_result(h.get_self());
} }
} }
return action_result::failed(); return action_result::failed();
} }
/* Close branch IF h is of the form (H : a ~ a) where ~ is a reflexive relation */ /* Close branch IF h is of the form (H : not a ~ a) where ~ is a reflexive relation */
static optional<expr> try_not_refl_relation(hypothesis const & h) { static optional<expr> try_not_refl_relation(hypothesis const & h) {
expr p; expr p;
if (!is_not(h.get_type(), p)) if (!is_not(h.get_type(), p))
@ -62,15 +62,15 @@ action_result assumption_contradiction_actions(hypothesis_idx hidx) {
hypothesis const & h = s.get_hypothesis_decl(hidx); hypothesis const & h = s.get_hypothesis_decl(hidx);
expr const & type = h.get_type(); expr const & type = h.get_type();
if (blast::is_false(type)) { if (blast::is_false(type)) {
trace_action("contradiction"); lean_trace_action(tout() << "contradiction " << h << "\n";);
return action_result(b.mk_false_rec(s.get_target(), h.get_self())); return action_result(b.mk_false_rec(s.get_target(), h.get_self()));
} }
if (is_def_eq(type, s.get_target())) { if (is_def_eq(type, s.get_target())) {
trace_action("assumption"); lean_trace_action(tout() << "assumption " << h << "\n";);
return action_result(h.get_self()); return action_result(h.get_self());
} }
if (auto pr = try_not_refl_relation(h)) { if (auto pr = try_not_refl_relation(h)) {
trace_action("contradiction"); lean_trace_action(tout() << "contradiction " << h << "\n";);
return action_result(*pr); return action_result(*pr);
} }
expr p1 = type; expr p1 = type;
@ -82,7 +82,7 @@ action_result assumption_contradiction_actions(hypothesis_idx hidx) {
unsigned num_not2 = consume_not(p2); unsigned num_not2 = consume_not(p2);
if ((num_not1 % 2) != (num_not2 % 2)) { if ((num_not1 % 2) != (num_not2 % 2)) {
if (is_def_eq(p1, p2)) { if (is_def_eq(p1, p2)) {
trace_action("contradiction"); lean_trace_action(tout() << "contradiction " << h << " " << h2 << "\n";);
expr pr1 = h.get_self(); expr pr1 = h.get_self();
expr pr2 = h2.get_self(); expr pr2 = h2.get_self();
reduce_nots(pr1, num_not1); reduce_nots(pr1, num_not1);
@ -158,7 +158,7 @@ bool discard(hypothesis_idx hidx) {
action_result discard_action(hypothesis_idx hidx) { action_result discard_action(hypothesis_idx hidx) {
if (discard(hidx)) { if (discard(hidx)) {
curr_state().del_hypothesis(hidx); curr_state().del_hypothesis(hidx);
trace_action("discard"); lean_trace_action(tout() << "discard " << curr_state().get_hypothesis_decl(hidx) << "\n";);
return action_result::new_branch(); return action_result::new_branch();
} else { } else {
return action_result::failed(); return action_result::failed();

View file

@ -109,7 +109,7 @@ public:
m_lemmas = tail(m_lemmas); m_lemmas = tail(m_lemmas);
action_result r = try_lemma(lemma, m_prop_only); action_result r = try_lemma(lemma, m_prop_only);
if (!failed(r)) { if (!failed(r)) {
lean_trace(name({"blast", "action"}), tout() << m_action_name << " (next) " << lemma << "\n";); lean_trace_action(tout() << m_action_name << " (next) " << lemma << "\n";);
return r; return r;
} }
} }
@ -128,7 +128,7 @@ action_result backward_action_core(list<gexpr> const & lemmas, bool prop_only_br
// create choice point // create choice point
if (!cut && !empty(it)) if (!cut && !empty(it))
push_choice_point(choice_point(new backward_choice_point_cell(action_name, s, it, prop_only_branches))); push_choice_point(choice_point(new backward_choice_point_cell(action_name, s, it, prop_only_branches)));
lean_trace(name({"blast", "action"}), tout() << action_name << " " << H << "\n";); lean_trace_action(tout() << action_name << " " << H << "\n";);
return r; return r;
} }
curr_state() = s; curr_state() = s;

View file

@ -841,7 +841,7 @@ optional<unsigned> state::select_hypothesis_to_activate() {
} }
void state::activate_hypothesis(hypothesis_idx hidx) { void state::activate_hypothesis(hypothesis_idx hidx) {
lean_trace(name({"blast", "search"}), lean_trace_search(
hypothesis const & h = get_hypothesis_decl(hidx); hypothesis const & h = get_hypothesis_decl(hidx);
tout() << "activate " << h.get_name() << " : " << ppb(h.get_type()) << "\n";); tout() << "activate " << h.get_name() << " : " << ppb(h.get_type()) << "\n";);
m_branch.m_active.insert(hidx); m_branch.m_active.insert(hidx);

View file

@ -57,7 +57,7 @@ optional<expr> strategy_fn::search() {
m_init_num_choices = get_num_choice_points(); m_init_num_choices = get_num_choice_points();
unsigned init_proof_depth = curr_state().get_proof_depth(); unsigned init_proof_depth = curr_state().get_proof_depth();
unsigned max_depth = get_config().m_max_depth; unsigned max_depth = get_config().m_max_depth;
lean_trace(name({"blast", "search"}), tout() << "search upto depth " << max_depth << "\n";); lean_trace_search(tout() << "search upto depth " << max_depth << "\n";);
trace_curr_state(); trace_curr_state();
trace_target(); trace_target();
action_result r = next_action(); action_result r = next_action();

View file

@ -19,7 +19,7 @@ MK_THREAD_LOCAL_GET_DEF(expr, get_last_target);
void trace_target() { void trace_target() {
if (lean_is_trace_enabled(name({"blast", "search"})) && if (lean_is_trace_enabled(name({"blast", "search"})) &&
curr_state().get_target() != get_last_target()) { curr_state().get_target() != get_last_target()) {
lean_trace(name({"blast", "search"}), tout() << "target " << ppb(curr_state().get_target()) << "\n";); lean_trace_search(tout() << "target " << ppb(curr_state().get_target()) << "\n";);
get_last_target() = curr_state().get_target(); get_last_target() = curr_state().get_target();
} }
} }
@ -67,16 +67,15 @@ void trace_depth_nchoices() {
p.second == get_num_choice_points()) p.second == get_num_choice_points())
return; return;
p = mk_pair(curr_state().get_proof_depth(), get_num_choice_points()); p = mk_pair(curr_state().get_proof_depth(), get_num_choice_points());
lean_trace(name({"blast", "search"}), lean_trace_search(tout() << "depth: " << p.first << ", #choice: " << p.second << "\n";);
tout() << "depth: " << p.first << ", #choice: " << p.second << "\n";);
} }
void trace_search(char const * msg) { void trace_search(char const * msg) {
lean_trace(name({"blast", "search"}), tout() << msg << "\n";); lean_trace_search(tout() << msg << "\n";);
} }
void trace_action(char const * a) { void trace_action(char const * a) {
lean_trace(name({"blast", "action"}), tout() << a << "\n";); lean_trace_action(tout() << a << "\n";);
} }
void trace_curr_state_if(action_result r) { void trace_curr_state_if(action_result r) {
@ -89,4 +88,9 @@ io_state_stream const & operator<<(io_state_stream const & out, ppb const & e) {
out << tmp; out << tmp;
return out; return out;
} }
io_state_stream const & operator<<(io_state_stream const & out, hypothesis const & h) {
out << ppb(h.get_self());
return out;
}
}} }}

View file

@ -5,8 +5,9 @@ Released under Apache 2.0 license as described in the file LICENSE.
Author: Leonardo de Moura Author: Leonardo de Moura
*/ */
#include "library/trace.h" #include "library/trace.h"
#include "library/blast/action_result.h"
#include "library/io_state_stream.h" #include "library/io_state_stream.h"
#include "library/blast/action_result.h"
#include "library/blast/hypothesis.h"
namespace lean { namespace lean {
namespace blast { namespace blast {
@ -17,6 +18,9 @@ void trace_depth_nchoices();
void trace_action(char const * a); void trace_action(char const * a);
void trace_curr_state_if(action_result r); void trace_curr_state_if(action_result r);
#define lean_trace_action(Code) lean_trace(name({"blast", "action"}), Code)
#define lean_trace_search(Code) lean_trace(name({"blast", "search"}), Code)
/** \brief Helper class for pretty printing blast expressions. /** \brief Helper class for pretty printing blast expressions.
It uses state::to_kernel_expr to export a blast expression It uses state::to_kernel_expr to export a blast expression
into an expression that can be processed by the pretty printer */ into an expression that can be processed by the pretty printer */
@ -26,4 +30,5 @@ struct ppb {
}; };
io_state_stream const & operator<<(io_state_stream const & out, ppb const & e); io_state_stream const & operator<<(io_state_stream const & out, ppb const & e);
io_state_stream const & operator<<(io_state_stream const & out, hypothesis const & h);
}} }}