/* 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 #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/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 apply_preprocess() { return preprocess_and_then([]() { return none_expr(); })(); } static optional apply_simp() { flet set(get_config().m_simp, true); return mk_simplify_using_hypotheses_strategy()(); } static optional apply_simp_nohyps() { flet set(get_config().m_simp, true); return mk_simplify_all_strategy()(); } static optional apply_simple() { return preprocess_and_then(mk_simple_strategy())(); } static optional apply_cc() { flet set(get_config().m_cc, true); return mk_debug_pre_action_strategy(assert_cc_action)(); } static optional apply_ematch() { flet set(get_config().m_ematch, true); return mk_debug_action_strategy([](hypothesis_idx hidx) { Try(unit_propagate(hidx)); TrySolve(assert_cc_action(hidx)); return action_result::new_branch(); }, unit_propagate, ematch_action)(); } optional 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 == "cc") { return apply_cc(); } else if (s_name == "ematch") { return apply_ematch(); } else { // TODO(Leo): add more builtin strategies return apply_simple(); } } }}