0148bb08fd
This strategy is based on ematching and congruence closure, but it uses the [simp] lemmas instead of [forward] lemmas.
114 lines
3.6 KiB
C++
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 << "'");
|
|
}
|
|
}
|
|
}}
|