lean2/src/library/blast/strategies/portfolio.cpp
Leonardo de Moura 0148bb08fd feat(library/blast): add 'ematch_simp' strategy for blast and msimp shortcut for it.
This strategy is based on ematching and congruence closure, but it uses
the [simp] lemmas instead of [forward] lemmas.
2015-12-29 20:04:31 -08:00

114 lines
3.6 KiB
C++

/*
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 <string>
#include "util/sstream.h"
#include "library/blast/actions/assert_cc_action.h"
#include "library/blast/simplifier/simplifier_strategies.h"
#include "library/blast/unit/unit_actions.h"
#include "library/blast/forward/ematch.h"
#include "library/blast/backward/backward_action.h"
#include "library/blast/backward/backward_strategy.h"
#include "library/blast/grinder/grinder_strategy.h"
#include "library/blast/strategies/simple_strategy.h"
#include "library/blast/strategies/preprocess_strategy.h"
#include "library/blast/strategies/debug_action_strategy.h"
namespace lean {
namespace blast {
static optional<expr> apply_preprocess() {
return preprocess_and_then([]() { return none_expr(); })();
}
static optional<expr> apply_simp() {
flet<bool> set(get_config().m_simp, true);
return mk_simplify_using_hypotheses_strategy()();
}
static optional<expr> apply_simp_nohyps() {
flet<bool> set(get_config().m_simp, true);
return mk_simplify_all_strategy()();
}
static optional<expr> apply_simple() {
return preprocess_and_then(mk_simple_strategy())();
}
static optional<expr> apply_cc() {
flet<bool> set(get_config().m_cc, true);
return mk_debug_pre_action_strategy(assert_cc_action)();
}
static optional<expr> apply_ematch() {
flet<bool> set(get_config().m_ematch, true);
return mk_debug_action_strategy(assert_cc_action,
unit_propagate,
ematch_action)();
}
static optional<expr> apply_ematch_simp() {
flet<bool> set(get_config().m_ematch, true);
return mk_debug_action_strategy(assert_cc_action,
unit_propagate,
ematch_simp_action)();
}
static optional<expr> apply_constructor() {
return mk_debug_action_strategy([]() { return constructor_action(); })();
}
static optional<expr> apply_backward() {
return preprocess_and_then(mk_backward_strategy())();
}
static optional<expr> apply_unit() {
return mk_debug_action_strategy(unit_preprocess,
unit_propagate,
[]() { return action_result::failed(); })();
}
static optional<expr> apply_grind() {
return preprocess_and_then(grind_and_then([]() { return none_expr(); }))();
}
static optional<expr> apply_core_grind() {
return grind_and_then([]() { return none_expr(); })();
}
optional<expr> apply_strategy() {
std::string s_name(get_config().m_strategy);
if (s_name == "preprocess") {
return apply_preprocess();
} else if (s_name == "simp") {
return apply_simp();
} else if (s_name == "simp_nohyps") {
return apply_simp_nohyps();
} else if (s_name == "simple") {
return apply_simple();
} else if (s_name == "all") {
// TODO(Leo):
return apply_simple();
} else if (s_name == "cc") {
return apply_cc();
} else if (s_name == "grind") {
return apply_grind();
} else if (s_name == "core_grind") {
return apply_core_grind();
} else if (s_name == "ematch") {
return apply_ematch();
} else if (s_name == "ematch_simp") {
return apply_ematch_simp();
} else if (s_name == "constructor") {
return apply_constructor();
} else if (s_name == "unit") {
return apply_unit();
} else if (s_name == "backward") {
return apply_backward();
} else {
throw exception(sstream() << "unknown blast strategy '" << s_name << "'");
}
}
}}