2015-06-23 17:21:04 +00:00
|
|
|
/-
|
2015-06-23 18:46:55 +00:00
|
|
|
Copyright (c) 2015 Floris van Doorn. All rights reserved.
|
2015-06-23 17:21:04 +00:00
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
Author: Floris van Doorn
|
|
|
|
|
|
|
|
Theorems about 2-dimensional paths
|
|
|
|
-/
|
|
|
|
|
|
|
|
import .cubical.square
|
|
|
|
open function
|
|
|
|
|
|
|
|
namespace eq
|
|
|
|
variables {A B C : Type} {f : A → B} {a a' a₁ a₂ a₃ a₄ : A} {b b' : B}
|
|
|
|
|
2015-09-10 22:32:52 +00:00
|
|
|
theorem ap_is_constant_eq (p : Πx, f x = b) (q : a = a') :
|
|
|
|
ap_is_constant p q =
|
2016-03-19 15:25:08 +00:00
|
|
|
eq_con_inv_of_con_eq ((eq_of_square (square_of_pathover (apd p q)))⁻¹ ⬝
|
2015-06-23 17:21:04 +00:00
|
|
|
whisker_left (p a) (ap_constant q b)) :=
|
|
|
|
begin
|
|
|
|
induction q, esimp, generalize (p a), intro p, cases p, apply idpath idp
|
|
|
|
end
|
|
|
|
|
|
|
|
definition ap_inv2 {p q : a = a'} (r : p = q)
|
|
|
|
: square (ap (ap f) (inverse2 r))
|
|
|
|
(inverse2 (ap (ap f) r))
|
|
|
|
(ap_inv f p)
|
|
|
|
(ap_inv f q) :=
|
|
|
|
by induction r;exact hrfl
|
|
|
|
|
|
|
|
definition ap_con2 {p₁ q₁ : a₁ = a₂} {p₂ q₂ : a₂ = a₃} (r₁ : p₁ = q₁) (r₂ : p₂ = q₂)
|
|
|
|
: square (ap (ap f) (r₁ ◾ r₂))
|
|
|
|
(ap (ap f) r₁ ◾ ap (ap f) r₂)
|
|
|
|
(ap_con f p₁ p₂)
|
|
|
|
(ap_con f q₁ q₂) :=
|
|
|
|
by induction r₂;induction r₁;exact hrfl
|
|
|
|
|
|
|
|
theorem ap_con_right_inv_sq {A B : Type} {a1 a2 : A} (f : A → B) (p : a1 = a2) :
|
|
|
|
square (ap (ap f) (con.right_inv p))
|
|
|
|
(con.right_inv (ap f p))
|
|
|
|
(ap_con f p p⁻¹ ⬝ whisker_left _ (ap_inv f p))
|
|
|
|
idp :=
|
|
|
|
by cases p;apply hrefl
|
|
|
|
|
|
|
|
theorem ap_con_left_inv_sq {A B : Type} {a1 a2 : A} (f : A → B) (p : a1 = a2) :
|
|
|
|
square (ap (ap f) (con.left_inv p))
|
|
|
|
(con.left_inv (ap f p))
|
2016-11-24 05:13:05 +00:00
|
|
|
(ap_con f p⁻¹ p ⬝ whisker_right _ (ap_inv f p))
|
2015-06-23 17:21:04 +00:00
|
|
|
idp :=
|
|
|
|
by cases p;apply vrefl
|
|
|
|
|
2015-09-10 22:32:52 +00:00
|
|
|
theorem ap_ap_is_constant {A B C : Type} (g : B → C) {f : A → B} {b : B}
|
2015-06-23 17:21:04 +00:00
|
|
|
(p : Πx, f x = b) {x y : A} (q : x = y) :
|
2015-09-10 22:32:52 +00:00
|
|
|
square (ap (ap g) (ap_is_constant p q))
|
|
|
|
(ap_is_constant (λa, ap g (p a)) q)
|
2015-06-23 17:21:04 +00:00
|
|
|
(ap_compose g f q)⁻¹
|
|
|
|
(!ap_con ⬝ whisker_left _ !ap_inv) :=
|
|
|
|
begin
|
|
|
|
induction q, esimp, generalize (p x), intro p, cases p, apply ids
|
|
|
|
-- induction q, rewrite [↑ap_compose,ap_inv], apply hinverse, apply ap_con_right_inv_sq,
|
|
|
|
end
|
|
|
|
|
|
|
|
theorem ap_ap_compose {A B C D : Type} (h : C → D) (g : B → C) (f : A → B)
|
|
|
|
{x y : A} (p : x = y) :
|
|
|
|
square (ap_compose (h ∘ g) f p)
|
|
|
|
(ap (ap h) (ap_compose g f p))
|
|
|
|
(ap_compose h (g ∘ f) p)
|
|
|
|
(ap_compose h g (ap f p)) :=
|
|
|
|
by induction p;exact ids
|
|
|
|
|
|
|
|
theorem ap_compose_inv {A B C : Type} (g : B → C) (f : A → B)
|
|
|
|
{x y : A} (p : x = y) :
|
|
|
|
square (ap_compose g f p⁻¹)
|
|
|
|
(inverse2 (ap_compose g f p) ⬝ (ap_inv g (ap f p))⁻¹)
|
|
|
|
(ap_inv (g ∘ f) p)
|
|
|
|
(ap (ap g) (ap_inv f p)) :=
|
|
|
|
by induction p;exact ids
|
|
|
|
|
|
|
|
theorem ap_compose_con (g : B → C) (f : A → B) (p : a₁ = a₂) (q : a₂ = a₃) :
|
|
|
|
square (ap_compose g f (p ⬝ q))
|
|
|
|
(ap_compose g f p ◾ ap_compose g f q ⬝ (ap_con g (ap f p) (ap f q))⁻¹)
|
|
|
|
(ap_con (g ∘ f) p q)
|
|
|
|
(ap (ap g) (ap_con f p q)) :=
|
|
|
|
by induction q;induction p;exact ids
|
|
|
|
|
|
|
|
theorem ap_compose_natural {A B C : Type} (g : B → C) (f : A → B)
|
|
|
|
{x y : A} {p q : x = y} (r : p = q) :
|
|
|
|
square (ap (ap (g ∘ f)) r)
|
|
|
|
(ap (ap g ∘ ap f) r)
|
|
|
|
(ap_compose g f p)
|
|
|
|
(ap_compose g f q) :=
|
2016-11-23 22:59:13 +00:00
|
|
|
natural_square_tr (ap_compose g f) r
|
2015-06-23 17:21:04 +00:00
|
|
|
|
2015-11-22 06:37:13 +00:00
|
|
|
theorem whisker_right_eq_of_con_inv_eq_idp {p q : a₁ = a₂} (r : p ⬝ q⁻¹ = idp) :
|
2016-11-24 05:13:05 +00:00
|
|
|
whisker_right q⁻¹ (eq_of_con_inv_eq_idp r) ⬝ con.right_inv q = r :=
|
2015-11-22 06:37:13 +00:00
|
|
|
by induction q; esimp at r; cases r; reflexivity
|
|
|
|
|
2015-06-26 02:25:08 +00:00
|
|
|
theorem ap_eq_of_con_inv_eq_idp (f : A → B) {p q : a₁ = a₂} (r : p ⬝ q⁻¹ = idp)
|
|
|
|
: ap02 f (eq_of_con_inv_eq_idp r) =
|
|
|
|
eq_of_con_inv_eq_idp (whisker_left _ !ap_inv⁻¹ ⬝ !ap_con⁻¹ ⬝ ap02 f r)
|
|
|
|
:=
|
|
|
|
by induction q;esimp at *;cases r;reflexivity
|
|
|
|
|
2015-08-04 17:00:12 +00:00
|
|
|
theorem eq_of_con_inv_eq_idp_con2 {p p' q q' : a₁ = a₂} (r : p = p') (s : q = q')
|
|
|
|
(t : p' ⬝ q'⁻¹ = idp)
|
|
|
|
: eq_of_con_inv_eq_idp (r ◾ inverse2 s ⬝ t) = r ⬝ eq_of_con_inv_eq_idp t ⬝ s⁻¹ :=
|
|
|
|
by induction s;induction r;induction q;reflexivity
|
|
|
|
|
2016-03-19 15:25:08 +00:00
|
|
|
definition naturality_apd_eq {A : Type} {B : A → Type} {a a₂ : A} {f g : Πa, B a}
|
2015-07-29 17:31:40 +00:00
|
|
|
(H : f ~ g) (p : a = a₂)
|
2016-03-19 15:25:08 +00:00
|
|
|
: apd f p = concato_eq (eq_concato (H a) (apd g p)) (H a₂)⁻¹ :=
|
2015-07-29 17:31:40 +00:00
|
|
|
begin
|
|
|
|
induction p, esimp,
|
|
|
|
generalizes [H a, g a], intro ga Ha, induction Ha,
|
|
|
|
reflexivity
|
|
|
|
end
|
|
|
|
|
|
|
|
theorem con_tr_idp {P : A → Type} {x y : A} (q : x = y) (u : P x) :
|
|
|
|
con_tr idp q u = ap (λp, p ▸ u) (idp_con q) :=
|
|
|
|
by induction q;reflexivity
|
|
|
|
|
2016-11-23 22:59:13 +00:00
|
|
|
definition eq_transport_Fl_idp_left {A B : Type} {a : A} {b : B} (f : A → B) (q : f a = b)
|
|
|
|
: eq_transport_Fl idp q = !idp_con⁻¹ :=
|
2016-04-11 17:11:59 +00:00
|
|
|
by induction q; reflexivity
|
|
|
|
|
|
|
|
definition whisker_left_idp_con_eq_assoc
|
|
|
|
{A : Type} {a₁ a₂ a₃ : A} (p : a₁ = a₂) (q : a₂ = a₃)
|
|
|
|
: whisker_left p (idp_con q)⁻¹ = con.assoc p idp q :=
|
|
|
|
by induction q; reflexivity
|
2015-06-23 17:21:04 +00:00
|
|
|
|
|
|
|
end eq
|