From 08052c1988b1e77dc7665697dbd98467fd0013f1 Mon Sep 17 00:00:00 2001 From: Leonardo de Moura Date: Tue, 8 Dec 2015 19:52:32 -0800 Subject: [PATCH] feat(library/blast): improve tracing --- src/library/blast/blast.cpp | 2 +- src/library/blast/forward/ematch.cpp | 3 +-- src/library/blast/state.cpp | 5 +++++ src/library/blast/strategy.cpp | 3 +++ src/library/blast/trace.cpp | 4 +--- 5 files changed, 11 insertions(+), 6 deletions(-) diff --git a/src/library/blast/blast.cpp b/src/library/blast/blast.cpp index 94e647d4b..ff788df06 100644 --- a/src/library/blast/blast.cpp +++ b/src/library/blast/blast.cpp @@ -1148,7 +1148,7 @@ optional blast_goal(environment const & env, io_state const & ios, list #include "util/interrupt.h" -#include "library/trace.h" #include "library/constants.h" #include "library/idx_metavar.h" #include "library/head_map.h" @@ -305,7 +304,7 @@ struct ematch_fn { if (!m_new_instances) { trace_action("ematch"); } - lean_trace(name({"blast", "ematch"}), tout() << "ematch_instance: " << ppb(new_inst) << "\n";); + lean_trace(name({"blast", "ematch"}), tout() << "instance: " << ppb(new_inst) << "\n";); m_new_instances = true; expr new_proof = m_ctx->instantiate_uvars_mvars(lemma.m_proof); m_ext.m_instances.insert(new_inst); diff --git a/src/library/blast/state.cpp b/src/library/blast/state.cpp index c49024a5e..837e8310d 100644 --- a/src/library/blast/state.cpp +++ b/src/library/blast/state.cpp @@ -6,12 +6,14 @@ Author: Leonardo de Moura */ #include #include +#include "library/trace.h" #include "kernel/instantiate.h" #include "kernel/abstract.h" #include "kernel/for_each_fn.h" #include "kernel/replace_fn.h" #include "library/replace_visitor.h" #include "library/blast/util.h" +#include "library/blast/trace.h" #include "library/blast/blast.h" #include "library/blast/state.h" @@ -840,6 +842,9 @@ optional state::select_hypothesis_to_activate() { } void state::activate_hypothesis(hypothesis_idx hidx) { + lean_trace(name({"blast", "search"}), + hypothesis const & h = get_hypothesis_decl(hidx); + tout() << "activate: " << h.get_name() << " : " << ppb(h.get_type()) << "\n";); m_branch.m_active.insert(hidx); update_indices(hidx); } diff --git a/src/library/blast/strategy.cpp b/src/library/blast/strategy.cpp index e3eb8f112..16517b6b5 100644 --- a/src/library/blast/strategy.cpp +++ b/src/library/blast/strategy.cpp @@ -93,6 +93,9 @@ optional strategy_fn::search() { r = next_action(); break; } + lean_trace(name({"blast", "search"}), + tout() << "depth [" << curr_state().get_proof_depth() << "], #choice: " + << get_num_choice_points() << "\n";); trace_curr_state_if(r); } } diff --git a/src/library/blast/trace.cpp b/src/library/blast/trace.cpp index 5a5b9b41f..b6302eb9e 100644 --- a/src/library/blast/trace.cpp +++ b/src/library/blast/trace.cpp @@ -14,9 +14,7 @@ Author: Leonardo de Moura namespace lean { namespace blast { void trace_curr_state() { - lean_trace(name({"blast", "state"}), - tout() << "[" << curr_state().get_proof_depth() << "], #choice: " << get_num_choice_points() << "\n"; - curr_state().display(tout());); + lean_trace(name({"blast", "state"}), tout() << "\n"; curr_state().display(tout());); } void trace_search(char const * msg) {