fix(library/tactic/inversion_tactic): fix bug in 'cases' tactic for HoTT library
This commit is contained in:
parent
d2958044fd
commit
1d79cb9c07
4 changed files with 39 additions and 1 deletions
|
@ -35,7 +35,7 @@ optional<expr> apply_eq_rec_eq(type_checker & tc, io_state const & ios, list<exp
|
||||||
if (args.size() != 6)
|
if (args.size() != 6)
|
||||||
return none_expr();
|
return none_expr();
|
||||||
expr const & p = args[5];
|
expr const & p = args[5];
|
||||||
if (!is_local(p) || !is_eq_a_a(mlocal_type(p)))
|
if (!is_local(p) || !is_eq_a_a(tc, mlocal_type(p)))
|
||||||
return none_expr();
|
return none_expr();
|
||||||
expr const & A = args[0];
|
expr const & A = args[0];
|
||||||
auto is_hset_A = mk_hset_instance(tc, ios, ctx, A);
|
auto is_hset_A = mk_hset_instance(tc, ios, ctx, A);
|
||||||
|
|
|
@ -342,6 +342,17 @@ bool is_eq_a_a(expr const & e) {
|
||||||
return args.size() == 3 && args[1] == args[2];
|
return args.size() == 3 && args[1] == args[2];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool is_eq_a_a(type_checker & tc, expr const & e) {
|
||||||
|
if (!is_eq(e))
|
||||||
|
return false;
|
||||||
|
buffer<expr> args;
|
||||||
|
get_app_args(e, args);
|
||||||
|
if (args.size() != 3)
|
||||||
|
return false;
|
||||||
|
pair<bool, constraint_seq> d = tc.is_def_eq(args[1], args[2]);
|
||||||
|
return d.first && !d.second;
|
||||||
|
}
|
||||||
|
|
||||||
void mk_telescopic_eq(type_checker & tc, buffer<expr> const & t, buffer<expr> const & s, buffer<expr> & eqs) {
|
void mk_telescopic_eq(type_checker & tc, buffer<expr> const & t, buffer<expr> const & s, buffer<expr> & eqs) {
|
||||||
lean_assert(t.size() == s.size());
|
lean_assert(t.size() == s.size());
|
||||||
lean_assert(std::all_of(s.begin(), s.end(), is_local));
|
lean_assert(std::all_of(s.begin(), s.end(), is_local));
|
||||||
|
|
|
@ -101,7 +101,10 @@ expr mk_eq(type_checker & tc, expr const & lhs, expr const & rhs);
|
||||||
expr mk_refl(type_checker & tc, expr const & a);
|
expr mk_refl(type_checker & tc, expr const & a);
|
||||||
bool is_eq_rec(expr const & e);
|
bool is_eq_rec(expr const & e);
|
||||||
bool is_eq(expr const & e);
|
bool is_eq(expr const & e);
|
||||||
|
/** \brief Return true iff \c e is of the form (eq A a a) */
|
||||||
bool is_eq_a_a(expr const & e);
|
bool is_eq_a_a(expr const & e);
|
||||||
|
/** \brief Return true iff \c e is of the form (eq A a a') where \c a and \c a' are definitionally equal */
|
||||||
|
bool is_eq_a_a(type_checker & tc, expr const & e);
|
||||||
|
|
||||||
/** \brief Create a telescope equality for HoTT library.
|
/** \brief Create a telescope equality for HoTT library.
|
||||||
This procedure assumes eq supports dependent elimination.
|
This procedure assumes eq supports dependent elimination.
|
||||||
|
|
24
tests/lean/hott/inv_bug.hlean
Normal file
24
tests/lean/hott/inv_bug.hlean
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
open nat
|
||||||
|
open eq.ops
|
||||||
|
|
||||||
|
inductive even : nat → Type :=
|
||||||
|
even_zero : even zero,
|
||||||
|
even_succ_of_odd : ∀ {a}, odd a → even (succ a)
|
||||||
|
with odd : nat → Type :=
|
||||||
|
odd_succ_of_even : ∀ {a}, even a → odd (succ a)
|
||||||
|
|
||||||
|
example : even 1 → empty :=
|
||||||
|
begin
|
||||||
|
intro He1,
|
||||||
|
cases He1 with (a, Ho0),
|
||||||
|
cases Ho0
|
||||||
|
end
|
||||||
|
|
||||||
|
example : even 3 → empty :=
|
||||||
|
begin
|
||||||
|
intro He3,
|
||||||
|
cases He3 with (a, Ho2),
|
||||||
|
cases Ho2 with (a, He1),
|
||||||
|
cases He1 with (a, Ho0),
|
||||||
|
cases Ho0
|
||||||
|
end
|
Loading…
Reference in a new issue