2015-10-26 22:29:19 +00:00
|
|
|
/-
|
|
|
|
Copyright (c) 2015 Floris van Doorn. All rights reserved.
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
Author: Floris van Doorn
|
|
|
|
|
|
|
|
Coherence conditions for operations on pathovers
|
|
|
|
-/
|
|
|
|
|
2015-11-22 06:37:13 +00:00
|
|
|
open function equiv
|
2015-10-26 22:29:19 +00:00
|
|
|
|
|
|
|
namespace eq
|
|
|
|
|
2015-11-22 06:37:13 +00:00
|
|
|
variables {A A' A'' : Type} {B B' : A → Type} {B'' : A' → Type} {C : Π⦃a⦄, B a → Type}
|
|
|
|
{a a₂ a₃ a₄ : A} {p p' p'' : a = a₂} {p₂ p₂' : a₂ = a₃} {p₃ : a₃ = a₄} {p₁₃ : a = a₃}
|
|
|
|
{a' : A'}
|
|
|
|
{b b' : B a} {b₂ b₂' : B a₂} {b₃ : B a₃} {b₄ : B a₄}
|
|
|
|
{c : C b} {c₂ : C b₂}
|
2015-10-26 22:29:19 +00:00
|
|
|
|
|
|
|
definition pathover_ap_id (q : b =[p] b₂) : pathover_ap B id q = change_path (ap_id p)⁻¹ q :=
|
|
|
|
by induction q; reflexivity
|
|
|
|
|
|
|
|
definition pathover_ap_compose (B : A'' → Type) (g : A' → A'') (f : A → A')
|
|
|
|
{b : B (g (f a))} {b₂ : B (g (f a₂))} (q : b =[p] b₂) : pathover_ap B (g ∘ f) q
|
|
|
|
= change_path (ap_compose g f p)⁻¹ (pathover_ap B g (pathover_ap (B ∘ g) f q)) :=
|
|
|
|
by induction q; reflexivity
|
|
|
|
|
|
|
|
definition pathover_ap_compose_rev (B : A'' → Type) (g : A' → A'') (f : A → A')
|
|
|
|
{b : B (g (f a))} {b₂ : B (g (f a₂))} (q : b =[p] b₂) :
|
|
|
|
pathover_ap B g (pathover_ap (B ∘ g) f q)
|
|
|
|
= change_path (ap_compose g f p) (pathover_ap B (g ∘ f) q) :=
|
|
|
|
by induction q; reflexivity
|
|
|
|
|
2018-08-19 11:51:12 +00:00
|
|
|
definition pathover_idp_of_eq_def (r : b = b') : pathover_of_tr_eq r = pathover_idp_of_eq r :=
|
2015-10-26 22:29:19 +00:00
|
|
|
idp
|
|
|
|
|
|
|
|
definition pathover_of_tr_eq_eq_concato (r : p ▸ b = b₂)
|
|
|
|
: pathover_of_tr_eq r = pathover_tr p b ⬝o pathover_idp_of_eq r :=
|
|
|
|
by induction r; induction p; reflexivity
|
|
|
|
|
2016-06-23 20:49:54 +00:00
|
|
|
definition apd011_eq_apo11_apd (f : Πa, B a → A') (p : a = a₂) (q : b =[p] b₂)
|
|
|
|
: apd011 f p q = apo11_constant_right (apd f p) q :=
|
2015-10-26 22:29:19 +00:00
|
|
|
by induction q; reflexivity
|
|
|
|
|
2015-11-22 06:37:13 +00:00
|
|
|
definition change_path_con (q : p = p') (q' : p' = p'') (r : b =[p] b₂) :
|
|
|
|
change_path (q ⬝ q') r = change_path q' (change_path q r) :=
|
|
|
|
by induction q; induction q'; reflexivity
|
|
|
|
|
|
|
|
definition change_path_invo (q : p = p') (r : b =[p] b₂) :
|
|
|
|
change_path (inverse2 q) r⁻¹ᵒ = (change_path q r)⁻¹ᵒ :=
|
|
|
|
by induction q; reflexivity
|
|
|
|
|
|
|
|
definition change_path_cono (q : p = p') (q₂ : p₂ = p₂') (r : b =[p] b₂) (r₂ : b₂ =[p₂] b₃):
|
|
|
|
change_path (q ◾ q₂) (r ⬝o r₂) = change_path q r ⬝o change_path q₂ r₂ :=
|
|
|
|
by induction q; induction q₂; reflexivity
|
|
|
|
|
|
|
|
definition pathover_of_pathover_ap_invo (B' : A' → Type) (f : A → A')
|
|
|
|
{b : B' (f a)} {b₂ : B' (f a₂)} (q : b =[ap f p] b₂) :
|
|
|
|
pathover_of_pathover_ap B' f (change_path (ap_inv f p)⁻¹ q⁻¹ᵒ) =
|
|
|
|
(pathover_of_pathover_ap B' f q)⁻¹ᵒ:=
|
|
|
|
by induction p; eapply idp_rec_on q; reflexivity
|
|
|
|
|
|
|
|
definition pathover_of_pathover_ap_cono (B' : A' → Type) (f : A → A')
|
|
|
|
{b : B' (f a)} {b₂ : B' (f a₂)} {b₃ : B' (f a₃)} (q : b =[ap f p] b₂) (q₂ : b₂ =[ap f p₂] b₃) :
|
|
|
|
pathover_of_pathover_ap B' f (change_path (ap_con f p p₂)⁻¹ (q ⬝o q₂)) =
|
|
|
|
pathover_of_pathover_ap B' f q ⬝o pathover_of_pathover_ap B' f q₂ :=
|
|
|
|
by induction p; induction p₂; eapply idp_rec_on q; eapply idp_rec_on q₂; reflexivity
|
|
|
|
|
|
|
|
definition pathover_ap_pathover_of_pathover_ap (P : A'' → Type) (g : A' → A'') (f : A → A')
|
|
|
|
{p : a = a₂} {b : P (g (f a))} {b₂ : P (g (f a₂))} (q : b =[ap f p] b₂) :
|
|
|
|
pathover_ap P (g ∘ f) (pathover_of_pathover_ap (P ∘ g) f q) =
|
|
|
|
change_path (ap_compose g f p)⁻¹ (pathover_ap P g q) :=
|
|
|
|
by induction p; eapply (idp_rec_on q); reflexivity
|
|
|
|
|
|
|
|
definition change_path_pathover_of_pathover_ap (B' : A' → Type) (f : A → A') {p p' : a = a₂}
|
|
|
|
(r : p = p') {b : B' (f a)} {b₂ : B' (f a₂)} (q : b =[ap f p] b₂) :
|
|
|
|
change_path r (pathover_of_pathover_ap B' f q) =
|
|
|
|
pathover_of_pathover_ap B' f (change_path (ap02 f r) q) :=
|
|
|
|
by induction r; reflexivity
|
|
|
|
|
|
|
|
definition pathover_ap_change_path (B' : A' → Type) (f : A → A') {p p' : a = a₂}
|
|
|
|
(r : p = p') {b : B' (f a)} {b₂ : B' (f a₂)} (q : b =[p] b₂) :
|
|
|
|
pathover_ap B' f (change_path r q) = change_path (ap02 f r) (pathover_ap B' f q) :=
|
|
|
|
by induction r; reflexivity
|
|
|
|
|
|
|
|
definition change_path_equiv [constructor] (b : B a) (b₂ : B a₂) (q : p = p')
|
|
|
|
: (b =[p] b₂) ≃ (b =[p'] b₂) :=
|
|
|
|
begin
|
|
|
|
fapply equiv.MK,
|
|
|
|
{ exact change_path q},
|
|
|
|
{ exact change_path q⁻¹},
|
|
|
|
{ intro r, induction q, reflexivity},
|
|
|
|
{ intro r, induction q, reflexivity},
|
|
|
|
end
|
|
|
|
|
2016-03-19 15:25:08 +00:00
|
|
|
definition apd_ap {B : A' → Type} (g : Πb, B b) (f : A → A') (p : a = a₂)
|
|
|
|
: apd g (ap f p) = pathover_ap B f (apd (λx, g (f x)) p) :=
|
2015-11-22 06:37:13 +00:00
|
|
|
by induction p; reflexivity
|
|
|
|
|
2016-03-19 15:25:08 +00:00
|
|
|
definition apd_eq_apd_ap {B : A' → Type} (g : Πb, B b) (f : A → A') (p : a = a₂)
|
|
|
|
: apd (λx, g (f x)) p = pathover_of_pathover_ap B f (apd g (ap f p)) :=
|
2015-11-22 06:37:13 +00:00
|
|
|
by induction p; reflexivity
|
|
|
|
|
|
|
|
definition ap_compose_ap02_constant {A B C : Type} {a a' : A} (p : a = a') (b : B) (c : C) :
|
|
|
|
ap_compose (λc, b) (λa, c) p ⬝ ap02 (λc, b) (ap_constant p c) = ap_constant p b :=
|
|
|
|
by induction p; reflexivity
|
|
|
|
|
2016-03-19 15:25:08 +00:00
|
|
|
theorem apd_constant (b : B'' a') (p : a = a) :
|
|
|
|
pathover_ap B'' (λa, a') (apd (λa, b) p) = change_path (ap_constant p a')⁻¹ idpo :=
|
2015-11-22 06:37:13 +00:00
|
|
|
begin
|
2016-03-19 15:25:08 +00:00
|
|
|
rewrite [apd_eq_apd_ap _ _ p],
|
|
|
|
let y := !change_path_of_pathover (apd (apd id) (ap_constant p b))⁻¹ᵒ,
|
2015-12-10 18:37:55 +00:00
|
|
|
rewrite -y, esimp,
|
2015-11-22 06:37:13 +00:00
|
|
|
refine !pathover_ap_pathover_of_pathover_ap ⬝ _,
|
|
|
|
rewrite pathover_ap_change_path,
|
|
|
|
rewrite -change_path_con, apply ap (λx, change_path x idpo),
|
|
|
|
unfold ap02, rewrite [ap_inv,-con_inv], apply inverse2,
|
|
|
|
apply ap_compose_ap02_constant
|
|
|
|
end
|
|
|
|
|
2017-06-02 16:13:20 +00:00
|
|
|
theorem apd_constant' {A A' : Type} {B : A' → Type} {a₁ a₂ : A} {a' : A'} (b : B a')
|
|
|
|
(p : a₁ = a₂) : apd (λx, b) p = pathover_of_eq p idp :=
|
|
|
|
by induction p; reflexivity
|
|
|
|
|
2016-03-19 15:25:08 +00:00
|
|
|
definition apd_change_path {B : A → Type} {a a₂ : A} (f : Πa, B a) {p p' : a = a₂} (s : p = p')
|
|
|
|
: apd f p' = change_path s (apd f p) :=
|
2015-11-22 06:37:13 +00:00
|
|
|
by induction s; reflexivity
|
|
|
|
|
|
|
|
definition cono_invo_eq_idpo {q q' : b =[p] b₂} (r : q = q')
|
|
|
|
: change_path (con.right_inv p) (q ⬝o q'⁻¹ᵒ) = idpo :=
|
|
|
|
by induction r; induction q; reflexivity
|
|
|
|
|
2016-06-23 20:49:54 +00:00
|
|
|
definition tr_eq_of_pathover_concato_eq {A : Type} {B : A → Type} {a a' : A} {p : a = a'}
|
|
|
|
{b : B a} {b' b'' : B a'} (q : b =[p] b') (r : b' = b'') :
|
|
|
|
tr_eq_of_pathover (q ⬝op r) = tr_eq_of_pathover q ⬝ r :=
|
|
|
|
by induction r; reflexivity
|
|
|
|
|
2018-08-19 11:51:12 +00:00
|
|
|
definition pathover_tr_pathover_idp_of_eq {A : Type} {B : A → Type} {a a' : A} {b : B a} {b' : B a'} {p : a = a'}
|
|
|
|
(q : b =[p] b') :
|
|
|
|
pathover_tr p b ⬝o pathover_idp_of_eq (tr_eq_of_pathover q) = q :=
|
|
|
|
begin induction q; reflexivity end
|
|
|
|
|
|
|
|
definition pathover_of_tr_eq_idp' {A : Type} {B : A → Type} {a a₂ : A} (p : a = a₂) (b : B a) :
|
|
|
|
pathover_of_tr_eq idp = pathover_tr p b :=
|
|
|
|
by induction p; constructor
|
|
|
|
|
|
|
|
definition eq_of_pathover_apo {A C : Type} {B : A → Type} {a a' : A} {b : B a} {b' : B a'}
|
|
|
|
{p : a = a'} (g : Πa, B a → C) (q : b =[p] b') :
|
|
|
|
eq_of_pathover (apo g q) = apd011 g p q :=
|
|
|
|
by induction q; reflexivity
|
|
|
|
|
|
|
|
definition pathover_ap_cono {A A' : Type} {a₁ a₂ a₃ : A}
|
|
|
|
{p₁ : a₁ = a₂} {p₂ : a₂ = a₃} (B' : A' → Type) (f : A → A')
|
|
|
|
{b₁ : B' (f a₁)} {b₂ : B' (f a₂)} {b₃ : B' (f a₃)}
|
|
|
|
(q₁ : b₁ =[p₁] b₂) (q₂ : b₂ =[p₂] b₃) :
|
|
|
|
pathover_ap B' f (q₁ ⬝o q₂) =
|
|
|
|
change_path !ap_con⁻¹ (pathover_ap B' f q₁ ⬝o pathover_ap B' f q₂) :=
|
|
|
|
by induction q₁; induction q₂; reflexivity
|
|
|
|
|
|
|
|
definition concato_eq_eq {A : Type} {B : A → Type} {a₁ a₂ : A} {p₁ : a₁ = a₂}
|
|
|
|
{b₁ : B a₁} {b₂ b₂' : B a₂} (r : b₁ =[p₁] b₂) (q : b₂ = b₂') :
|
|
|
|
r ⬝op q = r ⬝o pathover_idp_of_eq q :=
|
|
|
|
by induction q; reflexivity
|
|
|
|
|
|
|
|
definition eq_tr_of_pathover_con_tr_eq_of_pathover {A : Type} {B : A → Type}
|
|
|
|
{a₁ a₂ : A} (p : a₁ = a₂) {b₁ : B a₁} {b₂ : B a₂} (q : b₁ =[p] b₂) :
|
|
|
|
eq_tr_of_pathover q ⬝ tr_eq_of_pathover q⁻¹ᵒ = idp :=
|
|
|
|
by induction q; reflexivity
|
|
|
|
|
2015-10-26 22:29:19 +00:00
|
|
|
end eq
|