2015-04-07 01:01:08 +00: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
|
|
|
|
|
|
|
|
|
|
Declaration of the circle
|
|
|
|
|
-/
|
|
|
|
|
|
2015-05-27 01:17:26 +00:00
|
|
|
|
import .sphere
|
2016-04-20 15:51:56 +00:00
|
|
|
|
import types.int.hott
|
|
|
|
|
import algebra.homotopy_group .connectedness
|
2015-04-07 01:01:08 +00:00
|
|
|
|
|
2016-06-24 08:54:00 +00:00
|
|
|
|
open eq susp bool sphere_index is_equiv equiv is_trunc is_conn pi algebra pointed
|
2015-04-07 01:01:08 +00:00
|
|
|
|
|
2015-05-07 20:35:14 +00:00
|
|
|
|
definition circle : Type₀ := sphere 1
|
2015-04-07 01:01:08 +00:00
|
|
|
|
|
|
|
|
|
namespace circle
|
2015-05-14 02:01:48 +00:00
|
|
|
|
notation `S¹` := circle
|
2016-04-26 00:11:34 +00:00
|
|
|
|
definition base1 : S¹ := !north
|
|
|
|
|
definition base2 : S¹ := !south
|
2015-04-28 02:05:59 +00:00
|
|
|
|
definition seg1 : base1 = base2 := merid !north
|
|
|
|
|
definition seg2 : base1 = base2 := merid !south
|
2015-04-07 01:01:08 +00:00
|
|
|
|
|
2016-04-26 00:11:34 +00:00
|
|
|
|
definition base : S¹ := base1
|
2015-05-22 08:35:38 +00:00
|
|
|
|
definition loop : base = base := seg2 ⬝ seg1⁻¹
|
2015-04-07 01:01:08 +00:00
|
|
|
|
|
2016-04-26 00:11:34 +00:00
|
|
|
|
definition rec2 {P : S¹ → Type} (Pb1 : P base1) (Pb2 : P base2)
|
|
|
|
|
(Ps1 : Pb1 =[seg1] Pb2) (Ps2 : Pb1 =[seg2] Pb2) (x : S¹) : P x :=
|
2015-04-07 01:01:08 +00:00
|
|
|
|
begin
|
2015-05-21 04:16:23 +00:00
|
|
|
|
induction x with b,
|
2015-04-07 01:01:08 +00:00
|
|
|
|
{ exact Pb1},
|
|
|
|
|
{ exact Pb2},
|
2015-05-21 04:16:23 +00:00
|
|
|
|
{ esimp at *, induction b with y,
|
2015-04-28 02:05:59 +00:00
|
|
|
|
{ exact Ps1},
|
|
|
|
|
{ exact Ps2},
|
2015-05-21 04:16:23 +00:00
|
|
|
|
{ cases y}},
|
2015-04-07 01:01:08 +00:00
|
|
|
|
end
|
|
|
|
|
|
2016-04-26 00:11:34 +00:00
|
|
|
|
definition rec2_on [reducible] {P : S¹ → Type} (x : S¹) (Pb1 : P base1) (Pb2 : P base2)
|
2015-05-22 08:35:38 +00:00
|
|
|
|
(Ps1 : Pb1 =[seg1] Pb2) (Ps2 : Pb1 =[seg2] Pb2) : P x :=
|
2015-04-07 01:01:08 +00:00
|
|
|
|
circle.rec2 Pb1 Pb2 Ps1 Ps2 x
|
|
|
|
|
|
2016-04-26 00:11:34 +00:00
|
|
|
|
theorem rec2_seg1 {P : S¹ → Type} (Pb1 : P base1) (Pb2 : P base2)
|
2015-05-22 08:35:38 +00:00
|
|
|
|
(Ps1 : Pb1 =[seg1] Pb2) (Ps2 : Pb1 =[seg2] Pb2)
|
2016-03-19 15:25:08 +00:00
|
|
|
|
: apd (rec2 Pb1 Pb2 Ps1 Ps2) seg1 = Ps1 :=
|
2015-04-28 01:30:20 +00:00
|
|
|
|
!rec_merid
|
2015-04-07 01:01:08 +00:00
|
|
|
|
|
2016-04-26 00:11:34 +00:00
|
|
|
|
theorem rec2_seg2 {P : S¹ → Type} (Pb1 : P base1) (Pb2 : P base2)
|
2015-05-22 08:35:38 +00:00
|
|
|
|
(Ps1 : Pb1 =[seg1] Pb2) (Ps2 : Pb1 =[seg2] Pb2)
|
2016-03-19 15:25:08 +00:00
|
|
|
|
: apd (rec2 Pb1 Pb2 Ps1 Ps2) seg2 = Ps2 :=
|
2015-04-28 02:05:59 +00:00
|
|
|
|
!rec_merid
|
2015-04-07 01:01:08 +00:00
|
|
|
|
|
2016-04-26 00:11:34 +00:00
|
|
|
|
definition elim2 {P : Type} (Pb1 Pb2 : P) (Ps1 Ps2 : Pb1 = Pb2) (x : S¹) : P :=
|
2016-06-23 20:49:54 +00:00
|
|
|
|
rec2 Pb1 Pb2 (pathover_of_eq _ Ps1) (pathover_of_eq _ Ps2) x
|
2015-04-07 01:01:08 +00:00
|
|
|
|
|
2016-04-26 00:11:34 +00:00
|
|
|
|
definition elim2_on [reducible] {P : Type} (x : S¹) (Pb1 Pb2 : P)
|
2015-04-28 02:05:59 +00:00
|
|
|
|
(Ps1 : Pb1 = Pb2) (Ps2 : Pb1 = Pb2) : P :=
|
2015-04-07 01:01:08 +00:00
|
|
|
|
elim2 Pb1 Pb2 Ps1 Ps2 x
|
|
|
|
|
|
2015-04-28 02:05:59 +00:00
|
|
|
|
theorem elim2_seg1 {P : Type} (Pb1 Pb2 : P) (Ps1 : Pb1 = Pb2) (Ps2 : Pb1 = Pb2)
|
2015-04-27 21:34:55 +00:00
|
|
|
|
: ap (elim2 Pb1 Pb2 Ps1 Ps2) seg1 = Ps1 :=
|
|
|
|
|
begin
|
2015-05-22 08:35:38 +00:00
|
|
|
|
apply eq_of_fn_eq_fn_inv !(pathover_constant seg1),
|
2016-03-19 15:25:08 +00:00
|
|
|
|
rewrite [▸*,-apd_eq_pathover_of_eq_ap,↑elim2,rec2_seg1],
|
2015-04-27 21:34:55 +00:00
|
|
|
|
end
|
2015-04-07 01:01:08 +00:00
|
|
|
|
|
2015-04-28 02:05:59 +00:00
|
|
|
|
theorem elim2_seg2 {P : Type} (Pb1 Pb2 : P) (Ps1 : Pb1 = Pb2) (Ps2 : Pb1 = Pb2)
|
2015-04-27 21:34:55 +00:00
|
|
|
|
: ap (elim2 Pb1 Pb2 Ps1 Ps2) seg2 = Ps2 :=
|
|
|
|
|
begin
|
2015-05-22 08:35:38 +00:00
|
|
|
|
apply eq_of_fn_eq_fn_inv !(pathover_constant seg2),
|
2016-03-19 15:25:08 +00:00
|
|
|
|
rewrite [▸*,-apd_eq_pathover_of_eq_ap,↑elim2,rec2_seg2],
|
2015-04-27 21:34:55 +00:00
|
|
|
|
end
|
2015-04-07 01:01:08 +00:00
|
|
|
|
|
2016-04-26 00:11:34 +00:00
|
|
|
|
definition elim2_type (Pb1 Pb2 : Type) (Ps1 Ps2 : Pb1 ≃ Pb2) (x : S¹) : Type :=
|
2015-05-07 20:35:14 +00:00
|
|
|
|
elim2 Pb1 Pb2 (ua Ps1) (ua Ps2) x
|
|
|
|
|
|
2016-04-26 00:11:34 +00:00
|
|
|
|
definition elim2_type_on [reducible] (x : S¹) (Pb1 Pb2 : Type) (Ps1 Ps2 : Pb1 ≃ Pb2)
|
2015-05-07 20:35:14 +00:00
|
|
|
|
: Type :=
|
|
|
|
|
elim2_type Pb1 Pb2 Ps1 Ps2 x
|
|
|
|
|
|
|
|
|
|
theorem elim2_type_seg1 (Pb1 Pb2 : Type) (Ps1 Ps2 : Pb1 ≃ Pb2)
|
|
|
|
|
: transport (elim2_type Pb1 Pb2 Ps1 Ps2) seg1 = Ps1 :=
|
|
|
|
|
by rewrite [tr_eq_cast_ap_fn,↑elim2_type,elim2_seg1];apply cast_ua_fn
|
|
|
|
|
|
|
|
|
|
theorem elim2_type_seg2 (Pb1 Pb2 : Type) (Ps1 Ps2 : Pb1 ≃ Pb2)
|
|
|
|
|
: transport (elim2_type Pb1 Pb2 Ps1 Ps2) seg2 = Ps2 :=
|
|
|
|
|
by rewrite [tr_eq_cast_ap_fn,↑elim2_type,elim2_seg2];apply cast_ua_fn
|
|
|
|
|
|
2016-04-26 00:11:34 +00:00
|
|
|
|
protected definition rec {P : S¹ → Type} (Pbase : P base) (Ploop : Pbase =[loop] Pbase)
|
|
|
|
|
(x : S¹) : P x :=
|
2015-04-07 01:01:08 +00:00
|
|
|
|
begin
|
|
|
|
|
fapply (rec2_on x),
|
|
|
|
|
{ exact Pbase},
|
|
|
|
|
{ exact (transport P seg1 Pbase)},
|
2015-05-22 08:35:38 +00:00
|
|
|
|
{ apply pathover_tr},
|
|
|
|
|
{ apply pathover_tr_of_pathover, exact Ploop}
|
2015-04-07 01:01:08 +00:00
|
|
|
|
end
|
2015-04-27 21:34:55 +00:00
|
|
|
|
|
2016-04-26 00:11:34 +00:00
|
|
|
|
protected definition rec_on [reducible] {P : S¹ → Type} (x : S¹) (Pbase : P base)
|
2015-05-22 08:35:38 +00:00
|
|
|
|
(Ploop : Pbase =[loop] Pbase) : P x :=
|
2015-05-19 05:35:18 +00:00
|
|
|
|
circle.rec Pbase Ploop x
|
2015-04-28 20:49:11 +00:00
|
|
|
|
|
|
|
|
|
theorem rec_loop_helper {A : Type} (P : A → Type)
|
2015-05-22 08:35:38 +00:00
|
|
|
|
{x y z : A} {p : x = y} {p' : z = y} {u : P x} {v : P z} (q : u =[p ⬝ p'⁻¹] v) :
|
|
|
|
|
pathover_tr_of_pathover q ⬝o !pathover_tr⁻¹ᵒ = q :=
|
|
|
|
|
by cases p'; cases q; exact idp
|
2015-04-28 20:49:11 +00:00
|
|
|
|
|
2015-04-29 00:48:39 +00:00
|
|
|
|
definition con_refl {A : Type} {x y : A} (p : x = y) : p ⬝ refl _ = p :=
|
|
|
|
|
eq.rec_on p idp
|
|
|
|
|
|
2016-04-26 00:11:34 +00:00
|
|
|
|
theorem rec_loop {P : S¹ → Type} (Pbase : P base) (Ploop : Pbase =[loop] Pbase) :
|
2016-03-19 15:25:08 +00:00
|
|
|
|
apd (circle.rec Pbase Ploop) loop = Ploop :=
|
2015-04-28 20:49:11 +00:00
|
|
|
|
begin
|
2016-03-19 15:25:08 +00:00
|
|
|
|
rewrite [↑loop,apd_con,↑circle.rec,↑circle.rec2_on,↑base,rec2_seg2,apd_inv,rec2_seg1],
|
2015-05-22 08:35:38 +00:00
|
|
|
|
apply rec_loop_helper
|
2015-04-28 20:49:11 +00:00
|
|
|
|
end
|
2015-04-07 01:01:08 +00:00
|
|
|
|
|
|
|
|
|
protected definition elim {P : Type} (Pbase : P) (Ploop : Pbase = Pbase)
|
2016-04-26 00:11:34 +00:00
|
|
|
|
(x : S¹) : P :=
|
2016-06-23 20:49:54 +00:00
|
|
|
|
circle.rec Pbase (pathover_of_eq _ Ploop) x
|
2015-04-07 01:01:08 +00:00
|
|
|
|
|
2016-04-26 00:11:34 +00:00
|
|
|
|
protected definition elim_on [reducible] {P : Type} (x : S¹) (Pbase : P)
|
2015-04-07 01:01:08 +00:00
|
|
|
|
(Ploop : Pbase = Pbase) : P :=
|
2015-05-19 05:35:18 +00:00
|
|
|
|
circle.elim Pbase Ploop x
|
2015-04-07 01:01:08 +00:00
|
|
|
|
|
2015-04-27 21:34:55 +00:00
|
|
|
|
theorem elim_loop {P : Type} (Pbase : P) (Ploop : Pbase = Pbase) :
|
2015-05-19 05:35:18 +00:00
|
|
|
|
ap (circle.elim Pbase Ploop) loop = Ploop :=
|
2015-04-27 21:34:55 +00:00
|
|
|
|
begin
|
2015-05-22 08:35:38 +00:00
|
|
|
|
apply eq_of_fn_eq_fn_inv !(pathover_constant loop),
|
2016-03-19 15:25:08 +00:00
|
|
|
|
rewrite [▸*,-apd_eq_pathover_of_eq_ap,↑circle.elim,rec_loop],
|
2015-04-27 21:34:55 +00:00
|
|
|
|
end
|
2015-04-07 01:01:08 +00:00
|
|
|
|
|
2016-02-08 11:07:53 +00:00
|
|
|
|
theorem elim_seg1 {P : Type} (Pbase : P) (Ploop : Pbase = Pbase)
|
|
|
|
|
: ap (circle.elim Pbase Ploop) seg1 = (tr_constant seg1 Pbase)⁻¹ :=
|
|
|
|
|
begin
|
|
|
|
|
apply eq_of_fn_eq_fn_inv !(pathover_constant seg1),
|
2016-03-19 15:25:08 +00:00
|
|
|
|
rewrite [▸*,-apd_eq_pathover_of_eq_ap,↑circle.elim,↑circle.rec],
|
2016-02-08 11:07:53 +00:00
|
|
|
|
rewrite [↑circle.rec2_on,rec2_seg1], apply inverse,
|
|
|
|
|
apply pathover_of_eq_tr_constant_inv
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
theorem elim_seg2 {P : Type} (Pbase : P) (Ploop : Pbase = Pbase)
|
|
|
|
|
: ap (circle.elim Pbase Ploop) seg2 = Ploop ⬝ (tr_constant seg1 Pbase)⁻¹ :=
|
|
|
|
|
begin
|
|
|
|
|
apply eq_of_fn_eq_fn_inv !(pathover_constant seg2),
|
2016-03-19 15:25:08 +00:00
|
|
|
|
rewrite [▸*,-apd_eq_pathover_of_eq_ap,↑circle.elim,↑circle.rec],
|
2016-02-08 11:07:53 +00:00
|
|
|
|
rewrite [↑circle.rec2_on,rec2_seg2],
|
|
|
|
|
assert l : Π(A B : Type)(a a₂ a₂' : A)(b b' : B)(p : a = a₂)(p' : a₂' = a₂)
|
|
|
|
|
(q : b = b'),
|
2016-06-23 20:49:54 +00:00
|
|
|
|
pathover_tr_of_pathover (pathover_of_eq _ q)
|
|
|
|
|
= pathover_of_eq _ (q ⬝ (tr_constant p' b')⁻¹)
|
2016-02-08 11:07:53 +00:00
|
|
|
|
:> b =[p] p' ▸ b',
|
|
|
|
|
{ intros, cases q, cases p', cases p, reflexivity },
|
|
|
|
|
apply l
|
|
|
|
|
end
|
|
|
|
|
|
2015-04-19 21:56:24 +00:00
|
|
|
|
protected definition elim_type (Pbase : Type) (Ploop : Pbase ≃ Pbase)
|
2016-04-26 00:11:34 +00:00
|
|
|
|
(x : S¹) : Type :=
|
2015-05-19 05:35:18 +00:00
|
|
|
|
circle.elim Pbase (ua Ploop) x
|
2015-04-19 21:56:24 +00:00
|
|
|
|
|
2016-04-26 00:11:34 +00:00
|
|
|
|
protected definition elim_type_on [reducible] (x : S¹) (Pbase : Type)
|
2015-04-19 21:56:24 +00:00
|
|
|
|
(Ploop : Pbase ≃ Pbase) : Type :=
|
2015-05-19 05:35:18 +00:00
|
|
|
|
circle.elim_type Pbase Ploop x
|
2015-04-19 21:56:24 +00:00
|
|
|
|
|
2015-04-27 21:34:55 +00:00
|
|
|
|
theorem elim_type_loop (Pbase : Type) (Ploop : Pbase ≃ Pbase) :
|
2015-05-19 05:35:18 +00:00
|
|
|
|
transport (circle.elim_type Pbase Ploop) loop = Ploop :=
|
2016-03-08 05:16:45 +00:00
|
|
|
|
by rewrite [tr_eq_cast_ap_fn,↑circle.elim_type,elim_loop];apply cast_ua_fn
|
2015-04-07 01:01:08 +00:00
|
|
|
|
|
2015-05-07 02:48:11 +00:00
|
|
|
|
theorem elim_type_loop_inv (Pbase : Type) (Ploop : Pbase ≃ Pbase) :
|
2015-05-19 05:35:18 +00:00
|
|
|
|
transport (circle.elim_type Pbase Ploop) loop⁻¹ = to_inv Ploop :=
|
2015-08-07 17:23:00 +00:00
|
|
|
|
by rewrite [tr_inv_fn]; apply inv_eq_inv; apply elim_type_loop
|
2015-05-07 20:35:14 +00:00
|
|
|
|
end circle
|
|
|
|
|
|
2015-05-21 03:37:43 +00:00
|
|
|
|
attribute circle.base1 circle.base2 circle.base [constructor]
|
2015-07-07 23:37:06 +00:00
|
|
|
|
attribute circle.rec2 circle.elim2 [unfold 6] [recursor 6]
|
|
|
|
|
attribute circle.elim2_type [unfold 5]
|
|
|
|
|
attribute circle.rec2_on circle.elim2_on [unfold 2]
|
|
|
|
|
attribute circle.elim2_type [unfold 1]
|
2015-07-29 12:17:16 +00:00
|
|
|
|
attribute circle.rec circle.elim [unfold 4] [recursor 4]
|
2015-07-07 23:37:06 +00:00
|
|
|
|
attribute circle.elim_type [unfold 3]
|
|
|
|
|
attribute circle.rec_on circle.elim_on [unfold 2]
|
|
|
|
|
attribute circle.elim_type_on [unfold 1]
|
2015-05-07 02:48:11 +00:00
|
|
|
|
|
2015-05-07 20:35:14 +00:00
|
|
|
|
namespace circle
|
2016-03-08 05:16:45 +00:00
|
|
|
|
open sigma
|
|
|
|
|
/- universal property of the circle -/
|
|
|
|
|
definition circle_pi_equiv [constructor] (P : S¹ → Type)
|
|
|
|
|
: (Π(x : S¹), P x) ≃ Σ(p : P base), p =[loop] p :=
|
|
|
|
|
begin
|
|
|
|
|
fapply equiv.MK,
|
2016-03-19 15:25:08 +00:00
|
|
|
|
{ intro f, exact ⟨f base, apd f loop⟩},
|
2016-03-08 05:16:45 +00:00
|
|
|
|
{ intro v x, induction v with p q, induction x,
|
|
|
|
|
{ exact p},
|
|
|
|
|
{ exact q}},
|
|
|
|
|
{ intro v, induction v with p q, fapply sigma_eq,
|
|
|
|
|
{ reflexivity},
|
|
|
|
|
{ esimp, apply pathover_idp_of_eq, apply rec_loop}},
|
|
|
|
|
{ intro f, apply eq_of_homotopy, intro x, induction x,
|
|
|
|
|
{ reflexivity},
|
|
|
|
|
{ apply eq_pathover_dep, apply hdeg_squareover, esimp, apply rec_loop}}
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
definition circle_arrow_equiv [constructor] (P : Type)
|
|
|
|
|
: (S¹ → P) ≃ Σ(p : P), p = p :=
|
|
|
|
|
begin
|
|
|
|
|
fapply equiv.MK,
|
|
|
|
|
{ intro f, exact ⟨f base, ap f loop⟩},
|
|
|
|
|
{ intro v x, induction v with p q, induction x,
|
|
|
|
|
{ exact p},
|
|
|
|
|
{ exact q}},
|
|
|
|
|
{ intro v, induction v with p q, fapply sigma_eq,
|
|
|
|
|
{ reflexivity},
|
|
|
|
|
{ esimp, apply pathover_idp_of_eq, apply elim_loop}},
|
|
|
|
|
{ intro f, apply eq_of_homotopy, intro x, induction x,
|
|
|
|
|
{ reflexivity},
|
|
|
|
|
{ apply eq_pathover, apply hdeg_square, esimp, apply elim_loop}}
|
|
|
|
|
end
|
|
|
|
|
|
2016-02-15 23:23:28 +00:00
|
|
|
|
definition pointed_circle [instance] [constructor] : pointed S¹ :=
|
2015-05-14 02:01:48 +00:00
|
|
|
|
pointed.mk base
|
|
|
|
|
|
2016-02-15 23:23:28 +00:00
|
|
|
|
definition pcircle [constructor] : Type* := pointed.mk' S¹
|
2016-09-22 19:42:46 +00:00
|
|
|
|
notation `S¹*` := pcircle
|
2015-11-16 20:30:28 +00:00
|
|
|
|
|
2015-05-01 00:45:31 +00:00
|
|
|
|
definition loop_neq_idp : loop ≠ idp :=
|
|
|
|
|
assume H : loop = idp,
|
2015-05-22 08:35:38 +00:00
|
|
|
|
have H2 : Π{A : Type₁} {a : A} {p : a = a}, p = idp,
|
2015-05-01 00:45:31 +00:00
|
|
|
|
from λA a p, calc
|
|
|
|
|
p = ap (circle.elim a p) loop : elim_loop
|
|
|
|
|
... = ap (circle.elim a p) (refl base) : by rewrite H,
|
2015-10-16 19:15:44 +00:00
|
|
|
|
eq_bnot_ne_idp H2
|
2015-05-01 00:45:31 +00:00
|
|
|
|
|
2016-06-23 20:10:37 +00:00
|
|
|
|
definition circle_turn [reducible] (x : S¹) : x = x :=
|
2015-05-22 08:35:38 +00:00
|
|
|
|
begin
|
|
|
|
|
induction x,
|
2016-06-23 20:10:37 +00:00
|
|
|
|
{ exact loop },
|
|
|
|
|
{ apply eq_pathover, apply square_of_eq, rewrite ap_id }
|
2015-05-22 08:35:38 +00:00
|
|
|
|
end
|
2015-05-01 00:45:31 +00:00
|
|
|
|
|
2016-06-23 20:10:37 +00:00
|
|
|
|
definition turn_neq_idp : circle_turn ≠ (λx, idp) :=
|
|
|
|
|
assume H : circle_turn = λx, idp,
|
2015-05-01 00:45:31 +00:00
|
|
|
|
have H2 : loop = idp, from apd10 H base,
|
|
|
|
|
absurd H2 loop_neq_idp
|
|
|
|
|
|
2015-05-07 02:48:11 +00:00
|
|
|
|
open int
|
|
|
|
|
|
2016-04-26 00:11:34 +00:00
|
|
|
|
protected definition code [unfold 1] (x : S¹) : Type₀ :=
|
2015-05-07 02:48:11 +00:00
|
|
|
|
circle.elim_type_on x ℤ equiv_succ
|
|
|
|
|
|
2015-05-19 05:35:18 +00:00
|
|
|
|
definition transport_code_loop (a : ℤ) : transport circle.code loop a = succ a :=
|
2015-05-07 02:48:11 +00:00
|
|
|
|
ap10 !elim_type_loop a
|
|
|
|
|
|
2015-11-18 23:08:38 +00:00
|
|
|
|
definition transport_code_loop_inv (a : ℤ) : transport circle.code loop⁻¹ a = pred a :=
|
2015-05-07 02:48:11 +00:00
|
|
|
|
ap10 !elim_type_loop_inv a
|
|
|
|
|
|
2016-04-26 00:11:34 +00:00
|
|
|
|
protected definition encode [unfold 2] {x : S¹} (p : base = x) : circle.code x :=
|
2016-06-23 20:10:37 +00:00
|
|
|
|
transport circle.code p (0 : ℤ)
|
2015-05-07 02:48:11 +00:00
|
|
|
|
|
2016-04-26 00:11:34 +00:00
|
|
|
|
protected definition decode [unfold 1] {x : S¹} : circle.code x → base = x :=
|
2015-05-14 02:01:48 +00:00
|
|
|
|
begin
|
2015-05-21 04:16:23 +00:00
|
|
|
|
induction x,
|
2015-05-14 02:01:48 +00:00
|
|
|
|
{ exact power loop},
|
2016-06-23 20:10:37 +00:00
|
|
|
|
{ apply arrow_pathover_left, intro b, apply eq_pathover_constant_left_id_right,
|
|
|
|
|
apply square_of_eq, rewrite [idp_con, power_con,transport_code_loop]}
|
2015-05-14 02:01:48 +00:00
|
|
|
|
end
|
|
|
|
|
|
2016-04-26 00:11:34 +00:00
|
|
|
|
definition circle_eq_equiv [constructor] (x : S¹) : (base = x) ≃ circle.code x :=
|
2015-05-07 02:48:11 +00:00
|
|
|
|
begin
|
|
|
|
|
fapply equiv.MK,
|
2015-05-19 05:35:18 +00:00
|
|
|
|
{ exact circle.encode},
|
|
|
|
|
{ exact circle.decode},
|
2015-11-18 20:08:06 +00:00
|
|
|
|
{ exact abstract [irreducible] begin
|
|
|
|
|
induction x,
|
|
|
|
|
{ intro a, esimp, apply rec_nat_on a,
|
|
|
|
|
{ exact idp},
|
|
|
|
|
{ intros n p, rewrite [↑circle.encode, -power_con, con_tr, transport_code_loop],
|
|
|
|
|
exact ap succ p},
|
|
|
|
|
{ intros n p, rewrite [↑circle.encode, nat_succ_eq_int_succ, neg_succ, -power_con_inv,
|
|
|
|
|
@con_tr _ circle.code, transport_code_loop_inv, ↑[circle.encode] at p, p, -neg_succ] }},
|
2016-02-15 20:18:07 +00:00
|
|
|
|
{ apply pathover_of_tr_eq, apply eq_of_homotopy, intro a, apply @is_set.elim,
|
2015-11-18 20:08:06 +00:00
|
|
|
|
esimp, exact _} end end},
|
2015-05-07 02:48:11 +00:00
|
|
|
|
{ intro p, cases p, exact idp},
|
|
|
|
|
end
|
|
|
|
|
|
2015-07-29 14:08:28 +00:00
|
|
|
|
definition base_eq_base_equiv [constructor] : base = base ≃ ℤ :=
|
2015-05-07 02:48:11 +00:00
|
|
|
|
circle_eq_equiv base
|
|
|
|
|
|
2016-04-22 19:12:25 +00:00
|
|
|
|
definition decode_add (a b : ℤ) : circle.decode (a +[ℤ] b) = circle.decode a ⬝ circle.decode b :=
|
|
|
|
|
!power_con_power⁻¹
|
2015-05-14 02:01:48 +00:00
|
|
|
|
|
2015-12-09 05:02:05 +00:00
|
|
|
|
definition encode_con (p q : base = base)
|
|
|
|
|
: circle.encode (p ⬝ q) = circle.encode p +[ℤ] circle.encode q :=
|
|
|
|
|
preserve_binary_of_inv_preserve base_eq_base_equiv concat (@add ℤ _) decode_add p q
|
2015-05-14 02:01:48 +00:00
|
|
|
|
|
|
|
|
|
--the carrier of π₁(S¹) is the set-truncation of base = base.
|
2016-04-20 15:51:56 +00:00
|
|
|
|
open algebra trunc group
|
2015-12-09 05:02:05 +00:00
|
|
|
|
|
2016-09-22 19:42:46 +00:00
|
|
|
|
definition fg_carrier_equiv_int : π[1](S¹*) ≃ ℤ :=
|
2016-03-06 00:35:12 +00:00
|
|
|
|
trunc_equiv_trunc 0 base_eq_base_equiv ⬝e @(trunc_equiv 0 ℤ) proof _ qed
|
2015-05-14 02:01:48 +00:00
|
|
|
|
|
2015-07-29 14:08:28 +00:00
|
|
|
|
definition con_comm_base (p q : base = base) : p ⬝ q = q ⬝ p :=
|
|
|
|
|
eq_of_fn_eq_fn base_eq_base_equiv (by esimp;rewrite [+encode_con,add.comm])
|
|
|
|
|
|
2016-09-22 19:42:46 +00:00
|
|
|
|
definition fundamental_group_of_circle : π₁(S¹*) ≃g gℤ :=
|
2015-05-14 02:01:48 +00:00
|
|
|
|
begin
|
2016-04-20 15:51:56 +00:00
|
|
|
|
apply (isomorphism_of_equiv fg_carrier_equiv_int),
|
2015-05-14 02:01:48 +00:00
|
|
|
|
intros g h,
|
2015-05-27 02:33:27 +00:00
|
|
|
|
induction g with g', induction h with h',
|
2015-05-14 02:01:48 +00:00
|
|
|
|
apply encode_con,
|
|
|
|
|
end
|
2015-05-07 02:48:11 +00:00
|
|
|
|
|
2015-11-18 23:08:38 +00:00
|
|
|
|
open nat
|
2016-09-22 19:42:46 +00:00
|
|
|
|
definition homotopy_group_of_circle (n : ℕ) : πg[n+2] S¹* ≃g G0 :=
|
2015-11-18 23:08:38 +00:00
|
|
|
|
begin
|
2016-09-22 19:42:46 +00:00
|
|
|
|
refine @trivial_homotopy_add_of_is_set_loopn S¹* 1 n _,
|
2015-11-18 23:08:38 +00:00
|
|
|
|
apply is_trunc_equiv_closed_rev, apply base_eq_base_equiv
|
|
|
|
|
end
|
|
|
|
|
|
2015-07-29 14:08:28 +00:00
|
|
|
|
definition eq_equiv_Z (x : S¹) : x = x ≃ ℤ :=
|
|
|
|
|
begin
|
|
|
|
|
induction x,
|
|
|
|
|
{ apply base_eq_base_equiv},
|
|
|
|
|
{ apply equiv_pathover, intro p p' q, apply pathover_of_eq,
|
2015-12-10 18:37:55 +00:00
|
|
|
|
note H := eq_of_square (square_of_pathover q),
|
2015-07-29 14:08:28 +00:00
|
|
|
|
rewrite con_comm_base at H,
|
2016-02-15 17:57:51 +00:00
|
|
|
|
note H' := cancel_left _ H,
|
2015-07-29 14:08:28 +00:00
|
|
|
|
induction H', reflexivity}
|
|
|
|
|
end
|
|
|
|
|
|
2016-02-08 11:07:53 +00:00
|
|
|
|
proposition is_trunc_circle [instance] : is_trunc 1 S¹ :=
|
2016-02-15 21:24:24 +00:00
|
|
|
|
begin
|
|
|
|
|
apply is_trunc_succ_of_is_trunc_loop,
|
2016-02-25 00:43:50 +00:00
|
|
|
|
{ apply trunc_index.minus_one_le_succ},
|
2016-02-15 21:24:24 +00:00
|
|
|
|
{ intro x, apply is_trunc_equiv_closed_rev, apply eq_equiv_Z}
|
|
|
|
|
end
|
|
|
|
|
|
2016-04-26 00:11:34 +00:00
|
|
|
|
proposition is_conn_circle [instance] : is_conn 0 S¹ :=
|
2016-02-08 11:07:53 +00:00
|
|
|
|
sphere.is_conn_sphere -1.+2
|
2016-02-15 21:24:24 +00:00
|
|
|
|
|
2016-09-22 19:42:46 +00:00
|
|
|
|
definition is_conn_pcircle [instance] : is_conn 0 S¹* := !is_conn_circle
|
|
|
|
|
definition is_trunc_pcircle [instance] : is_trunc 1 S¹* := !is_trunc_circle
|
2016-06-24 08:54:00 +00:00
|
|
|
|
|
2016-02-08 11:07:53 +00:00
|
|
|
|
definition circle_mul [reducible] (x y : S¹) : S¹ :=
|
|
|
|
|
circle.elim y (circle_turn y) x
|
|
|
|
|
|
2016-01-23 19:15:59 +00:00
|
|
|
|
definition circle_mul_base (x : S¹) : circle_mul x base = x :=
|
|
|
|
|
begin
|
|
|
|
|
induction x,
|
|
|
|
|
{ reflexivity },
|
2016-06-23 20:10:37 +00:00
|
|
|
|
{ apply eq_pathover_id_right, apply hdeg_square, apply elim_loop }
|
2016-01-23 19:15:59 +00:00
|
|
|
|
end
|
|
|
|
|
|
2016-06-23 20:10:37 +00:00
|
|
|
|
definition circle_base_mul [reducible] (x : S¹) : circle_mul base x = x :=
|
2016-02-08 11:07:53 +00:00
|
|
|
|
idp
|
2016-01-23 19:15:59 +00:00
|
|
|
|
|
2015-04-07 01:01:08 +00:00
|
|
|
|
end circle
|