2015-04-04 00:20:19 -04:00
|
|
|
/-
|
|
|
|
Copyright (c) 2015 Floris van Doorn. All rights reserved.
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
Authors: Floris van Doorn
|
|
|
|
|
2015-04-06 21:01:08 -04:00
|
|
|
Declaration of suspension
|
2015-04-04 00:20:19 -04:00
|
|
|
-/
|
|
|
|
|
2015-06-03 21:41:21 -04:00
|
|
|
import .pushout types.pointed
|
2015-04-04 00:20:19 -04:00
|
|
|
|
2015-06-03 21:41:21 -04:00
|
|
|
open pushout unit eq equiv equiv.ops pointed
|
2015-04-04 00:20:19 -04:00
|
|
|
|
2015-04-10 20:33:33 -04:00
|
|
|
definition suspension (A : Type) : Type := pushout (λ(a : A), star.{0}) (λ(a : A), star.{0})
|
2015-04-04 00:20:19 -04:00
|
|
|
|
|
|
|
namespace suspension
|
2015-04-19 17:56:24 -04:00
|
|
|
variable {A : Type}
|
2015-04-04 00:20:19 -04:00
|
|
|
|
|
|
|
definition north (A : Type) : suspension A :=
|
|
|
|
inl _ _ star
|
|
|
|
|
|
|
|
definition south (A : Type) : suspension A :=
|
|
|
|
inr _ _ star
|
|
|
|
|
2015-04-19 17:56:24 -04:00
|
|
|
definition merid (a : A) : north A = south A :=
|
2015-04-04 00:20:19 -04:00
|
|
|
glue _ _ a
|
|
|
|
|
2015-04-19 17:56:24 -04:00
|
|
|
protected definition rec {P : suspension A → Type} (PN : P !north) (PS : P !south)
|
2015-05-22 04:35:38 -04:00
|
|
|
(Pm : Π(a : A), PN =[merid a] PS) (x : suspension A) : P x :=
|
2015-04-04 00:20:19 -04:00
|
|
|
begin
|
2015-05-26 09:56:41 -04:00
|
|
|
fapply pushout.rec_on _ _ x,
|
2015-04-04 00:20:19 -04:00
|
|
|
{ intro u, cases u, exact PN},
|
|
|
|
{ intro u, cases u, exact PS},
|
2015-04-06 21:01:08 -04:00
|
|
|
{ exact Pm},
|
2015-04-04 00:20:19 -04:00
|
|
|
end
|
|
|
|
|
2015-04-19 17:56:24 -04:00
|
|
|
protected definition rec_on [reducible] {P : suspension A → Type} (y : suspension A)
|
2015-05-22 04:35:38 -04:00
|
|
|
(PN : P !north) (PS : P !south) (Pm : Π(a : A), PN =[merid a] PS) : P y :=
|
2015-05-18 22:35:18 -07:00
|
|
|
suspension.rec PN PS Pm y
|
2015-04-04 00:20:19 -04:00
|
|
|
|
2015-04-27 17:34:55 -04:00
|
|
|
theorem rec_merid {P : suspension A → Type} (PN : P !north) (PS : P !south)
|
2015-05-22 04:35:38 -04:00
|
|
|
(Pm : Π(a : A), PN =[merid a] PS) (a : A)
|
|
|
|
: apdo (suspension.rec PN PS Pm) (merid a) = Pm a :=
|
2015-04-27 21:30:20 -04:00
|
|
|
!rec_glue
|
2015-04-05 01:46:44 -04:00
|
|
|
|
2015-04-19 17:56:24 -04:00
|
|
|
protected definition elim {P : Type} (PN : P) (PS : P) (Pm : A → PN = PS)
|
2015-04-06 21:01:08 -04:00
|
|
|
(x : suspension A) : P :=
|
2015-05-22 04:35:38 -04:00
|
|
|
suspension.rec PN PS (λa, pathover_of_eq (Pm a)) x
|
2015-04-05 01:46:44 -04:00
|
|
|
|
2015-04-19 17:56:24 -04:00
|
|
|
protected definition elim_on [reducible] {P : Type} (x : suspension A)
|
2015-04-06 21:01:08 -04:00
|
|
|
(PN : P) (PS : P) (Pm : A → PN = PS) : P :=
|
2015-05-18 22:35:18 -07:00
|
|
|
suspension.elim PN PS Pm x
|
2015-04-05 01:46:44 -04:00
|
|
|
|
2015-04-27 17:34:55 -04:00
|
|
|
theorem elim_merid {P : Type} (PN : P) (PS : P) (Pm : A → PN = PS) (a : A)
|
2015-05-18 22:35:18 -07:00
|
|
|
: ap (suspension.elim PN PS Pm) (merid a) = Pm a :=
|
2015-04-27 17:34:55 -04:00
|
|
|
begin
|
2015-05-22 04:35:38 -04:00
|
|
|
apply eq_of_fn_eq_fn_inv !(pathover_constant (merid a)),
|
|
|
|
rewrite [▸*,-apdo_eq_pathover_of_eq_ap,↑suspension.elim,rec_merid],
|
2015-04-27 17:34:55 -04:00
|
|
|
end
|
2015-04-05 01:46:44 -04:00
|
|
|
|
2015-04-19 17:56:24 -04:00
|
|
|
protected definition elim_type (PN : Type) (PS : Type) (Pm : A → PN ≃ PS)
|
|
|
|
(x : suspension A) : Type :=
|
2015-05-18 22:35:18 -07:00
|
|
|
suspension.elim PN PS (λa, ua (Pm a)) x
|
2015-04-19 17:56:24 -04:00
|
|
|
|
|
|
|
protected definition elim_type_on [reducible] (x : suspension A)
|
|
|
|
(PN : Type) (PS : Type) (Pm : A → PN ≃ PS) : Type :=
|
2015-05-18 22:35:18 -07:00
|
|
|
suspension.elim_type PN PS Pm x
|
2015-04-19 17:56:24 -04:00
|
|
|
|
2015-04-27 17:34:55 -04:00
|
|
|
theorem elim_type_merid (PN : Type) (PS : Type) (Pm : A → PN ≃ PS)
|
2015-05-26 09:56:41 -04:00
|
|
|
(a : A) : transport (suspension.elim_type PN PS Pm) (merid a) = Pm a :=
|
2015-05-18 22:35:18 -07:00
|
|
|
by rewrite [tr_eq_cast_ap_fn,↑suspension.elim_type,elim_merid];apply cast_ua_fn
|
2015-04-19 17:56:24 -04:00
|
|
|
|
2015-04-06 21:01:08 -04:00
|
|
|
end suspension
|
2015-05-07 16:35:14 -04:00
|
|
|
|
|
|
|
attribute suspension.north suspension.south [constructor]
|
2015-05-26 22:33:27 -04:00
|
|
|
attribute suspension.rec suspension.elim [unfold-c 6] [recursor 6]
|
2015-05-07 16:35:14 -04:00
|
|
|
attribute suspension.elim_type [unfold-c 5]
|
|
|
|
attribute suspension.rec_on suspension.elim_on [unfold-c 3]
|
|
|
|
attribute suspension.elim_type_on [unfold-c 2]
|
2015-06-03 21:41:21 -04:00
|
|
|
|
|
|
|
namespace suspension
|
|
|
|
|
|
|
|
definition pointed_suspension [instance] [constructor] (A : Type) : pointed (suspension A) :=
|
|
|
|
pointed.mk !north
|
|
|
|
|
|
|
|
definition suspension_adjoint_loop (A B : Pointed)
|
|
|
|
: map₊ (pointed.mk' (suspension A)) B ≃ map₊ A (Ω B) :=
|
|
|
|
begin
|
|
|
|
fapply equiv.MK,
|
|
|
|
{ intro f, fapply pointed_map.mk,
|
|
|
|
intro a, refine !respect_pt⁻¹ ⬝ ap f (merid a ⬝ (merid pt)⁻¹) ⬝ !respect_pt,
|
|
|
|
refine ap _ !con.right_inv ⬝ !con.left_inv},
|
|
|
|
{ intro g, fapply pointed_map.mk,
|
|
|
|
{ esimp, intro a, induction a,
|
|
|
|
exact pt,
|
|
|
|
exact pt,
|
|
|
|
exact g a} ,
|
|
|
|
{ reflexivity}},
|
|
|
|
{ intro g, fapply pointed_map_eq,
|
|
|
|
intro a, esimp [respect_pt], refine !idp_con ⬝ !ap_con ⬝ ap _ !ap_inv
|
|
|
|
⬝ ap _ !elim_merid ⬝ ap _ !elim_merid ⬝ ap _ (respect_pt g) ⬝ _, exact idp,
|
|
|
|
-- rewrite [ap_con,ap_inv,+elim_merid,idp_con,respect_pt],
|
|
|
|
esimp, exact sorry},
|
|
|
|
{ intro f, fapply pointed_map_eq,
|
|
|
|
{ esimp, intro a, induction a; all_goals esimp,
|
|
|
|
exact !respect_pt⁻¹,
|
|
|
|
exact !respect_pt⁻¹ ⬝ ap f (merid pt),
|
|
|
|
apply pathover_eq, exact sorry},
|
|
|
|
{ esimp, exact !con.left_inv⁻¹}},
|
|
|
|
end
|
|
|
|
|
|
|
|
end suspension
|