chore(library/tactic): remove simp

This commit is contained in:
Leonardo de Moura 2018-08-23 11:04:52 -07:00
parent 9b4f59e511
commit ef27df8907
4 changed files with 1 additions and 1521 deletions

View file

@ -6,5 +6,5 @@ add_library(tactic OBJECT occurrences.cpp kabstract.cpp tactic_state.cpp
induction_tactic.cpp cases_tactic.cpp
generalize_tactic.cpp rewrite_tactic.cpp unfold_tactic.cpp
hsubstitution.cpp gexpr.cpp elaborate.cpp init_module.cpp
simp_result.cpp eval.cpp simp_lemmas.cpp eqn_lemmas.cpp dsimplify.cpp simplify.cpp
simp_result.cpp eval.cpp simp_lemmas.cpp eqn_lemmas.cpp dsimplify.cpp
destruct_tactic.cpp elaborator_exception.cpp tactic_evaluator.cpp)

View file

@ -27,7 +27,6 @@ Author: Leonardo de Moura
#include "library/tactic/simp_lemmas.h"
#include "library/tactic/eqn_lemmas.h"
#include "library/tactic/dsimplify.h"
#include "library/tactic/simplify.h"
#include "library/tactic/destruct_tactic.h"
namespace lean {
@ -50,7 +49,6 @@ void initialize_tactic_module() {
initialize_generalize_tactic();
initialize_rewrite_tactic();
initialize_unfold_tactic();
initialize_simplify();
initialize_elaborate();
initialize_eval();
initialize_simp_lemmas();
@ -65,7 +63,6 @@ void finalize_tactic_module() {
finalize_simp_lemmas();
finalize_eval();
finalize_elaborate();
finalize_simplify();
finalize_unfold_tactic();
finalize_rewrite_tactic();
finalize_generalize_tactic();

File diff suppressed because it is too large Load diff

View file

@ -1,197 +0,0 @@
/*
Copyright (c) 2015 Daniel Selsam. All rights reserved.
Released under Apache 2.0 license as described in the file LICENSE.
Author: Daniel Selsam, Leonardo de Moura
*/
#pragma once
#include "kernel/expr_pair.h"
#include "library/type_context.h"
#include "library/defeq_canonizer.h"
#include "library/vm/vm.h"
#include "library/tactic/simp_lemmas.h"
#include "library/tactic/simp_result.h"
namespace lean {
/*
structure simp_config :=
(max_steps : nat)
(contextual : bool)
(lift_eq : bool)
(canonize_instances : bool)
(canonize_proofs : bool)
(use_axioms : bool)
(zeta : bool)
(beta : bool)
(eta : bool)
(proj : bool)
(iota : bool)
(iota_eqn : bool)
(constructor_eq : bool)
(single_pass : bool)
(fail_if_unchaged : bool)
(memoize : bool)
*/
struct simp_config {
unsigned m_max_steps;
bool m_contextual;
bool m_lift_eq;
bool m_canonize_instances;
bool m_canonize_proofs;
bool m_use_axioms;
bool m_zeta;
bool m_beta;
bool m_eta;
bool m_proj;
bool m_iota;
bool m_iota_eqn;
bool m_constructor_eq;
bool m_single_pass;
bool m_fail_if_unchanged;
bool m_memoize;
simp_config();
simp_config(vm_obj const & o);
};
/* Core simplification procedure. It performs the following tasks:
1- Manages the cache;
2- Applies congruence lemmas;
3- Canonizes instances & proofs;
4- Manages contextual rewriting
This is a base class for many simplification strategies.
Its behavior can be configured by overriding its virtual methods.
This class does *not* apply any simp lemma, nor it tries to
put subterms in weak-head-normal-form.
This class also does *not* use axioms. For example, it will
not use funext to go inside lambda terms. This feature is provided
by subclasses.
Remark: it is debatable whether the options m_lift_eq, m_canonize_instances and
m_canonize_proofs really need to be here. They may be moved to subclasses in the
future.
*/
class simplify_core_fn {
protected:
typedef expr_map<simp_result> simplify_cache;
type_context_old & m_ctx;
defeq_canonizer m_defeq_canonizer;
name m_rel;
simp_lemmas m_slss;
simplify_cache m_cache;
/* Logging */
unsigned m_num_steps{0};
bool m_need_restart{false};
/* Options */
simp_config m_cfg;
simp_result join(simp_result const & r1, simp_result const & r2);
void inc_num_steps();
bool is_dependent_fn(expr const & f);
bool should_defeq_canonize() const {
return m_cfg.m_canonize_instances || m_cfg.m_canonize_proofs;
}
bool instantiate_emetas(tmp_type_context & tmp_tctx, list <expr> const & emetas,
list<bool> const & instances);
simp_result lift_from_eq(simp_result const & r_eq);
simp_lemmas add_to_slss(simp_lemmas const & slss, buffer<expr> const & ls);
expr remove_unnecessary_casts(expr const & e);
expr defeq_canonize_args_step(expr const & e);
/* Congruence */
simp_result try_user_congrs(expr const & e);
simp_result try_user_congr(expr const & e, simp_lemma const & cr);
optional<simp_result> try_auto_eq_congr(expr const & e);
simp_result congr_fun_arg(simp_result const & r_f, simp_result const & r_arg);
simp_result congr(simp_result const & r_f, simp_result const & r_arg);
simp_result congr_fun(simp_result const & r_f, expr const & arg);
simp_result congr_arg(expr const & f, simp_result const & r_arg);
simp_result congr_funs(simp_result const & r_f, buffer<expr> const & args);
/* Rewriting
Remark: the rewriting methods are implemented on this base class once and for all,
but used in subclasses.*/
simp_result rewrite(expr const & e);
simp_result rewrite(expr const & e, simp_lemma const & sl);
simp_result rewrite_core(expr const & e, simp_lemma const & sl);
simp_result propext_rewrite(expr const & e);
/* Simplify equalities of the form (c ... = c' ...) where `c` and `c'` are
constructors.
Return true if `r` was simplified. */
bool simplify_constructor_eq_constructor(simp_result & r);
/* Visitors */
virtual optional<pair<simp_result, bool>> pre(expr const & e, optional<expr> const & parent);
virtual optional<pair<simp_result, bool>> post(expr const & e, optional<expr> const & parent);
virtual optional<expr> prove(expr const & goal);
friend class simp_prover;
simp_result visit_fn(expr const & e);
virtual simp_result visit_lambda(expr const & e);
virtual simp_result visit_pi(expr const & e);
virtual simp_result visit_let(expr const & e);
virtual simp_result visit_app(expr const & e);
virtual simp_result visit_macro(expr const & e);
virtual simp_result visit(expr const & e, optional<expr> const & parent);
simp_result simplify(expr const & e);
/* Apply conversion rules: beta, projection */
expr reduce(expr e);
simp_result reduce(simp_result r);
bool match(tmp_type_context & ctx, simp_lemma const & sl, expr const & t);
public:
simplify_core_fn(type_context_old & ctx, defeq_canonizer::state & dcs, simp_lemmas const & slss,
simp_config const & cfg);
environment const & env() const;
simp_result operator()(name const & rel, expr const & e);
optional<expr> prove_by_simp(name const & rel, expr const & e);
};
/* Extend simplify_core_fn functionality by assuming function
extensionality and propositional extensionality. */
class simplify_ext_core_fn : public simplify_core_fn {
protected:
simp_result forall_congr(expr const & e);
simp_result imp_congr(expr const & e);
virtual simp_result visit_lambda(expr const & e) override;
virtual simp_result visit_pi(expr const & e) override;
virtual simp_result visit_let(expr const & e) override;
virtual simp_result visit_macro(expr const & e) override;
public:
simplify_ext_core_fn(type_context_old & ctx, defeq_canonizer::state & dcs, simp_lemmas const & slss,
simp_config const & cfg);
};
/* Default (bottom-up) simplifier: reduce projections, apply simplification lemmas,
and use itself to discharge hypotheses. */
class simplify_fn : public simplify_ext_core_fn {
protected:
name_set m_to_unfold;
virtual optional<pair<simp_result, bool>> pre(expr const & e, optional<expr> const & parent) override;
virtual optional<pair<simp_result, bool>> post(expr const & e, optional<expr> const & parent) override;
virtual optional<expr> prove(expr const & e) override;
public:
simplify_fn(type_context_old & ctx, defeq_canonizer::state & dcs, simp_lemmas const & slss, names const & to_unfold,
simp_config const & cfg):
simplify_ext_core_fn(ctx, dcs, slss, cfg),
m_to_unfold(to_name_set(to_unfold)) {}
};
void initialize_simplify();
void finalize_simplify();
}