From b2e414dc9c9b922cac626ae771678e0e187a63ff Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Thu, 8 Feb 2024 00:05:07 +0100 Subject: [PATCH 01/53] `is-emb-is-coherently-invertible` --- .../coherently-invertible-maps.lagda.md | 157 ++++++++++++++---- .../contractible-maps.lagda.md | 4 +- src/foundation-core/equivalences.lagda.md | 42 +---- src/foundation-core/invertible-maps.lagda.md | 35 ++-- .../coherently-invertible-maps.lagda.md | 100 +++++------ src/foundation/invertible-maps.lagda.md | 36 ++-- 6 files changed, 221 insertions(+), 153 deletions(-) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index 177ec4b883..62787d6011 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -7,6 +7,7 @@ module foundation-core.coherently-invertible-maps where
Imports ```agda +open import foundation.action-on-identifications-binary-functions open import foundation.action-on-identifications-functions open import foundation.dependent-pair-types open import foundation.universe-levels @@ -59,36 +60,38 @@ module _ map-inv-is-coherently-invertible : B → A map-inv-is-coherently-invertible = pr1 H - is-retraction-is-coherently-invertible : - (f ∘ map-inv-is-coherently-invertible) ~ id - is-retraction-is-coherently-invertible = pr1 (pr2 H) + is-section-map-inv-is-coherently-invertible : + f ∘ map-inv-is-coherently-invertible ~ id + is-section-map-inv-is-coherently-invertible = pr1 (pr2 H) - is-section-is-coherently-invertible : - (map-inv-is-coherently-invertible ∘ f) ~ id - is-section-is-coherently-invertible = pr1 (pr2 (pr2 H)) + is-retraction-map-inv-is-coherently-invertible : + map-inv-is-coherently-invertible ∘ f ~ id + is-retraction-map-inv-is-coherently-invertible = pr1 (pr2 (pr2 H)) coh-is-coherently-invertible : coherence-is-coherently-invertible f ( map-inv-is-coherently-invertible) - ( is-retraction-is-coherently-invertible) - ( is-section-is-coherently-invertible) + ( is-section-map-inv-is-coherently-invertible) + ( is-retraction-map-inv-is-coherently-invertible) coh-is-coherently-invertible = pr2 (pr2 (pr2 H)) is-invertible-is-coherently-invertible : is-invertible f pr1 is-invertible-is-coherently-invertible = map-inv-is-coherently-invertible pr1 (pr2 is-invertible-is-coherently-invertible) = - is-retraction-is-coherently-invertible + is-section-map-inv-is-coherently-invertible pr2 (pr2 is-invertible-is-coherently-invertible) = - is-section-is-coherently-invertible + is-retraction-map-inv-is-coherently-invertible section-is-coherently-invertible : section f pr1 section-is-coherently-invertible = map-inv-is-coherently-invertible - pr2 section-is-coherently-invertible = is-retraction-is-coherently-invertible + pr2 section-is-coherently-invertible = + is-section-map-inv-is-coherently-invertible retraction-is-coherently-invertible : retraction f pr1 retraction-is-coherently-invertible = map-inv-is-coherently-invertible - pr2 retraction-is-coherently-invertible = is-section-is-coherently-invertible + pr2 retraction-is-coherently-invertible = + is-retraction-map-inv-is-coherently-invertible ``` ## Properties @@ -115,46 +118,56 @@ module _ where abstract - is-section-map-inv-is-invertible : + is-section-map-inv-is-coherently-invertible-is-invertible : (H : is-invertible f) → (f ∘ map-inv-is-invertible H) ~ id - is-section-map-inv-is-invertible H y = - ( inv (is-retraction-is-invertible H (f (map-inv-is-invertible H y)))) ∙ - ( ( ap f (is-section-is-invertible H (map-inv-is-invertible H y))) ∙ - ( is-retraction-is-invertible H y)) - - is-retraction-map-inv-is-invertible : + is-section-map-inv-is-coherently-invertible-is-invertible H y = + ( inv + ( is-section-map-inv-is-invertible H (f (map-inv-is-invertible H y)))) ∙ + ( ( ap + ( f) + ( is-retraction-map-inv-is-invertible + ( H) + ( map-inv-is-invertible H y))) ∙ + ( is-section-map-inv-is-invertible H y)) + + is-retraction-map-inv-is-coherently-invertible-is-invertible : (H : is-invertible f) → (map-inv-is-invertible H ∘ f) ~ id - is-retraction-map-inv-is-invertible = is-section-is-invertible + is-retraction-map-inv-is-coherently-invertible-is-invertible = + is-retraction-map-inv-is-invertible inv-coherence-map-inv-is-invertible : (H : is-invertible f) → - f ·l is-retraction-map-inv-is-invertible H ~ - is-section-map-inv-is-invertible H ·r f + f ·l is-retraction-map-inv-is-coherently-invertible-is-invertible H ~ + is-section-map-inv-is-coherently-invertible-is-invertible H ·r f inv-coherence-map-inv-is-invertible H x = left-transpose-eq-concat - ( is-retraction-is-invertible H (f (map-inv-is-invertible H (f x)))) - ( ap f (is-section-is-invertible H x)) + ( is-section-map-inv-is-invertible + ( H) + ( f (map-inv-is-invertible H (f x)))) + ( ap f (is-retraction-map-inv-is-invertible H x)) ( ( ap f - ( is-section-is-invertible H (map-inv-is-invertible H (f x)))) ∙ - ( is-retraction-is-invertible H (f x))) + ( is-retraction-map-inv-is-invertible + ( H) + ( map-inv-is-invertible H (f x)))) ∙ + ( is-section-map-inv-is-invertible H (f x))) ( ( nat-htpy - ( right-whisker-comp (is-retraction-is-invertible H) f) - ( is-section-is-invertible H x)) ∙ + ( right-whisker-comp (is-section-map-inv-is-invertible H) f) + ( is-retraction-map-inv-is-invertible H x)) ∙ ( ap - ( concat' _ (is-retraction-is-invertible H (f x))) + ( concat' _ (is-section-map-inv-is-invertible H (f x))) ( ( ap-comp f ( map-inv-is-invertible H ∘ f) - ( is-section-is-invertible H x)) ∙ + ( is-retraction-map-inv-is-invertible H x)) ∙ ( inv ( ap ( ap f) ( coh-is-coherently-invertible-id - ( is-section-is-invertible H) x)))))) + ( is-retraction-map-inv-is-invertible H) x)))))) coherence-map-inv-is-invertible : ( H : is-invertible f) → - ( is-section-map-inv-is-invertible H ·r f) ~ - ( f ·l is-retraction-map-inv-is-invertible H) + ( is-section-map-inv-is-coherently-invertible-is-invertible H ·r f) ~ + ( f ·l is-retraction-map-inv-is-coherently-invertible-is-invertible H) coherence-map-inv-is-invertible H x = inv (inv-coherence-map-inv-is-invertible H x) @@ -164,13 +177,87 @@ module _ pr1 (is-coherently-invertible-is-invertible H) = map-inv-is-invertible H pr1 (pr2 (is-coherently-invertible-is-invertible H)) = - is-section-map-inv-is-invertible H + is-section-map-inv-is-coherently-invertible-is-invertible H pr1 (pr2 (pr2 (is-coherently-invertible-is-invertible H))) = - is-retraction-map-inv-is-invertible H + is-retraction-map-inv-is-coherently-invertible-is-invertible H pr2 (pr2 (pr2 (is-coherently-invertible-is-invertible H))) = coherence-map-inv-is-invertible H ``` +### Coherently invertible maps are embeddings + +We first construct the converse map to the action on identifications. This is +essentially a repeat of the proof that maps with retractions are injective, and +we repeat the proof to avoid cyclic dependencies. + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} {f : A → B} + (H : is-coherently-invertible f) {x y : A} + where + + map-inv-ap-is-coherently-invertible : f x = f y → x = y + map-inv-ap-is-coherently-invertible p = + ( inv (is-retraction-map-inv-is-coherently-invertible H x)) ∙ + ( ( ap (map-inv-is-coherently-invertible H) p) ∙ + ( is-retraction-map-inv-is-coherently-invertible H y)) +``` + +Next, we show that this converse map is a section and retraction of `ap f`. + +```agda + abstract + is-section-map-inv-ap-is-coherently-invertible : + ap f ∘ map-inv-ap-is-coherently-invertible ~ id + is-section-map-inv-ap-is-coherently-invertible p = + ( ap-concat f + ( inv (is-retraction-map-inv-is-coherently-invertible H x)) + ( ( ap (map-inv-is-coherently-invertible H) p) ∙ + ( is-retraction-map-inv-is-coherently-invertible H y))) ∙ + ( ( ap-binary + ( _∙_) + ( ap-inv f (is-retraction-map-inv-is-coherently-invertible H x)) + ( ( ap-concat f + ( ap (map-inv-is-coherently-invertible H) p) + ( is-retraction-map-inv-is-coherently-invertible H y)) ∙ + ( ap-binary + ( _∙_) + ( inv (ap-comp f (map-inv-is-coherently-invertible H) p)) + ( inv (coh-is-coherently-invertible H y))))) ∙ + ( inv + ( left-transpose-eq-concat + ( ap f (is-retraction-map-inv-is-coherently-invertible H x)) + ( p) + ( ( ap (f ∘ map-inv-is-coherently-invertible H) p) ∙ + ( is-section-map-inv-is-coherently-invertible H (f y))) + ( ( ap-binary + ( _∙_) + ( inv (coh-is-coherently-invertible H x)) + ( inv (ap-id p))) ∙ + ( nat-htpy (is-section-map-inv-is-coherently-invertible H) p))))) + + abstract + is-retraction-map-inv-ap-is-coherently-invertible : + map-inv-ap-is-coherently-invertible ∘ ap f ~ id + is-retraction-map-inv-ap-is-coherently-invertible refl = + left-inv (is-retraction-map-inv-is-coherently-invertible H x) + + abstract + is-invertible-ap-is-coherently-invertible : is-invertible (ap f {x} {y}) + pr1 is-invertible-ap-is-coherently-invertible = + map-inv-ap-is-coherently-invertible + pr1 (pr2 is-invertible-ap-is-coherently-invertible) = + is-section-map-inv-ap-is-coherently-invertible + pr2 (pr2 is-invertible-ap-is-coherently-invertible) = + is-retraction-map-inv-ap-is-coherently-invertible + + is-coherently-invertible-ap-is-coherently-invertible : + is-coherently-invertible (ap f {x} {y}) + is-coherently-invertible-ap-is-coherently-invertible = + is-coherently-invertible-is-invertible + ( is-invertible-ap-is-coherently-invertible) +``` + ## See also - For the notion of biinvertible maps see diff --git a/src/foundation-core/contractible-maps.lagda.md b/src/foundation-core/contractible-maps.lagda.md index 46a3cecce5..bdab98b6f0 100644 --- a/src/foundation-core/contractible-maps.lagda.md +++ b/src/foundation-core/contractible-maps.lagda.md @@ -93,14 +93,14 @@ module _ pr1 (center-fiber-is-coherently-invertible H y) = map-inv-is-coherently-invertible H y pr2 (center-fiber-is-coherently-invertible H y) = - is-retraction-is-coherently-invertible H y + is-section-map-inv-is-coherently-invertible H y contraction-fiber-is-coherently-invertible : (H : is-coherently-invertible f) → (y : B) → (t : fiber f y) → (center-fiber-is-coherently-invertible H y) = t contraction-fiber-is-coherently-invertible H y (pair x refl) = eq-Eq-fiber f y - ( is-section-is-coherently-invertible H x) + ( is-retraction-map-inv-is-coherently-invertible H x) ( ( right-unit) ∙ ( inv ( coh-is-coherently-invertible H x))) diff --git a/src/foundation-core/equivalences.lagda.md b/src/foundation-core/equivalences.lagda.md index 3d1af2c9bb..8315ef527f 100644 --- a/src/foundation-core/equivalences.lagda.md +++ b/src/foundation-core/equivalences.lagda.md @@ -232,11 +232,13 @@ module _ is-section-map-inv-is-equiv : is-section f map-inv-is-equiv is-section-map-inv-is-equiv = - is-section-map-inv-is-invertible (is-invertible-is-equiv H) + is-section-map-inv-is-coherently-invertible-is-invertible + ( is-invertible-is-equiv H) is-retraction-map-inv-is-equiv : is-retraction f map-inv-is-equiv is-retraction-map-inv-is-equiv = - is-retraction-map-inv-is-invertible (is-invertible-is-equiv H) + is-retraction-map-inv-is-coherently-invertible-is-invertible + ( is-invertible-is-equiv H) coherence-map-inv-is-equiv : coherence-is-coherently-invertible f @@ -662,38 +664,10 @@ module _ abstract is-emb-is-equiv : {f : A → B} → is-equiv f → (x y : A) → is-equiv (ap f {x} {y}) - is-emb-is-equiv {f} H x y = - is-equiv-is-invertible - ( λ p → - ( inv (is-retraction-map-inv-is-equiv H x)) ∙ - ( ( ap (map-inv-is-equiv H) p) ∙ - ( is-retraction-map-inv-is-equiv H y))) - ( λ p → - ( ap-concat f - ( inv (is-retraction-map-inv-is-equiv H x)) - ( ap (map-inv-is-equiv H) p ∙ is-retraction-map-inv-is-equiv H y)) ∙ - ( ( ap-binary - ( λ u v → u ∙ v) - ( ap-inv f (is-retraction-map-inv-is-equiv H x)) - ( ( ap-concat f - ( ap (map-inv-is-equiv H) p) - ( is-retraction-map-inv-is-equiv H y)) ∙ - ( ap-binary - ( λ u v → u ∙ v) - ( inv (ap-comp f (map-inv-is-equiv H) p)) - ( inv (coherence-map-inv-is-equiv H y))))) ∙ - ( inv - ( left-transpose-eq-concat - ( ap f (is-retraction-map-inv-is-equiv H x)) - ( p) - ( ( ap (f ∘ map-inv-is-equiv H) p) ∙ - ( is-section-map-inv-is-equiv H (f y))) - ( ( ap-binary - ( λ u v → u ∙ v) - ( inv (coherence-map-inv-is-equiv H x)) - ( inv (ap-id p))) ∙ - ( nat-htpy (is-section-map-inv-is-equiv H) p)))))) - ( λ where refl → left-inv (is-retraction-map-inv-is-equiv H x)) + is-emb-is-equiv H x y = + is-equiv-is-invertible' + ( is-invertible-ap-is-coherently-invertible + ( is-coherently-invertible-is-equiv H)) equiv-ap : (e : A ≃ B) (x y : A) → (x = y) ≃ (map-equiv e x = map-equiv e y) diff --git a/src/foundation-core/invertible-maps.lagda.md b/src/foundation-core/invertible-maps.lagda.md index 3392fd1794..4169e13d85 100644 --- a/src/foundation-core/invertible-maps.lagda.md +++ b/src/foundation-core/invertible-maps.lagda.md @@ -7,12 +7,15 @@ module foundation-core.invertible-maps where
Imports ```agda +open import foundation.action-on-identifications-binary-functions +open import foundation.action-on-identifications-functions open import foundation.dependent-pair-types open import foundation.universe-levels open import foundation-core.cartesian-product-types open import foundation-core.function-types open import foundation-core.homotopies +open import foundation-core.identity-types open import foundation-core.retractions open import foundation-core.sections ``` @@ -64,19 +67,19 @@ module _ is-inverse-map-inv-is-invertible : is-inverse f map-inv-is-invertible is-inverse-map-inv-is-invertible = pr2 g - is-retraction-is-invertible : (f ∘ map-inv-is-invertible) ~ id - is-retraction-is-invertible = pr1 is-inverse-map-inv-is-invertible + is-section-map-inv-is-invertible : f ∘ map-inv-is-invertible ~ id + is-section-map-inv-is-invertible = pr1 is-inverse-map-inv-is-invertible - is-section-is-invertible : (map-inv-is-invertible ∘ f) ~ id - is-section-is-invertible = pr2 is-inverse-map-inv-is-invertible + is-retraction-map-inv-is-invertible : map-inv-is-invertible ∘ f ~ id + is-retraction-map-inv-is-invertible = pr2 is-inverse-map-inv-is-invertible section-is-invertible : section f pr1 section-is-invertible = map-inv-is-invertible - pr2 section-is-invertible = is-retraction-is-invertible + pr2 section-is-invertible = is-section-map-inv-is-invertible retraction-is-invertible : retraction f pr1 retraction-is-invertible = map-inv-is-invertible - pr2 retraction-is-invertible = is-section-is-invertible + pr2 retraction-is-invertible = is-retraction-map-inv-is-invertible ``` ### The type of invertible maps @@ -100,17 +103,17 @@ module _ map-inv-invertible-map = map-inv-is-invertible ∘ is-invertible-map-invertible-map - is-section-map-invertible-map : + is-retraction-map-inv-invertible-map : (f : invertible-map A B) → - (map-inv-invertible-map f ∘ map-invertible-map f) ~ id - is-section-map-invertible-map = - is-section-is-invertible ∘ is-invertible-map-invertible-map + map-inv-invertible-map f ∘ map-invertible-map f ~ id + is-retraction-map-inv-invertible-map = + is-retraction-map-inv-is-invertible ∘ is-invertible-map-invertible-map - is-retraction-map-invertible-map : + is-section-map-inv-invertible-map : (f : invertible-map A B) → - (map-invertible-map f ∘ map-inv-invertible-map f) ~ id - is-retraction-map-invertible-map = - is-retraction-is-invertible ∘ is-invertible-map-invertible-map + map-invertible-map f ∘ map-inv-invertible-map f ~ id + is-section-map-inv-invertible-map = + is-section-map-inv-is-invertible ∘ is-invertible-map-invertible-map ``` ## Properties @@ -123,8 +126,8 @@ module _ where inv-is-inverse : {g : B → A} → is-inverse f g → is-inverse g f - pr1 (inv-is-inverse {g} H) = is-section-is-invertible (g , H) - pr2 (inv-is-inverse {g} H) = is-retraction-is-invertible (g , H) + pr1 (inv-is-inverse {g} H) = is-retraction-map-inv-is-invertible (g , H) + pr2 (inv-is-inverse {g} H) = is-section-map-inv-is-invertible (g , H) inv-is-invertible : (g : is-invertible f) → is-invertible (map-inv-is-invertible g) diff --git a/src/foundation/coherently-invertible-maps.lagda.md b/src/foundation/coherently-invertible-maps.lagda.md index 9bc14bb139..74eb88be1f 100644 --- a/src/foundation/coherently-invertible-maps.lagda.md +++ b/src/foundation/coherently-invertible-maps.lagda.md @@ -35,63 +35,51 @@ open import foundation-core.type-theoretic-principle-of-choice ### Being coherently invertible is a property ```agda -abstract - is-prop-is-coherently-invertible : - {l1 l2 : Level} {A : UU l1} {B : UU l2} (f : A → B) → - is-prop (is-coherently-invertible f) - is-prop-is-coherently-invertible {A = A} {B} f = - is-prop-is-proof-irrelevant - ( λ H → - is-contr-equiv' - ( Σ ( section f) - ( λ s → - Σ ( ( map-section f s ∘ f) ~ id) - ( λ H → - ( right-whisker-comp (is-section-map-section f s) f) ~ - ( left-whisker-comp f H)))) - ( associative-Σ - ( B → A) - ( λ g → (f ∘ g) ~ id) - ( λ s → - Σ ( ( map-section f s ∘ f) ~ id) - ( λ H → - ( right-whisker-comp (is-section-map-section f s) f) ~ - ( left-whisker-comp f H)))) - ( is-contr-Σ - ( is-contr-section-is-equiv (is-equiv-is-coherently-invertible H)) - ( section-is-coherently-invertible H) - ( is-contr-equiv' - ( (x : A) → - Σ ( map-inv-is-coherently-invertible H (f x) = x) - ( λ p → - is-retraction-is-coherently-invertible H (f x) = ap f p)) - ( distributive-Π-Σ) - ( is-contr-Π - ( λ x → - is-contr-equiv' - ( fiber - ( ap f) - ( is-retraction-is-coherently-invertible H (f x))) - ( equiv-tot - ( λ p → - equiv-inv - ( ap f p) - ( is-retraction-is-coherently-invertible H (f x)))) - ( is-contr-map-is-equiv - ( is-emb-is-equiv - ( is-equiv-is-coherently-invertible H) - ( map-inv-is-coherently-invertible H (f x)) x) - ( is-retraction-is-coherently-invertible H (f x)))))))) +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} (f : A → B) + where -abstract - is-equiv-is-coherently-invertible-is-equiv : - {l1 l2 : Level} {A : UU l1} {B : UU l2} (f : A → B) → - is-equiv (is-coherently-invertible-is-equiv {f = f}) - is-equiv-is-coherently-invertible-is-equiv f = - is-equiv-is-prop - ( is-property-is-equiv f) - ( is-prop-is-coherently-invertible f) - ( is-equiv-is-coherently-invertible) + abstract + is-proof-irrelevant-is-coherently-invertible : + is-proof-irrelevant (is-coherently-invertible f) + is-proof-irrelevant-is-coherently-invertible H = + is-contr-equiv' + ( _) + ( associative-Σ _ _ _) + ( is-contr-Σ + ( is-contr-section-is-equiv (is-equiv-is-coherently-invertible H)) + ( section-is-coherently-invertible H) + ( is-contr-equiv' + ( _) + ( distributive-Π-Σ) + ( is-contr-Π + ( λ x → + is-contr-equiv' + ( _) + ( equiv-tot + ( λ p → + equiv-inv + ( ap f p) + ( is-section-map-inv-is-coherently-invertible H (f x)))) + ( is-contr-map-is-equiv + ( is-emb-is-equiv + ( is-equiv-is-coherently-invertible H) + ( map-inv-is-coherently-invertible H (f x)) x) + ( is-section-map-inv-is-coherently-invertible H (f x))))))) + + abstract + is-prop-is-coherently-invertible : is-prop (is-coherently-invertible f) + is-prop-is-coherently-invertible = + is-prop-is-proof-irrelevant is-proof-irrelevant-is-coherently-invertible + + abstract + is-equiv-is-coherently-invertible-is-equiv : + is-equiv (is-coherently-invertible-is-equiv {f = f}) + is-equiv-is-coherently-invertible-is-equiv = + is-equiv-is-prop + ( is-property-is-equiv f) + ( is-prop-is-coherently-invertible) + ( is-equiv-is-coherently-invertible) ``` ## See also diff --git a/src/foundation/invertible-maps.lagda.md b/src/foundation/invertible-maps.lagda.md index 6f2b2ec088..623e969144 100644 --- a/src/foundation/invertible-maps.lagda.md +++ b/src/foundation/invertible-maps.lagda.md @@ -9,6 +9,7 @@ open import foundation-core.invertible-maps public
Imports ```agda +open import foundation.action-on-identifications-functions open import foundation.commuting-triangles-of-homotopies open import foundation.dependent-pair-types open import foundation.equality-cartesian-product-types @@ -31,6 +32,7 @@ open import foundation.universe-levels open import foundation.whiskering-homotopies-composition open import foundation-core.cartesian-product-types +open import foundation-core.coherently-invertible-maps open import foundation-core.function-types open import foundation-core.functoriality-dependent-pair-types open import foundation-core.identity-types @@ -110,9 +112,9 @@ module _ ( is-torsorial-htpy (map-inv-is-invertible s)) ( map-inv-is-invertible s , refl-htpy) ( is-torsorial-Eq-structure - ( is-torsorial-htpy (is-retraction-is-invertible s)) - ( is-retraction-is-invertible s , refl-htpy) - (is-torsorial-htpy (is-section-is-invertible s))) + ( is-torsorial-htpy (is-section-map-inv-is-invertible s)) + ( is-section-map-inv-is-invertible s , refl-htpy) + (is-torsorial-htpy (is-retraction-map-inv-is-invertible s))) is-equiv-htpy-eq-is-invertible : (s t : is-invertible f) → is-equiv (htpy-eq-is-invertible s t) @@ -144,12 +146,12 @@ module _ map-inv-invertible-map s ~ map-inv-invertible-map t → UU (l1 ⊔ l2) coherence-htpy-invertible-map s t H I = ( coherence-triangle-homotopies - ( is-retraction-map-invertible-map s) - ( is-retraction-map-invertible-map t) + ( is-section-map-inv-invertible-map s) + ( is-section-map-inv-invertible-map t) ( horizontal-concat-htpy I H)) × ( coherence-triangle-homotopies - ( is-section-map-invertible-map s) - ( is-section-map-invertible-map t) + ( is-retraction-map-inv-invertible-map s) + ( is-retraction-map-inv-invertible-map t) ( horizontal-concat-htpy H I)) htpy-invertible-map : (s t : invertible-map A B) → UU (l1 ⊔ l2) @@ -179,9 +181,9 @@ module _ ( is-torsorial-htpy (map-inv-invertible-map s)) ( map-inv-invertible-map s , refl-htpy) ( is-torsorial-Eq-structure - ( is-torsorial-htpy (is-retraction-map-invertible-map s)) - ( is-retraction-map-invertible-map s , refl-htpy) - ( is-torsorial-htpy (is-section-map-invertible-map s)))) + ( is-torsorial-htpy (is-section-map-inv-invertible-map s)) + ( is-section-map-inv-invertible-map s , refl-htpy) + ( is-torsorial-htpy (is-retraction-map-inv-invertible-map s)))) is-equiv-htpy-eq-invertible-map : (s t : invertible-map A B) → is-equiv (htpy-eq-invertible-map s t) @@ -375,6 +377,20 @@ module _ equiv-free-loop-equivalence-invertible-equivalence ``` +### Invertible maps are embeddings + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} {f : A → B} + (H : is-invertible f) {x y : A} + where + + is-invertible-ap-is-invertible : is-invertible (ap f {x} {y}) + is-invertible-ap-is-invertible = + is-invertible-ap-is-coherently-invertible + ( is-coherently-invertible-is-invertible H) +``` + ## See also - For the coherent notion of invertible maps see From bc58787dac659f1749eb3adc8e2b99c1f927cf1d Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Thu, 8 Feb 2024 00:10:43 +0100 Subject: [PATCH 02/53] links --- .../coherently-invertible-maps.lagda.md | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index 62787d6011..c39defc615 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -186,8 +186,11 @@ module _ ### Coherently invertible maps are embeddings -We first construct the converse map to the action on identifications. This is -essentially a repeat of the proof that maps with retractions are injective, and +We first construct the converse map to the +[action on identifications](foundation.action-on-identifications-functions.md). +This is a rerun of the proof that maps with +[retractions](foundation-core.retractions.md) are +[injective](foundation-core.injective-maps.md) (`is-injective-retraction`), and we repeat the proof to avoid cyclic dependencies. ```agda @@ -203,7 +206,8 @@ module _ ( is-retraction-map-inv-is-coherently-invertible H y)) ``` -Next, we show that this converse map is a section and retraction of `ap f`. +Next, we show that this converse map is a [section](foundation-core.sections.md) +and retraction of `ap f`. ```agda abstract From 8f7620f134a5aa8e7e8d02ed681dd12ba067fbce Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Thu, 8 Feb 2024 00:16:39 +0100 Subject: [PATCH 03/53] nitpick --- .../coherently-invertible-maps.lagda.md | 30 +++++++++++-------- 1 file changed, 17 insertions(+), 13 deletions(-) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index c39defc615..a5017c54b5 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -42,15 +42,17 @@ module _ where coherence-is-coherently-invertible : - (f : A → B) (g : B → A) (G : (f ∘ g) ~ id) (H : (g ∘ f) ~ id) → UU (l1 ⊔ l2) - coherence-is-coherently-invertible f g G H = (G ·r f) ~ (f ·l H) + (f : A → B) (g : B → A) (G : f ∘ g ~ id) (H : g ∘ f ~ id) → UU (l1 ⊔ l2) + coherence-is-coherently-invertible f g G H = G ·r f ~ f ·l H is-coherently-invertible : (A → B) → UU (l1 ⊔ l2) is-coherently-invertible f = Σ ( B → A) - ( λ g → Σ ((f ∘ g) ~ id) - ( λ G → Σ ((g ∘ f) ~ id) - ( λ H → coherence-is-coherently-invertible f g G H))) + ( λ g → + Σ (f ∘ g ~ id) + ( λ G → + Σ (g ∘ f ~ id) + ( λ H → coherence-is-coherently-invertible f g G H))) module _ {l1 l2 : Level} {A : UU l1} {B : UU l2} {f : A → B} @@ -84,12 +86,14 @@ module _ is-retraction-map-inv-is-coherently-invertible section-is-coherently-invertible : section f - pr1 section-is-coherently-invertible = map-inv-is-coherently-invertible + pr1 section-is-coherently-invertible = + map-inv-is-coherently-invertible pr2 section-is-coherently-invertible = is-section-map-inv-is-coherently-invertible retraction-is-coherently-invertible : retraction f - pr1 retraction-is-coherently-invertible = map-inv-is-coherently-invertible + pr1 retraction-is-coherently-invertible = + map-inv-is-coherently-invertible pr2 retraction-is-coherently-invertible = is-retraction-map-inv-is-coherently-invertible ``` @@ -104,10 +108,10 @@ module _ coh-is-coherently-invertible-id : {l : Level} {A : UU l} {f : A → A} (H : f ~ (λ x → x)) → (x : A) → H (f x) = ap f (H x) -coh-is-coherently-invertible-id {_} {A} {f} H x = - is-injective-concat' (H x) - ( ( ap (concat (H (f x)) x) (inv (ap-id (H x)))) ∙ - ( nat-htpy H (H x))) +coh-is-coherently-invertible-id {A = A} {f} H x = + is-injective-concat' + ( H x) + ( ap (concat (H (f x)) x) (inv (ap-id (H x))) ∙ nat-htpy H (H x)) ``` #### The proof that invertible maps are coherently invertible @@ -119,7 +123,7 @@ module _ abstract is-section-map-inv-is-coherently-invertible-is-invertible : - (H : is-invertible f) → (f ∘ map-inv-is-invertible H) ~ id + (H : is-invertible f) → f ∘ map-inv-is-invertible H ~ id is-section-map-inv-is-coherently-invertible-is-invertible H y = ( inv ( is-section-map-inv-is-invertible H (f (map-inv-is-invertible H y)))) ∙ @@ -131,7 +135,7 @@ module _ ( is-section-map-inv-is-invertible H y)) is-retraction-map-inv-is-coherently-invertible-is-invertible : - (H : is-invertible f) → (map-inv-is-invertible H ∘ f) ~ id + (H : is-invertible f) → map-inv-is-invertible H ∘ f ~ id is-retraction-map-inv-is-coherently-invertible-is-invertible = is-retraction-map-inv-is-invertible From 9fd741c4de98912efb1bd569d7c80ff362c7d005 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Thu, 8 Feb 2024 09:17:36 +0100 Subject: [PATCH 04/53] the type of coherently invertible maps and friends --- .../coherently-invertible-maps.lagda.md | 170 +++++++++++++----- src/foundation-core/equivalences.lagda.md | 2 +- .../coherently-invertible-maps.lagda.md | 2 +- 3 files changed, 130 insertions(+), 44 deletions(-) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index a5017c54b5..0557f97f48 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -25,17 +25,35 @@ open import foundation-core.sections ## Idea -An [inverse](foundation-core.invertible-maps.md) for a map `f : A → B` is a map -`g : B → A` equipped with [homotopies](foundation-core.homotopies.md) -` (f ∘ g) ~ id` and `(g ∘ f) ~ id`. Such data, however is -[structure](foundation.structure.md) on the map `f`, and not generally a -[property](foundation-core.propositions.md). Therefore we include a coherence -condition for the homotopies of an inverse. A **coherently invertible map** -`f : A → B` is a map equipped with a two-sided inverse and this additional -coherence law. They are also called half-adjoint equivalences. +A [(two-sided) inverse](foundation-core.invertible-maps.md) for a map +`f : A → B` is a map `g : B → A` equipped with +[homotopies](foundation-core.homotopies.md) ` f ∘ g ~ id` and `g ∘ f ~ id`. Such +data, however is [structure](foundation.structure.md) on the map `f`, and not +generally a [property](foundation-core.propositions.md). One way to make the +type of inverses into a property is by adding a single coherence condition +between the homotopies of the inverse, asking that the following diagram +commmutes + +```text + G ·r f + ~~~~~~~~~~ + f ∘ g ∘ f f. + ~~~~~~~~~~ + f ·l H +``` + +We call such data a +{{# "coherently invertible map" Agda=coherently-invertible-map}}. I.e., a +coherently invertible map `f : A → B` is a map equipped with a two-sided inverse +and this additional coherence. + +**Note.** Coherently invertible maps are also called +{{#concept "half adjoint equivalences"}}. ## Definition +### The predicate of being coherently invertible on maps + ```agda module _ {l1 l2 : Level} {A : UU l1} {B : UU l2} @@ -85,19 +103,85 @@ module _ pr2 (pr2 is-invertible-is-coherently-invertible) = is-retraction-map-inv-is-coherently-invertible - section-is-coherently-invertible : section f - pr1 section-is-coherently-invertible = + section-map-is-coherently-invertible : section f + pr1 section-map-is-coherently-invertible = map-inv-is-coherently-invertible - pr2 section-is-coherently-invertible = + pr2 section-map-is-coherently-invertible = is-section-map-inv-is-coherently-invertible - retraction-is-coherently-invertible : retraction f - pr1 retraction-is-coherently-invertible = + retraction-map-is-coherently-invertible : retraction f + pr1 retraction-map-is-coherently-invertible = map-inv-is-coherently-invertible - pr2 retraction-is-coherently-invertible = + pr2 retraction-map-is-coherently-invertible = is-retraction-map-inv-is-coherently-invertible ``` +We will show that `is-coherently-invertible` is a proposition in +[`foundation.coherently-invertible-maps`](foundation.coherently-invertible-maps.md). + +### The type of coherently invertible maps + +```agda +coherently-invertible-map : {l1 l2 : Level} → UU l1 → UU l2 → UU (l1 ⊔ l2) +coherently-invertible-map A B = Σ (A → B) (is-coherently-invertible) + +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} (e : coherently-invertible-map A B) + where + + map-coherently-invertible-map : A → B + map-coherently-invertible-map = pr1 e + + is-coherently-invertible-map-coherently-invertible-map : + is-coherently-invertible map-coherently-invertible-map + is-coherently-invertible-map-coherently-invertible-map = pr2 e + + map-inv-coherently-invertible-map : B → A + map-inv-coherently-invertible-map = + map-inv-is-coherently-invertible + ( is-coherently-invertible-map-coherently-invertible-map) + + is-section-map-inv-coherently-invertible-map : + map-coherently-invertible-map ∘ map-inv-coherently-invertible-map ~ id + is-section-map-inv-coherently-invertible-map = + is-section-map-inv-is-coherently-invertible + ( is-coherently-invertible-map-coherently-invertible-map) + + is-retraction-map-inv-coherently-invertible-map : + map-inv-coherently-invertible-map ∘ map-coherently-invertible-map ~ id + is-retraction-map-inv-coherently-invertible-map = + is-retraction-map-inv-is-coherently-invertible + ( is-coherently-invertible-map-coherently-invertible-map) + + coh-coherently-invertible-map : + coherence-is-coherently-invertible + ( map-coherently-invertible-map) + ( map-inv-coherently-invertible-map) + ( is-section-map-inv-coherently-invertible-map) + ( is-retraction-map-inv-coherently-invertible-map) + coh-coherently-invertible-map = + coh-is-coherently-invertible + ( is-coherently-invertible-map-coherently-invertible-map) + + section-map-coherently-invertible-map : + section map-coherently-invertible-map + section-map-coherently-invertible-map = + section-map-is-coherently-invertible + ( is-coherently-invertible-map-coherently-invertible-map) + + retraction-map-coherently-invertible-map : + retraction map-coherently-invertible-map + retraction-map-coherently-invertible-map = + retraction-map-is-coherently-invertible + ( is-coherently-invertible-map-coherently-invertible-map) + + is-invertible-map-coherently-invertible-map : + is-invertible map-coherently-invertible-map + is-invertible-map-coherently-invertible-map = + is-invertible-is-coherently-invertible + ( is-coherently-invertible-map-coherently-invertible-map) +``` + ## Properties ### Invertible maps are coherently invertible @@ -106,7 +190,7 @@ module _ ```agda coh-is-coherently-invertible-id : - {l : Level} {A : UU l} {f : A → A} (H : f ~ (λ x → x)) → + {l : Level} {A : UU l} {f : A → A} (H : f ~ id) → (x : A) → H (f x) = ap f (H x) coh-is-coherently-invertible-id {A = A} {f} H x = is-injective-concat' @@ -118,13 +202,13 @@ coh-is-coherently-invertible-id {A = A} {f} H x = ```agda module _ - {l1 l2 : Level} {A : UU l1} {B : UU l2} {f : A → B} + {l1 l2 : Level} {A : UU l1} {B : UU l2} {f : A → B} (H : is-invertible f) where abstract is-section-map-inv-is-coherently-invertible-is-invertible : - (H : is-invertible f) → f ∘ map-inv-is-invertible H ~ id - is-section-map-inv-is-coherently-invertible-is-invertible H y = + f ∘ map-inv-is-invertible H ~ id + is-section-map-inv-is-coherently-invertible-is-invertible y = ( inv ( is-section-map-inv-is-invertible H (f (map-inv-is-invertible H y)))) ∙ ( ( ap @@ -134,16 +218,16 @@ module _ ( map-inv-is-invertible H y))) ∙ ( is-section-map-inv-is-invertible H y)) - is-retraction-map-inv-is-coherently-invertible-is-invertible : - (H : is-invertible f) → map-inv-is-invertible H ∘ f ~ id - is-retraction-map-inv-is-coherently-invertible-is-invertible = - is-retraction-map-inv-is-invertible + is-retraction-map-inv-is-coherently-invertible-is-invertible : + map-inv-is-invertible H ∘ f ~ id + is-retraction-map-inv-is-coherently-invertible-is-invertible = + is-retraction-map-inv-is-invertible H - inv-coherence-map-inv-is-invertible : - (H : is-invertible f) → - f ·l is-retraction-map-inv-is-coherently-invertible-is-invertible H ~ - is-section-map-inv-is-coherently-invertible-is-invertible H ·r f - inv-coherence-map-inv-is-invertible H x = + abstract + inv-coh-is-coherently-invertible-is-invertible : + f ·l is-retraction-map-inv-is-coherently-invertible-is-invertible ~ + is-section-map-inv-is-coherently-invertible-is-invertible ·r f + inv-coh-is-coherently-invertible-is-invertible x = left-transpose-eq-concat ( is-section-map-inv-is-invertible ( H) @@ -168,24 +252,26 @@ module _ ( coh-is-coherently-invertible-id ( is-retraction-map-inv-is-invertible H) x)))))) - coherence-map-inv-is-invertible : - ( H : is-invertible f) → - ( is-section-map-inv-is-coherently-invertible-is-invertible H ·r f) ~ - ( f ·l is-retraction-map-inv-is-coherently-invertible-is-invertible H) - coherence-map-inv-is-invertible H x = - inv (inv-coherence-map-inv-is-invertible H x) + abstract + coh-is-coherently-invertible-is-invertible : + coherence-is-coherently-invertible + ( f) + ( map-inv-is-invertible H) + ( is-section-map-inv-is-coherently-invertible-is-invertible) + ( is-retraction-map-inv-is-coherently-invertible-is-invertible) + coh-is-coherently-invertible-is-invertible x = + inv (inv-coh-is-coherently-invertible-is-invertible x) abstract - is-coherently-invertible-is-invertible : - (H : is-invertible f) → is-coherently-invertible f - pr1 (is-coherently-invertible-is-invertible H) = + is-coherently-invertible-is-invertible : is-coherently-invertible f + pr1 is-coherently-invertible-is-invertible = map-inv-is-invertible H - pr1 (pr2 (is-coherently-invertible-is-invertible H)) = - is-section-map-inv-is-coherently-invertible-is-invertible H - pr1 (pr2 (pr2 (is-coherently-invertible-is-invertible H))) = - is-retraction-map-inv-is-coherently-invertible-is-invertible H - pr2 (pr2 (pr2 (is-coherently-invertible-is-invertible H))) = - coherence-map-inv-is-invertible H + pr1 (pr2 is-coherently-invertible-is-invertible) = + is-section-map-inv-is-coherently-invertible-is-invertible + pr1 (pr2 (pr2 is-coherently-invertible-is-invertible)) = + is-retraction-map-inv-is-coherently-invertible-is-invertible + pr2 (pr2 (pr2 is-coherently-invertible-is-invertible)) = + coh-is-coherently-invertible-is-invertible ``` ### Coherently invertible maps are embeddings diff --git a/src/foundation-core/equivalences.lagda.md b/src/foundation-core/equivalences.lagda.md index 8315ef527f..bd631e0918 100644 --- a/src/foundation-core/equivalences.lagda.md +++ b/src/foundation-core/equivalences.lagda.md @@ -246,7 +246,7 @@ module _ ( is-section-map-inv-is-equiv) ( is-retraction-map-inv-is-equiv) coherence-map-inv-is-equiv = - coherence-map-inv-is-invertible (is-invertible-is-equiv H) + coh-is-coherently-invertible-is-invertible (is-invertible-is-equiv H) is-equiv-map-inv-is-equiv : is-equiv map-inv-is-equiv is-equiv-map-inv-is-equiv = diff --git a/src/foundation/coherently-invertible-maps.lagda.md b/src/foundation/coherently-invertible-maps.lagda.md index 74eb88be1f..862fe29fe3 100644 --- a/src/foundation/coherently-invertible-maps.lagda.md +++ b/src/foundation/coherently-invertible-maps.lagda.md @@ -48,7 +48,7 @@ module _ ( associative-Σ _ _ _) ( is-contr-Σ ( is-contr-section-is-equiv (is-equiv-is-coherently-invertible H)) - ( section-is-coherently-invertible H) + ( section-map-is-coherently-invertible H) ( is-contr-equiv' ( _) ( distributive-Π-Σ) From a01265db04ee0ad5baea2adce44ca473fedcab9e Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Thu, 8 Feb 2024 17:04:47 +0100 Subject: [PATCH 05/53] wip coherently invertible maps --- .../coherently-invertible-maps.lagda.md | 248 +++++++++++++++++- src/foundation-core/homotopies.lagda.md | 14 + .../coherently-invertible-maps.lagda.md | 2 +- ...ing-higher-homotopies-composition.lagda.md | 20 +- ...whiskering-homotopies-composition.lagda.md | 9 +- 5 files changed, 280 insertions(+), 13 deletions(-) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index 0557f97f48..4fbcef1072 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -11,6 +11,7 @@ open import foundation.action-on-identifications-binary-functions open import foundation.action-on-identifications-functions open import foundation.dependent-pair-types open import foundation.universe-levels +open import foundation.whiskering-higher-homotopies-composition open import foundation.whiskering-homotopies-composition open import foundation-core.function-types @@ -43,10 +44,23 @@ commmutes ``` We call such data a -{{# "coherently invertible map" Agda=coherently-invertible-map}}. I.e., a +{{#concept "coherently invertible map" Agda=coherently-invertible-map}}. I.e., a coherently invertible map `f : A → B` is a map equipped with a two-sided inverse and this additional coherence. +There is also the alternative coherence condition we could add + +```text + H ·r g + ~~~~~~~~~~ + g ∘ f ∘ g g. + ~~~~~~~~~~ + g ·l G +``` + +We will colloquially refer to invertible maps equipped with this coherence for +_transpose coherently invertible maps_. + **Note.** Coherently invertible maps are also called {{#concept "half adjoint equivalences"}}. @@ -103,16 +117,16 @@ module _ pr2 (pr2 is-invertible-is-coherently-invertible) = is-retraction-map-inv-is-coherently-invertible - section-map-is-coherently-invertible : section f - pr1 section-map-is-coherently-invertible = + section-is-coherently-invertible : section f + pr1 section-is-coherently-invertible = map-inv-is-coherently-invertible - pr2 section-map-is-coherently-invertible = + pr2 section-is-coherently-invertible = is-section-map-inv-is-coherently-invertible - retraction-map-is-coherently-invertible : retraction f - pr1 retraction-map-is-coherently-invertible = + retraction-is-coherently-invertible : retraction f + pr1 retraction-is-coherently-invertible = map-inv-is-coherently-invertible - pr2 retraction-map-is-coherently-invertible = + pr2 retraction-is-coherently-invertible = is-retraction-map-inv-is-coherently-invertible ``` @@ -166,13 +180,13 @@ module _ section-map-coherently-invertible-map : section map-coherently-invertible-map section-map-coherently-invertible-map = - section-map-is-coherently-invertible + section-is-coherently-invertible ( is-coherently-invertible-map-coherently-invertible-map) retraction-map-coherently-invertible-map : retraction map-coherently-invertible-map retraction-map-coherently-invertible-map = - retraction-map-is-coherently-invertible + retraction-is-coherently-invertible ( is-coherently-invertible-map-coherently-invertible-map) is-invertible-map-coherently-invertible-map : @@ -182,6 +196,144 @@ module _ ( is-coherently-invertible-map-coherently-invertible-map) ``` +### The predicate of being transpose coherently invertible on maps + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} + where + + coherence-is-transpose-coherently-invertible : + (f : A → B) (g : B → A) (G : f ∘ g ~ id) (H : g ∘ f ~ id) → UU (l1 ⊔ l2) + coherence-is-transpose-coherently-invertible f g G H = H ·r g ~ g ·l G + + is-transpose-coherently-invertible : (A → B) → UU (l1 ⊔ l2) + is-transpose-coherently-invertible f = + Σ ( B → A) + ( λ g → + Σ (f ∘ g ~ id) + ( λ G → + Σ (g ∘ f ~ id) + ( λ H → coherence-is-transpose-coherently-invertible f g G H))) + +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} {f : A → B} + (H : is-transpose-coherently-invertible f) + where + + map-inv-is-transpose-coherently-invertible : B → A + map-inv-is-transpose-coherently-invertible = pr1 H + + is-section-map-inv-is-transpose-coherently-invertible : + f ∘ map-inv-is-transpose-coherently-invertible ~ id + is-section-map-inv-is-transpose-coherently-invertible = pr1 (pr2 H) + + is-retraction-map-inv-is-transpose-coherently-invertible : + map-inv-is-transpose-coherently-invertible ∘ f ~ id + is-retraction-map-inv-is-transpose-coherently-invertible = pr1 (pr2 (pr2 H)) + + coh-is-transpose-coherently-invertible : + coherence-is-transpose-coherently-invertible f + ( map-inv-is-transpose-coherently-invertible) + ( is-section-map-inv-is-transpose-coherently-invertible) + ( is-retraction-map-inv-is-transpose-coherently-invertible) + coh-is-transpose-coherently-invertible = pr2 (pr2 (pr2 H)) + + is-invertible-is-transpose-coherently-invertible : is-invertible f + pr1 is-invertible-is-transpose-coherently-invertible = + map-inv-is-transpose-coherently-invertible + pr1 (pr2 is-invertible-is-transpose-coherently-invertible) = + is-section-map-inv-is-transpose-coherently-invertible + pr2 (pr2 is-invertible-is-transpose-coherently-invertible) = + is-retraction-map-inv-is-transpose-coherently-invertible + + section-is-transpose-coherently-invertible : section f + pr1 section-is-transpose-coherently-invertible = + map-inv-is-transpose-coherently-invertible + pr2 section-is-transpose-coherently-invertible = + is-section-map-inv-is-transpose-coherently-invertible + + retraction-is-transpose-coherently-invertible : retraction f + pr1 retraction-is-transpose-coherently-invertible = + map-inv-is-transpose-coherently-invertible + pr2 retraction-is-transpose-coherently-invertible = + is-retraction-map-inv-is-transpose-coherently-invertible +``` + +We will show that `is-transpose-coherently-invertible` is a proposition in +[`foundation.coherently-invertible-maps`](foundation.coherently-invertible-maps.md). + +### The type of transpose coherently invertible maps + +```agda +transpose-coherently-invertible-map : + {l1 l2 : Level} → UU l1 → UU l2 → UU (l1 ⊔ l2) +transpose-coherently-invertible-map A B = + Σ (A → B) (is-transpose-coherently-invertible) + +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} + (e : transpose-coherently-invertible-map A B) + where + + map-transpose-coherently-invertible-map : A → B + map-transpose-coherently-invertible-map = pr1 e + + is-transpose-coherently-invertible-map-transpose-coherently-invertible-map : + is-transpose-coherently-invertible map-transpose-coherently-invertible-map + is-transpose-coherently-invertible-map-transpose-coherently-invertible-map = + pr2 e + + map-inv-transpose-coherently-invertible-map : B → A + map-inv-transpose-coherently-invertible-map = + map-inv-is-transpose-coherently-invertible + ( is-transpose-coherently-invertible-map-transpose-coherently-invertible-map) + + is-section-map-inv-transpose-coherently-invertible-map : + ( map-transpose-coherently-invertible-map ∘ + map-inv-transpose-coherently-invertible-map) ~ + ( id) + is-section-map-inv-transpose-coherently-invertible-map = + is-section-map-inv-is-transpose-coherently-invertible + ( is-transpose-coherently-invertible-map-transpose-coherently-invertible-map) + + is-retraction-map-inv-transpose-coherently-invertible-map : + ( map-inv-transpose-coherently-invertible-map ∘ + map-transpose-coherently-invertible-map) ~ + ( id) + is-retraction-map-inv-transpose-coherently-invertible-map = + is-retraction-map-inv-is-transpose-coherently-invertible + ( is-transpose-coherently-invertible-map-transpose-coherently-invertible-map) + + coh-transpose-coherently-invertible-map : + coherence-is-transpose-coherently-invertible + ( map-transpose-coherently-invertible-map) + ( map-inv-transpose-coherently-invertible-map) + ( is-section-map-inv-transpose-coherently-invertible-map) + ( is-retraction-map-inv-transpose-coherently-invertible-map) + coh-transpose-coherently-invertible-map = + coh-is-transpose-coherently-invertible + ( is-transpose-coherently-invertible-map-transpose-coherently-invertible-map) + + section-map-transpose-coherently-invertible-map : + section map-transpose-coherently-invertible-map + section-map-transpose-coherently-invertible-map = + section-is-transpose-coherently-invertible + ( is-transpose-coherently-invertible-map-transpose-coherently-invertible-map) + + retraction-map-transpose-coherently-invertible-map : + retraction map-transpose-coherently-invertible-map + retraction-map-transpose-coherently-invertible-map = + retraction-is-transpose-coherently-invertible + ( is-transpose-coherently-invertible-map-transpose-coherently-invertible-map) + + is-invertible-map-transpose-coherently-invertible-map : + is-invertible map-transpose-coherently-invertible-map + is-invertible-map-transpose-coherently-invertible-map = + is-invertible-is-transpose-coherently-invertible + ( is-transpose-coherently-invertible-map-transpose-coherently-invertible-map) +``` + ## Properties ### Invertible maps are coherently invertible @@ -352,6 +504,84 @@ and retraction of `ap f`. ( is-invertible-ap-is-coherently-invertible) ``` +### Given a coherently invertible map, its inverse is transpose coherently invertible + +Of course there is also a converse construction, and since these just move data +around, they are strict inverses to one another. + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} + where + + is-transpose-coherently-invertible-map-inv-is-coherently-invertible : + {f : A → B} (H : is-coherently-invertible f) → + is-transpose-coherently-invertible (map-inv-is-coherently-invertible H) + is-transpose-coherently-invertible-map-inv-is-coherently-invertible {f} H = + ( f , + is-retraction-map-inv-is-coherently-invertible H , + is-section-map-inv-is-coherently-invertible H , + coh-is-coherently-invertible H) + + is-coherently-invertible-map-inv-is-transpose-coherently-invertible : + {f : A → B} (H : is-transpose-coherently-invertible f) → + is-coherently-invertible (map-inv-is-transpose-coherently-invertible H) + is-coherently-invertible-map-inv-is-transpose-coherently-invertible {f} H = + ( f , + is-retraction-map-inv-is-transpose-coherently-invertible H , + is-section-map-inv-is-transpose-coherently-invertible H , + coh-is-transpose-coherently-invertible H) + + transpose-coherently-invertible-map-inv-coherently-invertible-map : + coherently-invertible-map A B → transpose-coherently-invertible-map B A + transpose-coherently-invertible-map-inv-coherently-invertible-map e = + ( map-inv-coherently-invertible-map e , + is-transpose-coherently-invertible-map-inv-is-coherently-invertible + ( is-coherently-invertible-map-coherently-invertible-map e)) + + coherently-invertible-map-inv-transpose-coherently-invertible-map : + transpose-coherently-invertible-map A B → coherently-invertible-map B A + coherently-invertible-map-inv-transpose-coherently-invertible-map e = + ( map-inv-transpose-coherently-invertible-map e , + is-coherently-invertible-map-inv-is-transpose-coherently-invertible + ( is-transpose-coherently-invertible-map-transpose-coherently-invertible-map + ( e))) +``` + +### Coherently invertible maps in either sense are coherently invertible in both senses + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} + where + + coh-is-transpose-coherently-invertible-is-coherently-invertible' : + {f : A → B} (H : is-coherently-invertible f) → + ( ( map-inv-is-coherently-invertible H ∘ f) ·l + ( is-retraction-map-inv-is-coherently-invertible H) ·r + ( map-inv-is-coherently-invertible H)) ~ + ( ( map-inv-is-coherently-invertible H) ·l + ( is-section-map-inv-is-coherently-invertible H) ·r + ( f ∘ map-inv-is-coherently-invertible H)) + coh-is-transpose-coherently-invertible-is-coherently-invertible' {f} H = + ( inv-preserves-comp-left-whisker-comp + ( map-inv-is-coherently-invertible H) + ( f) + ( ( is-retraction-map-inv-is-coherently-invertible H) ·r + ( map-inv-is-coherently-invertible H))) ∙h + ( double-whisker-comp² + ( map-inv-is-coherently-invertible H) + ( inv-htpy (coh-is-coherently-invertible H)) + ( map-inv-is-coherently-invertible H)) ∙h + ( preserves-comp-right-whisker-comp + ( f) + ( map-inv-is-coherently-invertible H) + ( ( map-inv-is-coherently-invertible H) ·l + ( is-section-map-inv-is-coherently-invertible H))) +``` + +The rest remains to be formalized. + ## See also - For the notion of biinvertible maps see diff --git a/src/foundation-core/homotopies.lagda.md b/src/foundation-core/homotopies.lagda.md index fc6b8eb7de..94c20ef65d 100644 --- a/src/foundation-core/homotopies.lagda.md +++ b/src/foundation-core/homotopies.lagda.md @@ -247,6 +247,20 @@ module _ ### Naturality of homotopies with respect to identifications +Given two maps `f g : A → B` and a homotopy `H : f ~ g`, then for every +identification `p : x = y` in `A`, we have a +[commuting square of identifications](foundation-core.commuting-squares-of-identifications.md) + +```text + ap f p + f x -------- f y + | | + H x | | H y + | | + g x -------- g y. + ap g p +``` + ```agda nat-htpy : {l1 l2 : Level} {A : UU l1} {B : UU l2} {f g : A → B} (H : f ~ g) diff --git a/src/foundation/coherently-invertible-maps.lagda.md b/src/foundation/coherently-invertible-maps.lagda.md index 862fe29fe3..74eb88be1f 100644 --- a/src/foundation/coherently-invertible-maps.lagda.md +++ b/src/foundation/coherently-invertible-maps.lagda.md @@ -48,7 +48,7 @@ module _ ( associative-Σ _ _ _) ( is-contr-Σ ( is-contr-section-is-equiv (is-equiv-is-coherently-invertible H)) - ( section-map-is-coherently-invertible H) + ( section-is-coherently-invertible H) ( is-contr-equiv' ( _) ( distributive-Π-Σ) diff --git a/src/foundation/whiskering-higher-homotopies-composition.lagda.md b/src/foundation/whiskering-higher-homotopies-composition.lagda.md index eb981d65af..2970a34a1e 100644 --- a/src/foundation/whiskering-higher-homotopies-composition.lagda.md +++ b/src/foundation/whiskering-higher-homotopies-composition.lagda.md @@ -38,8 +38,7 @@ by ``` Similarly, the {{#concept "right whiskering" Disambiguation="2-homotopies with -respect to composition" Agda=right-whisker-comp²]} is defined to be the -operation +respect to composition" Agda=right-whisker-comp²}} is defined to be the operation ```text (H ~ H') → (h : (x : A) → B x) → (H ·r h ~ H' ·r h) @@ -81,3 +80,20 @@ module _ (α : {x : A} → H {x} ~ H' {x}) (h : (x : A) → B x) → H ·r h ~ H' ·r h right-whisker-comp² α h = α ·r h ``` + +### Double whiskering higher homotopies + +```agda +module _ + {l1 l2 l3 l4 : Level} {A : UU l1} {B : A → UU l2} + {C : (x : A) → B x → UU l3} {D : (x : A) → B x → UU l4} + {f g : {x : A} (y : B x) → C x y} {H H' : {x : A} → f {x} ~ g {x}} + where + + double-whisker-comp² : + (left : {x : A} {y : B x} → C x y → D x y) + (α : {x : A} → H {x} ~ H' {x}) + (right : (x : A) → B x) → + left ·l H ·r right ~ left ·l H' ·r right + double-whisker-comp² left α right = double-whisker-comp (ap left) α right +``` diff --git a/src/foundation/whiskering-homotopies-composition.lagda.md b/src/foundation/whiskering-homotopies-composition.lagda.md index 12a6729411..67bcc797cb 100644 --- a/src/foundation/whiskering-homotopies-composition.lagda.md +++ b/src/foundation/whiskering-homotopies-composition.lagda.md @@ -235,11 +235,18 @@ module _ {A : UU l1} {B : A → UU l2} {C : A → UU l3} {D : A → UU l4} where + inv-preserves-comp-left-whisker-comp : + ( k : {x : A} → C x → D x) (h : {x : A} → B x → C x) {f g : (x : A) → B x} + ( H : f ~ g) → + (k ∘ h) ·l H ~ k ·l (h ·l H) + inv-preserves-comp-left-whisker-comp k h H x = ap-comp k h (H x) + preserves-comp-left-whisker-comp : ( k : {x : A} → C x → D x) (h : {x : A} → B x → C x) {f g : (x : A) → B x} ( H : f ~ g) → k ·l (h ·l H) ~ (k ∘ h) ·l H - preserves-comp-left-whisker-comp k h H x = inv (ap-comp k h (H x)) + preserves-comp-left-whisker-comp k h H = + inv-htpy (inv-preserves-comp-left-whisker-comp k h H) module _ { l1 l2 l3 l4 : Level} From 5bbfa49bfb81db4917d8342415ac58f2c4b8aae5 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Sat, 10 Feb 2024 11:43:36 +0100 Subject: [PATCH 06/53] core files for squares of ids and whiskering wrt. concatenation --- .../adjunctions-large-precategories.lagda.md | 2 +- src/foundation-core.lagda.md | 3 + ...muting-squares-of-identifications.lagda.md | 1548 +++++++++++++++++ .../commuting-squares-of-maps.lagda.md | 12 +- ...iskering-homotopies-concatenation.lagda.md | 125 ++ ...ing-identifications-concatenation.lagda.md | 327 ++++ .../commuting-squares-of-homotopies.lagda.md | 6 +- ...muting-squares-of-identifications.lagda.md | 1199 +------------ .../commuting-squares-of-maps.lagda.md | 6 +- src/foundation/embeddings.lagda.md | 2 +- src/foundation/equivalences-arrows.lagda.md | 2 +- ...stcomposition-dependent-functions.lagda.md | 2 +- ...recomposition-dependent-functions.lagda.md | 2 +- .../precomposition-functions.lagda.md | 2 +- ...iskering-homotopies-concatenation.lagda.md | 2 + ...ing-identifications-concatenation.lagda.md | 286 +-- .../equivalences-group-actions.lagda.md | 2 +- ...types-equipped-with-endomorphisms.lagda.md | 2 +- .../equivalences-sequential-diagrams.lagda.md | 2 +- 19 files changed, 2075 insertions(+), 1457 deletions(-) create mode 100644 src/foundation-core/commuting-squares-of-identifications.lagda.md create mode 100644 src/foundation-core/whiskering-homotopies-concatenation.lagda.md create mode 100644 src/foundation-core/whiskering-identifications-concatenation.lagda.md diff --git a/src/category-theory/adjunctions-large-precategories.lagda.md b/src/category-theory/adjunctions-large-precategories.lagda.md index 0f3ddc0d82..d98a4ff347 100644 --- a/src/category-theory/adjunctions-large-precategories.lagda.md +++ b/src/category-theory/adjunctions-large-precategories.lagda.md @@ -160,7 +160,7 @@ module _ ( map-inv-equiv-is-adjoint-pair-Large-Precategory H X2 Y2) naturality-inv-equiv-is-adjoint-pair-Large-Precategory H {X1 = X1} {X2} {Y1} {Y2} f g = - coherence-square-maps-inv-equiv-horizontal + horizontal-inv-equiv-coherence-square-maps ( equiv-is-adjoint-pair-Large-Precategory H X1 Y1) ( λ h → comp-hom-Large-Precategory D diff --git a/src/foundation-core.lagda.md b/src/foundation-core.lagda.md index 5244d7271e..7f25f3e438 100644 --- a/src/foundation-core.lagda.md +++ b/src/foundation-core.lagda.md @@ -10,6 +10,7 @@ open import foundation-core.cartesian-product-types public open import foundation-core.coherently-invertible-maps public open import foundation-core.commuting-prisms-of-maps public open import foundation-core.commuting-squares-of-homotopies public +open import foundation-core.commuting-squares-of-identifications public open import foundation-core.commuting-squares-of-maps public open import foundation-core.commuting-triangles-of-maps public open import foundation-core.constant-maps public @@ -59,4 +60,6 @@ open import foundation-core.type-theoretic-principle-of-choice public open import foundation-core.univalence public open import foundation-core.universal-property-pullbacks public open import foundation-core.universal-property-truncation public +open import foundation-core.whiskering-homotopies-concatenation public +open import foundation-core.whiskering-identifications-concatenation public ``` diff --git a/src/foundation-core/commuting-squares-of-identifications.lagda.md b/src/foundation-core/commuting-squares-of-identifications.lagda.md new file mode 100644 index 0000000000..f73e51935f --- /dev/null +++ b/src/foundation-core/commuting-squares-of-identifications.lagda.md @@ -0,0 +1,1548 @@ +# Commuting squares of identifications + +```agda +module foundation-core.commuting-squares-of-identifications where +``` + +
Imports + +```agda +open import foundation.action-on-identifications-functions +open import foundation.dependent-pair-types +open import foundation.universe-levels +open import foundation.whiskering-identifications-concatenation + +open import foundation-core.function-types +open import foundation-core.identity-types +open import foundation-core.retractions +open import foundation-core.sections +``` + +
+ +## Idea + +A square of [identifications](foundation-core.identity-types.md) + +```text + top + x -------> y + | | + left | | right + ∨ ∨ + z -------> w + bottom +``` + +is said to be a +{{#concept "commuting square" Disambiguation="identifications" Agda=coherence-square-identifications}} +if there is an identification `left ∙ bottom = top ∙ right`. Such an +identification is called a +{{#concept "coherence" Disambiguation="commuting square of identifications" Agda=coherence-square-identifications}} +of the square. + +## Definitions + +### Commuting squares of identifications + +```agda +module _ + {l : Level} {A : UU l} {x y z w : A} + (top : x = y) (left : x = z) (right : y = w) (bottom : z = w) + where + + coherence-square-identifications : UU l + coherence-square-identifications = left ∙ bottom = top ∙ right +``` + +### Horizontally constant squares + +{{#concept "Horizontally constant squares" Disambiguation="identifications" Agda=horizontal-refl-coherence-square-identifications}} +are commuting squares of identifications of the form + +```text + refl + a -----> a + | | + p | | p + ∨ ∨ + b -----> b. + refl +``` + +```agda +module _ + {l : Level} {A : UU l} {a b : A} (p : a = b) + where + + horizontal-refl-coherence-square-identifications : + coherence-square-identifications refl p p refl + horizontal-refl-coherence-square-identifications = right-unit +``` + +### Vertically constant squares + +{{#concept "Vertically constant squares" Disambiguation="identifications" Agda=vertical-refl-coherence-square-identifications}} +are commuting squares of identifications of the form + +```text + p + a -----> b + | | + refl | | refl + ∨ ∨ + a -----> b. + p +``` + +```agda +module _ + {l : Level} {A : UU l} {a b : A} (p : a = b) + where + + vertical-refl-coherence-square-identifications : + coherence-square-identifications p refl refl p + vertical-refl-coherence-square-identifications = inv right-unit +``` + +## Operations + +### Inverting squares of identifications horizontally + +Given a commuting square of identifications + +```text + top + x -------> y + | | + left | | right + ∨ ∨ + z -------> w, + bottom +``` + +the square of identifications + +```text + inv top + y ------------> x + | | + right | | left + ∨ ∨ + w ------------> z + inv bottom +``` + +commutes. + +```agda +module _ + {l : Level} {A : UU l} {x y z w : A} + where + + horizontal-inv-coherence-square-identifications : + (top : x = y) (left : x = z) (right : y = w) (bottom : z = w) → + coherence-square-identifications top left right bottom → + coherence-square-identifications (inv top) right left (inv bottom) + horizontal-inv-coherence-square-identifications refl left right bottom coh = + inv (right-transpose-eq-concat left bottom right coh) +``` + +### Inverting squares of identifications vertically + +Given a commuting square of identifications + +```text + top + x -------> y + | | + left | | right + ∨ ∨ + z -------> w, + bottom +``` + +the square of identifications + +```text + bottom + z -------> w + | | + inv left | | inv right + ∨ ∨ + x -------> y + top +``` + +commutes. + +```agda +module _ + {l : Level} {A : UU l} {x y z w : A} + where + + vertical-inv-coherence-square-identifications : + (top : x = y) (left : x = z) (right : y = w) (bottom : z = w) → + coherence-square-identifications top left right bottom → + coherence-square-identifications bottom (inv left) (inv right) top + vertical-inv-coherence-square-identifications top refl right bottom coh = + right-transpose-eq-concat top right (bottom) (inv coh) +``` + +### Functions acting on squares of identifications + +Given a commuting square of identifications + +```text + top + x -------> y + | | + left | | right + ∨ ∨ + z -------> w + bottom +``` + +in a type `A`, and given a map `f : A → B`, the square of identifications + +```text + ap f top + f x -----------> f y + | | + ap f left | | ap f right + ∨ ∨ + z -------------> w + ap f bottom +``` + +commutes. + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} {x y z w : A} (f : A → B) + where + + map-coherence-square-identifications : + (top : x = y) (left : x = z) (right : y = w) (bottom : z = w) → + coherence-square-identifications top left right bottom → + coherence-square-identifications + ( ap f top) + ( ap f left) + ( ap f right) + ( ap f bottom) + map-coherence-square-identifications refl refl _ _ coh = ap (ap f) coh +``` + +### Concatenating identifications of edges and coherences of commuting squares of identifications + +Consider a commuting square of identifications and an identification of one of +the four sides with another identification, as for example in the diagram below: + +```text + top + a ---------> b + | | | + left | right |=| right' + ∨ ∨ ∨ + c ---------> d. + bottom +``` + +Then any identification witnessing that the square commutes can be concatenated +with the identification on the side, to obtain a new commuting square of +identifications. + +**Note.** To avoid cyclic module dependencies we will give direct proofs that +concatenating identifications of edges of a square with the coherence of its +commutativity is an equivalence. + +#### Concatenating identifications of the top edge with a coherence of a commuting square of identifications + +Consider a commuting diagram of identifications + +```text + top' + -------> + x -------> y + | top | + left | | right + ∨ ∨ + z -------> w. + bottom +``` + +with an identification `top = top'`. Then we get an equivalence + +```text + top top' + x -------> y x -------> y + | | | | + left | | right ≃ left | | right + ∨ ∨ ∨ ∨ + z -------> w z -------> w. + bottom bottom +``` + +```agda +module _ + {l : Level} {A : UU l} {x y z w : A} + (top : x = y) (left : x = z) (right : y = w) (bottom : z = w) + {top' : x = y} (s : top = top') + where + + concat-top-identification-coherence-square-identifications : + coherence-square-identifications top left right bottom → + coherence-square-identifications top' left right bottom + concat-top-identification-coherence-square-identifications t = + t ∙ ap (concat' _ right) s + + inv-concat-top-identification-coherence-square-identifications : + coherence-square-identifications top' left right bottom → + coherence-square-identifications top left right bottom + inv-concat-top-identification-coherence-square-identifications t = + t ∙ inv (ap (concat' _ right) s) + + is-section-inv-concat-top-identification-coherence-square-identifications : + is-section + concat-top-identification-coherence-square-identifications + inv-concat-top-identification-coherence-square-identifications + is-section-inv-concat-top-identification-coherence-square-identifications = + is-section-inv-concat' (ap (concat' _ right) s) + + is-retraction-inv-concat-top-identification-coherence-square-identifications : + is-retraction + concat-top-identification-coherence-square-identifications + inv-concat-top-identification-coherence-square-identifications + is-retraction-inv-concat-top-identification-coherence-square-identifications = + is-retraction-inv-concat' (ap (concat' _ right) s) +``` + +We record that this construction is an equivalence in +[`foundation.commuting-squares-of-identifications`](foundation.commuting-squares-of-identifications.md). + +#### Concatenating identifications of the left edge with a coherence of a commuting square of identifications + +Consider a commuting diagram of identifications + +```text + top + x -------> y + | | | + left' | | left | right + ∨ ∨ ∨ + z -------> w. + bottom +``` + +with an identification `left = left'`. Then we get an equivalence + +```text + top top + x -------> y x -------> y + | | | | + left | | right ≃ left' | | right + ∨ ∨ ∨ ∨ + z -------> w z -------> w. + bottom bottom +``` + +```agda +module _ + {l : Level} {A : UU l} {x y z w : A} + (top : x = y) (left : x = z) (right : y = w) (bottom : z = w) + {left' : x = z} (s : left = left') + where + + concat-left-identification-coherence-square-identifications : + coherence-square-identifications top left right bottom → + coherence-square-identifications top left' right bottom + concat-left-identification-coherence-square-identifications t = + inv (ap (concat' _ bottom) s) ∙ t + + inv-concat-left-identification-coherence-square-identifications : + coherence-square-identifications top left' right bottom → + coherence-square-identifications top left right bottom + inv-concat-left-identification-coherence-square-identifications t = + ap (concat' _ bottom) s ∙ t + + is-section-inv-concat-left-identification-coherence-square-identifications : + is-section + concat-left-identification-coherence-square-identifications + inv-concat-left-identification-coherence-square-identifications + is-section-inv-concat-left-identification-coherence-square-identifications = + is-retraction-inv-concat (ap (concat' _ bottom) s) + + is-retraction-inv-concat-left-identification-coherence-square-identifications : + is-retraction + concat-left-identification-coherence-square-identifications + inv-concat-left-identification-coherence-square-identifications + is-retraction-inv-concat-left-identification-coherence-square-identifications = + is-section-inv-concat (ap (concat' _ bottom) s) +``` + +We record that this construction is an equivalence in +[`foundation.commuting-squares-of-identifications`](foundation.commuting-squares-of-identifications.md). + +#### Concatenating identifications of the right edge with a coherence of a commuting square of identifications + +Consider a commuting diagram of identifications + +```text + top + x -------> y + | | | + left | right | | right' + ∨ ∨ ∨ + z -------> w. + bottom +``` + +with an identification `right = right'`. Then we get an equivalence + +```text + top top + x -------> y x -------> y + | | | | + left | | right ≃ left | | right' + ∨ ∨ ∨ ∨ + z -------> w z -------> w. + bottom bottom +``` + +```agda +module _ + {l : Level} {A : UU l} {x y z w : A} + (top : x = y) (left : x = z) (right : y = w) (bottom : z = w) + {right' : y = w} (s : right = right') + where + + concat-right-identification-coherence-square-identifications : + coherence-square-identifications top left right bottom → + coherence-square-identifications top left right' bottom + concat-right-identification-coherence-square-identifications t = + t ∙ ap (concat top _) s + + inv-concat-right-identification-coherence-square-identifications : + coherence-square-identifications top left right' bottom → + coherence-square-identifications top left right bottom + inv-concat-right-identification-coherence-square-identifications t = + t ∙ inv (ap (concat top _) s) + + is-section-inv-concat-right-identification-coherence-square-identifications : + is-section + concat-right-identification-coherence-square-identifications + inv-concat-right-identification-coherence-square-identifications + is-section-inv-concat-right-identification-coherence-square-identifications = + is-section-inv-concat' (ap (concat top _) s) + + is-retraction-inv-concat-right-identification-coherence-square-identifications : + is-retraction + concat-right-identification-coherence-square-identifications + inv-concat-right-identification-coherence-square-identifications + is-retraction-inv-concat-right-identification-coherence-square-identifications = + is-retraction-inv-concat' (ap (concat top _) s) +``` + +We record that this construction is an equivalence in +[`foundation.commuting-squares-of-identifications`](foundation.commuting-squares-of-identifications.md). + +#### Concatenating identifications of the bottom edge with a coherence of a commuting square of identifications + +Consider a commuting diagram of identifications + +```text + top + x -------> y + | | + left | | right + ∨ bottom ∨ + z -------> w. + -------> + bottom' +``` + +with an identification `bottom = bottom'`. Then we get an equivalence + +```text + top top + x -------> y x -------> y + | | | | + left | | right ≃ left | | right + ∨ ∨ ∨ ∨ + z -------> w z -------> w. + bottom bottom' +``` + +```agda +module _ + {l : Level} {A : UU l} {x y z w : A} + (top : x = y) (left : x = z) (right : y = w) (bottom : z = w) + {bottom' : z = w} (s : bottom = bottom') + where + + concat-bottom-identification-coherence-square-identifications : + coherence-square-identifications top left right bottom → + coherence-square-identifications top left right bottom' + concat-bottom-identification-coherence-square-identifications t = + inv (ap (concat left _) s) ∙ t + + inv-concat-bottom-identification-coherence-square-identifications : + coherence-square-identifications top left right bottom' → + coherence-square-identifications top left right bottom + inv-concat-bottom-identification-coherence-square-identifications t = + ap (concat left _) s ∙ t + + is-section-inv-concat-bottom-identification-coherence-square-identifications : + is-section + concat-bottom-identification-coherence-square-identifications + inv-concat-bottom-identification-coherence-square-identifications + is-section-inv-concat-bottom-identification-coherence-square-identifications = + is-retraction-inv-concat (ap (concat left _) s) + + is-retraction-inv-concat-bottom-identification-coherence-square-identifications : + is-retraction + concat-bottom-identification-coherence-square-identifications + inv-concat-bottom-identification-coherence-square-identifications + is-retraction-inv-concat-bottom-identification-coherence-square-identifications = + is-section-inv-concat (ap (concat left _) s) +``` + +We record that this construction is an equivalence in +[`foundation.commuting-squares-of-identifications`](foundation.commuting-squares-of-identifications.md). + +### Whiskering and splicing coherences of commuting squares of identifications + +Given a commuting square of identifications + +```text + top + x -------> y + | | + left | | right + ∨ ∨ + z -------> w, + bottom +``` + +we may consider four ways of attaching new identifications to it: + +1. Prepending `p : u = x` to the left gives us a commuting square + + ```text + p ∙ top + u -------> y + | | + p ∙ left | | right + ∨ ∨ + z -------> w. + bottom + ``` + + More precisely, we have an equivalence + + ```text + (left ∙ bottom = top ∙ right) ≃ ((p ∙ left) ∙ bottom = (p ∙ top) ∙ right). + ``` + +2. Appending an identification `p : w = u` to the right gives a commuting + square of identifications + + ```text + top + x ------------> y + | | + left | | right ∙ p + ∨ ∨ + z ------------> u. + bottom ∙ p + ``` + + More precisely, we have an equivalence + + ```text + (left ∙ bottom = top ∙ right) ≃ (left ∙ (bottom ∙ p) = top ∙ (right ∙ p)). + ``` + +3. Splicing an identification `p : z = u` and its inverse into the middle gives + a commuting square of identifications + + ```text + top + x --------------> y + | | + left ∙ p | | right + ∨ ∨ + u --------------> w. + p⁻¹ ∙ bottom + ``` + + More precisely, we have an equivalence + + ```text + (left ∙ bottom = top ∙ right) ≃ ((left ∙ p) ∙ (p⁻¹ ∙ bottom) = top ∙ right). + ``` + + Similarly, we have an equivalence + + ```text + (left ∙ bottom = top ∙ right) ≃ ((left ∙ p⁻¹) ∙ (p ∙ bottom) = top ∙ right). + ``` + +4. Splicing an identification `p : y = u` and its inverse into the middle gives + a commuting square of identifications + + ```text + top ∙ p + x --------> u + | | + left | | p⁻¹ ∙ right + ∨ ∨ + z --------> w. + bottom + ``` + + More precisely, we have an equivalence + + ```text + (left ∙ bottom = top ∙ right) ≃ (left ∙ bottom = (top ∙ p) ∙ (p⁻¹ ∙ right)). + ``` + + Similarly, we have an equivalence + + ```text + (left ∙ bottom = top ∙ right) ≃ (left ∙ bottom = (top ∙ p⁻¹) ∙ (p ∙ right)). + ``` + +These operations are useful in proofs involving path algebra, because taking +`equiv-right-whisker-concat-coherence-square-identicications` as an example, it +provides us with two maps: the forward direction states +`(p ∙ r = q ∙ s) → (p ∙ (r ∙ t)) = q ∙ (s ∙ t))`, which allows one to append +an identification without needing to reassociate on the right, and the backwards +direction conversely allows one to cancel out an identification in parentheses. + +#### Left whiskering coherences of commuting squares of identifications + +For any identification `p : u = x` we obtain an equivalence + +```text + top p ∙ top + x -------> y u -------> y + | | | | + left | | right ≃ p ∙ left | | right + ∨ ∨ ∨ ∨ + z -------> w z -------> w + bottom bottom +``` + +of coherences of commuting squares of identifications. + +```agda +module _ + {l : Level} {A : UU l} {x y z w u : A} + where + + left-whisker-concat-coherence-square-identifications : + (p : u = x) + (top : x = y) (left : x = z) (right : y = w) (bottom : z = w) → + coherence-square-identifications top left right bottom → + coherence-square-identifications (p ∙ top) (p ∙ left) right bottom + left-whisker-concat-coherence-square-identifications + refl top left right bottom = + id + + left-unwhisker-concat-coherence-square-identifications : + (p : u = x) + (top : x = y) (left : x = z) (right : y = w) (bottom : z = w) → + coherence-square-identifications (p ∙ top) (p ∙ left) right bottom → + coherence-square-identifications top left right bottom + left-unwhisker-concat-coherence-square-identifications + refl top left right bottom = + id +``` + +#### Right whiskering coherences of commuting squares of identifications + +For any identification `p : w = u` we obtain an equivalence + +```text + top top + x -------> y x ------------> y + | | | | + left | | right ≃ left | | right ∙ p + ∨ ∨ ∨ ∨ + z -------> w z ------------> w + bottom bottom ∙ p +``` + +of coherences of commuting squares of identifications. + +```agda +module _ + {l : Level} {A : UU l} {x y z w : A} + (top : x = y) (left : x = z) (right : y = w) (bottom : z = w) + where + + right-whisker-concat-coherence-square-identifications : + coherence-square-identifications top left right bottom → + {u : A} (p : w = u) → + coherence-square-identifications top left (right ∙ p) (bottom ∙ p) + right-whisker-concat-coherence-square-identifications s refl = + concat-bottom-identification-coherence-square-identifications + ( top) + ( left) + ( right ∙ refl) + ( bottom) + ( inv right-unit) + ( concat-right-identification-coherence-square-identifications + ( top) + ( left) + ( right) + ( bottom) + ( inv right-unit) + ( s)) + + right-unwhisker-cohernece-square-identifications : + {u : A} (p : w = u) → + coherence-square-identifications top left (right ∙ p) (bottom ∙ p) → + coherence-square-identifications top left right bottom + right-unwhisker-cohernece-square-identifications refl = + ( inv-concat-right-identification-coherence-square-identifications + ( top) + ( left) + ( right) + ( bottom) + ( inv right-unit)) ∘ + ( inv-concat-bottom-identification-coherence-square-identifications + ( top) + ( left) + ( right ∙ refl) + ( bottom) + ( inv right-unit)) +``` + +#### Left splicing coherences of commuting squares of identifications + +For any inverse pair of identifications `p : y = u` and `q : u = y` equipped +with `α : inv p = q` we obtain an equivalence + +```text + top top + x -------> y x -----------> y + | | | | + left | | right ≃ left ∙ p | | right + ∨ ∨ ∨ ∨ + z -------> w u -----------> w + bottom q ∙ bottom +``` + +of coherences of commuting squares of identifications. + +```agda +module _ + {l : Level} {A : UU l} {x y z w : A} + (top : x = y) (left : x = z) (right : y = w) (bottom : z = w) + where + + left-splice-coherence-square-identifications : + {u : A} (p : z = u) (q : u = z) (α : inv p = q) → + coherence-square-identifications top left right bottom → + coherence-square-identifications top (left ∙ p) right (q ∙ bottom) + left-splice-coherence-square-identifications refl .refl refl = + concat-left-identification-coherence-square-identifications + ( top) + ( left) + ( right) + ( bottom) + ( inv right-unit) + + left-unsplice-coherence-square-identifications : + {u : A} (p : z = u) (q : u = z) (α : inv p = q) → + coherence-square-identifications top (left ∙ p) right (q ∙ bottom) → + coherence-square-identifications top left right bottom + left-unsplice-coherence-square-identifications refl .refl refl = + inv-concat-left-identification-coherence-square-identifications + ( top) + ( left) + ( right) + ( bottom) + ( inv right-unit) +``` + +#### Right splicing coherences of commuting squares of identifications + +For any inverse pair of identifications `p : y = u` and `q : u = y` equipped +with `α : inv p = q` we obtain an equivalence + +```text + top top ∙ p + x -------> y x --------> u + | | | | + left | | right ≃ left | | q ∙ right + ∨ ∨ ∨ ∨ + z -------> w z --------> w + bottom bottom +``` + +of coherences of commuting squares of identifications. + +```agda +module _ + {l : Level} {A : UU l} {x y z w : A} + (top : x = y) (left : x = z) (right : y = w) (bottom : z = w) + where + + right-splice-coherence-square-identifications : + {u : A} (p : y = u) (q : u = y) (α : inv p = q) → + coherence-square-identifications top left right bottom → + coherence-square-identifications (top ∙ p) left (inv p ∙ right) bottom + right-splice-coherence-square-identifications refl .refl refl = + concat-top-identification-coherence-square-identifications + ( top) + ( left) + ( right) + ( bottom) + ( inv right-unit) + + right-unsplice-coherence-square-identifications : + {u : A} (p : y = u) (q : u = y) (α : inv p = q) → + coherence-square-identifications (top ∙ p) left (inv p ∙ right) bottom → + coherence-square-identifications top left right bottom + right-unsplice-coherence-square-identifications refl .refl refl = + inv-concat-top-identification-coherence-square-identifications + ( top) + ( left) + ( right) + ( bottom) + ( inv right-unit) +``` + +### Horizontally pasting squares of identifications + +Consider two squares of identifications as in the diagram + +```text + top-left top-right + a -------------> b -------------> c + | | | + left | | middle | right + ∨ ∨ ∨ + d -------------> e -------------> f + bottom-left bottom-right +``` + +with `s : left ∙ bottom-left = top-left ∙ middle` and t : middle ∙ bottom-right += top-right ∙ right`. Then the outer square commutes. + +```agda +module _ + {l : Level} {A : UU l} {a b c d e f : A} + (top-left : a = b) (top-right : b = c) + (left : a = d) (middle : b = e) (right : c = f) + (bottom-left : d = e) (bottom-right : e = f) + where + + horizontal-pasting-coherence-square-identifications : + coherence-square-identifications top-left left middle bottom-left → + coherence-square-identifications top-right middle right bottom-right → + coherence-square-identifications + (top-left ∙ top-right) left right (bottom-left ∙ bottom-right) + horizontal-pasting-coherence-square-identifications s t = + ( right-whisker-concat-coherence-square-identifications + ( top-left) + ( left) + ( middle) + ( bottom-left) + ( s) + ( bottom-right)) ∙ + ( ( inv (assoc top-left middle bottom-right)) ∙ + ( left-whisker-concat-coherence-square-identifications + ( top-left) + ( top-right) + ( middle) + ( right) + ( bottom-right) + ( t))) +``` + +### Vertically pasting squares of identifications + +Consider two squares of identifications as in the diagram + +```text + top + a --------> b + | | + top-left | | top-right + ∨ middle ∨ + c --------> d + | | + bottom-left | | bottom-right + ∨ ∨ + e --------> f + bottom +``` + +with `s : top-left ∙ middle = top ∙ top-right` and +`t : bottom-left ∙ bottom = middle ∙ bottom-right`. Then the outer square +commutes. + +```agda +module _ + {l : Level} {A : UU l} {a b c d e f : A} + (top : a = b) (top-left : a = c) (top-right : b = d) + (middle : c = d) (bottom-left : c = e) (bottom-right : d = f) + (bottom : e = f) + where + + vertical-pasting-coherence-square-identifications : + coherence-square-identifications top top-left top-right middle → + coherence-square-identifications middle bottom-left bottom-right bottom → + coherence-square-identifications + top (top-left ∙ bottom-left) (top-right ∙ bottom-right) bottom + vertical-pasting-coherence-square-identifications p q = + ( left-whisker-concat-coherence-square-identifications + ( top-left) + ( middle) + ( bottom-left) + ( bottom-right) + ( bottom) + ( q)) ∙ + ( ( assoc top-left middle bottom-right) ∙ + ( right-whisker-concat-coherence-square-identifications + ( top) + ( top-left) + ( top-right) + ( middle) + ( p) + ( bottom-right))) +``` + +## Properties + +### Left unit law for horizontal pasting of commuting squares of identifications + +```agda +module _ + {l : Level} {A : UU l} {a b c d : A} + where + + left-unit-law-horizontal-pasting-coherence-square-identifications : + (top : a = b) (left : a = c) (right : b = d) (bottom : c = d) + (s : coherence-square-identifications top left right bottom) → + horizontal-pasting-coherence-square-identifications + ( refl) + ( top) + ( left) + ( left) + ( right) + ( refl) + ( bottom) + ( horizontal-refl-coherence-square-identifications left) + ( s) = + s + left-unit-law-horizontal-pasting-coherence-square-identifications + refl refl right refl s = refl +``` + +### Right unit law for horizontal pasting of commuting squares of identifications + +```agda +module _ + {l : Level} {A : UU l} {a b c d : A} + where + + right-unit-law-horizontal-pasting-coherence-square-identifications : + (top : a = b) (left : a = c) (right : b = d) (bottom : c = d) + (s : coherence-square-identifications top left right bottom) → + horizontal-pasting-coherence-square-identifications + ( top) + ( refl) + ( left) + ( right) + ( right) + ( bottom) + ( refl) + ( s) + ( horizontal-refl-coherence-square-identifications right) ∙ + right-whisker-concat right-unit right = + left-whisker-concat left right-unit ∙ s + right-unit-law-horizontal-pasting-coherence-square-identifications + refl refl .refl refl refl = + refl +``` + +### Left unit law for vertical pasting of commuting squares of identifications + +```agda +module _ + {l : Level} {A : UU l} {a b c d : A} + where + + left-unit-law-vertical-pasting-coherence-square-identifications : + (top : a = b) (left : a = c) (right : b = d) (bottom : c = d) + (s : coherence-square-identifications top left right bottom) → + vertical-pasting-coherence-square-identifications + ( top) + ( refl) + ( refl) + ( top) + ( left) + ( right) + ( bottom) + ( vertical-refl-coherence-square-identifications top) + ( s) = + s + left-unit-law-vertical-pasting-coherence-square-identifications + refl refl .refl refl refl = refl +``` + +### Right unit law for vertical pasting of commuting squares of identifications + +```agda +module _ + {l : Level} {A : UU l} {a b c d : A} + where + + right-unit-law-vertical-pasting-coherence-square-identifications : + (top : a = b) (left : a = c) (right : b = d) (bottom : c = d) + (s : coherence-square-identifications top left right bottom) → + vertical-pasting-coherence-square-identifications + ( top) + ( left) + ( right) + ( bottom) + ( refl) + ( refl) + ( bottom) + ( s) + ( vertical-refl-coherence-square-identifications bottom) ∙ + left-whisker-concat top right-unit = + right-whisker-concat right-unit bottom ∙ s + right-unit-law-vertical-pasting-coherence-square-identifications + refl refl .(refl ∙ refl) refl refl = + refl +``` + +### Computing the right whiskering of a vertically constant square with an identification + +Consider the vertically constant square of identifications + +```text + p + x -----> y + | | + refl | | refl + ∨ ∨ + x -----> y + p +``` + +at an identification `p : x = y`, and consider an identification `q : y = z`. +Then the right whiskering of the above square with `q` is the commuting square +of identifications + +```text + p + x -------> y + | | + refl | refl | q + ∨ ∨ + x -------> z + p ∙ q +``` + +```agda +module _ + {l1 : Level} {A : UU l1} + where + + right-whisker-concat-vertical-refl-coherence-square-identifications : + {x y z : A} (p : x = y) (q : y = z) → + right-whisker-concat-coherence-square-identifications p refl refl p + ( vertical-refl-coherence-square-identifications p) + ( q) = + refl + right-whisker-concat-vertical-refl-coherence-square-identifications + refl refl = + refl +``` + +### Computing the right whiskering of a horizontally constant square with an identification + +Consider a horizontally constant commuting square of identifications + +```text + refl + x -----> x + | | + p | | p + ∨ ∨ + y -----> y + refl +``` + +at an identification `p` and consider an identification `q : y = z`. Then the +right whiskering of the above square with `q` is the square + +```text + refl + x -----> x + | | + p | refl | p ∙ q + ∨ ∨ + y -----> z. + q +``` + +```agda +module _ + {l1 : Level} {A : UU l1} + where + + right-whisker-concat-horizontal-refl-coherence-square-identifications : + {x y z : A} (p : x = y) (q : y = z) → + right-whisker-concat-coherence-square-identifications refl p p refl + ( horizontal-refl-coherence-square-identifications p) + ( q) = + refl + right-whisker-concat-horizontal-refl-coherence-square-identifications + refl refl = + refl +``` + +### Computing the left whiskering of a horizontally constant square with an identification + +Consider an identification `p : x = y` and a horizontally constant commuting +square of identifications + +```text + refl + y -----> y + | | + q | | q + ∨ ∨ + z -----> z + refl +``` + +at an identification `q : y = z`. The the left whiskering of the above square +with `p` is the commuting square + +```text + q ∙ refl + x ------------------------------------------------------> y + | | + q ∙ p | right-unit ∙ inv (right-whisker-concat right-unit p) | p + ∨ ∨ + z ------------------------------------------------------> z. + refl +``` + +```agda +module _ + {l1 : Level} {A : UU l1} + where + + left-whisker-concat-horizontal-refl-coherence-square-identifications : + {x y z : A} (p : x = y) (q : y = z) → + left-whisker-concat-coherence-square-identifications p refl q q refl + ( horizontal-refl-coherence-square-identifications q) ∙ + right-whisker-concat right-unit q = + right-unit + left-whisker-concat-horizontal-refl-coherence-square-identifications + refl refl = + refl + + left-whisker-concat-horizontal-refl-coherence-square-identifications' : + {x y z : A} (p : x = y) (q : y = z) → + left-whisker-concat-coherence-square-identifications p refl q q refl + ( horizontal-refl-coherence-square-identifications q) = + right-unit ∙ inv (right-whisker-concat right-unit q) + left-whisker-concat-horizontal-refl-coherence-square-identifications' + refl refl = + refl +``` + +### Computing the left whiskering of a vertically constant square with an identification + +Consider the vertically constant square of identifications + +```text + q + y -----> z + | | + refl | | refl + ∨ ∨ + y -----> z + q +``` + +at an identification `q : y = z` and consider an identification `p : x = y`. +Then the left whiskering of the above square with `p` is the square + +```text + p ∙ q + x ---------------------------------------------------> z + | | + p ∙ refl | right-whisker-concat right-unit q ∙ inv right-unit | refl + ∨ ∨ + y ---------------------------------------------------> z. + q +``` + +```agda +module _ + {l1 : Level} {A : UU l1} + where + + left-whisker-concat-vertical-refl-coherence-square-identifications : + {x y z : A} (p : x = y) (q : y = z) → + left-whisker-concat-coherence-square-identifications p q refl refl q + ( vertical-refl-coherence-square-identifications q) ∙ + right-unit = + right-whisker-concat right-unit q + left-whisker-concat-vertical-refl-coherence-square-identifications + refl refl = + refl + + left-whisker-concat-vertical-refl-coherence-square-identifications' : + {x y z : A} (p : x = y) (q : y = z) → + left-whisker-concat-coherence-square-identifications p q refl refl q + ( vertical-refl-coherence-square-identifications q) = + right-whisker-concat right-unit q ∙ inv right-unit + left-whisker-concat-vertical-refl-coherence-square-identifications' + refl refl = + refl +``` + +### Left whiskering horizontal concatenations of squares with identifications + +Consider a commuting diagram of identifications of the form + +```text + top-left top-right + a -------------> c -------------> e + | | | + left | | middle | right + ∨ ∨ ∨ + b -------------> d -------------> f + bottom-left bottom-right +``` + +and consider an identification `p : x = a`. Then the left whiskering of `p` and +the horizontal concatenation of coherences of commuting squares is up to +associativity the horizontal concatenation of the squares + +```text + p ∙ top-left top-right + x -------------> c -------------> e + | | | + p ∙ left | | middle | right + ∨ ∨ ∨ + b -------------> d -------------> f + bottom-left bottom-right +``` + +where the left square is the left whiskering of `p` and the original left +square. + +```agda +module _ + {l1 : Level} {A : UU l1} + where + + left-whisker-concat-horizontal-pasting-coherence-square-identifications : + {x a b c d e f : A} (p : x = a) + (top-left : a = c) (top-right : c = e) + (left : a = b) (middle : c = d) (right : e = f) + (bottom-left : b = d) (bottom-right : d = f) + (l : coherence-square-identifications top-left left middle bottom-left) + (r : coherence-square-identifications top-right middle right bottom-right) → + left-whisker-concat-coherence-square-identifications p + ( top-left ∙ top-right) + ( left) + ( right) + ( bottom-left ∙ bottom-right) + ( horizontal-pasting-coherence-square-identifications + ( top-left) + ( top-right) + ( left) + ( middle) + ( right) + ( bottom-left) + ( bottom-right) + ( l) + ( r)) = + horizontal-pasting-coherence-square-identifications + ( p ∙ top-left) + ( top-right) + ( p ∙ left) + ( middle) + ( right) + ( bottom-left) + ( bottom-right) + ( left-whisker-concat-coherence-square-identifications p + ( top-left) + ( left) + ( middle) + ( bottom-left) + ( l)) + ( r) ∙ + right-whisker-concat + ( assoc p top-left top-right) + ( right) + left-whisker-concat-horizontal-pasting-coherence-square-identifications + refl top-left top-right left middle right bottom-left bottom-right l r = + inv right-unit +``` + +### Left whiskering vertical concatenations of squares with identifications + +Consider two squares of identifications as in the diagram + +```text + top + a --------> b + | | + top-left | | top-right + ∨ middle ∨ + c --------> d + | | + bottom-left | | bottom-right + ∨ ∨ + e --------> f + bottom +``` + +and consider an identification `p : x = a`. Then the left whiskering of `p` +with the vertical pasting of the two squares above is up to associativity the +vertical pasting of the squares + +```text + p ∙ top + x --------> b + | | + p ∙ top-left | | top-right + ∨ middle ∨ + c --------> d + | | + bottom-left | | bottom-right + ∨ ∨ + e --------> f. + bottom +``` + +```agda +module _ + {l1 : Level} {A : UU l1} + where + + left-whisker-concat-vertical-concat-coherence-square-identifications : + {x a b c d e f : A} (p : x = a) → + (top : a = b) (top-left : a = c) (top-right : b = d) (middle : c = d) + (bottom-left : c = e) (bottom-right : d = f) (bottom : e = f) + (t : coherence-square-identifications top top-left top-right middle) → + (b : + coherence-square-identifications middle bottom-left bottom-right bottom) → + right-whisker-concat (assoc p top-left bottom-left) bottom ∙ + left-whisker-concat-coherence-square-identifications p + ( top) + ( top-left ∙ bottom-left) + ( top-right ∙ bottom-right) + ( bottom) + ( vertical-pasting-coherence-square-identifications + ( top) + ( top-left) + ( top-right) + ( middle) + ( bottom-left) + ( bottom-right) + ( bottom) + ( t) + ( b)) = + vertical-pasting-coherence-square-identifications + ( p ∙ top) + ( p ∙ top-left) + ( top-right) + ( middle) + ( bottom-left) + ( bottom-right) + ( bottom) + ( left-whisker-concat-coherence-square-identifications p + ( top) + ( top-left) + ( top-right) + ( middle) + ( t)) + ( b) + left-whisker-concat-vertical-concat-coherence-square-identifications + refl top top-left top-right middle bottom-left bottom-right bottom t b = + refl +``` + +### Right whiskering horizontal pastings of commuting squares of identifications + +Consider a commuting diagram of identifications of the form + +```text + top-left top-right + a -------------> c -------------> e + | | | + left | | middle | right + ∨ ∨ ∨ + b -------------> d -------------> f + bottom-left bottom-right +``` + +and consider an identification `q : f = y`. Then the right whiskering of the +horizontal pasting of the squares above is up to associativity the horizontal +pasting of the squares + +```text + top-left top-right + a -------------> c ------------------> e + | | | + left | | middle | right ∙ q + ∨ ∨ ∨ + b -------------> d ------------------> y + bottom-left bottom-right ∙ q +``` + +```agda +module _ + {l1 : Level} {A : UU l1} + where + + right-whisker-concat-horizontal-pasting-coherence-square-identifications : + {a b c d e f y : A} + (top-left : a = c) (top-right : c = e) + (left : a = b) (middle : c = d) (right : e = f) + (bottom-left : b = d) (bottom-right : d = f) + (l : coherence-square-identifications top-left left middle bottom-left) → + (r : coherence-square-identifications top-right middle right bottom-right) → + (q : f = y) → + right-whisker-concat-coherence-square-identifications + ( top-left ∙ top-right) + ( left) + ( right) + ( bottom-left ∙ bottom-right) + ( horizontal-pasting-coherence-square-identifications + ( top-left) + ( top-right) + ( left) + ( middle) + ( right) + ( bottom-left) + ( bottom-right) + ( l) + ( r)) + ( q) = + left-whisker-concat left (assoc bottom-left bottom-right q) ∙ + horizontal-pasting-coherence-square-identifications + ( top-left) + ( top-right) + ( left) + ( middle) + ( right ∙ q) + ( bottom-left) + ( bottom-right ∙ q) + ( l) + ( right-whisker-concat-coherence-square-identifications + ( top-right) + ( middle) + ( right) + ( bottom-right) + ( r) + ( q)) + right-whisker-concat-horizontal-pasting-coherence-square-identifications + refl refl refl .refl .refl refl refl refl refl refl = + refl +``` + +### Right whiskering vertical concatenations of squares with identifications + +Consider two squares of identifications as in the diagram + +```text + top + a --------> b + | | + top-left | | top-right + ∨ middle ∨ + c --------> d + | | + bottom-left | | bottom-right + ∨ ∨ + e --------> f + bottom +``` + +and consider an identification `q : f = y`. Then the right whiskering of the +vertical pasting of the two squares above with `q` is up to associativity the +vertical pasting of the squares + +```text + top + a ------------> b + | | + top-left | | top-right + ∨ middle ∨ + c ------------> d + | | + bottom-left | | bottom-right ∙ q + ∨ ∨ + e ------------> y. + bottom ∙ q +``` + +```agda +module _ + {l1 : Level} {A : UU l1} + where + + right-whisker-concat-vertical-pasting-coherence-square-identifications : + {a b c d e f y : A} + (top : a = b) (top-left : a = c) (top-right : b = d) + (middle : c = d) + (bottom-left : c = e) (bottom-right : d = f) (bottom : e = f) + (t : coherence-square-identifications top top-left top-right middle) → + (b : + coherence-square-identifications middle bottom-left bottom-right bottom) → + (q : f = y) → + right-whisker-concat-coherence-square-identifications + ( top) + ( top-left ∙ bottom-left) + ( top-right ∙ bottom-right) + ( bottom) + ( vertical-pasting-coherence-square-identifications + ( top) + ( top-left) + ( top-right) + ( middle) + ( bottom-left) + ( bottom-right) + ( bottom) + ( t) + ( b)) + ( q) ∙ + left-whisker-concat top (assoc top-right bottom-right q) = + vertical-pasting-coherence-square-identifications + ( top) + ( top-left) + ( top-right) + ( middle) + ( bottom-left) + ( bottom-right ∙ q) + ( bottom ∙ q) + ( t) + ( right-whisker-concat-coherence-square-identifications + ( middle) + ( bottom-left) + ( bottom-right) + ( bottom) + ( b) + ( q)) + right-whisker-concat-vertical-pasting-coherence-square-identifications + refl refl .refl refl refl .refl refl refl refl refl = + refl +``` diff --git a/src/foundation-core/commuting-squares-of-maps.lagda.md b/src/foundation-core/commuting-squares-of-maps.lagda.md index 13c4b21118..92e9ba73f6 100644 --- a/src/foundation-core/commuting-squares-of-maps.lagda.md +++ b/src/foundation-core/commuting-squares-of-maps.lagda.md @@ -234,23 +234,23 @@ If the horizontal/vertical maps in a commuting square are both commuting if we invert those equivalences. ```agda -coherence-square-maps-inv-equiv-horizontal : +horizontal-inv-equiv-coherence-square-maps : {l1 l2 l3 l4 : Level} {A : UU l1} {B : UU l2} {X : UU l3} {Y : UU l4} (top : A ≃ B) (left : A → X) (right : B → Y) (bottom : X ≃ Y) → coherence-square-maps (map-equiv top) left right (map-equiv bottom) → coherence-square-maps (map-inv-equiv top) right left (map-inv-equiv bottom) -coherence-square-maps-inv-equiv-horizontal top left right bottom H b = +horizontal-inv-equiv-coherence-square-maps top left right bottom H b = map-eq-transpose-equiv-inv ( bottom) ( ( ap right (inv (is-section-map-inv-equiv top b))) ∙ ( inv (H (map-inv-equiv top b)))) -coherence-square-maps-inv-equiv-vertical : +vertical-inv-equiv-coherence-square-maps : {l1 l2 l3 l4 : Level} {A : UU l1} {B : UU l2} {X : UU l3} {Y : UU l4} (top : A → B) (left : A ≃ X) (right : B ≃ Y) (bottom : X → Y) → coherence-square-maps top (map-equiv left) (map-equiv right) bottom → coherence-square-maps bottom (map-inv-equiv left) (map-inv-equiv right) top -coherence-square-maps-inv-equiv-vertical top left right bottom H x = +vertical-inv-equiv-coherence-square-maps top left right bottom H x = map-eq-transpose-equiv ( right) ( ( inv (H (map-inv-equiv left x))) ∙ @@ -270,12 +270,12 @@ coherence-square-maps-inv-equiv : ( map-inv-equiv left) ( map-inv-equiv top) coherence-square-maps-inv-equiv top left right bottom H = - coherence-square-maps-inv-equiv-vertical + vertical-inv-equiv-coherence-square-maps ( map-inv-equiv top) ( right) ( left) ( map-inv-equiv bottom) - ( coherence-square-maps-inv-equiv-horizontal + ( horizontal-inv-equiv-coherence-square-maps ( top) ( map-equiv left) ( map-equiv right) diff --git a/src/foundation-core/whiskering-homotopies-concatenation.lagda.md b/src/foundation-core/whiskering-homotopies-concatenation.lagda.md new file mode 100644 index 0000000000..b761b11bb4 --- /dev/null +++ b/src/foundation-core/whiskering-homotopies-concatenation.lagda.md @@ -0,0 +1,125 @@ +# Whiskering homotopies with respect to concatenation + +```agda +module foundation-core.whiskering-homotopies-concatenation where +``` + +
Imports + +```agda +open import foundation.universe-levels +open import foundation.whiskering-operations + +open import foundation-core.homotopies +open import foundation-core.whiskering-identifications-concatenation +``` + +
+ +## Idea + +Consider a homotopy `H : f ~ g` and a homotopy `K : I ~ J` between two +homotopies `I J : g ~ f`. The +{{#concept "left whiskering" Disambiguation="homotopies with respect to concatenation" Agda=left-whisker-concat-htpy}} +of `H` and `K` is a homotopy `H ∙h I ~ H ∙h J`. In other words, left whiskering +of homotopies with respect to concatenation is a +[whiskering operation](foundation.whiskering-operations.md) + +```text + (H : f ~ g) {I J : g ~ h} → I ~ J → H ∙h I ~ H ∙h K. +``` + +Similarly, we introduce +{{#concept "right whiskering" Disambiguation="homotopies with respect to concatenation' Agda=right-whisker-concat-htpy}} +to be an operation + +```text + {H I : f ~ g} → H ~ I → (J : g ~ h) → H ∙h J ~ I ∙h J. +``` + +## Definitions + +### Left whiskering of homotopies with respect to concatenation + +Left whiskering of homotopies with respect to concatenation is an operation + +```text + (H : f ~ g) {I J : g ~ h} → I ~ J → H ∙h I ~ H ∙h K. +``` + +We implement the left whiskering operation of homotopies with respect to +concatenation as an instance of a general left whiskering operation. + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} + where + + left-whisker-concat-htpy : + left-whiskering-operation ((x : A) → B x) (_~_) (_∙h_) (_~_) + left-whisker-concat-htpy H K x = left-whisker-concat (H x) (K x) +``` + +### Right whiskering of homotopies with respect to concatenation + +Right whiskering of homotopies with respect to concatenation is an operation + +```text + {H I : f ~ g} → H ~ I → (J : g ~ h) → H ∙h J ~ I ∙h J. +``` + +We implement the right whiskering operation of homotopies with respect to +concatenation as an instance of a general right whiskering operation. + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} + where + + right-whisker-concat-htpy : + right-whiskering-operation ((x : A) → B x) (_~_) (_∙h_) (_~_) + right-whisker-concat-htpy K J x = right-whisker-concat (K x) (J x) +``` + +## Properties + +### The unit and absorption laws for left whiskering of homotopies with respect to concatenation + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} + where + + left-unit-law-left-whisker-concat-htpy : + {f g : (x : A) → B x} {I J : f ~ g} (K : I ~ J) → + left-whisker-concat-htpy refl-htpy K ~ K + left-unit-law-left-whisker-concat-htpy K x = + left-unit-law-left-whisker-concat (K x) + + right-absorption-law-left-whisker-concat-htpy : + {f g h : (x : A) → B x} (H : f ~ g) {I : g ~ h} → + left-whisker-concat-htpy H (refl-htpy' I) ~ refl-htpy + right-absorption-law-left-whisker-concat-htpy H x = + right-absorption-law-left-whisker-concat (H x) _ +``` + +### The unit and absorption laws for right whiskering of homotopies with respect to concatenation + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} + where + + left-absorption-law-right-whisker-concat-htpy : + {f g h : (x : A) → B x} {H : f ~ g} (J : g ~ h) → + right-whisker-concat-htpy (refl-htpy' H) J ~ refl-htpy + left-absorption-law-right-whisker-concat-htpy J x = + left-absorption-law-right-whisker-concat _ (J x) + + right-unit-law-right-whisker-concat-htpy : + {f g : (x : A) → B x} {I J : f ~ g} (K : I ~ J) → + right-unit-htpy ∙h K ~ + right-whisker-concat-htpy K refl-htpy ∙h right-unit-htpy + right-unit-law-right-whisker-concat-htpy K x = + right-unit-law-right-whisker-concat (K x) +``` diff --git a/src/foundation-core/whiskering-identifications-concatenation.lagda.md b/src/foundation-core/whiskering-identifications-concatenation.lagda.md new file mode 100644 index 0000000000..27f9cc20e6 --- /dev/null +++ b/src/foundation-core/whiskering-identifications-concatenation.lagda.md @@ -0,0 +1,327 @@ +# Whiskering identifications with respect to concatenation + +```agda +module foundation-core.whiskering-identifications-concatenation where +``` + +
Imports + +```agda +open import foundation.action-on-identifications-functions +open import foundation.dependent-pair-types +open import foundation-core.identity-types +open import foundation.universe-levels +open import foundation.whiskering-operations + +open import foundation-core.function-types +open import foundation-core.homotopies +``` + +
+ +## Idea + +Consider two [identifications](foundation-core.identity-types.md) `p q : x = y` +in a type `A`. The whiskering operations are operations that take +identifications `p = q` to identifications `r ∙ p = r ∙ q` or to +identifications `p ∙ r = q ∙ r`. + +The +{{#concept "left whiskering" Disambiguation="identifications" Agda=left-whisker-concat}} +operation takes an identification `r : z = x` and an identification `p = q` to +an identification `r ∙ p = r ∙ q`. Similarly, the +{{#concept "right whiskering" Disambiguation="identifications" Agda=right-whisker-concat}} +operation takes an identification `r : y = z` and an identification `p = q` to +an identification `p ∙ r = q ∙ r`. + +The whiskering operations can be defined by the +[acion on identifications](foundation.action-on-identifications-functions.md) of +concatenation. Since concatenation on either side is an +[equivalence](foundation-core.equivalences.md), it follows that the whiskering +operations are equivalences. + +## Definitions + +### Left whiskering of identifications + +Left whiskering of identifications with respect to concatenation is an operation + +```text + (p : x = y) {q r : y = z} → q = r → p ∙ q = p ∙ r +``` + +on any type. + +```agda +module _ + {l : Level} {A : UU l} + where + + left-whisker-concat : left-whiskering-operation A (_=_) (_∙_) (_=_) + left-whisker-concat p β = ap (p ∙_) β +``` + +### Right whiskering of identifications + +Right whiskering of identifications with respect to concatenation is an +operation + +```text + {p q : x = y} → p = q → (r : y = z) → p ∙ r = q ∙ r +``` + +on any type. + +```agda +module _ + {l : Level} {A : UU l} + where + + right-whisker-concat : right-whiskering-operation A (_=_) (_∙_) (_=_) + right-whisker-concat α q = ap (_∙ q) α +``` + +### Double whiskering of identifications + +```agda +module _ + {l : Level} {A : UU l} + {a b c d : A} (p : a = b) {r s : b = c} (t : r = s) (q : c = d) + where + + double-whisker-concat : (p ∙ r) ∙ q = (p ∙ s) ∙ q + double-whisker-concat = right-whisker-concat (left-whisker-concat p t) q + + double-whisker-concat' : p ∙ (r ∙ q) = p ∙ (s ∙ q) + double-whisker-concat' = left-whisker-concat p (right-whisker-concat t q) +``` + +## Properties + +### The unit and absorption laws for left whiskering of identifications + +```agda +module _ + {l : Level} {A : UU l} + where + + left-unit-law-left-whisker-concat : + {x y : A} {p p' : x = y} (α : p = p') → + left-whisker-concat refl α = α + left-unit-law-left-whisker-concat refl = refl + + right-absorption-law-left-whisker-concat : + {x y z : A} (p : x = y) (q : y = z) → + left-whisker-concat p (refl {x = q}) = refl + right-absorption-law-left-whisker-concat p q = refl +``` + +### The unit and absorption laws for right whiskering of identifications + +The right unit law for right whiskering of identifications with respect to +concatenation asserts that the square of identifications + +```text + right-whisker-concat α refl + p ∙ refl -----------------------------> p' ∙ refl + | | + right-unit | | + ∨ ∨ + p -------------------------------------> p' +``` + +commutes for any `α : p = p'`. Note that this law is slightly more complicated, +since concatenating with `refl` on the right does not compute to the identity +function. + +```agda +module _ + {l : Level} {A : UU l} + where + + right-unit-law-right-whisker-concat : + {x y : A} {p p' : x = y} (α : p = p') → + right-unit ∙ α = right-whisker-concat α refl ∙ right-unit + right-unit-law-right-whisker-concat {p = refl} refl = refl + + left-absorption-law-right-whisker-concat : + {x y z : A} (p : x = y) (q : y = z) → + right-whisker-concat (refl {x = p}) q = refl + left-absorption-law-right-whisker-concat p q = refl +``` + +### Commutativity of left and right whiskering of identifications + +Consider four identifications `p p' : x = y` and `q q' : y = z` in a type `A`. +Then the square of identifications + +```text + right-whisker α q + p ∙ q ---------------------> p' ∙ q + | | + left-whisker p β | | left-whisker p' β + ∨ ∨ + p ∙ q' --------------------> p' ∙ q' + right-whisker α q' +``` + +commutes. There are at least two natural ways in which this square is seen to +commute: + +1. The square commutes by naturality of the homotopy + `α ↦ left-whisker-concat α β`. +2. The transposed square commutes by the naturality of the homotopy + `β ↦ right-whisker-concat α β`. + +These two ways in which the square commutes are inverse to each other. + +**Note.** The following statements could have been formalized using +[commuting squares of identifications](foundation.commuting-squares-of-identifications.md). +However, in order to avoid cyclic module dependencies in the library we avoid +doing so. + +```agda +module _ + {l : Level} {A : UU l} {x y z : A} + where + + commutative-left-whisker-right-whisker-concat : + {q q' : y = z} (β : q = q') {p p' : x = y} (α : p = p') → + left-whisker-concat p β ∙ right-whisker-concat α q' = + right-whisker-concat α q ∙ left-whisker-concat p' β + commutative-left-whisker-right-whisker-concat β = + nat-htpy (λ α → left-whisker-concat α β) + + commutative-right-whisker-left-whisker-concat : + {p p' : x = y} (α : p = p') {q q' : y = z} (β : q = q') → + right-whisker-concat α q ∙ left-whisker-concat p' β = + left-whisker-concat p β ∙ right-whisker-concat α q' + commutative-right-whisker-left-whisker-concat α = + nat-htpy (right-whisker-concat α) + + compute-inv-commutative-left-whisker-right-whisker-concat : + {q q' : y = z} (β : q = q') {p p' : x = y} (α : p = p') → + inv (commutative-right-whisker-left-whisker-concat α β) = + commutative-left-whisker-right-whisker-concat β α + compute-inv-commutative-left-whisker-right-whisker-concat refl refl = + refl +``` + +### Swapping the order of left and right whiskering of identifications + +Consider a diagram of identifications + +```text + r + p -----> q + a -----> b -----> c -----> + s +``` + +with `t : r = s`. Then the square of identifications + +```text + assoc p r q + (p ∙ r) ∙ q -------------> p ∙ (r ∙ q) + | | + double-whisker p t q | | double-whisker' p t q + ∨ ∨ + (p ∙ s) ∙ q -------------> p ∙ (s ∙ q) + assoc p s q +``` + +commutes. + +```agda +module _ + {l1 : Level} {A : UU l1} + where + + swap-double-whisker-concat : + {a b c d : A} (p : a = b) {r s : b = c} (t : r = s) (q : c = d) → + double-whisker-concat p t q ∙ assoc p s q = + assoc p r q ∙ double-whisker-concat' p t q + swap-double-whisker-concat refl refl refl = refl +``` + +### The action on identifications of concatenating by `refl` on the right + +Consider an identification `r : p = q` between two identifications +`p q : x = y` in a type `A`. Then the square of identifications + +```text + right-whisker r refl + p ∙ refl ----------------------> q ∙ refl + | | + right-unit | | right-unit + ∨ ∨ + p -----------------------------> q + r +``` + +commutes. + +```agda +module _ + {l : Level} {A : UU l} {x y : A} {p q : x = y} + where + + compute-refl-right-whisker-concat : + (r : p = q) → + right-unit ∙ r = right-whisker-concat r refl ∙ right-unit + compute-refl-right-whisker-concat refl = right-unit +``` + +### Left whiskering of identifications distributes over concatenation + +```agda +module _ + {l : Level} {A : UU l} + where + + distributive-left-whisker-concat-concat : + {a b c : A} (p : a = b) {q r s : b = c} (α : q = r) (β : r = s) → + left-whisker-concat p (α ∙ β) = + left-whisker-concat p α ∙ left-whisker-concat p β + distributive-left-whisker-concat-concat p refl β = refl +``` + +### Right whiskering of identifications distributes over concatenation + +```agda +module _ + {l : Level} {A : UU l} + where + + distributive-right-whisker-concat-concat : + {a b c : A} {p q r : a = b} (α : p = q) (β : q = r) (s : b = c) → + right-whisker-concat (α ∙ β) s = + right-whisker-concat α s ∙ right-whisker-concat β s + distributive-right-whisker-concat-concat refl β s = refl +``` + +### Left whiskering of identifications commutes with inverses of identifications + +```agda +module _ + {l : Level} {A : UU l} + where + + compute-inv-left-whisker-concat : + {a b c : A} (p : a = b) {q r : b = c} (s : q = r) → + left-whisker-concat p (inv s) = inv (left-whisker-concat p s) + compute-inv-left-whisker-concat p s = ap-inv (concat p _) s +``` + +### Right whiskering of identifications commutes with inverses of identifications + +```agda +module _ + {l : Level} {A : UU l} + where + + compute-inv-right-whisker-concat : + {a b c : A} {p q : a = b} (s : p = q) (r : b = c) → + right-whisker-concat (inv s) r = inv (right-whisker-concat s r) + compute-inv-right-whisker-concat s r = ap-inv (concat' _ r) s +``` diff --git a/src/foundation/commuting-squares-of-homotopies.lagda.md b/src/foundation/commuting-squares-of-homotopies.lagda.md index 5ae628881b..1f8d3730f8 100644 --- a/src/foundation/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation/commuting-squares-of-homotopies.lagda.md @@ -263,8 +263,6 @@ homotopies f ·l K' ``` -and similarly we may whisker it on the right. - ```agda module _ { l1 l2 l3 : Level} {A : UU l1} {B : UU l2} {C : UU l3} @@ -277,7 +275,11 @@ module _ coherence-square-homotopies (f ·l H) (f ·l H') (f ·l K) (f ·l K') map-coherence-square-homotopies α a = map-coherence-square-identifications f (H a) (H' a) (K a) (K' a) (α a) +``` +And similarly we may whisker it on the right. + +```agda module _ { l1 l2 l3 : Level} {A : UU l1} {B : UU l2} {C : UU l3} { g h h' k : B → C} (H : g ~ h) (H' : g ~ h') {K : h ~ k} {K' : h' ~ k} diff --git a/src/foundation/commuting-squares-of-identifications.lagda.md b/src/foundation/commuting-squares-of-identifications.lagda.md index 8c537e89f2..e5acc92b99 100644 --- a/src/foundation/commuting-squares-of-identifications.lagda.md +++ b/src/foundation/commuting-squares-of-identifications.lagda.md @@ -2,6 +2,8 @@ ```agda module foundation.commuting-squares-of-identifications where + +open import foundation-core.commuting-squares-of-identifications public ```
Imports @@ -10,7 +12,6 @@ module foundation.commuting-squares-of-identifications where open import foundation.action-on-identifications-functions open import foundation.dependent-pair-types open import foundation.universe-levels -open import foundation.whiskering-identifications-concatenation open import foundation-core.equivalences open import foundation-core.function-types @@ -42,197 +43,6 @@ identification is called a {{#concept "coherence" Disambiguation="commuting square of identifications" Agda=coherence-square-identifications}} of the square. -## Definitions - -### Commuting squares of identifications - -```agda -module _ - {l : Level} {A : UU l} {x y z w : A} - (top : x = y) (left : x = z) (right : y = w) (bottom : z = w) - where - - coherence-square-identifications : UU l - coherence-square-identifications = left ∙ bottom = top ∙ right -``` - -### Horizontally constant squares - -{{#concept "Horizontally constant squares" Disambiguation="identifications" Agda=horizontal-refl-coherence-square-identifications}} -are commuting squares of identifications of the form - -```text - refl - a -----> a - | | - p | | p - ∨ ∨ - b -----> b. - refl -``` - -```agda -module _ - {l : Level} {A : UU l} {a b : A} (p : a = b) - where - - horizontal-refl-coherence-square-identifications : - coherence-square-identifications refl p p refl - horizontal-refl-coherence-square-identifications = right-unit -``` - -### Vertically constant squares - -{{#concept "Vertically constant squares" Disambiguation="identifications" Agda=vertical-refl-coherence-square-identifications}} -are commuting squares of identifications of the form - -```text - p - a -----> b - | | - refl | | refl - ∨ ∨ - a -----> b. - p -``` - -```agda -module _ - {l : Level} {A : UU l} {a b : A} (p : a = b) - where - - vertical-refl-coherence-square-identifications : - coherence-square-identifications p refl refl p - vertical-refl-coherence-square-identifications = inv right-unit -``` - -## Operations - -### Inverting squares of identifications horizontally - -Given a commuting square of identifications - -```text - top - x -------> y - | | - left | | right - ∨ ∨ - z -------> w, - bottom -``` - -the square of identifications - -```text - inv top - y ------------> x - | | - right | | left - ∨ ∨ - w ------------> z - inv bottom -``` - -commutes. - -```agda -module _ - {l : Level} {A : UU l} {x y z w : A} - where - - horizontal-inv-coherence-square-identifications : - (top : x = y) (left : x = z) (right : y = w) (bottom : z = w) → - coherence-square-identifications top left right bottom → - coherence-square-identifications (inv top) right left (inv bottom) - horizontal-inv-coherence-square-identifications refl refl right refl coh = - right-unit ∙ inv coh -``` - -### Inverting squares of identifications vertically - -Given a commuting square of identifications - -```text - top - x -------> y - | | - left | | right - ∨ ∨ - z -------> w, - bottom -``` - -the square of identifications - -```text - bottom - z -------> w - | | - inv left | | inv right - ∨ ∨ - x -------> y - top -``` - -commutes. - -```agda -module _ - {l : Level} {A : UU l} {x y z w : A} - where - - vertical-inv-coherence-square-identifications : - (top : x = y) (left : x = z) (right : y = w) (bottom : z = w) → - coherence-square-identifications top left right bottom → - coherence-square-identifications bottom (inv left) (inv right) top - vertical-inv-coherence-square-identifications refl refl refl refl refl = refl -``` - -### Functions acting on squares of identifications - -Given a commuting square of identifications - -```text - top - x -------> y - | | - left | | right - ∨ ∨ - z -------> w - bottom -``` - -in a type `A`, and given a map `f : A → B`, the square of identifications - -```text - ap f top - f x -----------> f y - | | - ap f left | | ap f right - ∨ ∨ - z -------------> w - ap f bottom -``` - -commutes. - -```agda -module _ - {l1 l2 : Level} {A : UU l1} {B : UU l2} {x y z w : A} (f : A → B) - where - - map-coherence-square-identifications : - (top : x = y) (left : x = z) (right : y = w) (bottom : z = w) → - coherence-square-identifications top left right bottom → - coherence-square-identifications - ( ap f top) - ( ap f left) - ( ap f right) - ( ap f bottom) - map-coherence-square-identifications refl refl right refl coh = ap (ap f) coh -``` - ### Concatenating identifications of edges and coherences of commuting squares of identifications Consider a commuting square of identifications and an identification of one of @@ -252,10 +62,6 @@ Then any identification witnessing that the square commutes can be concatenated with the identification on the side, to obtain a new commuting square of identifications. -**Note.** To avoid cyclic module dependencies we will give direct proofs that -concatenating identifications of edges of a square with the coherence of its -commutativity is an equivalence. - #### Concatenating identifications of the top edge with a coherence of a commuting square of identifications Consider a commuting diagram of identifications @@ -290,46 +96,26 @@ module _ {top' : x = y} (s : top = top') where - concat-top-identification-coherence-square-identifications : - coherence-square-identifications top left right bottom → - coherence-square-identifications top' left right bottom - concat-top-identification-coherence-square-identifications t = - t ∙ ap (concat' _ right) s - - inv-concat-top-identification-coherence-square-identifications : - coherence-square-identifications top' left right bottom → - coherence-square-identifications top left right bottom - inv-concat-top-identification-coherence-square-identifications t = - t ∙ inv (ap (concat' _ right) s) - - is-section-inv-concat-top-identification-coherence-square-identifications : - is-section - concat-top-identification-coherence-square-identifications - inv-concat-top-identification-coherence-square-identifications - is-section-inv-concat-top-identification-coherence-square-identifications = - is-section-inv-concat' (ap (concat' _ right) s) - - is-retraction-inv-concat-top-identification-coherence-square-identifications : - is-retraction - concat-top-identification-coherence-square-identifications - inv-concat-top-identification-coherence-square-identifications - is-retraction-inv-concat-top-identification-coherence-square-identifications = - is-retraction-inv-concat' (ap (concat' _ right) s) - abstract is-equiv-concat-top-identification-coherence-square-identifications : - is-equiv concat-top-identification-coherence-square-identifications + is-equiv + ( concat-top-identification-coherence-square-identifications + top left right bottom s) is-equiv-concat-top-identification-coherence-square-identifications = is-equiv-is-invertible - inv-concat-top-identification-coherence-square-identifications - is-section-inv-concat-top-identification-coherence-square-identifications - is-retraction-inv-concat-top-identification-coherence-square-identifications + ( inv-concat-top-identification-coherence-square-identifications + top left right bottom s) + ( is-section-inv-concat-top-identification-coherence-square-identifications + top left right bottom s) + ( is-retraction-inv-concat-top-identification-coherence-square-identifications + top left right bottom s) equiv-concat-top-identification-coherence-square-identifications : coherence-square-identifications top left right bottom ≃ coherence-square-identifications top' left right bottom pr1 equiv-concat-top-identification-coherence-square-identifications = concat-top-identification-coherence-square-identifications + top left right bottom s pr2 equiv-concat-top-identification-coherence-square-identifications = is-equiv-concat-top-identification-coherence-square-identifications ``` @@ -367,45 +153,26 @@ module _ {left' : x = z} (s : left = left') where - concat-left-identification-coherence-square-identifications : - coherence-square-identifications top left right bottom → - coherence-square-identifications top left' right bottom - concat-left-identification-coherence-square-identifications t = - inv (ap (concat' _ bottom) s) ∙ t - - inv-concat-left-identification-coherence-square-identifications : - coherence-square-identifications top left' right bottom → - coherence-square-identifications top left right bottom - inv-concat-left-identification-coherence-square-identifications t = - ap (concat' _ bottom) s ∙ t - - is-section-inv-concat-left-identification-coherence-square-identifications : - is-section - concat-left-identification-coherence-square-identifications - inv-concat-left-identification-coherence-square-identifications - is-section-inv-concat-left-identification-coherence-square-identifications = - is-retraction-inv-concat (ap (concat' _ bottom) s) - - is-retraction-inv-concat-left-identification-coherence-square-identifications : - is-retraction - concat-left-identification-coherence-square-identifications - inv-concat-left-identification-coherence-square-identifications - is-retraction-inv-concat-left-identification-coherence-square-identifications = - is-section-inv-concat (ap (concat' _ bottom) s) - - is-equiv-concat-left-identification-coherence-square-identifications : - is-equiv concat-left-identification-coherence-square-identifications - is-equiv-concat-left-identification-coherence-square-identifications = - is-equiv-is-invertible - inv-concat-left-identification-coherence-square-identifications - is-section-inv-concat-left-identification-coherence-square-identifications - is-retraction-inv-concat-left-identification-coherence-square-identifications + abstract + is-equiv-concat-left-identification-coherence-square-identifications : + is-equiv + ( concat-left-identification-coherence-square-identifications + top left right bottom s) + is-equiv-concat-left-identification-coherence-square-identifications = + is-equiv-is-invertible + ( inv-concat-left-identification-coherence-square-identifications + top left right bottom s) + ( is-section-inv-concat-left-identification-coherence-square-identifications + top left right bottom s) + ( is-retraction-inv-concat-left-identification-coherence-square-identifications + top left right bottom s) equiv-concat-left-identification-coherence-square-identifications : coherence-square-identifications top left right bottom ≃ coherence-square-identifications top left' right bottom pr1 equiv-concat-left-identification-coherence-square-identifications = concat-left-identification-coherence-square-identifications + top left right bottom s pr2 equiv-concat-left-identification-coherence-square-identifications = is-equiv-concat-left-identification-coherence-square-identifications ``` @@ -443,46 +210,26 @@ module _ {right' : y = w} (s : right = right') where - concat-right-identification-coherence-square-identifications : - coherence-square-identifications top left right bottom → - coherence-square-identifications top left right' bottom - concat-right-identification-coherence-square-identifications t = - t ∙ ap (concat top _) s - - inv-concat-right-identification-coherence-square-identifications : - coherence-square-identifications top left right' bottom → - coherence-square-identifications top left right bottom - inv-concat-right-identification-coherence-square-identifications t = - t ∙ inv (ap (concat top _) s) - - is-section-inv-concat-right-identification-coherence-square-identifications : - is-section - concat-right-identification-coherence-square-identifications - inv-concat-right-identification-coherence-square-identifications - is-section-inv-concat-right-identification-coherence-square-identifications = - is-section-inv-concat' (ap (concat top _) s) - - is-retraction-inv-concat-right-identification-coherence-square-identifications : - is-retraction - concat-right-identification-coherence-square-identifications - inv-concat-right-identification-coherence-square-identifications - is-retraction-inv-concat-right-identification-coherence-square-identifications = - is-retraction-inv-concat' (ap (concat top _) s) - abstract is-equiv-concat-right-identification-coherence-square-identifications : - is-equiv concat-right-identification-coherence-square-identifications + is-equiv + ( concat-right-identification-coherence-square-identifications + top left right bottom s) is-equiv-concat-right-identification-coherence-square-identifications = is-equiv-is-invertible - inv-concat-right-identification-coherence-square-identifications - is-section-inv-concat-right-identification-coherence-square-identifications - is-retraction-inv-concat-right-identification-coherence-square-identifications + ( inv-concat-right-identification-coherence-square-identifications + top left right bottom s) + ( is-section-inv-concat-right-identification-coherence-square-identifications + top left right bottom s) + ( is-retraction-inv-concat-right-identification-coherence-square-identifications + top left right bottom s) equiv-concat-right-identification-coherence-square-identifications : coherence-square-identifications top left right bottom ≃ coherence-square-identifications top left right' bottom pr1 equiv-concat-right-identification-coherence-square-identifications = concat-right-identification-coherence-square-identifications + top left right bottom s pr2 equiv-concat-right-identification-coherence-square-identifications = is-equiv-concat-right-identification-coherence-square-identifications ``` @@ -521,45 +268,25 @@ module _ {bottom' : z = w} (s : bottom = bottom') where - concat-bottom-identification-coherence-square-identifications : - coherence-square-identifications top left right bottom → - coherence-square-identifications top left right bottom' - concat-bottom-identification-coherence-square-identifications t = - inv (ap (concat left _) s) ∙ t - - inv-concat-bottom-identification-coherence-square-identifications : - coherence-square-identifications top left right bottom' → - coherence-square-identifications top left right bottom - inv-concat-bottom-identification-coherence-square-identifications t = - ap (concat left _) s ∙ t - - is-section-inv-concat-bottom-identification-coherence-square-identifications : - is-section - concat-bottom-identification-coherence-square-identifications - inv-concat-bottom-identification-coherence-square-identifications - is-section-inv-concat-bottom-identification-coherence-square-identifications = - is-retraction-inv-concat (ap (concat left _) s) - - is-retraction-inv-concat-bottom-identification-coherence-square-identifications : - is-retraction - concat-bottom-identification-coherence-square-identifications - inv-concat-bottom-identification-coherence-square-identifications - is-retraction-inv-concat-bottom-identification-coherence-square-identifications = - is-section-inv-concat (ap (concat left _) s) - is-equiv-concat-bottom-identification-coherence-square-identifications : - is-equiv concat-bottom-identification-coherence-square-identifications + is-equiv + ( concat-bottom-identification-coherence-square-identifications + top left right bottom s) is-equiv-concat-bottom-identification-coherence-square-identifications = is-equiv-is-invertible - inv-concat-bottom-identification-coherence-square-identifications - is-section-inv-concat-bottom-identification-coherence-square-identifications - is-retraction-inv-concat-bottom-identification-coherence-square-identifications + ( inv-concat-bottom-identification-coherence-square-identifications + top left right bottom s) + ( is-section-inv-concat-bottom-identification-coherence-square-identifications + top left right bottom s) + ( is-retraction-inv-concat-bottom-identification-coherence-square-identifications + top left right bottom s) equiv-concat-bottom-identification-coherence-square-identifications : coherence-square-identifications top left right bottom ≃ coherence-square-identifications top left right bottom' pr1 equiv-concat-bottom-identification-coherence-square-identifications = concat-bottom-identification-coherence-square-identifications + top left right bottom s pr2 equiv-concat-bottom-identification-coherence-square-identifications = is-equiv-concat-bottom-identification-coherence-square-identifications ``` @@ -703,24 +430,6 @@ module _ equiv-left-whisker-concat-coherence-square-identifications refl top left right bottom = id-equiv - - left-whisker-concat-coherence-square-identifications : - (p : u = x) - (top : x = y) (left : x = z) (right : y = w) (bottom : z = w) → - coherence-square-identifications top left right bottom → - coherence-square-identifications (p ∙ top) (p ∙ left) right bottom - left-whisker-concat-coherence-square-identifications - refl top left right bottom = - id - - left-unwhisker-concat-coherence-square-identifications : - (p : u = x) - (top : x = y) (left : x = z) (right : y = w) (bottom : z = w) → - coherence-square-identifications (p ∙ top) (p ∙ left) right bottom → - coherence-square-identifications top left right bottom - left-unwhisker-concat-coherence-square-identifications - refl top left right bottom = - id ``` #### Right whiskering coherences of commuting squares of identifications @@ -762,43 +471,6 @@ module _ ( right) ( bottom) ( inv right-unit)) - - right-whisker-concat-coherence-square-identifications : - coherence-square-identifications top left right bottom → - {u : A} (p : w = u) → - coherence-square-identifications top left (right ∙ p) (bottom ∙ p) - right-whisker-concat-coherence-square-identifications s refl = - concat-bottom-identification-coherence-square-identifications - ( top) - ( left) - ( right ∙ refl) - ( bottom) - ( inv right-unit) - ( concat-right-identification-coherence-square-identifications - ( top) - ( left) - ( right) - ( bottom) - ( inv right-unit) - ( s)) - - right-unwhisker-cohernece-square-identifications : - {u : A} (p : w = u) → - coherence-square-identifications top left (right ∙ p) (bottom ∙ p) → - coherence-square-identifications top left right bottom - right-unwhisker-cohernece-square-identifications refl = - ( inv-concat-right-identification-coherence-square-identifications - ( top) - ( left) - ( right) - ( bottom) - ( inv right-unit)) ∘ - ( inv-concat-bottom-identification-coherence-square-identifications - ( top) - ( left) - ( right ∙ refl) - ( bottom) - ( inv right-unit)) ``` #### Left splicing coherences of commuting squares of identifications @@ -835,30 +507,6 @@ module _ ( right) ( bottom) ( inv right-unit) - - left-splice-coherence-square-identifications : - {u : A} (p : z = u) (q : u = z) (α : inv p = q) → - coherence-square-identifications top left right bottom → - coherence-square-identifications top (left ∙ p) right (q ∙ bottom) - left-splice-coherence-square-identifications refl .refl refl = - concat-left-identification-coherence-square-identifications - ( top) - ( left) - ( right) - ( bottom) - ( inv right-unit) - - left-unsplice-coherence-square-identifications : - {u : A} (p : z = u) (q : u = z) (α : inv p = q) → - coherence-square-identifications top (left ∙ p) right (q ∙ bottom) → - coherence-square-identifications top left right bottom - left-unsplice-coherence-square-identifications refl .refl refl = - inv-concat-left-identification-coherence-square-identifications - ( top) - ( left) - ( right) - ( bottom) - ( inv right-unit) ``` #### Right splicing coherences of commuting squares of identifications @@ -895,30 +543,6 @@ module _ ( right) ( bottom) ( inv right-unit) - - right-splice-coherence-square-identifications : - {u : A} (p : y = u) (q : u = y) (α : inv p = q) → - coherence-square-identifications top left right bottom → - coherence-square-identifications (top ∙ p) left (inv p ∙ right) bottom - right-splice-coherence-square-identifications refl .refl refl = - concat-top-identification-coherence-square-identifications - ( top) - ( left) - ( right) - ( bottom) - ( inv right-unit) - - right-unsplice-coherence-square-identifications : - {u : A} (p : y = u) (q : u = y) (α : inv p = q) → - coherence-square-identifications (top ∙ p) left (inv p ∙ right) bottom → - coherence-square-identifications top left right bottom - right-unsplice-coherence-square-identifications refl .refl refl = - inv-concat-top-identification-coherence-square-identifications - ( top) - ( left) - ( right) - ( bottom) - ( inv right-unit) ``` ### Double whiskering of commuting squares of identifications @@ -949,734 +573,3 @@ module _ ( bottom) ( q) ``` - -### Horizontally pasting squares of identifications - -Consider two squares of identifications as in the diagram - -```text - top-left top-right - a -------------> b -------------> c - | | | - left | | middle | right - ∨ ∨ ∨ - d -------------> e -------------> f - bottom-left bottom-right -``` - -with `s : left ∙ bottom-left = top-left ∙ middle` and t : middle ∙ bottom-right -= top-right ∙ right`. Then the outer square commutes. - -```agda -module _ - {l : Level} {A : UU l} {a b c d e f : A} - (top-left : a = b) (top-right : b = c) - (left : a = d) (middle : b = e) (right : c = f) - (bottom-left : d = e) (bottom-right : e = f) - where - - horizontal-pasting-coherence-square-identifications : - coherence-square-identifications top-left left middle bottom-left → - coherence-square-identifications top-right middle right bottom-right → - coherence-square-identifications - (top-left ∙ top-right) left right (bottom-left ∙ bottom-right) - horizontal-pasting-coherence-square-identifications s t = - ( right-whisker-concat-coherence-square-identifications - ( top-left) - ( left) - ( middle) - ( bottom-left) - ( s) - ( bottom-right)) ∙ - ( ( inv (assoc top-left middle bottom-right)) ∙ - ( left-whisker-concat-coherence-square-identifications - ( top-left) - ( top-right) - ( middle) - ( right) - ( bottom-right) - ( t))) -``` - -### Vertically pasting squares of identifications - -Consider two squares of identifications as in the diagram - -```text - top - a --------> b - | | - top-left | | top-right - ∨ middle ∨ - c --------> d - | | - bottom-left | | bottom-right - ∨ ∨ - e --------> f - bottom -``` - -with `s : top-left ∙ middle = top ∙ top-right` and -`t : bottom-left ∙ bottom = middle ∙ bottom-right`. Then the outer square -commutes. - -```agda -module _ - {l : Level} {A : UU l} {a b c d e f : A} - (top : a = b) (top-left : a = c) (top-right : b = d) - (middle : c = d) (bottom-left : c = e) (bottom-right : d = f) - (bottom : e = f) - where - - vertical-pasting-coherence-square-identifications : - coherence-square-identifications top top-left top-right middle → - coherence-square-identifications middle bottom-left bottom-right bottom → - coherence-square-identifications - top (top-left ∙ bottom-left) (top-right ∙ bottom-right) bottom - vertical-pasting-coherence-square-identifications p q = - ( left-whisker-concat-coherence-square-identifications - ( top-left) - ( middle) - ( bottom-left) - ( bottom-right) - ( bottom) - ( q)) ∙ - ( ( assoc top-left middle bottom-right) ∙ - ( right-whisker-concat-coherence-square-identifications - ( top) - ( top-left) - ( top-right) - ( middle) - ( p) - ( bottom-right))) -``` - -## Properties - -### Left unit law for horizontal pasting of commuting squares of identifications - -```agda -module _ - {l : Level} {A : UU l} {a b c d : A} - where - - left-unit-law-horizontal-pasting-coherence-square-identifications : - (top : a = b) (left : a = c) (right : b = d) (bottom : c = d) - (s : coherence-square-identifications top left right bottom) → - horizontal-pasting-coherence-square-identifications - ( refl) - ( top) - ( left) - ( left) - ( right) - ( refl) - ( bottom) - ( horizontal-refl-coherence-square-identifications left) - ( s) = - s - left-unit-law-horizontal-pasting-coherence-square-identifications - refl refl right refl s = refl -``` - -### Right unit law for horizontal pasting of commuting squares of identifications - -```agda -module _ - {l : Level} {A : UU l} {a b c d : A} - where - - right-unit-law-horizontal-pasting-coherence-square-identifications : - (top : a = b) (left : a = c) (right : b = d) (bottom : c = d) - (s : coherence-square-identifications top left right bottom) → - horizontal-pasting-coherence-square-identifications - ( top) - ( refl) - ( left) - ( right) - ( right) - ( bottom) - ( refl) - ( s) - ( horizontal-refl-coherence-square-identifications right) ∙ - right-whisker-concat right-unit right = - left-whisker-concat left right-unit ∙ s - right-unit-law-horizontal-pasting-coherence-square-identifications - refl refl .refl refl refl = - refl -``` - -### Left unit law for vertical pasting of commuting squares of identifications - -```agda -module _ - {l : Level} {A : UU l} {a b c d : A} - where - - left-unit-law-vertical-pasting-coherence-square-identifications : - (top : a = b) (left : a = c) (right : b = d) (bottom : c = d) - (s : coherence-square-identifications top left right bottom) → - vertical-pasting-coherence-square-identifications - ( top) - ( refl) - ( refl) - ( top) - ( left) - ( right) - ( bottom) - ( vertical-refl-coherence-square-identifications top) - ( s) = - s - left-unit-law-vertical-pasting-coherence-square-identifications - refl refl .refl refl refl = refl -``` - -### Right unit law for vertical pasting of commuting squares of identifications - -```agda -module _ - {l : Level} {A : UU l} {a b c d : A} - where - - right-unit-law-vertical-pasting-coherence-square-identifications : - (top : a = b) (left : a = c) (right : b = d) (bottom : c = d) - (s : coherence-square-identifications top left right bottom) → - vertical-pasting-coherence-square-identifications - ( top) - ( left) - ( right) - ( bottom) - ( refl) - ( refl) - ( bottom) - ( s) - ( vertical-refl-coherence-square-identifications bottom) ∙ - left-whisker-concat top right-unit = - right-whisker-concat right-unit bottom ∙ s - right-unit-law-vertical-pasting-coherence-square-identifications - refl refl .(refl ∙ refl) refl refl = - refl -``` - -### Computing the right whiskering of a vertically constant square with an identification - -Consider the vertically constant square of identifications - -```text - p - x -----> y - | | - refl | | refl - ∨ ∨ - x -----> y - p -``` - -at an identification `p : x = y`, and consider an identification `q : y = z`. -Then the right whiskering of the above square with `q` is the commuting square -of identifications - -```text - p - x -------> y - | | - refl | refl | q - ∨ ∨ - x -------> z - p ∙ q -``` - -```agda -module _ - {l1 : Level} {A : UU l1} - where - - right-whisker-concat-vertical-refl-coherence-square-identifications : - {x y z : A} (p : x = y) (q : y = z) → - right-whisker-concat-coherence-square-identifications p refl refl p - ( vertical-refl-coherence-square-identifications p) - ( q) = - refl - right-whisker-concat-vertical-refl-coherence-square-identifications - refl refl = - refl -``` - -### Computing the right whiskering of a horizontally constant square with an identification - -Consider a horizontally constant commuting square of identifications - -```text - refl - x -----> x - | | - p | | p - ∨ ∨ - y -----> y - refl -``` - -at an identification `p` and consider an identification `q : y = z`. Then the -right whiskering of the above square with `q` is the square - -```text - refl - x -----> x - | | - p | refl | p ∙ q - ∨ ∨ - y -----> z. - q -``` - -```agda -module _ - {l1 : Level} {A : UU l1} - where - - right-whisker-concat-horizontal-refl-coherence-square-identifications : - {x y z : A} (p : x = y) (q : y = z) → - right-whisker-concat-coherence-square-identifications refl p p refl - ( horizontal-refl-coherence-square-identifications p) - ( q) = - refl - right-whisker-concat-horizontal-refl-coherence-square-identifications - refl refl = - refl -``` - -### Computing the left whiskering of a horizontally constant square with an identification - -Consider an identification `p : x = y` and a horizontally constant commuting -square of identifications - -```text - refl - y -----> y - | | - q | | q - ∨ ∨ - z -----> z - refl -``` - -at an identification `q : y = z`. The the left whiskering of the above square -with `p` is the commuting square - -```text - q ∙ refl - x ------------------------------------------------------> y - | | - q ∙ p | right-unit ∙ inv (right-whisker-concat right-unit p) | p - ∨ ∨ - z ------------------------------------------------------> z. - refl -``` - -```agda -module _ - {l1 : Level} {A : UU l1} - where - - left-whisker-concat-horizontal-refl-coherence-square-identifications : - {x y z : A} (p : x = y) (q : y = z) → - left-whisker-concat-coherence-square-identifications p refl q q refl - ( horizontal-refl-coherence-square-identifications q) ∙ - right-whisker-concat right-unit q = - right-unit - left-whisker-concat-horizontal-refl-coherence-square-identifications - refl refl = - refl - - left-whisker-concat-horizontal-refl-coherence-square-identifications' : - {x y z : A} (p : x = y) (q : y = z) → - left-whisker-concat-coherence-square-identifications p refl q q refl - ( horizontal-refl-coherence-square-identifications q) = - right-unit ∙ inv (right-whisker-concat right-unit q) - left-whisker-concat-horizontal-refl-coherence-square-identifications' - refl refl = - refl -``` - -### Computing the left whiskering of a vertically constant square with an identification - -Consider the vertically constant square of identifications - -```text - q - y -----> z - | | - refl | | refl - ∨ ∨ - y -----> z - q -``` - -at an identification `q : y = z` and consider an identification `p : x = y`. -Then the left whiskering of the above square with `p` is the square - -```text - p ∙ q - x ---------------------------------------------------> z - | | - p ∙ refl | right-whisker-concat right-unit q ∙ inv right-unit | refl - ∨ ∨ - y ---------------------------------------------------> z. - q -``` - -```agda -module _ - {l1 : Level} {A : UU l1} - where - - left-whisker-concat-vertical-refl-coherence-square-identifications : - {x y z : A} (p : x = y) (q : y = z) → - left-whisker-concat-coherence-square-identifications p q refl refl q - ( vertical-refl-coherence-square-identifications q) ∙ - right-unit = - right-whisker-concat right-unit q - left-whisker-concat-vertical-refl-coherence-square-identifications - refl refl = - refl - - left-whisker-concat-vertical-refl-coherence-square-identifications' : - {x y z : A} (p : x = y) (q : y = z) → - left-whisker-concat-coherence-square-identifications p q refl refl q - ( vertical-refl-coherence-square-identifications q) = - right-whisker-concat right-unit q ∙ inv right-unit - left-whisker-concat-vertical-refl-coherence-square-identifications' - refl refl = - refl -``` - -### Left whiskering horizontal concatenations of squares with identifications - -Consider a commuting diagram of identifications of the form - -```text - top-left top-right - a -------------> c -------------> e - | | | - left | | middle | right - ∨ ∨ ∨ - b -------------> d -------------> f - bottom-left bottom-right -``` - -and consider an identification `p : x = a`. Then the left whiskering of `p` and -the horizontal concatenation of coherences of commuting squares is up to -associativity the horizontal concatenation of the squares - -```text - p ∙ top-left top-right - x -------------> c -------------> e - | | | - p ∙ left | | middle | right - ∨ ∨ ∨ - b -------------> d -------------> f - bottom-left bottom-right -``` - -where the left square is the left whiskering of `p` and the original left -square. - -```agda -module _ - {l1 : Level} {A : UU l1} - where - - left-whisker-concat-horizontal-pasting-coherence-square-identifications : - {x a b c d e f : A} (p : x = a) - (top-left : a = c) (top-right : c = e) - (left : a = b) (middle : c = d) (right : e = f) - (bottom-left : b = d) (bottom-right : d = f) - (l : coherence-square-identifications top-left left middle bottom-left) - (r : coherence-square-identifications top-right middle right bottom-right) → - left-whisker-concat-coherence-square-identifications p - ( top-left ∙ top-right) - ( left) - ( right) - ( bottom-left ∙ bottom-right) - ( horizontal-pasting-coherence-square-identifications - ( top-left) - ( top-right) - ( left) - ( middle) - ( right) - ( bottom-left) - ( bottom-right) - ( l) - ( r)) = - horizontal-pasting-coherence-square-identifications - ( p ∙ top-left) - ( top-right) - ( p ∙ left) - ( middle) - ( right) - ( bottom-left) - ( bottom-right) - ( left-whisker-concat-coherence-square-identifications p - ( top-left) - ( left) - ( middle) - ( bottom-left) - ( l)) - ( r) ∙ - right-whisker-concat - ( assoc p top-left top-right) - ( right) - left-whisker-concat-horizontal-pasting-coherence-square-identifications - refl top-left top-right left middle right bottom-left bottom-right l r = - inv right-unit -``` - -### Left whiskering vertical concatenations of squares with identifications - -Consider two squares of identifications as in the diagram - -```text - top - a --------> b - | | - top-left | | top-right - ∨ middle ∨ - c --------> d - | | - bottom-left | | bottom-right - ∨ ∨ - e --------> f - bottom -``` - -and consider an identification `p : x = a`. Then the left whiskering of `p` -with the vertical pasting of the two squares above is up to associativity the -vertical pasting of the squares - -```text - p ∙ top - x --------> b - | | - p ∙ top-left | | top-right - ∨ middle ∨ - c --------> d - | | - bottom-left | | bottom-right - ∨ ∨ - e --------> f. - bottom -``` - -```agda -module _ - {l1 : Level} {A : UU l1} - where - - left-whisker-concat-vertical-concat-coherence-square-identifications : - {x a b c d e f : A} (p : x = a) → - (top : a = b) (top-left : a = c) (top-right : b = d) (middle : c = d) - (bottom-left : c = e) (bottom-right : d = f) (bottom : e = f) - (t : coherence-square-identifications top top-left top-right middle) → - (b : - coherence-square-identifications middle bottom-left bottom-right bottom) → - right-whisker-concat (assoc p top-left bottom-left) bottom ∙ - left-whisker-concat-coherence-square-identifications p - ( top) - ( top-left ∙ bottom-left) - ( top-right ∙ bottom-right) - ( bottom) - ( vertical-pasting-coherence-square-identifications - ( top) - ( top-left) - ( top-right) - ( middle) - ( bottom-left) - ( bottom-right) - ( bottom) - ( t) - ( b)) = - vertical-pasting-coherence-square-identifications - ( p ∙ top) - ( p ∙ top-left) - ( top-right) - ( middle) - ( bottom-left) - ( bottom-right) - ( bottom) - ( left-whisker-concat-coherence-square-identifications p - ( top) - ( top-left) - ( top-right) - ( middle) - ( t)) - ( b) - left-whisker-concat-vertical-concat-coherence-square-identifications - refl top top-left top-right middle bottom-left bottom-right bottom t b = - refl -``` - -### Right whiskering horizontal pastings of commuting squares of identifications - -Consider a commuting diagram of identifications of the form - -```text - top-left top-right - a -------------> c -------------> e - | | | - left | | middle | right - ∨ ∨ ∨ - b -------------> d -------------> f - bottom-left bottom-right -``` - -and consider an identification `q : f = y`. Then the right whiskering of the -horizontal pasting of the squares above is up to associativity the horizontal -pasting of the squares - -```text - top-left top-right - a -------------> c ------------------> e - | | | - left | | middle | right ∙ q - ∨ ∨ ∨ - b -------------> d ------------------> y - bottom-left bottom-right ∙ q -``` - -```agda -module _ - {l1 : Level} {A : UU l1} - where - - right-whisker-concat-horizontal-pasting-coherence-square-identifications : - {a b c d e f y : A} - (top-left : a = c) (top-right : c = e) - (left : a = b) (middle : c = d) (right : e = f) - (bottom-left : b = d) (bottom-right : d = f) - (l : coherence-square-identifications top-left left middle bottom-left) → - (r : coherence-square-identifications top-right middle right bottom-right) → - (q : f = y) → - right-whisker-concat-coherence-square-identifications - ( top-left ∙ top-right) - ( left) - ( right) - ( bottom-left ∙ bottom-right) - ( horizontal-pasting-coherence-square-identifications - ( top-left) - ( top-right) - ( left) - ( middle) - ( right) - ( bottom-left) - ( bottom-right) - ( l) - ( r)) - ( q) = - left-whisker-concat left (assoc bottom-left bottom-right q) ∙ - horizontal-pasting-coherence-square-identifications - ( top-left) - ( top-right) - ( left) - ( middle) - ( right ∙ q) - ( bottom-left) - ( bottom-right ∙ q) - ( l) - ( right-whisker-concat-coherence-square-identifications - ( top-right) - ( middle) - ( right) - ( bottom-right) - ( r) - ( q)) - right-whisker-concat-horizontal-pasting-coherence-square-identifications - refl refl refl .refl .refl refl refl refl refl refl = - refl -``` - -### Right whiskering vertical concatenations of squares with identifications - -Consider two squares of identifications as in the diagram - -```text - top - a --------> b - | | - top-left | | top-right - ∨ middle ∨ - c --------> d - | | - bottom-left | | bottom-right - ∨ ∨ - e --------> f - bottom -``` - -and consider an identification `q : f = y`. Then the right whiskering of the -vertical pasting of the two squares above with `q` is up to associativity the -vertical pasting of the squares - -```text - top - a ------------> b - | | - top-left | | top-right - ∨ middle ∨ - c ------------> d - | | - bottom-left | | bottom-right ∙ q - ∨ ∨ - e ------------> y. - bottom ∙ q -``` - -```agda -module _ - {l1 : Level} {A : UU l1} - where - - right-whisker-concat-vertical-pasting-coherence-square-identifications : - {a b c d e f y : A} - (top : a = b) (top-left : a = c) (top-right : b = d) - (middle : c = d) - (bottom-left : c = e) (bottom-right : d = f) (bottom : e = f) - (t : coherence-square-identifications top top-left top-right middle) → - (b : - coherence-square-identifications middle bottom-left bottom-right bottom) → - (q : f = y) → - right-whisker-concat-coherence-square-identifications - ( top) - ( top-left ∙ bottom-left) - ( top-right ∙ bottom-right) - ( bottom) - ( vertical-pasting-coherence-square-identifications - ( top) - ( top-left) - ( top-right) - ( middle) - ( bottom-left) - ( bottom-right) - ( bottom) - ( t) - ( b)) - ( q) ∙ - left-whisker-concat top (assoc top-right bottom-right q) = - vertical-pasting-coherence-square-identifications - ( top) - ( top-left) - ( top-right) - ( middle) - ( bottom-left) - ( bottom-right ∙ q) - ( bottom ∙ q) - ( t) - ( right-whisker-concat-coherence-square-identifications - ( middle) - ( bottom-left) - ( bottom-right) - ( bottom) - ( b) - ( q)) - right-whisker-concat-vertical-pasting-coherence-square-identifications - refl refl .refl refl refl .refl refl refl refl refl = - refl -``` diff --git a/src/foundation/commuting-squares-of-maps.lagda.md b/src/foundation/commuting-squares-of-maps.lagda.md index aeaece94f2..3bb13edc53 100644 --- a/src/foundation/commuting-squares-of-maps.lagda.md +++ b/src/foundation/commuting-squares-of-maps.lagda.md @@ -175,7 +175,7 @@ module _ ( id) ( is-retraction-map-inv-equiv left) ( H) - ( coherence-square-maps-inv-equiv-vertical top left right bottom H) + ( vertical-inv-equiv-coherence-square-maps top left right bottom H) ( refl-htpy) ( is-retraction-map-inv-equiv right) left-inverse-law-pasting-vertical-coherence-square-maps H a = @@ -284,7 +284,7 @@ module _ ( id) ( id) ( is-section-map-inv-equiv left) - ( coherence-square-maps-inv-equiv-vertical top left right bottom H) + ( vertical-inv-equiv-coherence-square-maps top left right bottom H) ( H) ( refl-htpy) ( is-section-map-inv-equiv right) @@ -295,7 +295,7 @@ module _ ( H (map-inv-equiv left a)) ( ap ( map-equiv right) - ( coherence-square-maps-inv-equiv-vertical top left right bottom + ( vertical-inv-equiv-coherence-square-maps top left right bottom ( H) ( a))) ( is-section-map-inv-equiv right (bottom a))) ∙ diff --git a/src/foundation/embeddings.lagda.md b/src/foundation/embeddings.lagda.md index 85b638587e..38bd69b1da 100644 --- a/src/foundation/embeddings.lagda.md +++ b/src/foundation/embeddings.lagda.md @@ -407,7 +407,7 @@ module _ ( map-inv-is-equiv K) ( map-inv-is-equiv L) ( top) - ( coherence-square-maps-inv-equiv-vertical + ( vertical-inv-equiv-coherence-square-maps ( top) ( left , K) ( right , L) diff --git a/src/foundation/equivalences-arrows.lagda.md b/src/foundation/equivalences-arrows.lagda.md index 98c901b158..eac852d2c4 100644 --- a/src/foundation/equivalences-arrows.lagda.md +++ b/src/foundation/equivalences-arrows.lagda.md @@ -218,7 +218,7 @@ module _ ( equiv-domain-inv-equiv-arrow) ( equiv-codomain-inv-equiv-arrow) coh-inv-equiv-arrow = - coherence-square-maps-inv-equiv-horizontal + horizontal-inv-equiv-coherence-square-maps ( equiv-domain-equiv-arrow f g α) ( f) ( g) diff --git a/src/foundation/postcomposition-dependent-functions.lagda.md b/src/foundation/postcomposition-dependent-functions.lagda.md index 137f0f6cca..7e35bf5c87 100644 --- a/src/foundation/postcomposition-dependent-functions.lagda.md +++ b/src/foundation/postcomposition-dependent-functions.lagda.md @@ -102,7 +102,7 @@ module _ ( eq-htpy) ( ap (postcomp-Π A f)) compute-eq-htpy-ap-postcomp-Π = - coherence-square-maps-inv-equiv-vertical + vertical-inv-equiv-coherence-square-maps ( ap (postcomp-Π A f)) ( equiv-funext) ( equiv-funext) diff --git a/src/foundation/precomposition-dependent-functions.lagda.md b/src/foundation/precomposition-dependent-functions.lagda.md index 9ef0b0863b..a4ef43be00 100644 --- a/src/foundation/precomposition-dependent-functions.lagda.md +++ b/src/foundation/precomposition-dependent-functions.lagda.md @@ -91,7 +91,7 @@ module _ ( eq-htpy) ( ap (precomp-Π f C) {g} {h}) compute-eq-htpy-ap-precomp-Π = - coherence-square-maps-inv-equiv-vertical + vertical-inv-equiv-coherence-square-maps ( ap (precomp-Π f C)) ( equiv-funext) ( equiv-funext) diff --git a/src/foundation/precomposition-functions.lagda.md b/src/foundation/precomposition-functions.lagda.md index c667f7f2f3..3f21781779 100644 --- a/src/foundation/precomposition-functions.lagda.md +++ b/src/foundation/precomposition-functions.lagda.md @@ -206,7 +206,7 @@ module _ ( eq-htpy) ( ap (precomp f C)) compute-eq-htpy-ap-precomp = - coherence-square-maps-inv-equiv-vertical + vertical-inv-equiv-coherence-square-maps ( ap (precomp f C)) ( equiv-funext) ( equiv-funext) diff --git a/src/foundation/whiskering-homotopies-concatenation.lagda.md b/src/foundation/whiskering-homotopies-concatenation.lagda.md index 9803a73be7..4af4983d5f 100644 --- a/src/foundation/whiskering-homotopies-concatenation.lagda.md +++ b/src/foundation/whiskering-homotopies-concatenation.lagda.md @@ -2,6 +2,8 @@ ```agda module foundation.whiskering-homotopies-concatenation where + +open import foundation-core.whiskering-homotopies-concatenation public ```
Imports diff --git a/src/foundation/whiskering-identifications-concatenation.lagda.md b/src/foundation/whiskering-identifications-concatenation.lagda.md index 661b2b9c4e..c2e632249a 100644 --- a/src/foundation/whiskering-identifications-concatenation.lagda.md +++ b/src/foundation/whiskering-identifications-concatenation.lagda.md @@ -2,6 +2,8 @@ ```agda module foundation.whiskering-identifications-concatenation where + +open import foundation-core.whiskering-identifications-concatenation public ```
Imports @@ -41,62 +43,6 @@ concatenation. Since concatenation on either side is an [equivalence](foundation-core.equivalences.md), it follows that the whiskering operations are equivalences. -## Definitions - -### Left whiskering of identifications - -Left whiskering of identifications with respect to concatenation is an operation - -```text - (p : x = y) {q r : y = z} → q = r → p ∙ q = p ∙ r -``` - -on any type. - -```agda -module _ - {l : Level} {A : UU l} - where - - left-whisker-concat : left-whiskering-operation A (_=_) (_∙_) (_=_) - left-whisker-concat p β = ap (p ∙_) β -``` - -### Right whiskering of identifications - -Right whiskering of identifications with respect to concatenation is an -operation - -```text - {p q : x = y} → p = q → (r : y = z) → p ∙ r = q ∙ r -``` - -on any type. - -```agda -module _ - {l : Level} {A : UU l} - where - - right-whisker-concat : right-whiskering-operation A (_=_) (_∙_) (_=_) - right-whisker-concat α q = ap (_∙ q) α -``` - -### Double whiskering of identifications - -```agda -module _ - {l : Level} {A : UU l} - {a b c d : A} (p : a = b) {r s : b = c} (t : r = s) (q : c = d) - where - - double-whisker-concat : (p ∙ r) ∙ q = (p ∙ s) ∙ q - double-whisker-concat = right-whisker-concat (left-whisker-concat p t) q - - double-whisker-concat' : p ∙ (r ∙ q) = p ∙ (s ∙ q) - double-whisker-concat' = left-whisker-concat p (right-whisker-concat t q) -``` - ## Properties ### Left whiskering of identifications is an equivalence @@ -136,231 +82,3 @@ module _ pr2 equiv-right-whisker-concat = is-equiv-right-whisker-concat ``` - -### The unit and absorption laws for left whiskering of identifications - -```agda -module _ - {l : Level} {A : UU l} - where - - left-unit-law-left-whisker-concat : - {x y : A} {p p' : x = y} (α : p = p') → - left-whisker-concat refl α = α - left-unit-law-left-whisker-concat refl = refl - - right-absorption-law-left-whisker-concat : - {x y z : A} (p : x = y) (q : y = z) → - left-whisker-concat p (refl {x = q}) = refl - right-absorption-law-left-whisker-concat p q = refl -``` - -### The unit and absorption laws for right whiskering of identifications - -The right unit law for right whiskering of identifications with respect to -concatenation asserts that the square of identifications - -```text - right-whisker-concat α refl - p ∙ refl -----------------------------> p' ∙ refl - | | - right-unit | | - ∨ ∨ - p -------------------------------------> p' -``` - -commutes for any `α : p = p'`. Note that this law is slightly more complicated, -since concatenating with `refl` on the right does not compute to the identity -function. - -```agda -module _ - {l : Level} {A : UU l} - where - - right-unit-law-right-whisker-concat : - {x y : A} {p p' : x = y} (α : p = p') → - right-unit ∙ α = right-whisker-concat α refl ∙ right-unit - right-unit-law-right-whisker-concat {p = refl} refl = refl - - left-absorption-law-right-whisker-concat : - {x y z : A} (p : x = y) (q : y = z) → - right-whisker-concat (refl {x = p}) q = refl - left-absorption-law-right-whisker-concat p q = refl -``` - -### Commutativity of left and right whiskering of identifications - -Consider four identifications `p p' : x = y` and `q q' : y = z` in a type `A`. -Then the square of identifications - -```text - right-whisker α q - p ∙ q ---------------------> p' ∙ q - | | - left-whisker p β | | left-whisker p' β - ∨ ∨ - p ∙ q' --------------------> p' ∙ q' - right-whisker α q' -``` - -commutes. There are at least two natural ways in which this square is seen to -commute: - -1. The square commutes by naturality of the homotopy - `α ↦ left-whisker-concat α β`. -2. The transposed square commutes by the naturality of the homotopy - `β ↦ right-whisker-concat α β`. - -These two ways in which the square commutes are inverse to each other. - -**Note.** The following statements could have been formalized using -[commuting squares of identifications](foundation.commuting-squares-of-identifications.md). -However, in order to avoid cyclic module dependencies in the library we avoid -doing so. - -```agda -module _ - {l : Level} {A : UU l} {x y z : A} - where - - commutative-left-whisker-right-whisker-concat : - {q q' : y = z} (β : q = q') {p p' : x = y} (α : p = p') → - left-whisker-concat p β ∙ right-whisker-concat α q' = - right-whisker-concat α q ∙ left-whisker-concat p' β - commutative-left-whisker-right-whisker-concat β = - nat-htpy (λ α → left-whisker-concat α β) - - commutative-right-whisker-left-whisker-concat : - {p p' : x = y} (α : p = p') {q q' : y = z} (β : q = q') → - right-whisker-concat α q ∙ left-whisker-concat p' β = - left-whisker-concat p β ∙ right-whisker-concat α q' - commutative-right-whisker-left-whisker-concat α = - nat-htpy (right-whisker-concat α) - - compute-inv-commutative-left-whisker-right-whisker-concat : - {q q' : y = z} (β : q = q') {p p' : x = y} (α : p = p') → - inv (commutative-right-whisker-left-whisker-concat α β) = - commutative-left-whisker-right-whisker-concat β α - compute-inv-commutative-left-whisker-right-whisker-concat refl refl = - refl -``` - -### Swapping the order of left and right whiskering of identifications - -Consider a diagram of identifications - -```text - r - p -----> q - a -----> b -----> c -----> - s -``` - -with `t : r = s`. Then the square of identifications - -```text - assoc p r q - (p ∙ r) ∙ q -------------> p ∙ (r ∙ q) - | | - double-whisker p t q | | double-whisker' p t q - ∨ ∨ - (p ∙ s) ∙ q -------------> p ∙ (s ∙ q) - assoc p s q -``` - -commutes. - -```agda -module _ - {l1 : Level} {A : UU l1} - where - - swap-double-whisker-concat : - {a b c d : A} (p : a = b) {r s : b = c} (t : r = s) (q : c = d) → - double-whisker-concat p t q ∙ assoc p s q = - assoc p r q ∙ double-whisker-concat' p t q - swap-double-whisker-concat refl refl refl = refl -``` - -### The action on identifications of concatenating by `refl` on the right - -Consider an identification `r : p = q` between two identifications -`p q : x = y` in a type `A`. Then the square of identifications - -```text - right-whisker r refl - p ∙ refl ----------------------> q ∙ refl - | | - right-unit | | right-unit - ∨ ∨ - p -----------------------------> q - r -``` - -commutes. - -```agda -module _ - {l : Level} {A : UU l} {x y : A} {p q : x = y} - where - - compute-refl-right-whisker-concat : - (r : p = q) → - right-unit ∙ r = right-whisker-concat r refl ∙ right-unit - compute-refl-right-whisker-concat refl = right-unit -``` - -### Left whiskering of identifications distributes over concatenation - -```agda -module _ - {l : Level} {A : UU l} - where - - distributive-left-whisker-concat-concat : - {a b c : A} (p : a = b) {q r s : b = c} (α : q = r) (β : r = s) → - left-whisker-concat p (α ∙ β) = - left-whisker-concat p α ∙ left-whisker-concat p β - distributive-left-whisker-concat-concat p refl β = refl -``` - -### Right whiskering of identifications distributes over concatenation - -```agda -module _ - {l : Level} {A : UU l} - where - - distributive-right-whisker-concat-concat : - {a b c : A} {p q r : a = b} (α : p = q) (β : q = r) (s : b = c) → - right-whisker-concat (α ∙ β) s = - right-whisker-concat α s ∙ right-whisker-concat β s - distributive-right-whisker-concat-concat refl β s = refl -``` - -### Left whiskering of identifications commutes with inverses of identifications - -```agda -module _ - {l : Level} {A : UU l} - where - - compute-inv-left-whisker-concat : - {a b c : A} (p : a = b) {q r : b = c} (s : q = r) → - left-whisker-concat p (inv s) = inv (left-whisker-concat p s) - compute-inv-left-whisker-concat p s = ap-inv (concat p _) s -``` - -### Right whiskering of identifications commutes with inverses of identifications - -```agda -module _ - {l : Level} {A : UU l} - where - - compute-inv-right-whisker-concat : - {a b c : A} {p q : a = b} (s : p = q) (r : b = c) → - right-whisker-concat (inv s) r = inv (right-whisker-concat s r) - compute-inv-right-whisker-concat s r = ap-inv (concat' _ r) s -``` diff --git a/src/group-theory/equivalences-group-actions.lagda.md b/src/group-theory/equivalences-group-actions.lagda.md index 87c300fea4..cabae428b7 100644 --- a/src/group-theory/equivalences-group-actions.lagda.md +++ b/src/group-theory/equivalences-group-actions.lagda.md @@ -199,7 +199,7 @@ module _ (e : equiv-action-Group G X Y) → preserves-action-Group G Y X (map-inv-equiv-action-Group e) preserves-action-map-inv-equiv-action-Group (e , H) g = - coherence-square-maps-inv-equiv-horizontal + horizontal-inv-equiv-coherence-square-maps ( e) ( mul-action-Group G X g) ( mul-action-Group G Y g) diff --git a/src/structured-types/equivalences-types-equipped-with-endomorphisms.lagda.md b/src/structured-types/equivalences-types-equipped-with-endomorphisms.lagda.md index d5a4a65454..3b8b45fb50 100644 --- a/src/structured-types/equivalences-types-equipped-with-endomorphisms.lagda.md +++ b/src/structured-types/equivalences-types-equipped-with-endomorphisms.lagda.md @@ -158,7 +158,7 @@ inv-equiv-Type-With-Endomorphism : pr1 (inv-equiv-Type-With-Endomorphism X Y e) = inv-equiv (equiv-equiv-Type-With-Endomorphism X Y e) pr2 (inv-equiv-Type-With-Endomorphism X Y e) = - coherence-square-maps-inv-equiv-horizontal + horizontal-inv-equiv-coherence-square-maps ( equiv-equiv-Type-With-Endomorphism X Y e) ( endomorphism-Type-With-Endomorphism X) ( endomorphism-Type-With-Endomorphism Y) diff --git a/src/synthetic-homotopy-theory/equivalences-sequential-diagrams.lagda.md b/src/synthetic-homotopy-theory/equivalences-sequential-diagrams.lagda.md index d399a7affc..b82afe8957 100644 --- a/src/synthetic-homotopy-theory/equivalences-sequential-diagrams.lagda.md +++ b/src/synthetic-homotopy-theory/equivalences-sequential-diagrams.lagda.md @@ -140,7 +140,7 @@ module _ pr1 inv-equiv-sequential-diagram n = inv-equiv (equiv-equiv-sequential-diagram B e n) pr2 inv-equiv-sequential-diagram n = - coherence-square-maps-inv-equiv-vertical + vertical-inv-equiv-coherence-square-maps ( map-sequential-diagram A n) ( equiv-equiv-sequential-diagram B e n) ( equiv-equiv-sequential-diagram B e (succ-ℕ n)) From 324825e3ab38d296d0614aea5a949992b49acf9b Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Sat, 10 Feb 2024 11:43:58 +0100 Subject: [PATCH 07/53] `inv-coh-is-coherently-invertible-is-invertible` reasoning with homotopies --- .../coherently-invertible-maps.lagda.md | 112 +++++++----------- .../commuting-squares-of-homotopies.lagda.md | 85 ++++++++++++- ...ing-identifications-concatenation.lagda.md | 2 +- .../coherently-invertible-maps.lagda.md | 77 ++++++++++++ 4 files changed, 207 insertions(+), 69 deletions(-) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index 4fbcef1072..b5dd3765e5 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -20,6 +20,7 @@ open import foundation-core.identity-types open import foundation-core.invertible-maps open import foundation-core.retractions open import foundation-core.sections +open import foundation-core.whiskering-homotopies-concatenation ```
@@ -61,8 +62,9 @@ There is also the alternative coherence condition we could add We will colloquially refer to invertible maps equipped with this coherence for _transpose coherently invertible maps_. -**Note.** Coherently invertible maps are also called -{{#concept "half adjoint equivalences"}}. +**Note.** Coherently invertible maps are referred to as +{{#concept "half adjoint equivalences"}} in _Homotopy Type Theory – Univalent +Foundations of Mathematics_. ## Definition @@ -342,21 +344,35 @@ module _ ```agda coh-is-coherently-invertible-id : - {l : Level} {A : UU l} {f : A → A} (H : f ~ id) → - (x : A) → H (f x) = ap f (H x) + {l : Level} {A : UU l} {f : A → A} (H : f ~ id) → H ·r f ~ f ·l H coh-is-coherently-invertible-id {A = A} {f} H x = is-injective-concat' ( H x) ( ap (concat (H (f x)) x) (inv (ap-id (H x))) ∙ nat-htpy H (H x)) + +inv-coh-is-coherently-invertible-id : + {l : Level} {A : UU l} {f : A → A} (H : f ~ id) → f ·l H ~ H ·r f +inv-coh-is-coherently-invertible-id {A = A} {f} H x = + is-injective-concat' + ( H x) + ( inv (nat-htpy H (H x)) ∙ ap (concat (H (f x)) x) (ap-id (H x))) ``` #### The proof that invertible maps are coherently invertible +The construction follows Theorem 4.2.3 in _Homotopy Type Theory – Univalent +Foundations of Mathematics_. + ```agda module _ {l1 l2 : Level} {A : UU l1} {B : UU l2} {f : A → B} (H : is-invertible f) where + is-retraction-map-inv-is-coherently-invertible-is-invertible : + map-inv-is-invertible H ∘ f ~ id + is-retraction-map-inv-is-coherently-invertible-is-invertible = + is-retraction-map-inv-is-invertible H + abstract is-section-map-inv-is-coherently-invertible-is-invertible : f ∘ map-inv-is-invertible H ~ id @@ -370,39 +386,31 @@ module _ ( map-inv-is-invertible H y))) ∙ ( is-section-map-inv-is-invertible H y)) - is-retraction-map-inv-is-coherently-invertible-is-invertible : - map-inv-is-invertible H ∘ f ~ id - is-retraction-map-inv-is-coherently-invertible-is-invertible = - is-retraction-map-inv-is-invertible H - abstract inv-coh-is-coherently-invertible-is-invertible : f ·l is-retraction-map-inv-is-coherently-invertible-is-invertible ~ is-section-map-inv-is-coherently-invertible-is-invertible ·r f - inv-coh-is-coherently-invertible-is-invertible x = - left-transpose-eq-concat - ( is-section-map-inv-is-invertible - ( H) - ( f (map-inv-is-invertible H (f x)))) - ( ap f (is-retraction-map-inv-is-invertible H x)) - ( ( ap f - ( is-retraction-map-inv-is-invertible - ( H) - ( map-inv-is-invertible H (f x)))) ∙ - ( is-section-map-inv-is-invertible H (f x))) - ( ( nat-htpy - ( right-whisker-comp (is-section-map-inv-is-invertible H) f) - ( is-retraction-map-inv-is-invertible H x)) ∙ - ( ap - ( concat' _ (is-section-map-inv-is-invertible H (f x))) - ( ( ap-comp f + inv-coh-is-coherently-invertible-is-invertible = + left-transpose-htpy-concat + ( ( is-section-map-inv-is-invertible H) ·r + ( f ∘ map-inv-is-invertible H ∘ f)) + ( f ·l is-retraction-map-inv-is-invertible H) + ( ( ( f) ·l + ( is-retraction-map-inv-is-invertible H) ·r + ( map-inv-is-invertible H ∘ f)) ∙h + ( is-section-map-inv-is-invertible H ·r f)) + ( ( ( nat-htpy (is-section-map-inv-is-invertible H ·r f)) ·r + ( is-retraction-map-inv-is-invertible H)) ∙h + ( right-whisker-concat-htpy + ( ( inv-preserves-comp-left-whisker-comp + ( f) ( map-inv-is-invertible H ∘ f) - ( is-retraction-map-inv-is-invertible H x)) ∙ - ( inv - ( ap - ( ap f) - ( coh-is-coherently-invertible-id - ( is-retraction-map-inv-is-invertible H) x)))))) + ( is-retraction-map-inv-is-invertible H)) ∙h + ( left-whisker-comp² + ( f) + ( inv-coh-is-coherently-invertible-id + ( is-retraction-map-inv-is-invertible H)))) + ( is-section-map-inv-is-invertible H ·r f))) abstract coh-is-coherently-invertible-is-invertible : @@ -411,8 +419,8 @@ module _ ( map-inv-is-invertible H) ( is-section-map-inv-is-coherently-invertible-is-invertible) ( is-retraction-map-inv-is-coherently-invertible-is-invertible) - coh-is-coherently-invertible-is-invertible x = - inv (inv-coh-is-coherently-invertible-is-invertible x) + coh-is-coherently-invertible-is-invertible = + inv-htpy inv-coh-is-coherently-invertible-is-invertible abstract is-coherently-invertible-is-invertible : is-coherently-invertible f @@ -548,39 +556,11 @@ module _ ( e))) ``` -### Coherently invertible maps in either sense are coherently invertible in both senses - -```agda -module _ - {l1 l2 : Level} {A : UU l1} {B : UU l2} - where - - coh-is-transpose-coherently-invertible-is-coherently-invertible' : - {f : A → B} (H : is-coherently-invertible f) → - ( ( map-inv-is-coherently-invertible H ∘ f) ·l - ( is-retraction-map-inv-is-coherently-invertible H) ·r - ( map-inv-is-coherently-invertible H)) ~ - ( ( map-inv-is-coherently-invertible H) ·l - ( is-section-map-inv-is-coherently-invertible H) ·r - ( f ∘ map-inv-is-coherently-invertible H)) - coh-is-transpose-coherently-invertible-is-coherently-invertible' {f} H = - ( inv-preserves-comp-left-whisker-comp - ( map-inv-is-coherently-invertible H) - ( f) - ( ( is-retraction-map-inv-is-coherently-invertible H) ·r - ( map-inv-is-coherently-invertible H))) ∙h - ( double-whisker-comp² - ( map-inv-is-coherently-invertible H) - ( inv-htpy (coh-is-coherently-invertible H)) - ( map-inv-is-coherently-invertible H)) ∙h - ( preserves-comp-right-whisker-comp - ( f) - ( map-inv-is-coherently-invertible H) - ( ( map-inv-is-coherently-invertible H) ·l - ( is-section-map-inv-is-coherently-invertible H))) -``` +## References -The rest remains to be formalized. +1. Univalent Foundations Project, _Homotopy Type Theory – Univalent Foundations + of Mathematics_ (2013) ([website](https://homotopytypetheory.org/book/), + [arXiv:1308.0729](https://arxiv.org/abs/1308.0729)) ## See also diff --git a/src/foundation-core/commuting-squares-of-homotopies.lagda.md b/src/foundation-core/commuting-squares-of-homotopies.lagda.md index 1af11c0a1d..35faad40df 100644 --- a/src/foundation-core/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation-core/commuting-squares-of-homotopies.lagda.md @@ -7,9 +7,9 @@ module foundation-core.commuting-squares-of-homotopies where
Imports ```agda +open import foundation.commuting-squares-of-identifications open import foundation.universe-levels -open import foundation-core.equivalences open import foundation-core.homotopies ``` @@ -39,7 +39,7 @@ of the square. ```agda module _ - {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (f : A) → B f} (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) where @@ -51,3 +51,84 @@ module _ coherence-square-homotopies' = top ∙h right ~ left ∙h bottom ``` + +### Inverting squares of homotopies horizontally + +Given a commuting square of homotopies + +```text + top + f -------> g + | | + left | | right + ∨ ∨ + h -------> i, + bottom +``` + +the square of homotopies + +```text + inv top + g ------------> f + | | + right | | left + ∨ ∨ + i ------------> h + inv bottom +``` + +commutes. + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} + where + + horizontal-inv-coherence-square-homotopies : + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) → + coherence-square-homotopies top left right bottom → + coherence-square-homotopies (inv-htpy top) right left (inv-htpy bottom) + horizontal-inv-coherence-square-homotopies top left right bottom = {! !} +``` + +### Inverting squares of homotopies vertically + +Given a commuting square of homotopies + +```text + top + f -------> g + | | + left | | right + ∨ ∨ + h -------> i, + bottom +``` + +the square of homotopies + +```text + bottom + h -------> i + | | + inv left | | inv right + ∨ ∨ + f -------> g + top +``` + +commutes. + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} + where + + vertical-inv-coherence-square-homotopies : + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) → + coherence-square-homotopies top left right bottom → + coherence-square-homotopies bottom (inv-htpy left) (inv-htpy right) top + vertical-inv-coherence-square-homotopies top left right bottom H x = + {! vertical-inv-coherence-square-identifications (top x) (left x) (right x) (bottom x) (H x) !} +``` diff --git a/src/foundation-core/whiskering-identifications-concatenation.lagda.md b/src/foundation-core/whiskering-identifications-concatenation.lagda.md index 27f9cc20e6..a6b5116b02 100644 --- a/src/foundation-core/whiskering-identifications-concatenation.lagda.md +++ b/src/foundation-core/whiskering-identifications-concatenation.lagda.md @@ -9,12 +9,12 @@ module foundation-core.whiskering-identifications-concatenation where ```agda open import foundation.action-on-identifications-functions open import foundation.dependent-pair-types -open import foundation-core.identity-types open import foundation.universe-levels open import foundation.whiskering-operations open import foundation-core.function-types open import foundation-core.homotopies +open import foundation-core.identity-types ```
diff --git a/src/foundation/coherently-invertible-maps.lagda.md b/src/foundation/coherently-invertible-maps.lagda.md index 74eb88be1f..cf681a9a75 100644 --- a/src/foundation/coherently-invertible-maps.lagda.md +++ b/src/foundation/coherently-invertible-maps.lagda.md @@ -10,11 +10,13 @@ open import foundation-core.coherently-invertible-maps public ```agda open import foundation.action-on-identifications-functions +open import foundation.commuting-squares-of-homotopies open import foundation.dependent-pair-types open import foundation.equivalences open import foundation.identity-types open import foundation.type-arithmetic-dependent-pair-types open import foundation.universe-levels +open import foundation.whiskering-higher-homotopies-composition open import foundation.whiskering-homotopies-composition open import foundation-core.contractible-maps @@ -82,6 +84,81 @@ module _ ( is-equiv-is-coherently-invertible) ``` +### Coherently invertible maps are coherently invertible in both senses + +This is Lemma 4.2.2 in _Homotopy Type Theory – Univalent Foundations of +Mathematics_. + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} + where + + inv-coh-is-transpose-coherently-invertible-is-coherently-invertible' : + {f : A → B} (H : is-coherently-invertible f) → + ( ( map-inv-is-coherently-invertible H) ·l + ( is-section-map-inv-is-coherently-invertible H) ·r + ( f ∘ map-inv-is-coherently-invertible H)) ~ + ( ( map-inv-is-coherently-invertible H ∘ f) ·l + ( is-retraction-map-inv-is-coherently-invertible H) ·r + ( map-inv-is-coherently-invertible H)) + inv-coh-is-transpose-coherently-invertible-is-coherently-invertible' {f} H = + ( preserves-comp-right-whisker-comp + ( f) + ( map-inv-is-coherently-invertible H) + ( ( map-inv-is-coherently-invertible H) ·l + ( is-section-map-inv-is-coherently-invertible H))) ∙h + ( double-whisker-comp² + ( map-inv-is-coherently-invertible H) + ( coh-is-coherently-invertible H) + ( map-inv-is-coherently-invertible H)) ∙h + ( preserves-comp-left-whisker-comp + ( map-inv-is-coherently-invertible H) + ( f) + ( is-retraction-map-inv-is-coherently-invertible H ·r + map-inv-is-coherently-invertible H)) + + coh-is-transpose-coherently-invertible-is-coherently-invertible' : + {f : A → B} (H : is-coherently-invertible f) → + ( ( map-inv-is-coherently-invertible H ∘ f) ·l + ( is-retraction-map-inv-is-coherently-invertible H) ·r + ( map-inv-is-coherently-invertible H)) ~ + ( ( map-inv-is-coherently-invertible H) ·l + ( is-section-map-inv-is-coherently-invertible H) ·r + ( f ∘ map-inv-is-coherently-invertible H)) + coh-is-transpose-coherently-invertible-is-coherently-invertible' {f} H = + ( inv-preserves-comp-left-whisker-comp + ( map-inv-is-coherently-invertible H) + ( f) + ( ( is-retraction-map-inv-is-coherently-invertible H) ·r + ( map-inv-is-coherently-invertible H))) ∙h + ( double-whisker-comp² + ( map-inv-is-coherently-invertible H) + ( inv-htpy (coh-is-coherently-invertible H)) + ( map-inv-is-coherently-invertible H)) ∙h + ( preserves-comp-right-whisker-comp + ( f) + ( map-inv-is-coherently-invertible H) + ( ( map-inv-is-coherently-invertible H) ·l + ( is-section-map-inv-is-coherently-invertible H))) + + coh-is-transpose-coherently-invertible-is-coherently-invertible : + {f : A → B} (H : is-coherently-invertible f) → + coherence-is-transpose-coherently-invertible + ( f) + ( map-inv-is-coherently-invertible H) + ( is-section-map-inv-is-coherently-invertible H) + ( is-retraction-map-inv-is-coherently-invertible H) + coh-is-transpose-coherently-invertible-is-coherently-invertible {f} H = + {! !} +``` + +## References + +1. Univalent Foundations Project, _Homotopy Type Theory – Univalent Foundations + of Mathematics_ (2013) ([website](https://homotopytypetheory.org/book/), + [arXiv:1308.0729](https://arxiv.org/abs/1308.0729)) + ## See also - For the notion of biinvertible maps see From c578bfdeb98d8f64b73e3473b5f1d1c9730ef408 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Sat, 10 Feb 2024 12:27:58 +0100 Subject: [PATCH 08/53] wip operations on commuting squares of homotopies --- .../commuting-squares-of-homotopies.lagda.md | 398 +++++++++++++++++- 1 file changed, 394 insertions(+), 4 deletions(-) diff --git a/src/foundation-core/commuting-squares-of-homotopies.lagda.md b/src/foundation-core/commuting-squares-of-homotopies.lagda.md index 35faad40df..423e591c1c 100644 --- a/src/foundation-core/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation-core/commuting-squares-of-homotopies.lagda.md @@ -7,10 +7,13 @@ module foundation-core.commuting-squares-of-homotopies where
Imports ```agda -open import foundation.commuting-squares-of-identifications open import foundation.universe-levels +open import foundation.whiskering-homotopies-composition +open import foundation-core.commuting-squares-of-identifications open import foundation-core.homotopies +open import foundation-core.retractions +open import foundation-core.sections ```
@@ -39,7 +42,7 @@ of the square. ```agda module _ - {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (f : A) → B f} + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) where @@ -52,6 +55,60 @@ module _ top ∙h right ~ left ∙h bottom ``` +### Horizontally constant squares + +{{#concept "Horizontally constant squares" Disambiguation="homotopies" Agda=horizontal-refl-coherence-square-homotopies}} +are commuting squares of homotopies of the form + +```text + refl-htpy + f ----------> f + | | + H | | H + ∨ ∨ + g ----------> g. + refl-htpy +``` + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g : (x : A) → B x} (H : f ~ g) + where + + horizontal-refl-coherence-square-homotopies : + coherence-square-homotopies refl-htpy H H refl-htpy + horizontal-refl-coherence-square-homotopies x = + horizontal-refl-coherence-square-identifications (H x) +``` + +### Vertically constant squares + +{{#concept "Vertically constant squares" Disambiguation="homotopies" Agda=vertical-refl-coherence-square-homotopies}} +are commuting squares of homotopies of the form + +```text + H + f -----> g + | | + refl-htpy | | refl-htpy + ∨ ∨ + f -----> g. + H +``` + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g : (x : A) → B x} (H : f ~ g) + where + + vertical-refl-coherence-square-homotopies : + coherence-square-homotopies H refl-htpy refl-htpy H + vertical-refl-coherence-square-homotopies x = + vertical-refl-coherence-square-identifications (H x) +``` + +## Operations + ### Inverting squares of homotopies horizontally Given a commuting square of homotopies @@ -89,7 +146,13 @@ module _ (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) → coherence-square-homotopies top left right bottom → coherence-square-homotopies (inv-htpy top) right left (inv-htpy bottom) - horizontal-inv-coherence-square-homotopies top left right bottom = {! !} + horizontal-inv-coherence-square-homotopies top left right bottom H x = + horizontal-inv-coherence-square-identifications + ( top x) + ( left x) + ( right x) + ( bottom x) + ( H x) ``` ### Inverting squares of homotopies vertically @@ -130,5 +193,332 @@ module _ coherence-square-homotopies top left right bottom → coherence-square-homotopies bottom (inv-htpy left) (inv-htpy right) top vertical-inv-coherence-square-homotopies top left right bottom H x = - {! vertical-inv-coherence-square-identifications (top x) (left x) (right x) (bottom x) (H x) !} + vertical-inv-coherence-square-identifications + ( top x) + ( left x) + ( right x) + ( bottom x) + ( H x) +``` + +### Functions acting on squares of homotopies + +Given a commuting square of homotopies + +```text + top + f -------> g + | | + left | | right + ∨ ∨ + h -------> i + bottom +``` + +in `(x : A) → B x`, and given a dependent map `F : {x : A} → B x → C x`, the +square of homotopies + +```text + F ·l top + f f -----------> f g + | | + F ·l left | | F ·l right + ∨ ∨ + h -------------> i + F ·l bottom +``` + +commutes. + +```agda +module _ + {l1 l2 l3 : Level} {A : UU l1} {B : A → UU l2} {C : A → UU l3} + {f g h i : (x : A) → B x} + (F : {x : A} → B x → C x) + where + + map-coherence-square-homotopies : + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) → + coherence-square-homotopies top left right bottom → + coherence-square-homotopies + ( F ·l top) + ( F ·l left) + ( F ·l right) + ( F ·l bottom) + map-coherence-square-homotopies top left right bottom H x = + map-coherence-square-identifications + ( F) + ( top x) + ( left x) + ( right x) + ( bottom x) + ( H x) +``` + +### Concatenating homotopies of edges and coherences of commuting squares of homotopies + +Consider a commuting square of homotopies and a homotopy of one of the four +sides with another homotopy, as for example in the diagram below: + +```text + top + a ---------> b + | | | + left | right |=| right' + ∨ ∨ ∨ + c ---------> d. + bottom +``` + +Then any homotopy witnessing that the square commutes can be concatenated with +the homotopy on the side, to obtain a new commuting square of homotopies. + +**Note.** To avoid cyclic module dependencies we will give direct proofs that +concatenating homotopies of edges of a square with the coherence of its +commutativity is an equivalence. + +#### Concatenating homotopies of the top edge with a coherence of a commuting square of homotopies + +Consider a commuting diagram of homotopies + +```text + top' + -------> + f -------> g + | top | + left | | right + ∨ ∨ + h -------> i. + bottom +``` + +with a homotopy `top ~ top'`. Then we get an equivalence + +```text + top top' + f -------> g f -------> g + | | | | + left | | right ≃ left | | right + ∨ ∨ ∨ ∨ + h -------> i h -------> i. + bottom bottom +``` + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) + {top' : f ~ g} (s : top ~ top') + where + + concat-top-homotopy-coherence-square-homotopies : + coherence-square-homotopies top left right bottom → + coherence-square-homotopies top' left right bottom + concat-top-homotopy-coherence-square-homotopies H x = + concat-top-identification-coherence-square-identifications + ( top x) + ( left x) + ( right x) + ( bottom x) + ( s x) + ( H x) + + inv-concat-top-homotopy-coherence-square-homotopies : + coherence-square-homotopies top' left right bottom → + coherence-square-homotopies top left right bottom + inv-concat-top-homotopy-coherence-square-homotopies H x = + inv-concat-top-identification-coherence-square-identifications + ( top x) + ( left x) + ( right x) + ( bottom x) + ( s x) + ( H x) ``` + +We record that this construction is an equivalence in +[`foundation.commuting-squares-of-homotopies`](foundation.commuting-squares-of-homotopies.md). + +#### Concatenating homotopies of the left edge with a coherence of a commuting square of homotopies + +Consider a commuting diagram of homotopies + +```text + top + f -------> g + | | | + left' | | left | right + ∨ ∨ ∨ + h -------> i. + bottom +``` + +with a homotopy `left ~ left'`. Then we get an equivalence + +```text + top top + f -------> g f -------> g + | | | | + left | | right ≃ left' | | right + ∨ ∨ ∨ ∨ + h -------> i h -------> i. + bottom bottom +``` + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) + {left' : f ~ h} (s : left ~ left') + where + + concat-left-homotopy-coherence-square-homotopies : + coherence-square-homotopies top left right bottom → + coherence-square-homotopies top left' right bottom + concat-left-homotopy-coherence-square-homotopies H x = + concat-left-identification-coherence-square-identifications + ( top x) + ( left x) + ( right x) + ( bottom x) + ( s x) + ( H x) + + inv-concat-left-homotopy-coherence-square-homotopies : + coherence-square-homotopies top left' right bottom → + coherence-square-homotopies top left right bottom + inv-concat-left-homotopy-coherence-square-homotopies H x = + inv-concat-left-identification-coherence-square-identifications + ( top x) + ( left x) + ( right x) + ( bottom x) + ( s x) + ( H x) +``` + +We record that this construction is an equivalence in +[`foundation.commuting-squares-of-homotopies`](foundation.commuting-squares-of-homotopies.md). + +#### Concatenating homotopies of the right edge with a coherence of a commuting square of homotopies + +Consider a commuting diagram of homotopies + +```text + top + f -------> g + | | | + left | right | | right' + ∨ ∨ ∨ + h -------> i. + bottom +``` + +with a homotopy `right ~ right'`. Then we get an equivalence + +```text + top top + f -------> g f -------> g + | | | | + left | | right ≃ left | | right' + ∨ ∨ ∨ ∨ + h -------> i h -------> i. + bottom bottom +``` + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) + {right' : g ~ i} (s : right ~ right') + where + + concat-right-homotopy-coherence-square-homotopies : + coherence-square-homotopies top left right bottom → + coherence-square-homotopies top left right' bottom + concat-right-homotopy-coherence-square-homotopies H x = + concat-right-identification-coherence-square-identifications + ( top x) + ( left x) + ( right x) + ( bottom x) + ( s x) + ( H x) + + inv-concat-right-homotopy-coherence-square-homotopies : + coherence-square-homotopies top left right' bottom → + coherence-square-homotopies top left right bottom + inv-concat-right-homotopy-coherence-square-homotopies H x = + inv-concat-right-identification-coherence-square-identifications + ( top x) + ( left x) + ( right x) + ( bottom x) + ( s x) + ( H x) +``` + +We record that this construction is an equivalence in +[`foundation.commuting-squares-of-homotopies`](foundation.commuting-squares-of-homotopies.md). + +#### Concatenating homotopies of the bottom edge with a coherence of a commuting square of homotopies + +Consider a commuting diagram of homotopies + +```text + top + f -------> g + | | + left | | right + ∨ bottom ∨ + h -------> i. + -------> + bottom' +``` + +with a homotopy `bottom ~ bottom'`. Then we get an equivalence + +```text + top top + f -------> g f -------> g + | | | | + left | | right ≃ left | | right + ∨ ∨ ∨ ∨ + h -------> i h -------> i. + bottom bottom' +``` + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) + {bottom' : h ~ i} (s : bottom ~ bottom') + where + + concat-bottom-homotopy-coherence-square-homotopies : + coherence-square-homotopies top left right bottom → + coherence-square-homotopies top left right bottom' + concat-bottom-homotopy-coherence-square-homotopies H x = + concat-bottom-identification-coherence-square-identifications + ( top x) + ( left x) + ( right x) + ( bottom x) + ( s x) + ( H x) + + inv-concat-bottom-homotopy-coherence-square-homotopies : + coherence-square-homotopies top left right bottom' → + coherence-square-homotopies top left right bottom + inv-concat-bottom-homotopy-coherence-square-homotopies H x = + inv-concat-bottom-identification-coherence-square-identifications + ( top x) + ( left x) + ( right x) + ( bottom x) + ( s x) + ( H x) +``` + +We record that this construction is an equivalence in +[`foundation.commuting-squares-of-homotopies`](foundation.commuting-squares-of-homotopies.md). From 454e2f883aebbd48e0a35fcc083d103e4d27fbfa Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Sat, 10 Feb 2024 12:44:52 +0100 Subject: [PATCH 09/53] whiskering and splicing of commuting squares of homotopies --- .../commuting-squares-of-homotopies.lagda.md | 326 +++++++++++++++++- 1 file changed, 323 insertions(+), 3 deletions(-) diff --git a/src/foundation-core/commuting-squares-of-homotopies.lagda.md b/src/foundation-core/commuting-squares-of-homotopies.lagda.md index 423e591c1c..496aa7b2ee 100644 --- a/src/foundation-core/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation-core/commuting-squares-of-homotopies.lagda.md @@ -126,13 +126,13 @@ Given a commuting square of homotopies the square of homotopies ```text - inv top + top⁻¹ g ------------> f | | right | | left ∨ ∨ i ------------> h - inv bottom + bottom⁻¹ ``` commutes. @@ -175,7 +175,7 @@ the square of homotopies bottom h -------> i | | - inv left | | inv right + left⁻¹ | | right⁻¹ ∨ ∨ f -------> g top @@ -522,3 +522,323 @@ module _ We record that this construction is an equivalence in [`foundation.commuting-squares-of-homotopies`](foundation.commuting-squares-of-homotopies.md). + +### Whiskering and splicing coherences of commuting squares of homotopies + +Given a commuting square of homotopies + +```text + top + f -------> g + | | + left | | right + ∨ ∨ + h -------> i, + bottom +``` + +we may consider four ways of attaching new homotopies to it: + +1. Prepending `H : u ~ f` to the left gives us a commuting square + + ```text + H ∙h top + u -------> g + | | + H ∙h left | | right + ∨ ∨ + h -------> i. + bottom + ``` + + More precisely, we have an equivalence + + ```text + (left ∙h bottom ~ top ∙h right) ≃ ((H ∙h left) ∙h bottom ~ (H ∙h top) ∙h right). + ``` + +2. Appending a homotopy `H : i ~ u` to the right gives a commuting square of + homotopies + + ```text + top + f ------------> g + | | + left | | right ∙h H + ∨ ∨ + h ------------> u. + bottom ∙h H + ``` + + More precisely, we have an equivalence + + ```text + (left ∙h bottom ~ top ∙h right) ≃ (left ∙h (bottom ∙h H) ~ top ∙h (right ∙h H)). + ``` + +3. Splicing a homotopy `H : h ~ u` and its inverse into the middle gives a + commuting square of homotopies + + ```text + top + f --------------> g + | | + left ∙h H | | right + ∨ ∨ + u --------------> i. + H⁻¹ ∙h bottom + ``` + + More precisely, we have an equivalence + + ```text + (left ∙h bottom ~ top ∙h right) ≃ ((left ∙h H) ∙h (H⁻¹ ∙h bottom) ~ top ∙h right). + ``` + + Similarly, we have an equivalence + + ```text + (left ∙h bottom ~ top ∙h right) ≃ ((left ∙h H⁻¹) ∙h (H ∙h bottom) ~ top ∙h right). + ``` + +4. Splicing a homotopy `H : g ~ u` and its inverse into the middle gives a + commuting square of homotopies + + ```text + top ∙h H + f --------> u + | | + left | | H⁻¹ ∙h right + ∨ ∨ + h --------> i. + bottom + ``` + + More precisely, we have an equivalence + + ```text + (left ∙h bottom ~ top ∙h right) ≃ (left ∙h bottom ~ (top ∙h H) ∙h (H⁻¹ ∙h right)). + ``` + + Similarly, we have an equivalence + + ```text + (left ∙h bottom ~ top ∙h right) ≃ (left ∙h bottom ~ (top ∙h H⁻¹) ∙h (H ∙h right)). + ``` + +These operations are useful in proofs involving path algebra, because taking +`equiv-right-whisker-concat-coherence-square-identicications` as an example, it +provides us with two maps: the forward direction states +`(H ∙h r ~ K ∙h s) → (H ∙h (r ∙h t)) ~ K ∙h (s ∙h t))`, which allows one to +append an homotopy without needing to reassociate on the right, and the +backwards direction conversely allows one to cancel out a homotopy in +parentheses. + +#### Left whiskering coherences of commuting squares of homotopies + +For any homotopy `H : u ~ f` we obtain an equivalence + +```text + top H ∙h top + f -------> g u -------> g + | | | | + left | | right ≃ H ∙h left | | right + ∨ ∨ ∨ ∨ + h -------> i h -------> i + bottom bottom +``` + +of coherences of commuting squares of homotopies. + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} + where + + left-whisker-concat-coherence-square-homotopies : + {u : (x : A) → B x} (H : u ~ f) + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) → + coherence-square-homotopies top left right bottom → + coherence-square-homotopies (H ∙h top) (H ∙h left) right bottom + left-whisker-concat-coherence-square-homotopies + H top left right bottom coh x = + left-whisker-concat-coherence-square-identifications + ( H x) + ( top x) + ( left x) + ( right x) + ( bottom x) + ( coh x) + + left-unwhisker-concat-coherence-square-homotopies : + {u : (x : A) → B x} (H : u ~ f) + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) → + coherence-square-homotopies (H ∙h top) (H ∙h left) right bottom → + coherence-square-homotopies top left right bottom + left-unwhisker-concat-coherence-square-homotopies + H top left right bottom coh x = + left-unwhisker-concat-coherence-square-identifications + ( H x) + ( top x) + ( left x) + ( right x) + ( bottom x) + ( coh x) +``` + +#### Right whiskering coherences of commuting squares of homotopies + +For any homotopy `H : i ~ u` we obtain an equivalence + +```text + top top + f -------> g f ------------> g + | | | | + left | | right ≃ left | | right ∙h H + ∨ ∨ ∨ ∨ + h -------> i h ------------> i + bottom bottom ∙h H +``` + +of coherences of commuting squares of homotopies. + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) + where + + right-whisker-concat-coherence-square-homotopies : + coherence-square-homotopies top left right bottom → + {u : (x : A) → B x} (H : i ~ u) → + coherence-square-homotopies top left (right ∙h H) (bottom ∙h H) + right-whisker-concat-coherence-square-homotopies coh H x = + right-whisker-concat-coherence-square-identifications + ( top x) + ( left x) + ( right x) + ( bottom x) + ( coh x) + ( H x) + + right-unwhisker-cohernece-square-homotopies : + {u : (x : A) → B x} (H : i ~ u) → + coherence-square-homotopies top left (right ∙h H) (bottom ∙h H) → + coherence-square-homotopies top left right bottom + right-unwhisker-cohernece-square-homotopies H coh x = + right-unwhisker-cohernece-square-identifications + ( top x) + ( left x) + ( right x) + ( bottom x) + ( H x) + ( coh x) +``` + +#### Left splicing coherences of commuting squares of homotopies + +For any inverse pair of homotopies `H : g ~ u` and `K : u ~ g` equipped with +`α : inv-htpy H ~ K` we obtain an equivalence + +```text + top top + f -------> g f -----------> g + | | | | + left | | right ≃ left ∙h H | | right + ∨ ∨ ∨ ∨ + h -------> i u -----------> i + bottom K ∙h bottom +``` + +of coherences of commuting squares of homotopies. + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) + where + + left-splice-coherence-square-homotopies : + {u : (x : A) → B x} (H : h ~ u) (K : u ~ h) (α : inv-htpy H ~ K) → + coherence-square-homotopies top left right bottom → + coherence-square-homotopies top (left ∙h H) right (K ∙h bottom) + left-splice-coherence-square-homotopies H K α coh x = + left-splice-coherence-square-identifications + ( top x) + ( left x) + ( right x) + ( bottom x) + ( H x) + ( K x) + ( α x) + ( coh x) + + left-unsplice-coherence-square-homotopies : + {u : (x : A) → B x} (H : h ~ u) (K : u ~ h) (α : inv-htpy H ~ K) → + coherence-square-homotopies top (left ∙h H) right (K ∙h bottom) → + coherence-square-homotopies top left right bottom + left-unsplice-coherence-square-homotopies H K α coh x = + left-unsplice-coherence-square-identifications + ( top x) + ( left x) + ( right x) + ( bottom x) + ( H x) + ( K x) + ( α x) + ( coh x) +``` + +#### Right splicing coherences of commuting squares of homotopies + +For any inverse pair of homotopies `H : g ~ u` and `K : u ~ g` equipped with +`α : inv-htpy H ~ K` we obtain an equivalence + +```text + top top ∙h H + f -------> g f --------> u + | | | | + left | | right ≃ left | | K ∙h right + ∨ ∨ ∨ ∨ + h -------> i h --------> i + bottom bottom +``` + +of coherences of commuting squares of homotopies. + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) + where + + right-splice-coherence-square-homotopies : + {u : (x : A) → B x} (H : g ~ u) (K : u ~ g) (α : inv-htpy H ~ K) → + coherence-square-homotopies top left right bottom → + coherence-square-homotopies (top ∙h H) left (inv-htpy H ∙h right) bottom + right-splice-coherence-square-homotopies H K α coh x = + right-splice-coherence-square-identifications + ( top x) + ( left x) + ( right x) + ( bottom x) + ( H x) + ( K x) + ( α x) + ( coh x) + + right-unsplice-coherence-square-homotopies : + {u : (x : A) → B x} (H : g ~ u) (K : u ~ g) (α : inv-htpy H ~ K) → + coherence-square-homotopies (top ∙h H) left (inv-htpy H ∙h right) bottom → + coherence-square-homotopies top left right bottom + right-unsplice-coherence-square-homotopies H K α coh x = + right-unsplice-coherence-square-identifications + ( top x) + ( left x) + ( right x) + ( bottom x) + ( H x) + ( K x) + ( α x) + ( coh x) +``` From 5019a3c3ad9490de3d9e21b115d3ebcf583fe30e Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Sat, 10 Feb 2024 12:49:54 +0100 Subject: [PATCH 10/53] horizontal and vertical pasting commuting squares of homotopies --- .../commuting-squares-of-homotopies.lagda.md | 92 +++++++++++++++++++ ...muting-squares-of-identifications.lagda.md | 11 ++- 2 files changed, 98 insertions(+), 5 deletions(-) diff --git a/src/foundation-core/commuting-squares-of-homotopies.lagda.md b/src/foundation-core/commuting-squares-of-homotopies.lagda.md index 496aa7b2ee..51869dada8 100644 --- a/src/foundation-core/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation-core/commuting-squares-of-homotopies.lagda.md @@ -842,3 +842,95 @@ module _ ( α x) ( coh x) ``` + +### Horizontally pasting squares of homotopies + +Consider two squares of homotopies as in the diagram + +```text + top-left top-right + a -------------> b -------------> c + | | | + left | | middle | right + ∨ ∨ ∨ + d -------------> e -------------> f + bottom-left bottom-right +``` + +with `H : left ∙h bottom-left ~ top-left ∙h middle` and +`K : middle ∙h bottom-right ~ top-right ∙h right`. Then the outer square +commutes. + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {a b c d e f : (x : A) → B x} + (top-left : a ~ b) (top-right : b ~ c) + (left : a ~ d) (middle : b ~ e) (right : c ~ f) + (bottom-left : d ~ e) (bottom-right : e ~ f) + where + + horizontal-pasting-coherence-square-homotopies : + coherence-square-homotopies top-left left middle bottom-left → + coherence-square-homotopies top-right middle right bottom-right → + coherence-square-homotopies + (top-left ∙h top-right) left right (bottom-left ∙h bottom-right) + horizontal-pasting-coherence-square-homotopies H K x = + horizontal-pasting-coherence-square-identifications + ( top-left x) + ( top-right x) + ( left x) + ( middle x) + ( right x) + ( bottom-left x) + ( bottom-right x) + ( H x) + ( K x) +``` + +### Vertically pasting squares of homotopies + +Consider two squares of homotopies as in the diagram + +```text + top + a --------> b + | | + top-left | | top-right + ∨ middle ∨ + c --------> d + | | + bottom-left | | bottom-right + ∨ ∨ + e --------> f + bottom +``` + +with `H : top-left ∙h middle ~ top ∙h top-right` and +`K : bottom-left ∙h bottom ~ middle ∙h bottom-right`. Then the outer square +commutes. + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {a b c d e f : (x : A) → B x} + (top : a ~ b) (top-left : a ~ c) (top-right : b ~ d) + (middle : c ~ d) (bottom-left : c ~ e) (bottom-right : d ~ f) + (bottom : e ~ f) + where + + vertical-pasting-coherence-square-homotopies : + coherence-square-homotopies top top-left top-right middle → + coherence-square-homotopies middle bottom-left bottom-right bottom → + coherence-square-homotopies + top (top-left ∙h bottom-left) (top-right ∙h bottom-right) bottom + vertical-pasting-coherence-square-homotopies H K x = + vertical-pasting-coherence-square-identifications + ( top x) + ( top-left x) + ( top-right x) + ( middle x) + ( bottom-left x) + ( bottom-right x) + ( bottom x) + ( H x) + ( K x) +``` diff --git a/src/foundation-core/commuting-squares-of-identifications.lagda.md b/src/foundation-core/commuting-squares-of-identifications.lagda.md index f73e51935f..a081bf545f 100644 --- a/src/foundation-core/commuting-squares-of-identifications.lagda.md +++ b/src/foundation-core/commuting-squares-of-identifications.lagda.md @@ -830,8 +830,9 @@ Consider two squares of identifications as in the diagram bottom-left bottom-right ``` -with `s : left ∙ bottom-left = top-left ∙ middle` and t : middle ∙ bottom-right -= top-right ∙ right`. Then the outer square commutes. +with `s : left ∙ bottom-left = top-left ∙ middle` and +`t : middle ∙ bottom-right = top-right ∙ right`. Then the outer square +commutes. ```agda module _ @@ -899,21 +900,21 @@ module _ coherence-square-identifications middle bottom-left bottom-right bottom → coherence-square-identifications top (top-left ∙ bottom-left) (top-right ∙ bottom-right) bottom - vertical-pasting-coherence-square-identifications p q = + vertical-pasting-coherence-square-identifications s t = ( left-whisker-concat-coherence-square-identifications ( top-left) ( middle) ( bottom-left) ( bottom-right) ( bottom) - ( q)) ∙ + ( t)) ∙ ( ( assoc top-left middle bottom-right) ∙ ( right-whisker-concat-coherence-square-identifications ( top) ( top-left) ( top-right) ( middle) - ( p) + ( s) ( bottom-right))) ``` From 2ba5d86fb0cb148d43b0b1ea9b095e5112bde23f Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Sat, 10 Feb 2024 12:59:36 +0100 Subject: [PATCH 11/53] unit laws pasting commuting squares of homotopies --- .../commuting-squares-of-homotopies.lagda.md | 129 ++++++++++++++++++ 1 file changed, 129 insertions(+) diff --git a/src/foundation-core/commuting-squares-of-homotopies.lagda.md b/src/foundation-core/commuting-squares-of-homotopies.lagda.md index 51869dada8..2bf46e6101 100644 --- a/src/foundation-core/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation-core/commuting-squares-of-homotopies.lagda.md @@ -9,6 +9,7 @@ module foundation-core.commuting-squares-of-homotopies where ```agda open import foundation.universe-levels open import foundation.whiskering-homotopies-composition +open import foundation-core.whiskering-homotopies-concatenation open import foundation-core.commuting-squares-of-identifications open import foundation-core.homotopies @@ -934,3 +935,131 @@ module _ ( H x) ( K x) ``` + +## Properties + +### Left unit law for horizontal pasting of commuting squares of homotopies + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} + where + + left-unit-law-horizontal-pasting-coherence-square-homotopies : + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) → + (H : coherence-square-homotopies top left right bottom) → + horizontal-pasting-coherence-square-homotopies + ( refl-htpy) + ( top) + ( left) + ( left) + ( right) + ( refl-htpy) + ( bottom) + ( horizontal-refl-coherence-square-homotopies left) + ( H) ~ + H + left-unit-law-horizontal-pasting-coherence-square-homotopies + top left right bottom H x = + left-unit-law-horizontal-pasting-coherence-square-identifications + ( top x) + ( left x) + ( right x) + ( bottom x) + ( H x) +``` + +### Right unit law for horizontal pasting of commuting squares of homotopies + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} + where + + right-unit-law-horizontal-pasting-coherence-square-homotopies : + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) → + (H : coherence-square-homotopies top left right bottom) → + horizontal-pasting-coherence-square-homotopies + ( top) + ( refl-htpy) + ( left) + ( right) + ( right) + ( bottom) + ( refl-htpy) + ( H) + ( horizontal-refl-coherence-square-homotopies right) ∙h + right-whisker-concat-htpy right-unit-htpy right ~ + left-whisker-concat-htpy left right-unit-htpy ∙h H + right-unit-law-horizontal-pasting-coherence-square-homotopies + top left right bottom H x = + right-unit-law-horizontal-pasting-coherence-square-identifications + ( top x) + ( left x) + ( right x) + ( bottom x) + ( H x) +``` + +### Left unit law for vertical pasting of commuting squares of homotopies + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} + where + + left-unit-law-vertical-pasting-coherence-square-homotopies : + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) → + (H : coherence-square-homotopies top left right bottom) → + vertical-pasting-coherence-square-homotopies + ( top) + ( refl-htpy) + ( refl-htpy) + ( top) + ( left) + ( right) + ( bottom) + ( vertical-refl-coherence-square-homotopies top) + ( H) ~ + H + left-unit-law-vertical-pasting-coherence-square-homotopies + top left right bottom H x = + left-unit-law-vertical-pasting-coherence-square-identifications + ( top x) + ( left x) + ( right x) + ( bottom x) + ( H x) +``` + +### Right unit law for vertical pasting of commuting squares of homotopies + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} + where + + right-unit-law-vertical-pasting-coherence-square-homotopies : + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) → + (H : coherence-square-homotopies top left right bottom) → + vertical-pasting-coherence-square-homotopies + ( top) + ( left) + ( right) + ( bottom) + ( refl-htpy) + ( refl-htpy) + ( bottom) + ( H) + ( vertical-refl-coherence-square-homotopies bottom) ∙h + left-whisker-concat-htpy top right-unit-htpy ~ + right-whisker-concat-htpy right-unit-htpy bottom ∙h H + right-unit-law-vertical-pasting-coherence-square-homotopies + top left right bottom H x = + right-unit-law-vertical-pasting-coherence-square-identifications + ( top x) + ( left x) + ( right x) + ( bottom x) + ( H x) +``` From d1e88bd4c85f4cf9f0207f2abc832f44b90846e0 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Sat, 10 Feb 2024 13:12:32 +0100 Subject: [PATCH 12/53] computng left whiskering commuting squares of homotopies --- .../commuting-squares-of-homotopies.lagda.md | 197 ++++++++++++++++++ 1 file changed, 197 insertions(+) diff --git a/src/foundation-core/commuting-squares-of-homotopies.lagda.md b/src/foundation-core/commuting-squares-of-homotopies.lagda.md index 2bf46e6101..6f36a6ac0d 100644 --- a/src/foundation-core/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation-core/commuting-squares-of-homotopies.lagda.md @@ -1063,3 +1063,200 @@ module _ ( bottom x) ( H x) ``` + +### Computing the right whiskering of a vertically constant square with a homotopy + +Consider the vertically constant square of homotopies + +```text + H + f -----> g + | | + refl | | refl + ∨ ∨ + f -----> g + H +``` + +at a homotopy `H : f ~ g`, and consider a homotopy `K : g ~ h`. Then the right +whiskering of the above square with `K` is the commuting square of homotopies + +```text + H + f -------> g + | | + refl | refl | K + ∨ ∨ + f -------> h + H ∙h K +``` + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h : (x : A) → B x} + where + + right-whisker-concat-vertical-refl-coherence-square-homotopies : + (H : f ~ g) (K : g ~ h) → + right-whisker-concat-coherence-square-homotopies H refl-htpy refl-htpy H + ( vertical-refl-coherence-square-homotopies H) + ( K) ~ + refl-htpy + right-whisker-concat-vertical-refl-coherence-square-homotopies H K x = + right-whisker-concat-vertical-refl-coherence-square-identifications + ( H x) + ( K x) +``` + +### Computing the right whiskering of a horizontally constant square with a homotopy + +Consider a horizontally constant commuting square of homotopies + +```text + refl-htpy + f ----------> f + | | + H | | H + ∨ ∨ + g ----------> g + refl-htpy +``` + +at a homotopy `H` and consider a homotopy `K : g ~ h`. Then the right whiskering +of the above square with `K` is the square + +```text + refl-htpy + f ----------> f + | | + H | refl-htpy | H ∙h K + ∨ ∨ + g ----------> h. + K +``` + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h : (x : A) → B x} + where + + right-whisker-concat-horizontal-refl-coherence-square-homotopies : + (H : f ~ g) (K : g ~ h) → + right-whisker-concat-coherence-square-homotopies refl-htpy H H refl-htpy + ( horizontal-refl-coherence-square-homotopies H) + ( K) ~ + refl-htpy + right-whisker-concat-horizontal-refl-coherence-square-homotopies H K x = + right-whisker-concat-horizontal-refl-coherence-square-identifications + ( H x) + ( K x) +``` + +### Computing the left whiskering of a horizontally constant square with a homotopy + +Consider a homotopy `H : f ~ g` and a horizontally constant commuting square of +homotopies + +```text + refl-htpy + g ----------> g + | | + K | | K + ∨ ∨ + h ----------> h + refl-htpy +``` + +at a homotopy `K : g ~ h`. The the left whiskering of the above square with `H` +is the commuting square + +```text + K ∙h refl-htpy + f -----------------------------------------------------------------> g + | | + K ∙h H | right-unit-htpy ∙h (right-whisker-concat-htpy right-unit-htpy H)⁻¹ | H + ∨ ∨ + h -----------------------------------------------------------------> h. + refl-htpy +``` + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h : (x : A) → B x} + where + + left-whisker-concat-horizontal-refl-coherence-square-homotopies : + (H : f ~ g) (K : g ~ h) → + left-whisker-concat-coherence-square-homotopies H refl-htpy K K refl-htpy + ( horizontal-refl-coherence-square-homotopies K) ∙h + right-whisker-concat-htpy right-unit-htpy K ~ + right-unit-htpy + left-whisker-concat-horizontal-refl-coherence-square-homotopies H K x = + left-whisker-concat-horizontal-refl-coherence-square-identifications + ( H x) + ( K x) + + left-whisker-concat-horizontal-refl-coherence-square-homotopies' : + (H : f ~ g) (K : g ~ h) → + left-whisker-concat-coherence-square-homotopies H refl-htpy K K refl-htpy + ( horizontal-refl-coherence-square-homotopies K) ~ + right-unit-htpy ∙h inv-htpy (right-whisker-concat-htpy right-unit-htpy K) + left-whisker-concat-horizontal-refl-coherence-square-homotopies' H K x = + left-whisker-concat-horizontal-refl-coherence-square-identifications' + ( H x) + ( K x) +``` + +### Computing the left whiskering of a vertically constant square with a homotopy + +Consider the vertically constant square of homotopies + +```text + K + g -----> h + | | + refl-htpy | | refl-htpy + ∨ ∨ + g -----> h + K +``` + +at a homotopy `K : g ~ h` and consider a homotopy `H : f ~ g`. Then the left +whiskering of the above square with `H` is the square + +```text + H ∙h K + f ----------------------------------------------------------> h + | | + H ∙h refl-htpy | right-whisker-concat-htpy right-unit-htpy K ∙h right-unit⁻¹ | refl-htpy + ∨ ∨ + g ----------------------------------------------------------> h. + K +``` + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h : (x : A) → B x} + where + + left-whisker-concat-vertical-refl-coherence-square-homotopies : + (H : f ~ g) (K : g ~ h) → + left-whisker-concat-coherence-square-homotopies H K refl-htpy refl-htpy K + ( vertical-refl-coherence-square-homotopies K) ∙h + right-unit-htpy ~ + right-whisker-concat-htpy right-unit-htpy K + left-whisker-concat-vertical-refl-coherence-square-homotopies H K x = + left-whisker-concat-vertical-refl-coherence-square-identifications + ( H x) + ( K x) + + left-whisker-concat-vertical-refl-coherence-square-homotopies' : + (H : f ~ g) (K : g ~ h) → + left-whisker-concat-coherence-square-homotopies H K refl-htpy refl-htpy K + ( vertical-refl-coherence-square-homotopies K) ~ + right-whisker-concat-htpy right-unit-htpy K ∙h inv-htpy right-unit-htpy + left-whisker-concat-vertical-refl-coherence-square-homotopies' H K x = + left-whisker-concat-vertical-refl-coherence-square-identifications' + ( H x) + ( K x) +``` From 091341f0fb9815a1c82b474ad3f97f1cc2718ce9 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Sat, 10 Feb 2024 13:35:23 +0100 Subject: [PATCH 13/53] finish `foundation-core.commuting-squares-of-homotopies` --- .../commuting-squares-of-homotopies.lagda.md | 374 +++++++++++++++++- 1 file changed, 373 insertions(+), 1 deletion(-) diff --git a/src/foundation-core/commuting-squares-of-homotopies.lagda.md b/src/foundation-core/commuting-squares-of-homotopies.lagda.md index 6f36a6ac0d..944b6b67c2 100644 --- a/src/foundation-core/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation-core/commuting-squares-of-homotopies.lagda.md @@ -9,12 +9,12 @@ module foundation-core.commuting-squares-of-homotopies where ```agda open import foundation.universe-levels open import foundation.whiskering-homotopies-composition -open import foundation-core.whiskering-homotopies-concatenation open import foundation-core.commuting-squares-of-identifications open import foundation-core.homotopies open import foundation-core.retractions open import foundation-core.sections +open import foundation-core.whiskering-homotopies-concatenation ```
@@ -1260,3 +1260,375 @@ module _ ( H x) ( K x) ``` + +### Left whiskering horizontal concatenations of squares with homotopies + +Consider a commuting diagram of homotopies of the form + +```text + top-left top-right + a -------------> c -------------> e + | | | + left | | middle | right + ∨ ∨ ∨ + b -------------> d -------------> f + bottom-left bottom-right +``` + +and consider a homotopy `H : f ~ a`. Then the left whiskering of `H` and the +horizontal concatenation of coherences of commuting squares is up to +associativity the horizontal concatenation of the squares + +```text + H ∙h top-left top-right + u -------------> c -------------> e + | | | + H ∙h left | | middle | right + ∨ ∨ ∨ + b -------------> d -------------> f + bottom-left bottom-right +``` + +where the left square is the left whiskering of `H` and the original left +square. + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} + where + + left-whisker-concat-horizontal-pasting-coherence-square-homotopies : + {u a b c d e f : (x : A) → B x} (H : u ~ a) + (top-left : a ~ c) (top-right : c ~ e) + (left : a ~ b) (middle : c ~ d) (right : e ~ f) + (bottom-left : b ~ d) (bottom-right : d ~ f) + (l : coherence-square-homotopies top-left left middle bottom-left) + (r : coherence-square-homotopies top-right middle right bottom-right) → + left-whisker-concat-coherence-square-homotopies H + ( top-left ∙h top-right) + ( left) + ( right) + ( bottom-left ∙h bottom-right) + ( horizontal-pasting-coherence-square-homotopies + ( top-left) + ( top-right) + ( left) + ( middle) + ( right) + ( bottom-left) + ( bottom-right) + ( l) + ( r)) ~ + horizontal-pasting-coherence-square-homotopies + ( H ∙h top-left) + ( top-right) + ( H ∙h left) + ( middle) + ( right) + ( bottom-left) + ( bottom-right) + ( left-whisker-concat-coherence-square-homotopies H + ( top-left) + ( left) + ( middle) + ( bottom-left) + ( l)) + ( r) ∙h + right-whisker-concat-htpy + ( assoc-htpy H top-left top-right) + ( right) + left-whisker-concat-horizontal-pasting-coherence-square-homotopies + H top-left top-right left middle right bottom-left bottom-right l r x = + left-whisker-concat-horizontal-pasting-coherence-square-identifications + ( H x) + ( top-left x) + ( top-right x) + ( left x) + ( middle x) + ( right x) + ( bottom-left x) + ( bottom-right x) + ( l x) + ( r x) +``` + +### Left whiskering vertical concatenations of squares with homotopies + +Consider two squares of homotopies as in the diagram + +```text + top + a --------> b + | | + top-left | | top-right + ∨ middle ∨ + c --------> d + | | + bottom-left | | bottom-right + ∨ ∨ + e --------> f + bottom +``` + +and consider a homotopy `H : f ~ a`. Then the left whiskering of `H` with the +vertical pasting of the two squares above is up to associativity the vertical +pasting of the squares + +```text + H ∙h top + u --------> b + | | + H ∙h top-left | | top-right + ∨ middle ∨ + c --------> d + | | + bottom-left | | bottom-right + ∨ ∨ + e --------> f. + bottom +``` + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} + where + + left-whisker-concat-vertical-concat-coherence-square-homotopies : + {u a b c d e f : (x : A) → B x} (H : u ~ a) → + (top : a ~ b) (top-left : a ~ c) (top-right : b ~ d) (middle : c ~ d) + (bottom-left : c ~ e) (bottom-right : d ~ f) (bottom : e ~ f) + (t : coherence-square-homotopies top top-left top-right middle) → + (b : + coherence-square-homotopies middle bottom-left bottom-right bottom) → + right-whisker-concat-htpy (assoc-htpy H top-left bottom-left) bottom ∙h + left-whisker-concat-coherence-square-homotopies H + ( top) + ( top-left ∙h bottom-left) + ( top-right ∙h bottom-right) + ( bottom) + ( vertical-pasting-coherence-square-homotopies + ( top) + ( top-left) + ( top-right) + ( middle) + ( bottom-left) + ( bottom-right) + ( bottom) + ( t) + ( b)) ~ + vertical-pasting-coherence-square-homotopies + ( H ∙h top) + ( H ∙h top-left) + ( top-right) + ( middle) + ( bottom-left) + ( bottom-right) + ( bottom) + ( left-whisker-concat-coherence-square-homotopies H + ( top) + ( top-left) + ( top-right) + ( middle) + ( t)) + ( b) + left-whisker-concat-vertical-concat-coherence-square-homotopies + H top top-left top-right middle bottom-left bottom-right bottom t b x = + left-whisker-concat-vertical-concat-coherence-square-identifications + ( H x) + ( top x) + ( top-left x) + ( top-right x) + ( middle x) + ( bottom-left x) + ( bottom-right x) + ( bottom x) + ( t x) + ( b x) +``` + +### Right whiskering horizontal pastings of commuting squares of homotopies + +Consider a commuting diagram of homotopies of the form + +```text + top-left top-right + a -------------> c -------------> e + | | | + left | | middle | right + ∨ ∨ ∨ + b -------------> d -------------> f + bottom-left bottom-right +``` + +and consider a homotopy `K : f ~ g`. Then the right whiskering of the horizontal +pasting of the squares above is up to associativity the horizontal pasting of +the squares + +```text + top-left top-right + a -------------> c ------------------> e + | | | + left | | middle | right ∙h K + ∨ ∨ ∨ + b -------------> d ------------------> g + bottom-left bottom-right ∙h K +``` + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} + where + + right-whisker-concat-horizontal-pasting-coherence-square-homotopies : + {a b c d e f g : (x : A) → B x} + (top-left : a ~ c) (top-right : c ~ e) + (left : a ~ b) (middle : c ~ d) (right : e ~ f) + (bottom-left : b ~ d) (bottom-right : d ~ f) + (l : coherence-square-homotopies top-left left middle bottom-left) → + (r : coherence-square-homotopies top-right middle right bottom-right) → + (K : f ~ g) → + right-whisker-concat-coherence-square-homotopies + ( top-left ∙h top-right) + ( left) + ( right) + ( bottom-left ∙h bottom-right) + ( horizontal-pasting-coherence-square-homotopies + ( top-left) + ( top-right) + ( left) + ( middle) + ( right) + ( bottom-left) + ( bottom-right) + ( l) + ( r)) + ( K) ~ + left-whisker-concat-htpy left (assoc-htpy bottom-left bottom-right K) ∙h + horizontal-pasting-coherence-square-homotopies + ( top-left) + ( top-right) + ( left) + ( middle) + ( right ∙h K) + ( bottom-left) + ( bottom-right ∙h K) + ( l) + ( right-whisker-concat-coherence-square-homotopies + ( top-right) + ( middle) + ( right) + ( bottom-right) + ( r) + ( K)) + right-whisker-concat-horizontal-pasting-coherence-square-homotopies + top-left top-right left middle right bottom-left bottom-right l r K x = + right-whisker-concat-horizontal-pasting-coherence-square-identifications + ( top-left x) + ( top-right x) + ( left x) + ( middle x) + ( right x) + ( bottom-left x) + ( bottom-right x) + ( l x) + ( r x) + ( K x) +``` + +### Right whiskering vertical concatenations of squares with homotopies + +Consider two squares of homotopies as in the diagram + +```text + top + a --------> b + | | + top-left | | top-right + ∨ middle ∨ + c --------> d + | | + bottom-left | | bottom-right + ∨ ∨ + e --------> f + bottom +``` + +and consider a homotopy `K : f ~ g`. Then the right whiskering of the vertical +pasting of the two squares above with `K` is up to associativity the vertical +pasting of the squares + +```text + top + a ------------> b + | | + top-left | | top-right + ∨ middle ∨ + c ------------> d + | | + bottom-left | | bottom-right ∙h K + ∨ ∨ + e ------------> g. + bottom ∙h K +``` + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} + where + + right-whisker-concat-vertical-pasting-coherence-square-homotopies : + {a b c d e f g : (x : A) → B x} + (top : a ~ b) (top-left : a ~ c) (top-right : b ~ d) + (middle : c ~ d) + (bottom-left : c ~ e) (bottom-right : d ~ f) (bottom : e ~ f) + (t : coherence-square-homotopies top top-left top-right middle) → + (b : + coherence-square-homotopies middle bottom-left bottom-right bottom) → + (K : f ~ g) → + right-whisker-concat-coherence-square-homotopies + ( top) + ( top-left ∙h bottom-left) + ( top-right ∙h bottom-right) + ( bottom) + ( vertical-pasting-coherence-square-homotopies + ( top) + ( top-left) + ( top-right) + ( middle) + ( bottom-left) + ( bottom-right) + ( bottom) + ( t) + ( b)) + ( K) ∙h + left-whisker-concat-htpy top (assoc-htpy top-right bottom-right K) ~ + vertical-pasting-coherence-square-homotopies + ( top) + ( top-left) + ( top-right) + ( middle) + ( bottom-left) + ( bottom-right ∙h K) + ( bottom ∙h K) + ( t) + ( right-whisker-concat-coherence-square-homotopies + ( middle) + ( bottom-left) + ( bottom-right) + ( bottom) + ( b) + ( K)) + right-whisker-concat-vertical-pasting-coherence-square-homotopies + top top-left top-right middle bottom-left bottom-right bottom t b K x = + right-whisker-concat-vertical-pasting-coherence-square-identifications + ( top x) + ( top-left x) + ( top-right x) + ( middle x) + ( bottom-left x) + ( bottom-right x) + ( bottom x) + ( t x) + ( b x) + ( K x) +``` From 4ea5714cb6c246fc85ea63f1cf6e5df3c29f0563 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Sat, 10 Feb 2024 16:50:27 +0100 Subject: [PATCH 14/53] wip coherently invertible maps --- .../coherently-invertible-maps.lagda.md | 294 +++++++++++++++++- .../commuting-squares-of-homotopies.lagda.md | 18 +- ...muting-squares-of-identifications.lagda.md | 2 +- .../coherently-invertible-maps.lagda.md | 69 ---- 4 files changed, 303 insertions(+), 80 deletions(-) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index b5dd3765e5..5a9e0b3fee 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -14,6 +14,7 @@ open import foundation.universe-levels open import foundation.whiskering-higher-homotopies-composition open import foundation.whiskering-homotopies-composition +open import foundation-core.commuting-squares-of-homotopies open import foundation-core.function-types open import foundation-core.homotopies open import foundation-core.identity-types @@ -336,6 +337,47 @@ module _ ( is-transpose-coherently-invertible-map-transpose-coherently-invertible-map) ``` +### Invertible maps that are coherent are coherently invertible maps + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} {f : A → B} + (H : is-invertible f) + where + + coherence-is-invertible : UU (l1 ⊔ l2) + coherence-is-invertible = + coherence-is-coherently-invertible + ( f) + ( map-inv-is-invertible H) + ( is-section-map-inv-is-invertible H) + ( is-retraction-map-inv-is-invertible H) + + transpose-coherence-is-invertible : UU (l1 ⊔ l2) + transpose-coherence-is-invertible = + coherence-is-transpose-coherently-invertible + ( f) + ( map-inv-is-invertible H) + ( is-section-map-inv-is-invertible H) + ( is-retraction-map-inv-is-invertible H) + + is-coherently-invertible-coherence-is-invertible : + coherence-is-invertible → is-coherently-invertible f + is-coherently-invertible-coherence-is-invertible coh = + ( map-inv-is-invertible H , + is-section-map-inv-is-invertible H , + is-retraction-map-inv-is-invertible H , + coh) + + is-transpose-coherently-invertible-transpose-coherence-is-invertible : + transpose-coherence-is-invertible → is-transpose-coherently-invertible f + is-transpose-coherently-invertible-transpose-coherence-is-invertible coh = + ( map-inv-is-invertible H , + is-section-map-inv-is-invertible H , + is-retraction-map-inv-is-invertible H , + coh) +``` + ## Properties ### Invertible maps are coherently invertible @@ -512,7 +554,7 @@ and retraction of `ap f`. ( is-invertible-ap-is-coherently-invertible) ``` -### Given a coherently invertible map, its inverse is transpose coherently invertible +### The inverse of a coherently invertible map is transpose coherently invertible Of course there is also a converse construction, and since these just move data around, they are strict inverses to one another. @@ -556,6 +598,256 @@ module _ ( e))) ``` +### Coherently invertible maps are coherently invertible in both senses + +This is Lemma 4.2.2 in _Homotopy Type Theory – Univalent Foundations of +Mathematics_. + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} + where + + inv-coh-is-transpose-coherently-invertible-is-coherently-invertible' : + {f : A → B} (H : is-coherently-invertible f) → + ( ( map-inv-is-coherently-invertible H) ·l + ( is-section-map-inv-is-coherently-invertible H) ·r + ( f ∘ map-inv-is-coherently-invertible H)) ~ + ( ( map-inv-is-coherently-invertible H ∘ f) ·l + ( is-retraction-map-inv-is-coherently-invertible H) ·r + ( map-inv-is-coherently-invertible H)) + inv-coh-is-transpose-coherently-invertible-is-coherently-invertible' {f} H = + ( preserves-comp-right-whisker-comp + ( f) + ( map-inv-is-coherently-invertible H) + ( ( map-inv-is-coherently-invertible H) ·l + ( is-section-map-inv-is-coherently-invertible H))) ∙h + ( double-whisker-comp² + ( map-inv-is-coherently-invertible H) + ( coh-is-coherently-invertible H) + ( map-inv-is-coherently-invertible H)) ∙h + ( preserves-comp-left-whisker-comp + ( map-inv-is-coherently-invertible H) + ( f) + ( is-retraction-map-inv-is-coherently-invertible H ·r + map-inv-is-coherently-invertible H)) + + coh-is-transpose-coherently-invertible-is-coherently-invertible' : + {f : A → B} (H : is-coherently-invertible f) → + ( ( map-inv-is-coherently-invertible H ∘ f) ·l + ( is-retraction-map-inv-is-coherently-invertible H) ·r + ( map-inv-is-coherently-invertible H)) ~ + ( ( map-inv-is-coherently-invertible H) ·l + ( is-section-map-inv-is-coherently-invertible H) ·r + ( f ∘ map-inv-is-coherently-invertible H)) + coh-is-transpose-coherently-invertible-is-coherently-invertible' {f} H = + ( inv-preserves-comp-left-whisker-comp + ( map-inv-is-coherently-invertible H) + ( f) + ( ( is-retraction-map-inv-is-coherently-invertible H) ·r + ( map-inv-is-coherently-invertible H))) ∙h + ( double-whisker-comp² + ( map-inv-is-coherently-invertible H) + ( inv-htpy (coh-is-coherently-invertible H)) + ( map-inv-is-coherently-invertible H)) ∙h + ( preserves-comp-right-whisker-comp + ( f) + ( map-inv-is-coherently-invertible H) + ( ( map-inv-is-coherently-invertible H) ·l + ( is-section-map-inv-is-coherently-invertible H))) +``` + +By naturality of `R` we have the commuting square of homotopies + +```text + gfgS + gfgfg -----------------> gfg + | | + | | + Rgfg | (nat-htpy Rg) ·r S | Rg + | | + ∨ ∨ + gfg -------------------> g + gS +``` + +and by naturality of `S` we have + +```text + gfgS + gfgfg -------> gfg + | | + Rgfg | | Rg + ∨ ∨ + gfg ---------> g + gS +``` + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} {f : A → B} + (H : is-transpose-coherently-invertible f) + where + + -- lemma-nat : + -- coherence-square-homotopies + -- ( ( map-inv-is-coherently-invertible H ∘ f ∘ map-inv-is-coherently-invertible H) ·l + -- ( is-section-map-inv-is-coherently-invertible H)) + -- ( ( is-retraction-map-inv-is-coherently-invertible H) ·r + -- ( map-inv-is-coherently-invertible H ∘ f ∘ map-inv-is-coherently-invertible H)) + -- (is-retraction-map-inv-is-coherently-invertible H ·r map-inv-is-coherently-invertible H ) + -- ( map-inv-is-coherently-invertible H ·l is-section-map-inv-is-coherently-invertible H) + -- lemma-nat = + -- nat-htpy + -- ( is-retraction-map-inv-is-coherently-invertible H ·r map-inv-is-coherently-invertible H) ·r + -- ( is-section-map-inv-is-coherently-invertible H) + + lemma-nat1 : + coherence-square-homotopies + ( ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f) ·l + ( is-retraction-map-inv-is-transpose-coherently-invertible H)) + ( ( is-section-map-inv-is-transpose-coherently-invertible H) ·r + ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f)) + ( is-section-map-inv-is-transpose-coherently-invertible H ·r f) + ( f ·l is-retraction-map-inv-is-transpose-coherently-invertible H) + lemma-nat1 = + ( nat-htpy + ( is-section-map-inv-is-transpose-coherently-invertible H ·r f)) ·r + ( is-retraction-map-inv-is-transpose-coherently-invertible H) + + lemma-nat2 : + coherence-square-homotopies + ( ( map-inv-is-transpose-coherently-invertible H ∘ + f ∘ + map-inv-is-transpose-coherently-invertible H) ·l + ( is-section-map-inv-is-transpose-coherently-invertible H)) + ( ( is-retraction-map-inv-is-transpose-coherently-invertible H) ·r + ( map-inv-is-transpose-coherently-invertible H ∘ + f ∘ + map-inv-is-transpose-coherently-invertible H)) + ( map-inv-is-transpose-coherently-invertible H ·l + is-section-map-inv-is-transpose-coherently-invertible H) + ( map-inv-is-transpose-coherently-invertible H ·l + is-section-map-inv-is-transpose-coherently-invertible H) + lemma-nat2 = + concat-left-homotopy-coherence-square-homotopies + ( ( map-inv-is-transpose-coherently-invertible H ∘ + f ∘ + map-inv-is-transpose-coherently-invertible H) ·l + is-section-map-inv-is-transpose-coherently-invertible H) + ( map-inv-is-transpose-coherently-invertible H ·l + is-section-map-inv-is-transpose-coherently-invertible H ·r + ( f ∘ map-inv-is-transpose-coherently-invertible H)) + ( map-inv-is-transpose-coherently-invertible H ·l + is-section-map-inv-is-transpose-coherently-invertible H) + ( map-inv-is-transpose-coherently-invertible H ·l + is-section-map-inv-is-transpose-coherently-invertible H) + ( inv-htpy (coh-is-transpose-coherently-invertible H) ·r + ( f ∘ map-inv-is-transpose-coherently-invertible H)) + ( nat-htpy + ( map-inv-is-transpose-coherently-invertible H ·l + is-section-map-inv-is-transpose-coherently-invertible H) ·r + is-section-map-inv-is-transpose-coherently-invertible H) + + lemma-nat3 : + coherence-square-homotopies + ( ( is-section-map-inv-is-transpose-coherently-invertible H) ·r + ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f)) + ( ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f) ·l + ( is-retraction-map-inv-is-transpose-coherently-invertible H)) + ( is-section-map-inv-is-transpose-coherently-invertible H ·r f) + ( is-section-map-inv-is-transpose-coherently-invertible H ·r f) + lemma-nat3 = + {! nat-htpy (is-section-map-inv-is-transpose-coherently-invertible H ·r f) ·r ? !} + + lemma-nat4 : + coherence-square-homotopies + ( ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f) ·l + is-retraction-map-inv-is-transpose-coherently-invertible H) + {! !} + -- ( ( is-section-map-inv-is-transpose-coherently-invertible H) ·r + -- ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f)) + -- ( ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f) ·l + -- ( is-retraction-map-inv-is-transpose-coherently-invertible H)) + ( is-section-map-inv-is-transpose-coherently-invertible H ·r f) + {! !} + lemma-nat4 = + nat-htpy (is-section-map-inv-is-transpose-coherently-invertible H ·r f) ·r is-retraction-map-inv-is-transpose-coherently-invertible H + + coh-is-coherently-invertible-is-transpose-coherently-invertible : + coherence-is-coherently-invertible + ( f) + ( map-inv-is-transpose-coherently-invertible H) + ( is-section-map-inv-is-transpose-coherently-invertible H) + ( is-retraction-map-inv-is-transpose-coherently-invertible H) + coh-is-coherently-invertible-is-transpose-coherently-invertible = + inv-htpy right-unit-htpy ∙h + concat-bottom-homotopy-coherence-square-homotopies + ( refl-htpy) + ( is-section-map-inv-is-transpose-coherently-invertible H ·r f) + ( f ·l is-retraction-map-inv-is-transpose-coherently-invertible H) + ( _) + ( left-inv-htpy + ( is-section-map-inv-is-transpose-coherently-invertible H ·r f)) + ( concat-top-homotopy-coherence-square-homotopies + ( _) + ( is-section-map-inv-is-transpose-coherently-invertible H ·r f) + ( f ·l is-retraction-map-inv-is-transpose-coherently-invertible H) + ( _) + ( left-inv-htpy + ( is-section-map-inv-is-transpose-coherently-invertible H) ·r + ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f)) + ( horizontal-pasting-coherence-square-homotopies + ( _) + ( ( is-section-map-inv-is-transpose-coherently-invertible H) ·r + ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f)) + ( is-section-map-inv-is-transpose-coherently-invertible H ·r f) + ( ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f) ·l + ( is-retraction-map-inv-is-transpose-coherently-invertible H)) + ( f ·l is-retraction-map-inv-is-transpose-coherently-invertible H) + ( inv-htpy + ( is-section-map-inv-is-transpose-coherently-invertible H ·r f)) + ( is-section-map-inv-is-transpose-coherently-invertible H ·r f) + ( horizontal-inv-coherence-square-homotopies + ( ( is-section-map-inv-is-transpose-coherently-invertible H) ·r + ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f)) + ( ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f) ·l + ( is-retraction-map-inv-is-transpose-coherently-invertible H)) + ( is-section-map-inv-is-transpose-coherently-invertible H ·r f) + ( is-section-map-inv-is-transpose-coherently-invertible H ·r f) + ( lemma-nat3)) + ( inv-htpy lemma-nat1))) +``` + +### The identity map is coherently invertible + +```agda +module _ + {l : Level} {A : UU l} + where + + is-coherently-invertible-id : + is-coherently-invertible (id {A = A}) + is-coherently-invertible-id = + is-coherently-invertible-coherence-is-invertible is-invertible-id refl-htpy + + id-coherently-invertible-map : coherently-invertible-map A A + pr1 id-coherently-invertible-map = id + pr2 id-coherently-invertible-map = is-coherently-invertible-id + + is-transpose-coherently-invertible-id : + is-transpose-coherently-invertible (id {A = A}) + is-transpose-coherently-invertible-id = + is-transpose-coherently-invertible-map-inv-is-coherently-invertible + ( is-coherently-invertible-id) + + id-transpose-coherently-invertible-map : + transpose-coherently-invertible-map A A + pr1 id-transpose-coherently-invertible-map = id + pr2 id-transpose-coherently-invertible-map = + is-transpose-coherently-invertible-id +``` + ## References 1. Univalent Foundations Project, _Homotopy Type Theory – Univalent Foundations diff --git a/src/foundation-core/commuting-squares-of-homotopies.lagda.md b/src/foundation-core/commuting-squares-of-homotopies.lagda.md index 944b6b67c2..9b688ccdc8 100644 --- a/src/foundation-core/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation-core/commuting-squares-of-homotopies.lagda.md @@ -173,13 +173,13 @@ Given a commuting square of homotopies the square of homotopies ```text - bottom - h -------> i - | | - left⁻¹ | | right⁻¹ - ∨ ∨ - f -------> g - top + bottom + h -------> i + | | + left⁻¹ | | right⁻¹ + ∨ ∨ + f -------> g + top ``` commutes. @@ -584,7 +584,7 @@ we may consider four ways of attaching new homotopies to it: top f --------------> g | | - left ∙h H | | right + left ∙h H | | right ∨ ∨ u --------------> i. H⁻¹ ∙h bottom @@ -606,7 +606,7 @@ we may consider four ways of attaching new homotopies to it: commuting square of homotopies ```text - top ∙h H + top ∙h H f --------> u | | left | | H⁻¹ ∙h right diff --git a/src/foundation-core/commuting-squares-of-identifications.lagda.md b/src/foundation-core/commuting-squares-of-identifications.lagda.md index a081bf545f..9066afe521 100644 --- a/src/foundation-core/commuting-squares-of-identifications.lagda.md +++ b/src/foundation-core/commuting-squares-of-identifications.lagda.md @@ -10,12 +10,12 @@ module foundation-core.commuting-squares-of-identifications where open import foundation.action-on-identifications-functions open import foundation.dependent-pair-types open import foundation.universe-levels -open import foundation.whiskering-identifications-concatenation open import foundation-core.function-types open import foundation-core.identity-types open import foundation-core.retractions open import foundation-core.sections +open import foundation-core.whiskering-identifications-concatenation ```
diff --git a/src/foundation/coherently-invertible-maps.lagda.md b/src/foundation/coherently-invertible-maps.lagda.md index cf681a9a75..c0c6c6c1c7 100644 --- a/src/foundation/coherently-invertible-maps.lagda.md +++ b/src/foundation/coherently-invertible-maps.lagda.md @@ -84,75 +84,6 @@ module _ ( is-equiv-is-coherently-invertible) ``` -### Coherently invertible maps are coherently invertible in both senses - -This is Lemma 4.2.2 in _Homotopy Type Theory – Univalent Foundations of -Mathematics_. - -```agda -module _ - {l1 l2 : Level} {A : UU l1} {B : UU l2} - where - - inv-coh-is-transpose-coherently-invertible-is-coherently-invertible' : - {f : A → B} (H : is-coherently-invertible f) → - ( ( map-inv-is-coherently-invertible H) ·l - ( is-section-map-inv-is-coherently-invertible H) ·r - ( f ∘ map-inv-is-coherently-invertible H)) ~ - ( ( map-inv-is-coherently-invertible H ∘ f) ·l - ( is-retraction-map-inv-is-coherently-invertible H) ·r - ( map-inv-is-coherently-invertible H)) - inv-coh-is-transpose-coherently-invertible-is-coherently-invertible' {f} H = - ( preserves-comp-right-whisker-comp - ( f) - ( map-inv-is-coherently-invertible H) - ( ( map-inv-is-coherently-invertible H) ·l - ( is-section-map-inv-is-coherently-invertible H))) ∙h - ( double-whisker-comp² - ( map-inv-is-coherently-invertible H) - ( coh-is-coherently-invertible H) - ( map-inv-is-coherently-invertible H)) ∙h - ( preserves-comp-left-whisker-comp - ( map-inv-is-coherently-invertible H) - ( f) - ( is-retraction-map-inv-is-coherently-invertible H ·r - map-inv-is-coherently-invertible H)) - - coh-is-transpose-coherently-invertible-is-coherently-invertible' : - {f : A → B} (H : is-coherently-invertible f) → - ( ( map-inv-is-coherently-invertible H ∘ f) ·l - ( is-retraction-map-inv-is-coherently-invertible H) ·r - ( map-inv-is-coherently-invertible H)) ~ - ( ( map-inv-is-coherently-invertible H) ·l - ( is-section-map-inv-is-coherently-invertible H) ·r - ( f ∘ map-inv-is-coherently-invertible H)) - coh-is-transpose-coherently-invertible-is-coherently-invertible' {f} H = - ( inv-preserves-comp-left-whisker-comp - ( map-inv-is-coherently-invertible H) - ( f) - ( ( is-retraction-map-inv-is-coherently-invertible H) ·r - ( map-inv-is-coherently-invertible H))) ∙h - ( double-whisker-comp² - ( map-inv-is-coherently-invertible H) - ( inv-htpy (coh-is-coherently-invertible H)) - ( map-inv-is-coherently-invertible H)) ∙h - ( preserves-comp-right-whisker-comp - ( f) - ( map-inv-is-coherently-invertible H) - ( ( map-inv-is-coherently-invertible H) ·l - ( is-section-map-inv-is-coherently-invertible H))) - - coh-is-transpose-coherently-invertible-is-coherently-invertible : - {f : A → B} (H : is-coherently-invertible f) → - coherence-is-transpose-coherently-invertible - ( f) - ( map-inv-is-coherently-invertible H) - ( is-section-map-inv-is-coherently-invertible H) - ( is-retraction-map-inv-is-coherently-invertible H) - coh-is-transpose-coherently-invertible-is-coherently-invertible {f} H = - {! !} -``` - ## References 1. Univalent Foundations Project, _Homotopy Type Theory – Univalent Foundations From 48398e5a1b98bd1b236e98a4ffb2b498a58b86f9 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Sat, 10 Feb 2024 17:04:29 +0100 Subject: [PATCH 15/53] composition of invertible maps --- .../coherently-invertible-maps.lagda.md | 16 +-- src/foundation-core/invertible-maps.lagda.md | 111 ++++++++++++++++-- 2 files changed, 107 insertions(+), 20 deletions(-) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index 5a9e0b3fee..0c92594b36 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -30,12 +30,12 @@ open import foundation-core.whiskering-homotopies-concatenation A [(two-sided) inverse](foundation-core.invertible-maps.md) for a map `f : A → B` is a map `g : B → A` equipped with -[homotopies](foundation-core.homotopies.md) ` f ∘ g ~ id` and `g ∘ f ~ id`. Such -data, however is [structure](foundation.structure.md) on the map `f`, and not -generally a [property](foundation-core.propositions.md). One way to make the -type of inverses into a property is by adding a single coherence condition -between the homotopies of the inverse, asking that the following diagram -commmutes +[homotopies](foundation-core.homotopies.md) ` G : f ∘ g ~ id` and +`H : g ∘ f ~ id`. Such data, however is [structure](foundation.structure.md) on +the map `f`, and not generally a [property](foundation-core.propositions.md). +One way to make the type of inverses into a property is by adding a single +coherence condition between the homotopies of the inverse, asking that the +following diagram commmutes ```text G ·r f @@ -86,7 +86,7 @@ module _ ( λ g → Σ (f ∘ g ~ id) ( λ G → - Σ (g ∘ f ~ id) + Σ ( g ∘ f ~ id) ( λ H → coherence-is-coherently-invertible f g G H))) module _ @@ -214,7 +214,7 @@ module _ is-transpose-coherently-invertible f = Σ ( B → A) ( λ g → - Σ (f ∘ g ~ id) + Σ ( f ∘ g ~ id) ( λ G → Σ (g ∘ f ~ id) ( λ H → coherence-is-transpose-coherently-invertible f g G H))) diff --git a/src/foundation-core/invertible-maps.lagda.md b/src/foundation-core/invertible-maps.lagda.md index 4169e13d85..5cd3b2b04f 100644 --- a/src/foundation-core/invertible-maps.lagda.md +++ b/src/foundation-core/invertible-maps.lagda.md @@ -11,6 +11,7 @@ open import foundation.action-on-identifications-binary-functions open import foundation.action-on-identifications-functions open import foundation.dependent-pair-types open import foundation.universe-levels +open import foundation.whiskering-homotopies-composition open import foundation-core.cartesian-product-types open import foundation-core.function-types @@ -42,11 +43,11 @@ module _ is-inverse f g = ((f ∘ g) ~ id) × ((g ∘ f) ~ id) is-section-is-inverse : - {f : A → B} {g : B → A} → is-inverse f g → (f ∘ g) ~ id + {f : A → B} {g : B → A} → is-inverse f g → f ∘ g ~ id is-section-is-inverse = pr1 is-retraction-is-inverse : - {f : A → B} {g : B → A} → is-inverse f g → (g ∘ f) ~ id + {f : A → B} {g : B → A} → is-inverse f g → g ∘ f ~ id is-retraction-is-inverse = pr2 ``` @@ -118,22 +119,108 @@ module _ ## Properties -### The invertible inverse of an invertible map +### The identity invertible map ```agda module _ - {l1 l2 : Level} {A : UU l1} {B : UU l2} {f : A → B} + {l1 : Level} {A : UU l1} where - inv-is-inverse : {g : B → A} → is-inverse f g → is-inverse g f - pr1 (inv-is-inverse {g} H) = is-retraction-map-inv-is-invertible (g , H) - pr2 (inv-is-inverse {g} H) = is-section-map-inv-is-invertible (g , H) + is-inverse-id : is-inverse id (id {A = A}) + pr1 is-inverse-id = refl-htpy + pr2 is-inverse-id = refl-htpy - inv-is-invertible : - (g : is-invertible f) → is-invertible (map-inv-is-invertible g) - pr1 (inv-is-invertible g) = f - pr2 (inv-is-invertible g) = - inv-is-inverse (is-inverse-map-inv-is-invertible g) + is-invertible-id : is-invertible (id {A = A}) + pr1 is-invertible-id = id + pr2 is-invertible-id = is-inverse-id + + id-invertible-map : invertible-map A A + pr1 id-invertible-map = id + pr2 id-invertible-map = is-invertible-id +``` + +### The inverse of an invertible map + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} + where + + is-inverse-inv-is-inverse : + {f : A → B} {g : B → A} → is-inverse f g → is-inverse g f + pr1 (is-inverse-inv-is-inverse {f} {g} H) = + is-retraction-map-inv-is-invertible (g , H) + pr2 (is-inverse-inv-is-inverse {f} {g} H) = + is-section-map-inv-is-invertible (g , H) + + is-invertible-map-inv-is-invertible : + {f : A → B} (g : is-invertible f) → is-invertible (map-inv-is-invertible g) + pr1 (is-invertible-map-inv-is-invertible {f} g) = f + pr2 (is-invertible-map-inv-is-invertible {f} g) = + is-inverse-inv-is-inverse {f} (is-inverse-map-inv-is-invertible g) + + is-invertible-map-inv-invertible-map : + (f : invertible-map A B) → is-invertible (map-inv-invertible-map f) + is-invertible-map-inv-invertible-map f = + is-invertible-map-inv-is-invertible (is-invertible-map-invertible-map f) + + inv-invertible-map : invertible-map A B → invertible-map B A + pr1 (inv-invertible-map f) = map-inv-invertible-map f + pr2 (inv-invertible-map f) = is-invertible-map-inv-invertible-map f +``` + +### The inversion operation on invertible maps is a strict involution + +The inversion operation on invertible maps a strict involution, where, by strict +involution, we mean that `inv-invertible-map (inv-invertible-map f) ≐ f` +syntactically. This can be observed by the fact that the type-checker accepts +`refl` as proof of this equation. + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} + where + + is-involution-inv-invertible-map : + {f : invertible-map A B} → inv-invertible-map (inv-invertible-map f) = f + is-involution-inv-invertible-map = refl +``` + +### Composition of invertible maps + +```agda +module _ + {l1 l2 l3 : Level} {A : UU l1} {B : UU l2} {C : UU l3} + where + + is-invertible-comp : + (g : B → C) (f : A → B) → + is-invertible g → is-invertible f → is-invertible (g ∘ f) + pr1 (is-invertible-comp g f G F) = + map-inv-is-invertible F ∘ map-inv-is-invertible G + pr1 (pr2 (is-invertible-comp g f G F)) = + is-section-map-section-comp g f + ( section-is-invertible F) + ( section-is-invertible G) + pr2 (pr2 (is-invertible-comp g f G F)) = + is-retraction-map-retraction-comp g f + ( retraction-is-invertible G) + ( retraction-is-invertible F) + + is-invertible-map-comp-invertible-map : + (g : invertible-map B C) (f : invertible-map A B) → + is-invertible (map-invertible-map g ∘ map-invertible-map f) + is-invertible-map-comp-invertible-map g f = + is-invertible-comp + ( map-invertible-map g) + ( map-invertible-map f) + ( is-invertible-map-invertible-map g) + ( is-invertible-map-invertible-map f) + + comp-invertible-map : + invertible-map B C → invertible-map A B → invertible-map A C + pr1 (comp-invertible-map g f) = map-invertible-map g ∘ map-invertible-map f + pr2 (comp-invertible-map g f) = is-invertible-map-comp-invertible-map g f ``` ## See also From f2b57d2076de591bfd82b34a6ca0eb3518472e77 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Sun, 11 Feb 2024 17:30:54 +0100 Subject: [PATCH 16/53] wip Coherently invertible maps are coherently invertible in both senses --- .../coherently-invertible-maps.lagda.md | 421 +++++++++--------- src/foundation-core/invertible-maps.lagda.md | 27 +- ...ing-higher-homotopies-composition.lagda.md | 13 + 3 files changed, 240 insertions(+), 221 deletions(-) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index 0c92594b36..a53bedc0ac 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -30,19 +30,19 @@ open import foundation-core.whiskering-homotopies-concatenation A [(two-sided) inverse](foundation-core.invertible-maps.md) for a map `f : A → B` is a map `g : B → A` equipped with -[homotopies](foundation-core.homotopies.md) ` G : f ∘ g ~ id` and -`H : g ∘ f ~ id`. Such data, however is [structure](foundation.structure.md) on +[homotopies](foundation-core.homotopies.md) ` S : f ∘ g ~ id` and +`R : g ∘ f ~ id`. Such data, however is [structure](foundation.structure.md) on the map `f`, and not generally a [property](foundation-core.propositions.md). One way to make the type of inverses into a property is by adding a single coherence condition between the homotopies of the inverse, asking that the following diagram commmutes ```text - G ·r f + S ·r f ~~~~~~~~~~ f ∘ g ∘ f f. ~~~~~~~~~~ - f ·l H + f ·l R ``` We call such data a @@ -53,11 +53,11 @@ and this additional coherence. There is also the alternative coherence condition we could add ```text - H ·r g + R ·r g ~~~~~~~~~~ g ∘ f ∘ g g. ~~~~~~~~~~ - g ·l G + g ·l S ``` We will colloquially refer to invertible maps equipped with this coherence for @@ -382,26 +382,6 @@ module _ ### Invertible maps are coherently invertible -#### Lemma: A coherence for homotopies to an identity map - -```agda -coh-is-coherently-invertible-id : - {l : Level} {A : UU l} {f : A → A} (H : f ~ id) → H ·r f ~ f ·l H -coh-is-coherently-invertible-id {A = A} {f} H x = - is-injective-concat' - ( H x) - ( ap (concat (H (f x)) x) (inv (ap-id (H x))) ∙ nat-htpy H (H x)) - -inv-coh-is-coherently-invertible-id : - {l : Level} {A : UU l} {f : A → A} (H : f ~ id) → f ·l H ~ H ·r f -inv-coh-is-coherently-invertible-id {A = A} {f} H x = - is-injective-concat' - ( H x) - ( inv (nat-htpy H (H x)) ∙ ap (concat (H (f x)) x) (ap-id (H x))) -``` - -#### The proof that invertible maps are coherently invertible - The construction follows Theorem 4.2.3 in _Homotopy Type Theory – Univalent Foundations of Mathematics_. @@ -450,7 +430,7 @@ module _ ( is-retraction-map-inv-is-invertible H)) ∙h ( left-whisker-comp² ( f) - ( inv-coh-is-coherently-invertible-id + ( inv-htpy-coh-htpy-id ( is-retraction-map-inv-is-invertible H)))) ( is-section-map-inv-is-invertible H ·r f))) @@ -606,72 +586,76 @@ Mathematics_. ```agda module _ {l1 l2 : Level} {A : UU l1} {B : UU l2} + (f : A → B) + (g : B → A) + (S : is-section f g) + (R : is-retraction f g) + (🧘 : coherence-is-coherently-invertible f g S R) where - inv-coh-is-transpose-coherently-invertible-is-coherently-invertible' : - {f : A → B} (H : is-coherently-invertible f) → - ( ( map-inv-is-coherently-invertible H) ·l - ( is-section-map-inv-is-coherently-invertible H) ·r - ( f ∘ map-inv-is-coherently-invertible H)) ~ - ( ( map-inv-is-coherently-invertible H ∘ f) ·l - ( is-retraction-map-inv-is-coherently-invertible H) ·r - ( map-inv-is-coherently-invertible H)) - inv-coh-is-transpose-coherently-invertible-is-coherently-invertible' {f} H = - ( preserves-comp-right-whisker-comp - ( f) - ( map-inv-is-coherently-invertible H) - ( ( map-inv-is-coherently-invertible H) ·l - ( is-section-map-inv-is-coherently-invertible H))) ∙h - ( double-whisker-comp² - ( map-inv-is-coherently-invertible H) - ( coh-is-coherently-invertible H) - ( map-inv-is-coherently-invertible H)) ∙h - ( preserves-comp-left-whisker-comp - ( map-inv-is-coherently-invertible H) - ( f) - ( is-retraction-map-inv-is-coherently-invertible H ·r - map-inv-is-coherently-invertible H)) - - coh-is-transpose-coherently-invertible-is-coherently-invertible' : - {f : A → B} (H : is-coherently-invertible f) → - ( ( map-inv-is-coherently-invertible H ∘ f) ·l - ( is-retraction-map-inv-is-coherently-invertible H) ·r - ( map-inv-is-coherently-invertible H)) ~ - ( ( map-inv-is-coherently-invertible H) ·l - ( is-section-map-inv-is-coherently-invertible H) ·r - ( f ∘ map-inv-is-coherently-invertible H)) - coh-is-transpose-coherently-invertible-is-coherently-invertible' {f} H = - ( inv-preserves-comp-left-whisker-comp - ( map-inv-is-coherently-invertible H) - ( f) - ( ( is-retraction-map-inv-is-coherently-invertible H) ·r - ( map-inv-is-coherently-invertible H))) ∙h - ( double-whisker-comp² - ( map-inv-is-coherently-invertible H) - ( inv-htpy (coh-is-coherently-invertible H)) - ( map-inv-is-coherently-invertible H)) ∙h - ( preserves-comp-right-whisker-comp - ( f) - ( map-inv-is-coherently-invertible H) - ( ( map-inv-is-coherently-invertible H) ·l - ( is-section-map-inv-is-coherently-invertible H))) + inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible' : + g ·l S ·r (f ∘ g) ~ (g ∘ f) ·l R ·r g + inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible' = + ( preserves-comp-right-whisker-comp f g (g ·l S)) ∙h + ( double-whisker-comp² g 🧘 g) ∙h + ( preserves-comp-left-whisker-comp g f (R ·r g)) + + inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible''' : + g ·l S ·r (f ∘ g) ~ R ·r (g ∘ f ∘ g) + inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible''' = + inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible' ∙h + right-whisker-comp² (inv-htpy-coh-htpy-id R) g + + inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible : + g ·l S ~ R ·r g + inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible = + {! right-whisker-comp²' (eq-htpy ) !} + + inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible'' : + (g ∘ f ∘ g) ·l S ~ R ·r (g ∘ f ∘ g) + inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible'' = + ( inv-preserves-comp-left-whisker-comp g (f ∘ g) S) ∙h + ( left-whisker-comp² g (inv-htpy-coh-htpy-id S)) ∙h + ( inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible') ∙h + ( right-whisker-comp² (inv-htpy-coh-htpy-id R) g) + + coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible' : + ((g ∘ f) ·l R ·r g) ~ (g ·l S ·r (f ∘ g)) + coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible' = + ( inv-preserves-comp-left-whisker-comp g f (R ·r g)) ∙h + ( double-whisker-comp² g (inv-htpy 🧘) g) ∙h + ( preserves-comp-right-whisker-comp f g (g ·l S)) ``` -By naturality of `R` we have the commuting square of homotopies +By naturality we have ```text - gfgS - gfgfg -----------------> gfg - | | - | | - Rgfg | (nat-htpy Rg) ·r S | Rg - | | - ∨ ∨ - gfg -------------------> g - gS + gfgS + gfgfg --------------------> gfg + | | + Rgfg | nat-htpy (R ·r g) ·r S | Rg + ∨ ∨ + gfg ----------------------> g + gS ``` -and by naturality of `S` we have +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} + (f : A → B) + (g : B → A) + (S : is-section f g) + (R : is-retraction f g) + where + + naturality-square-is-retraction-is-section : + coherence-square-homotopies + ( (g ∘ f ∘ g) ·l S) + ( R ·r (g ∘ f ∘ g)) + ( R ·r g) + ( g ·l S) + naturality-square-is-retraction-is-section = nat-htpy (R ·r g) ·r S +``` ```text gfgS @@ -680,148 +664,88 @@ and by naturality of `S` we have Rgfg | | Rg ∨ ∨ gfg ---------> g - gS + Rg ``` ```agda module _ - {l1 l2 : Level} {A : UU l1} {B : UU l2} {f : A → B} - (H : is-transpose-coherently-invertible f) + {l1 l2 : Level} {A : UU l1} {B : UU l2} + (f : A → B) + (g : B → A) + (S : is-section f g) + (R : is-retraction f g) + (🧘 : coherence-is-coherently-invertible f g S R) where - -- lemma-nat : - -- coherence-square-homotopies - -- ( ( map-inv-is-coherently-invertible H ∘ f ∘ map-inv-is-coherently-invertible H) ·l - -- ( is-section-map-inv-is-coherently-invertible H)) - -- ( ( is-retraction-map-inv-is-coherently-invertible H) ·r - -- ( map-inv-is-coherently-invertible H ∘ f ∘ map-inv-is-coherently-invertible H)) - -- (is-retraction-map-inv-is-coherently-invertible H ·r map-inv-is-coherently-invertible H ) - -- ( map-inv-is-coherently-invertible H ·l is-section-map-inv-is-coherently-invertible H) - -- lemma-nat = - -- nat-htpy - -- ( is-retraction-map-inv-is-coherently-invertible H ·r map-inv-is-coherently-invertible H) ·r - -- ( is-section-map-inv-is-coherently-invertible H) - - lemma-nat1 : - coherence-square-homotopies - ( ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f) ·l - ( is-retraction-map-inv-is-transpose-coherently-invertible H)) - ( ( is-section-map-inv-is-transpose-coherently-invertible H) ·r - ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f)) - ( is-section-map-inv-is-transpose-coherently-invertible H ·r f) - ( f ·l is-retraction-map-inv-is-transpose-coherently-invertible H) - lemma-nat1 = - ( nat-htpy - ( is-section-map-inv-is-transpose-coherently-invertible H ·r f)) ·r - ( is-retraction-map-inv-is-transpose-coherently-invertible H) - - lemma-nat2 : - coherence-square-homotopies - ( ( map-inv-is-transpose-coherently-invertible H ∘ - f ∘ - map-inv-is-transpose-coherently-invertible H) ·l - ( is-section-map-inv-is-transpose-coherently-invertible H)) - ( ( is-retraction-map-inv-is-transpose-coherently-invertible H) ·r - ( map-inv-is-transpose-coherently-invertible H ∘ - f ∘ - map-inv-is-transpose-coherently-invertible H)) - ( map-inv-is-transpose-coherently-invertible H ·l - is-section-map-inv-is-transpose-coherently-invertible H) - ( map-inv-is-transpose-coherently-invertible H ·l - is-section-map-inv-is-transpose-coherently-invertible H) - lemma-nat2 = - concat-left-homotopy-coherence-square-homotopies - ( ( map-inv-is-transpose-coherently-invertible H ∘ - f ∘ - map-inv-is-transpose-coherently-invertible H) ·l - is-section-map-inv-is-transpose-coherently-invertible H) - ( map-inv-is-transpose-coherently-invertible H ·l - is-section-map-inv-is-transpose-coherently-invertible H ·r - ( f ∘ map-inv-is-transpose-coherently-invertible H)) - ( map-inv-is-transpose-coherently-invertible H ·l - is-section-map-inv-is-transpose-coherently-invertible H) - ( map-inv-is-transpose-coherently-invertible H ·l - is-section-map-inv-is-transpose-coherently-invertible H) - ( inv-htpy (coh-is-transpose-coherently-invertible H) ·r - ( f ∘ map-inv-is-transpose-coherently-invertible H)) - ( nat-htpy - ( map-inv-is-transpose-coherently-invertible H ·l - is-section-map-inv-is-transpose-coherently-invertible H) ·r - is-section-map-inv-is-transpose-coherently-invertible H) - - lemma-nat3 : + naturality-square-is-transpose-coherently-invertible-coherence-is-coherently-invertible : coherence-square-homotopies - ( ( is-section-map-inv-is-transpose-coherently-invertible H) ·r - ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f)) - ( ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f) ·l - ( is-retraction-map-inv-is-transpose-coherently-invertible H)) - ( is-section-map-inv-is-transpose-coherently-invertible H ·r f) - ( is-section-map-inv-is-transpose-coherently-invertible H ·r f) - lemma-nat3 = - {! nat-htpy (is-section-map-inv-is-transpose-coherently-invertible H ·r f) ·r ? !} - - lemma-nat4 : - coherence-square-homotopies - ( ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f) ·l - is-retraction-map-inv-is-transpose-coherently-invertible H) - {! !} - -- ( ( is-section-map-inv-is-transpose-coherently-invertible H) ·r - -- ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f)) - -- ( ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f) ·l - -- ( is-retraction-map-inv-is-transpose-coherently-invertible H)) - ( is-section-map-inv-is-transpose-coherently-invertible H ·r f) - {! !} - lemma-nat4 = - nat-htpy (is-section-map-inv-is-transpose-coherently-invertible H ·r f) ·r is-retraction-map-inv-is-transpose-coherently-invertible H + ( (g ∘ f ∘ g) ·l S) + ( R ·r (g ∘ f ∘ g)) + ( R ·r g) + ( R ·r g) + naturality-square-is-transpose-coherently-invertible-coherence-is-coherently-invertible = + ( ap-concat-htpy + ( R ·r (g ∘ f ∘ g)) + ( inv-htpy (left-unit-law-left-whisker-comp (R ·r g)))) ∙h + ( ( nat-htpy R) ·r (R ·r g)) ∙h + ( ap-concat-htpy' + ( R ·r g) + ( ( inv-preserves-comp-left-whisker-comp g f (R ·r g)) ∙h + ( left-whisker-comp² g (inv-htpy 🧘 ·r g)) ∙h + ( left-whisker-comp² g (coh-htpy-id S)) ∙h + ( preserves-comp-left-whisker-comp g (f ∘ g) S))) +``` - coh-is-coherently-invertible-is-transpose-coherently-invertible : - coherence-is-coherently-invertible - ( f) - ( map-inv-is-transpose-coherently-invertible H) - ( is-section-map-inv-is-transpose-coherently-invertible H) - ( is-retraction-map-inv-is-transpose-coherently-invertible H) - coh-is-coherently-invertible-is-transpose-coherently-invertible = - inv-htpy right-unit-htpy ∙h - concat-bottom-homotopy-coherence-square-homotopies - ( refl-htpy) - ( is-section-map-inv-is-transpose-coherently-invertible H ·r f) - ( f ·l is-retraction-map-inv-is-transpose-coherently-invertible H) - ( _) - ( left-inv-htpy - ( is-section-map-inv-is-transpose-coherently-invertible H ·r f)) - ( concat-top-homotopy-coherence-square-homotopies - ( _) - ( is-section-map-inv-is-transpose-coherently-invertible H ·r f) - ( f ·l is-retraction-map-inv-is-transpose-coherently-invertible H) - ( _) - ( left-inv-htpy - ( is-section-map-inv-is-transpose-coherently-invertible H) ·r - ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f)) - ( horizontal-pasting-coherence-square-homotopies - ( _) - ( ( is-section-map-inv-is-transpose-coherently-invertible H) ·r - ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f)) - ( is-section-map-inv-is-transpose-coherently-invertible H ·r f) - ( ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f) ·l - ( is-retraction-map-inv-is-transpose-coherently-invertible H)) - ( f ·l is-retraction-map-inv-is-transpose-coherently-invertible H) - ( inv-htpy - ( is-section-map-inv-is-transpose-coherently-invertible H ·r f)) - ( is-section-map-inv-is-transpose-coherently-invertible H ·r f) - ( horizontal-inv-coherence-square-homotopies - ( ( is-section-map-inv-is-transpose-coherently-invertible H) ·r - ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f)) - ( ( f ∘ map-inv-is-transpose-coherently-invertible H ∘ f) ·l - ( is-retraction-map-inv-is-transpose-coherently-invertible H)) - ( is-section-map-inv-is-transpose-coherently-invertible H ·r f) - ( is-section-map-inv-is-transpose-coherently-invertible H ·r f) - ( lemma-nat3)) - ( inv-htpy lemma-nat1))) +Pasting the two lemmas along the common edge `gfgS`, + +```text + Rg + gfg ---------> g + ∧ ∧ + Rgfg | | Rg + | | + gfgfg --gfgS-> gfg + | | + Rgfg | | Rg + ∨ ∨ + gfg ---------> g + gS ``` -### The identity map is coherently invertible +or along the common edge `Rgfg` + +```text + gfgS gfgS + gfg <------> gfgfg -------> gfg + | | | + Rg | Rgfg | Rg + ∨ ∨ ∨ + g <--------- gfg ---------> g + Rg gS +``` + +We observe that the left-hand and right-hand side cancel each other out, leaving +us with a homotopy `Rg ~ gS` as desired. ```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} + (f : A → B) + (g : B → A) + (S : is-section f g) + (R : is-retraction f g) + (🧘 : coherence-is-coherently-invertible f g S R) + where + + coherence-is-transpose-coherently-invertible-coherence-is-coherently-invertible : + coherence-is-transpose-coherently-invertible f g S R + coherence-is-transpose-coherently-invertible-coherence-is-coherently-invertible = + {! !} +``` + +### The identity map is coherently invertible + +```text module _ {l : Level} {A : UU l} where @@ -848,6 +772,73 @@ module _ is-transpose-coherently-invertible-id ``` +### Composition of coherently invertible maps + +```text +module _ + {l1 l2 l3 : Level} {A : UU l1} {B : UU l2} {C : UU l3} + (g : B → C) (f : A → B) + (G : is-coherently-invertible g) + (F : is-coherently-invertible f) + where + + coh-is-coherently-invertible-comp : + coherence-is-coherently-invertible + ( g ∘ f) + ( map-inv-is-invertible-comp g f + ( is-invertible-is-coherently-invertible G) + ( is-invertible-is-coherently-invertible F)) + ( is-section-map-inv-is-invertible-comp g f + ( is-invertible-is-coherently-invertible G) + ( is-invertible-is-coherently-invertible F)) + ( is-retraction-map-inv-is-invertible-comp g f + ( is-invertible-is-coherently-invertible G) + ( is-invertible-is-coherently-invertible F)) + coh-is-coherently-invertible-comp = + homotopy-reasoning + ( ( g) ·l + ( is-section-map-inv-is-coherently-invertible F) ·r + ( map-inv-is-coherently-invertible G ∘ g ∘ f)) ∙h + ( is-section-map-inv-is-coherently-invertible G ·r (g ∘ f)) + ~ + ( {! !}) ∙h + ( g ·l is-retraction-map-inv-is-coherently-invertible G ·r f) + by + ap-binary-concat-htpy + ( {! ( g) ·l + ( is-section-map-inv-is-coherently-invertible F) ·r + ( map-inv-is-coherently-invertible G ∘ g ∘ f) !}) + ( coh-is-coherently-invertible G ·r f) + ~ {! !} by {! !} + ~ {! !} by {! !} + ~ {! !} by {! !} + ~ {! !} by {! !} + ~ ( ( ( g ∘ f) ·l + ( map-inv-is-coherently-invertible F ·l + is-retraction-map-inv-is-coherently-invertible G ·r f)) ∙h + ( ( g ∘ f) ·l is-retraction-map-inv-is-coherently-invertible F)) + by {! !} + ~ ( ( g ∘ f) ·l + ( ( map-inv-is-coherently-invertible F ·l + is-retraction-map-inv-is-coherently-invertible G ·r f) ∙h + ( is-retraction-map-inv-is-coherently-invertible F))) + by + inv-htpy + ( distributive-left-whisker-comp-concat + ( g ∘ f) + ( map-inv-is-coherently-invertible F ·l is-retraction-map-inv-is-coherently-invertible G ·r f) + ( is-retraction-map-inv-is-coherently-invertible F)) + + is-coherently-invertible-comp : is-coherently-invertible (g ∘ f) + is-coherently-invertible-comp = + is-coherently-invertible-coherence-is-invertible + ( is-invertible-comp g f + ( is-invertible-is-coherently-invertible G) + ( is-invertible-is-coherently-invertible F)) + {! !} + +``` + ## References 1. Univalent Foundations Project, _Homotopy Type Theory – Univalent Foundations diff --git a/src/foundation-core/invertible-maps.lagda.md b/src/foundation-core/invertible-maps.lagda.md index 5cd3b2b04f..6cdae578cc 100644 --- a/src/foundation-core/invertible-maps.lagda.md +++ b/src/foundation-core/invertible-maps.lagda.md @@ -191,22 +191,37 @@ module _ ```agda module _ {l1 l2 l3 : Level} {A : UU l1} {B : UU l2} {C : UU l3} + (g : B → C) (f : A → B) (G : is-invertible g) (F : is-invertible f) where - is-invertible-comp : - (g : B → C) (f : A → B) → - is-invertible g → is-invertible f → is-invertible (g ∘ f) - pr1 (is-invertible-comp g f G F) = + map-inv-is-invertible-comp : C → A + map-inv-is-invertible-comp = map-inv-is-invertible F ∘ map-inv-is-invertible G - pr1 (pr2 (is-invertible-comp g f G F)) = + + is-section-map-inv-is-invertible-comp : + is-section (g ∘ f) map-inv-is-invertible-comp + is-section-map-inv-is-invertible-comp = is-section-map-section-comp g f ( section-is-invertible F) ( section-is-invertible G) - pr2 (pr2 (is-invertible-comp g f G F)) = + + is-retraction-map-inv-is-invertible-comp : + is-retraction (g ∘ f) map-inv-is-invertible-comp + is-retraction-map-inv-is-invertible-comp = is-retraction-map-retraction-comp g f ( retraction-is-invertible G) ( retraction-is-invertible F) + is-invertible-comp : is-invertible (g ∘ f) + is-invertible-comp = + ( map-inv-is-invertible-comp , + is-section-map-inv-is-invertible-comp , + is-retraction-map-inv-is-invertible-comp) + +module _ + {l1 l2 l3 : Level} {A : UU l1} {B : UU l2} {C : UU l3} + where + is-invertible-map-comp-invertible-map : (g : invertible-map B C) (f : invertible-map A B) → is-invertible (map-invertible-map g ∘ map-invertible-map f) diff --git a/src/foundation/whiskering-higher-homotopies-composition.lagda.md b/src/foundation/whiskering-higher-homotopies-composition.lagda.md index 2970a34a1e..98d1517c8f 100644 --- a/src/foundation/whiskering-higher-homotopies-composition.lagda.md +++ b/src/foundation/whiskering-higher-homotopies-composition.lagda.md @@ -8,10 +8,12 @@ module foundation.whiskering-higher-homotopies-composition where ```agda open import foundation.action-on-identifications-functions +open import foundation-core.transport-along-identifications open import foundation.universe-levels open import foundation.whiskering-homotopies-composition open import foundation-core.homotopies +open import foundation-core.identity-types ```
@@ -81,6 +83,17 @@ module _ right-whisker-comp² α h = α ·r h ``` +```agda +module _ + {l1 l2 l3 : Level} {A : UU l1} {B : UU l2} {C : B → UU l3} + {f g : (y : B) → C y} {H H' : f ~ g} {k k' : A → B} + where + + right-whisker-comp²' : + (K : k = k') → H ·r k ~ H' ·r k → H ·r k' ~ H' ·r k' + right-whisker-comp²' refl β = β +``` + ### Double whiskering higher homotopies ```agda From 4f44e3a45b82b8db2bca82d671c49191c94b2ef8 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Sun, 11 Feb 2024 21:41:52 +0100 Subject: [PATCH 17/53] `coherence-is-transpose-coherently-invertible-coherence-is-coherently-invertible` --- .../coherently-invertible-maps.lagda.md | 112 ++++++++---------- ...ing-higher-homotopies-composition.lagda.md | 11 -- 2 files changed, 50 insertions(+), 73 deletions(-) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index a53bedc0ac..d246cae717 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -580,8 +580,8 @@ module _ ### Coherently invertible maps are coherently invertible in both senses -This is Lemma 4.2.2 in _Homotopy Type Theory – Univalent Foundations of -Mathematics_. +The proof follows Lemma 4.2.2 in _Homotopy Type Theory – Univalent Foundations +of Mathematics_. ```agda module _ @@ -590,41 +590,22 @@ module _ (g : B → A) (S : is-section f g) (R : is-retraction f g) - (🧘 : coherence-is-coherently-invertible f g S R) + (H : coherence-is-coherently-invertible f g S R) where inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible' : g ·l S ·r (f ∘ g) ~ (g ∘ f) ·l R ·r g inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible' = ( preserves-comp-right-whisker-comp f g (g ·l S)) ∙h - ( double-whisker-comp² g 🧘 g) ∙h + ( double-whisker-comp² g H g) ∙h ( preserves-comp-left-whisker-comp g f (R ·r g)) - inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible''' : - g ·l S ·r (f ∘ g) ~ R ·r (g ∘ f ∘ g) - inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible''' = - inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible' ∙h - right-whisker-comp² (inv-htpy-coh-htpy-id R) g - inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible : - g ·l S ~ R ·r g + (g ∘ f ∘ g) ·l S ~ (g ∘ f) ·l R ·r g inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible = - {! right-whisker-comp²' (eq-htpy ) !} - - inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible'' : - (g ∘ f ∘ g) ·l S ~ R ·r (g ∘ f ∘ g) - inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible'' = ( inv-preserves-comp-left-whisker-comp g (f ∘ g) S) ∙h ( left-whisker-comp² g (inv-htpy-coh-htpy-id S)) ∙h - ( inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible') ∙h - ( right-whisker-comp² (inv-htpy-coh-htpy-id R) g) - - coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible' : - ((g ∘ f) ·l R ·r g) ~ (g ·l S ·r (f ∘ g)) - coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible' = - ( inv-preserves-comp-left-whisker-comp g f (R ·r g)) ∙h - ( double-whisker-comp² g (inv-htpy 🧘) g) ∙h - ( preserves-comp-right-whisker-comp f g (g ·l S)) + ( inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible') ``` By naturality we have @@ -658,10 +639,10 @@ module _ ``` ```text - gfgS + Rgfg gfgfg -------> gfg | | - Rgfg | | Rg + Sgfg | | Rg ∨ ∨ gfg ---------> g Rg @@ -674,58 +655,42 @@ module _ (g : B → A) (S : is-section f g) (R : is-retraction f g) - (🧘 : coherence-is-coherently-invertible f g S R) + (H : coherence-is-coherently-invertible f g S R) where naturality-square-is-transpose-coherently-invertible-coherence-is-coherently-invertible : coherence-square-homotopies - ( (g ∘ f ∘ g) ·l S) ( R ·r (g ∘ f ∘ g)) + ( (g ∘ f ∘ g) ·l S) ( R ·r g) ( R ·r g) naturality-square-is-transpose-coherently-invertible-coherence-is-coherently-invertible = - ( ap-concat-htpy - ( R ·r (g ∘ f ∘ g)) - ( inv-htpy (left-unit-law-left-whisker-comp (R ·r g)))) ∙h - ( ( nat-htpy R) ·r (R ·r g)) ∙h ( ap-concat-htpy' ( R ·r g) - ( ( inv-preserves-comp-left-whisker-comp g f (R ·r g)) ∙h - ( left-whisker-comp² g (inv-htpy 🧘 ·r g)) ∙h - ( left-whisker-comp² g (coh-htpy-id S)) ∙h - ( preserves-comp-left-whisker-comp g (f ∘ g) S))) -``` - -Pasting the two lemmas along the common edge `gfgS`, - -```text - Rg - gfg ---------> g - ∧ ∧ - Rgfg | | Rg - | | - gfgfg --gfgS-> gfg - | | - Rgfg | | Rg - ∨ ∨ - gfg ---------> g - gS + ( inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible + ( f) + ( g) + ( S) + ( R) + ( H))) ∙h + (inv-htpy (nat-htpy R ·r (R ·r g))) ∙h + ap-concat-htpy (R ·r (g ∘ f ∘ g)) (left-unit-law-left-whisker-comp (R ·r g)) ``` -or along the common edge `Rgfg` +Pasting the two lemmas along the common edge `Rgfg` ```text - gfgS gfgS - gfg <------> gfgfg -------> gfg + gfgS gfgS + gfg <------- gfgfg -------> gfg | | | Rg | Rgfg | Rg ∨ ∨ ∨ - g <--------- gfg ---------> g + g <--------- gfg ---------> gm Rg gS ``` -We observe that the left-hand and right-hand side cancel each other out, leaving -us with a homotopy `Rg ~ gS` as desired. +we observe that the homotopy `gfgS` at the top cancels itself, as well as the +`Rg` on the left, leaving us with a homotopy `Rg ~ gS` as desired. ```agda module _ @@ -734,18 +699,41 @@ module _ (g : B → A) (S : is-section f g) (R : is-retraction f g) - (🧘 : coherence-is-coherently-invertible f g S R) + (H : coherence-is-coherently-invertible f g S R) where coherence-is-transpose-coherently-invertible-coherence-is-coherently-invertible : coherence-is-transpose-coherently-invertible f g S R coherence-is-transpose-coherently-invertible-coherence-is-coherently-invertible = - {! !} + ( ap-concat-htpy' (R ·r g) (inv-htpy (left-inv-htpy ((g ∘ f ∘ g) ·l S)))) ∙h + ( assoc-htpy (inv-htpy ((g ∘ f ∘ g) ·l S)) (((g ∘ f ∘ g) ·l S)) (R ·r g)) ∙h + ( ap-concat-htpy + ( inv-htpy ((g ∘ f ∘ g) ·l S)) + ( inv-htpy (naturality-square-is-retraction-is-section f g S R))) ∙h + ( inv-htpy + ( assoc-htpy + ( inv-htpy ((g ∘ f ∘ g) ·l S)) + ( R ·r (g ∘ f ∘ g)) + ( g ·l S))) ∙h + ( ap-concat-htpy' + ( g ·l S) + ( ( vertical-inv-coherence-square-homotopies + ( R ·r (g ∘ f ∘ g)) + ( (g ∘ f ∘ g) ·l S) + ( R ·r g) + ( R ·r g) + ( naturality-square-is-transpose-coherently-invertible-coherence-is-coherently-invertible + ( f) + ( g) + ( S) + ( R) + ( H))) ∙h + ( right-inv-htpy (R ·r g)))) ``` ### The identity map is coherently invertible -```text +```agda module _ {l : Level} {A : UU l} where diff --git a/src/foundation/whiskering-higher-homotopies-composition.lagda.md b/src/foundation/whiskering-higher-homotopies-composition.lagda.md index 98d1517c8f..f0793a289b 100644 --- a/src/foundation/whiskering-higher-homotopies-composition.lagda.md +++ b/src/foundation/whiskering-higher-homotopies-composition.lagda.md @@ -83,17 +83,6 @@ module _ right-whisker-comp² α h = α ·r h ``` -```agda -module _ - {l1 l2 l3 : Level} {A : UU l1} {B : UU l2} {C : B → UU l3} - {f g : (y : B) → C y} {H H' : f ~ g} {k k' : A → B} - where - - right-whisker-comp²' : - (K : k = k') → H ·r k ~ H' ·r k → H ·r k' ~ H' ·r k' - right-whisker-comp²' refl β = β -``` - ### Double whiskering higher homotopies ```agda From edb4bf592f40d4c6b55935f8be2955b5564c393c Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Sun, 11 Feb 2024 22:16:27 +0100 Subject: [PATCH 18/53] finish formalizing Coherently invertible maps are coherently invertible in both senses --- .../coherently-invertible-maps.lagda.md | 104 +++++++++++++----- 1 file changed, 77 insertions(+), 27 deletions(-) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index d246cae717..fc8728eae1 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -593,9 +593,9 @@ module _ (H : coherence-is-coherently-invertible f g S R) where - inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible' : + lemma-is-coherently-invertible' : g ·l S ·r (f ∘ g) ~ (g ∘ f) ·l R ·r g - inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible' = + lemma-is-coherently-invertible' = ( preserves-comp-right-whisker-comp f g (g ·l S)) ∙h ( double-whisker-comp² g H g) ∙h ( preserves-comp-left-whisker-comp g f (R ·r g)) @@ -605,7 +605,7 @@ module _ inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible = ( inv-preserves-comp-left-whisker-comp g (f ∘ g) S) ∙h ( left-whisker-comp² g (inv-htpy-coh-htpy-id S)) ∙h - ( inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible') + ( lemma-is-coherently-invertible') ``` By naturality we have @@ -638,6 +638,8 @@ module _ naturality-square-is-retraction-is-section = nat-htpy (R ·r g) ·r S ``` +TODO Explain + ```text Rgfg gfgfg -------> gfg @@ -658,21 +660,17 @@ module _ (H : coherence-is-coherently-invertible f g S R) where - naturality-square-is-transpose-coherently-invertible-coherence-is-coherently-invertible : + naturality-square-transposition-coherence-is-coherently-invertible : coherence-square-homotopies ( R ·r (g ∘ f ∘ g)) ( (g ∘ f ∘ g) ·l S) ( R ·r g) ( R ·r g) - naturality-square-is-transpose-coherently-invertible-coherence-is-coherently-invertible = + naturality-square-transposition-coherence-is-coherently-invertible = ( ap-concat-htpy' ( R ·r g) ( inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible - ( f) - ( g) - ( S) - ( R) - ( H))) ∙h + ( f) (g) (S) (R) (H))) ∙h (inv-htpy (nat-htpy R ·r (R ·r g))) ∙h ap-concat-htpy (R ·r (g ∘ f ∘ g)) (left-unit-law-left-whisker-comp (R ·r g)) ``` @@ -700,37 +698,89 @@ module _ (S : is-section f g) (R : is-retraction f g) (H : coherence-is-coherently-invertible f g S R) - where + where abstract - coherence-is-transpose-coherently-invertible-coherence-is-coherently-invertible : + coherence-transposition-coherence-is-coherently-invertible : coherence-is-transpose-coherently-invertible f g S R - coherence-is-transpose-coherently-invertible-coherence-is-coherently-invertible = + coherence-transposition-coherence-is-coherently-invertible = ( ap-concat-htpy' (R ·r g) (inv-htpy (left-inv-htpy ((g ∘ f ∘ g) ·l S)))) ∙h - ( assoc-htpy (inv-htpy ((g ∘ f ∘ g) ·l S)) (((g ∘ f ∘ g) ·l S)) (R ·r g)) ∙h + ( assoc-htpy (inv-htpy ((g ∘ f ∘ g) ·l S)) ((g ∘ f ∘ g) ·l S) (R ·r g)) ∙h ( ap-concat-htpy ( inv-htpy ((g ∘ f ∘ g) ·l S)) ( inv-htpy (naturality-square-is-retraction-is-section f g S R))) ∙h ( inv-htpy ( assoc-htpy - ( inv-htpy ((g ∘ f ∘ g) ·l S)) - ( R ·r (g ∘ f ∘ g)) - ( g ·l S))) ∙h + ( inv-htpy ((g ∘ f ∘ g) ·l S)) (R ·r (g ∘ f ∘ g)) (g ·l S))) ∙h ( ap-concat-htpy' ( g ·l S) ( ( vertical-inv-coherence-square-homotopies - ( R ·r (g ∘ f ∘ g)) - ( (g ∘ f ∘ g) ·l S) - ( R ·r g) - ( R ·r g) - ( naturality-square-is-transpose-coherently-invertible-coherence-is-coherently-invertible - ( f) - ( g) - ( S) - ( R) - ( H))) ∙h + ( R ·r (g ∘ f ∘ g)) ((g ∘ f ∘ g) ·l S) (R ·r g) (R ·r g) + ( naturality-square-transposition-coherence-is-coherently-invertible + ( f) (g) (S) (R) (H))) ∙h ( right-inv-htpy (R ·r g)))) ``` +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} {f : A → B} + where + + coherence-transposition-is-coherently-invertible : + (H : is-coherently-invertible f) → + coherence-is-transpose-coherently-invertible + ( f) + ( map-inv-is-coherently-invertible H) + ( is-section-map-inv-is-coherently-invertible H) + ( is-retraction-map-inv-is-coherently-invertible H) + coherence-transposition-is-coherently-invertible + ( g , S , R , H) = + coherence-transposition-coherence-is-coherently-invertible + f g S R H + + transposition-is-coherently-invertible : + is-coherently-invertible f → is-transpose-coherently-invertible f + transposition-is-coherently-invertible H = + is-transpose-coherently-invertible-transpose-coherence-is-invertible + ( is-invertible-is-coherently-invertible H) + ( coherence-transposition-is-coherently-invertible H) + +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} {f : A → B} + where + + coherence-transposition-is-transpose-coherently-invertible : + (H : is-transpose-coherently-invertible f) → + coherence-is-coherently-invertible + ( f) + ( map-inv-is-transpose-coherently-invertible H) + ( is-section-map-inv-is-transpose-coherently-invertible H) + ( is-retraction-map-inv-is-transpose-coherently-invertible H) + coherence-transposition-is-transpose-coherently-invertible H = + coherence-transposition-is-coherently-invertible + ( is-coherently-invertible-map-inv-is-transpose-coherently-invertible H) + + transposition-is-transpose-coherently-invertible : + is-transpose-coherently-invertible f → is-coherently-invertible f + transposition-is-transpose-coherently-invertible H = + is-coherently-invertible-coherence-is-invertible + ( is-invertible-is-transpose-coherently-invertible H) + ( coherence-transposition-is-transpose-coherently-invertible H) + +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} + where + + transposition-coherently-invertible-map : + coherently-invertible-map A B → transpose-coherently-invertible-map A B + transposition-coherently-invertible-map (f , H) = + ( f , transposition-is-coherently-invertible H) + + transposition-transpose-coherently-invertible-map : + transpose-coherently-invertible-map A B → coherently-invertible-map A B + transposition-transpose-coherently-invertible-map (f , H) = + ( f , transposition-is-transpose-coherently-invertible H) +``` + ### The identity map is coherently invertible ```agda From 0af72a52620595312e87c0e9b54da1f6002bad9e Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Sun, 11 Feb 2024 22:32:41 +0100 Subject: [PATCH 19/53] Inversion of coherently invertible maps --- .../coherently-invertible-maps.lagda.md | 38 +++++++++++++++++++ 1 file changed, 38 insertions(+) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index fc8728eae1..0709ab3afa 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -781,6 +781,44 @@ module _ ( f , transposition-is-transpose-coherently-invertible H) ``` +### Inversion of coherently invertible maps + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} + where + + is-coherently-invertible-map-inv-is-coherently-invertible : + {f : A → B} (H : is-coherently-invertible f) → + is-coherently-invertible (map-inv-is-coherently-invertible H) + is-coherently-invertible-map-inv-is-coherently-invertible H = + is-coherently-invertible-map-inv-is-transpose-coherently-invertible + ( transposition-is-coherently-invertible H) + + is-transpose-coherently-invertible-map-inv-is-transpose-coherently-invertible : + {f : A → B} (H : is-transpose-coherently-invertible f) → + is-transpose-coherently-invertible + ( map-inv-is-transpose-coherently-invertible H) + is-transpose-coherently-invertible-map-inv-is-transpose-coherently-invertible + H = + transposition-is-coherently-invertible + ( is-coherently-invertible-map-inv-is-transpose-coherently-invertible H) + + inv-coherently-invertible-map : + coherently-invertible-map A B → coherently-invertible-map B A + inv-coherently-invertible-map (f , H) = + ( map-inv-is-coherently-invertible H , + is-coherently-invertible-map-inv-is-coherently-invertible H) + + inv-transpose-coherently-invertible-map : + transpose-coherently-invertible-map A B → + transpose-coherently-invertible-map B A + inv-transpose-coherently-invertible-map (f , H) = + ( map-inv-is-transpose-coherently-invertible H , + is-transpose-coherently-invertible-map-inv-is-transpose-coherently-invertible + ( H)) +``` + ### The identity map is coherently invertible ```agda From 7dd7fc8cb295c1971b22a8f87cb82a880835f0a5 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Sun, 11 Feb 2024 22:52:08 +0100 Subject: [PATCH 20/53] Invertible maps are closed under homotopies --- src/foundation-core/equivalences.lagda.md | 9 ++++----- src/foundation-core/invertible-maps.lagda.md | 18 ++++++++++++++++++ 2 files changed, 22 insertions(+), 5 deletions(-) diff --git a/src/foundation-core/equivalences.lagda.md b/src/foundation-core/equivalences.lagda.md index bd631e0918..08b8af5854 100644 --- a/src/foundation-core/equivalences.lagda.md +++ b/src/foundation-core/equivalences.lagda.md @@ -488,11 +488,10 @@ module _ {f g : A → B} (G : f ~ g) (H : is-equiv f) (K : is-equiv g) → map-inv-is-equiv H ~ map-inv-is-equiv K htpy-map-inv-is-equiv G H K b = - ( inv - ( is-retraction-map-inv-is-equiv K (map-inv-is-equiv H b))) ∙ - ( ap (map-inv-is-equiv K) - ( ( inv (G (map-inv-is-equiv H b))) ∙ - ( is-section-map-inv-is-equiv H b))) + ( inv (is-retraction-map-inv-is-equiv K (map-inv-is-equiv H b))) ∙ + ( ap + ( map-inv-is-equiv K) + ( inv (G (map-inv-is-equiv H b)) ∙ is-section-map-inv-is-equiv H b)) ``` ### Any retraction of an equivalence is an equivalence diff --git a/src/foundation-core/invertible-maps.lagda.md b/src/foundation-core/invertible-maps.lagda.md index 6cdae578cc..ac3ec846aa 100644 --- a/src/foundation-core/invertible-maps.lagda.md +++ b/src/foundation-core/invertible-maps.lagda.md @@ -238,6 +238,24 @@ module _ pr2 (comp-invertible-map g f) = is-invertible-map-comp-invertible-map g f ``` +### Invertible maps are closed under homotopies + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} + where + + is-invertible-htpy : + {f f' : A → B} → f ~ f' → is-invertible f' → is-invertible f + pr1 (is-invertible-htpy H (g , S , R)) = g + pr1 (pr2 (is-invertible-htpy H (g , S , R))) = (H ·r g) ∙h S + pr2 (pr2 (is-invertible-htpy H (g , S , R))) = (g ·l H) ∙h R + + is-invertible-inv-htpy : + {f f' : A → B} → f ~ f' → is-invertible f → is-invertible f' + is-invertible-inv-htpy H = is-invertible-htpy (inv-htpy H) +``` + ## See also - For the coherent notion of invertible maps see From 44ee30ef8420f5c97bda71e852957725d11b997b Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Mon, 12 Feb 2024 12:16:19 +0100 Subject: [PATCH 21/53] `is-coherently-invertible-comp` --- .../coherently-invertible-maps.lagda.md | 61 +++++++++++++++---- src/foundation-core/invertible-maps.lagda.md | 4 +- ...ing-higher-homotopies-composition.lagda.md | 1 - ...iskering-homotopies-concatenation.lagda.md | 2 +- 4 files changed, 52 insertions(+), 16 deletions(-) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index 0709ab3afa..878bb08bd7 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -819,6 +819,20 @@ module _ ( H)) ``` +### Coherently invertible maps are closed under homotopies + +```text +-- module _ +-- {l1 l2 : Level} {A : UU l1} {B : UU l2} {f f' : A → B} (H : f ~ f') +-- where + +-- is-coherently-invertible-htpy : +-- is-coherently-invertible f → is-coherently-invertible f' +-- pr1 (is-coherently-invertible-htpy (g , S , R , C)) = g +-- pr1 (pr2 (is-coherently-invertible-htpy (g , S , R , C))) = {! !} +-- pr2 (pr2 (is-coherently-invertible-htpy (g , S , R , C))) = {! !} +``` + ### The identity map is coherently invertible ```agda @@ -850,7 +864,7 @@ module _ ### Composition of coherently invertible maps -```text +```agda module _ {l1 l2 l3 : Level} {A : UU l1} {B : UU l2} {C : UU l3} (g : B → C) (f : A → B) @@ -858,6 +872,16 @@ module _ (F : is-coherently-invertible f) where + my-lemma' : + ( g ·l ( is-section-map-inv-is-coherently-invertible F) ·r + ( map-inv-is-coherently-invertible G ∘ g)) ∙h + ( g ·l is-retraction-map-inv-is-coherently-invertible G) ~ + ( (g ∘ f ∘ map-inv-is-coherently-invertible F) ·l + ( is-retraction-map-inv-is-coherently-invertible G)) ∙h + ( g ·l is-section-map-inv-is-coherently-invertible F) + my-lemma' = + nat-htpy (g ·l is-section-map-inv-is-coherently-invertible F) ·r (is-retraction-map-inv-is-coherently-invertible G) + coh-is-coherently-invertible-comp : coherence-is-coherently-invertible ( g ∘ f) @@ -877,23 +901,37 @@ module _ ( map-inv-is-coherently-invertible G ∘ g ∘ f)) ∙h ( is-section-map-inv-is-coherently-invertible G ·r (g ∘ f)) ~ - ( {! !}) ∙h + ( ( g) ·l + ( is-section-map-inv-is-coherently-invertible F) ·r + ( map-inv-is-coherently-invertible G ∘ g ∘ f)) ∙h ( g ·l is-retraction-map-inv-is-coherently-invertible G ·r f) by - ap-binary-concat-htpy - ( {! ( g) ·l + ap-concat-htpy + ( ( g) ·l ( is-section-map-inv-is-coherently-invertible F) ·r - ( map-inv-is-coherently-invertible G ∘ g ∘ f) !}) + ( map-inv-is-coherently-invertible G ∘ g ∘ f)) ( coh-is-coherently-invertible G ·r f) - ~ {! !} by {! !} - ~ {! !} by {! !} - ~ {! !} by {! !} - ~ {! !} by {! !} + ~ + ( ( g ∘ f ∘ map-inv-is-coherently-invertible F) ·l + ( is-retraction-map-inv-is-coherently-invertible G) ·r + ( f)) ∙h + ( g ·l is-section-map-inv-is-coherently-invertible F ·r f) + by + right-whisker-comp² my-lemma' f ~ ( ( ( g ∘ f) ·l ( map-inv-is-coherently-invertible F ·l is-retraction-map-inv-is-coherently-invertible G ·r f)) ∙h ( ( g ∘ f) ·l is-retraction-map-inv-is-coherently-invertible F)) - by {! !} + by + ap-binary-concat-htpy + ( inv-htpy + ( preserves-comp-left-whisker-comp + ( g ∘ f) + ( map-inv-is-coherently-invertible F) + ( is-retraction-map-inv-is-coherently-invertible G ·r f))) + ( ( left-whisker-comp² g (coh-is-coherently-invertible F)) ∙h + ( preserves-comp-left-whisker-comp g f + ( is-retraction-map-inv-is-coherently-invertible F))) ~ ( ( g ∘ f) ·l ( ( map-inv-is-coherently-invertible F ·l is-retraction-map-inv-is-coherently-invertible G ·r f) ∙h @@ -911,8 +949,7 @@ module _ ( is-invertible-comp g f ( is-invertible-is-coherently-invertible G) ( is-invertible-is-coherently-invertible F)) - {! !} - + ( coh-is-coherently-invertible-comp) ``` ## References diff --git a/src/foundation-core/invertible-maps.lagda.md b/src/foundation-core/invertible-maps.lagda.md index ac3ec846aa..fa38fcdb68 100644 --- a/src/foundation-core/invertible-maps.lagda.md +++ b/src/foundation-core/invertible-maps.lagda.md @@ -171,8 +171,8 @@ module _ ### The inversion operation on invertible maps is a strict involution -The inversion operation on invertible maps a strict involution, where, by strict -involution, we mean that `inv-invertible-map (inv-invertible-map f) ≐ f` +The inversion operation on invertible maps is a strict involution, where, by +strict involution, we mean that `inv-invertible-map (inv-invertible-map f) ≐ f` syntactically. This can be observed by the fact that the type-checker accepts `refl` as proof of this equation. diff --git a/src/foundation/whiskering-higher-homotopies-composition.lagda.md b/src/foundation/whiskering-higher-homotopies-composition.lagda.md index f0793a289b..68f4e6a54f 100644 --- a/src/foundation/whiskering-higher-homotopies-composition.lagda.md +++ b/src/foundation/whiskering-higher-homotopies-composition.lagda.md @@ -8,7 +8,6 @@ module foundation.whiskering-higher-homotopies-composition where ```agda open import foundation.action-on-identifications-functions -open import foundation-core.transport-along-identifications open import foundation.universe-levels open import foundation.whiskering-homotopies-composition diff --git a/src/foundation/whiskering-homotopies-concatenation.lagda.md b/src/foundation/whiskering-homotopies-concatenation.lagda.md index 4af4983d5f..7df3b7f2ff 100644 --- a/src/foundation/whiskering-homotopies-concatenation.lagda.md +++ b/src/foundation/whiskering-homotopies-concatenation.lagda.md @@ -34,7 +34,7 @@ of homotopies with respect to concatenation is a ``` Similarly, we introduce -{{#concept "right whiskering" Disambiguation="homotopies with respect to concatenation' Agda=right-whisker-concat-htpy}} +{{#concept "right whiskering" Disambiguation="homotopies with respect to concatenation" Agda=right-whisker-concat-htpy}} to be an operation ```text From b5eef37548cfaaa56309d8d40b68200a0c1ee66a Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Mon, 12 Feb 2024 14:10:34 +0100 Subject: [PATCH 22/53] clean up Composition of coherently invertible maps --- .../coherently-invertible-maps.lagda.md | 143 ++++++++++-------- 1 file changed, 81 insertions(+), 62 deletions(-) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index 878bb08bd7..61815d3ee4 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -846,8 +846,8 @@ module _ is-coherently-invertible-coherence-is-invertible is-invertible-id refl-htpy id-coherently-invertible-map : coherently-invertible-map A A - pr1 id-coherently-invertible-map = id - pr2 id-coherently-invertible-map = is-coherently-invertible-id + id-coherently-invertible-map = + ( id , is-coherently-invertible-id) is-transpose-coherently-invertible-id : is-transpose-coherently-invertible (id {A = A}) @@ -857,9 +857,8 @@ module _ id-transpose-coherently-invertible-map : transpose-coherently-invertible-map A A - pr1 id-transpose-coherently-invertible-map = id - pr2 id-transpose-coherently-invertible-map = - is-transpose-coherently-invertible-id + id-transpose-coherently-invertible-map = + ( id , is-transpose-coherently-invertible-id) ``` ### Composition of coherently invertible maps @@ -872,16 +871,6 @@ module _ (F : is-coherently-invertible f) where - my-lemma' : - ( g ·l ( is-section-map-inv-is-coherently-invertible F) ·r - ( map-inv-is-coherently-invertible G ∘ g)) ∙h - ( g ·l is-retraction-map-inv-is-coherently-invertible G) ~ - ( (g ∘ f ∘ map-inv-is-coherently-invertible F) ·l - ( is-retraction-map-inv-is-coherently-invertible G)) ∙h - ( g ·l is-section-map-inv-is-coherently-invertible F) - my-lemma' = - nat-htpy (g ·l is-section-map-inv-is-coherently-invertible F) ·r (is-retraction-map-inv-is-coherently-invertible G) - coh-is-coherently-invertible-comp : coherence-is-coherently-invertible ( g ∘ f) @@ -895,53 +884,30 @@ module _ ( is-invertible-is-coherently-invertible G) ( is-invertible-is-coherently-invertible F)) coh-is-coherently-invertible-comp = - homotopy-reasoning - ( ( g) ·l - ( is-section-map-inv-is-coherently-invertible F) ·r - ( map-inv-is-coherently-invertible G ∘ g ∘ f)) ∙h - ( is-section-map-inv-is-coherently-invertible G ·r (g ∘ f)) - ~ - ( ( g) ·l - ( is-section-map-inv-is-coherently-invertible F) ·r - ( map-inv-is-coherently-invertible G ∘ g ∘ f)) ∙h - ( g ·l is-retraction-map-inv-is-coherently-invertible G ·r f) - by - ap-concat-htpy - ( ( g) ·l - ( is-section-map-inv-is-coherently-invertible F) ·r - ( map-inv-is-coherently-invertible G ∘ g ∘ f)) - ( coh-is-coherently-invertible G ·r f) - ~ - ( ( g ∘ f ∘ map-inv-is-coherently-invertible F) ·l - ( is-retraction-map-inv-is-coherently-invertible G) ·r - ( f)) ∙h - ( g ·l is-section-map-inv-is-coherently-invertible F ·r f) - by - right-whisker-comp² my-lemma' f - ~ ( ( ( g ∘ f) ·l - ( map-inv-is-coherently-invertible F ·l - is-retraction-map-inv-is-coherently-invertible G ·r f)) ∙h - ( ( g ∘ f) ·l is-retraction-map-inv-is-coherently-invertible F)) - by - ap-binary-concat-htpy - ( inv-htpy - ( preserves-comp-left-whisker-comp - ( g ∘ f) - ( map-inv-is-coherently-invertible F) - ( is-retraction-map-inv-is-coherently-invertible G ·r f))) - ( ( left-whisker-comp² g (coh-is-coherently-invertible F)) ∙h - ( preserves-comp-left-whisker-comp g f - ( is-retraction-map-inv-is-coherently-invertible F))) - ~ ( ( g ∘ f) ·l - ( ( map-inv-is-coherently-invertible F ·l - is-retraction-map-inv-is-coherently-invertible G ·r f) ∙h - ( is-retraction-map-inv-is-coherently-invertible F))) - by - inv-htpy - ( distributive-left-whisker-comp-concat - ( g ∘ f) - ( map-inv-is-coherently-invertible F ·l is-retraction-map-inv-is-coherently-invertible G ·r f) - ( is-retraction-map-inv-is-coherently-invertible F)) + ( ap-concat-htpy + ( ( g) ·l + ( is-section-map-inv-is-coherently-invertible F) ·r + ( map-inv-is-coherently-invertible G ∘ g ∘ f)) + ( coh-is-coherently-invertible G ·r f)) ∙h + ( right-whisker-comp² + ( ( nat-htpy (g ·l is-section-map-inv-is-coherently-invertible F)) ·r + ( is-retraction-map-inv-is-coherently-invertible G)) + ( f)) ∙h + ( ap-binary-concat-htpy + ( inv-htpy + ( preserves-comp-left-whisker-comp + ( g ∘ f) + ( map-inv-is-coherently-invertible F) + ( is-retraction-map-inv-is-coherently-invertible G ·r f))) + ( ( left-whisker-comp² g (coh-is-coherently-invertible F)) ∙h + ( preserves-comp-left-whisker-comp g f + ( is-retraction-map-inv-is-coherently-invertible F)))) ∙h + ( inv-htpy + ( distributive-left-whisker-comp-concat + ( g ∘ f) + ( ( map-inv-is-coherently-invertible F) ·l + ( is-retraction-map-inv-is-coherently-invertible G ·r f)) + ( is-retraction-map-inv-is-coherently-invertible F))) is-coherently-invertible-comp : is-coherently-invertible (g ∘ f) is-coherently-invertible-comp = @@ -950,6 +916,59 @@ module _ ( is-invertible-is-coherently-invertible G) ( is-invertible-is-coherently-invertible F)) ( coh-is-coherently-invertible-comp) + +module _ + {l1 l2 l3 : Level} {A : UU l1} {B : UU l2} {C : UU l3} + (g : B → C) (f : A → B) + (G : is-transpose-coherently-invertible g) + (F : is-transpose-coherently-invertible f) + where + + coh-is-transpose-coherently-invertible-comp : + coherence-is-transpose-coherently-invertible + ( g ∘ f) + ( map-inv-is-invertible-comp g f + ( is-invertible-is-transpose-coherently-invertible G) + ( is-invertible-is-transpose-coherently-invertible F)) + ( is-section-map-inv-is-invertible-comp g f + ( is-invertible-is-transpose-coherently-invertible G) + ( is-invertible-is-transpose-coherently-invertible F)) + ( is-retraction-map-inv-is-invertible-comp g f + ( is-invertible-is-transpose-coherently-invertible G) + ( is-invertible-is-transpose-coherently-invertible F)) + coh-is-transpose-coherently-invertible-comp = + coh-is-coherently-invertible-comp + ( map-inv-is-transpose-coherently-invertible F) + ( map-inv-is-transpose-coherently-invertible G) + ( is-coherently-invertible-map-inv-is-transpose-coherently-invertible F) + ( is-coherently-invertible-map-inv-is-transpose-coherently-invertible G) + + is-transpose-coherently-invertible-comp : + is-transpose-coherently-invertible (g ∘ f) + is-transpose-coherently-invertible-comp = + is-transpose-coherently-invertible-transpose-coherence-is-invertible + ( is-invertible-comp g f + ( is-invertible-is-transpose-coherently-invertible G) + ( is-invertible-is-transpose-coherently-invertible F)) + ( coh-is-transpose-coherently-invertible-comp) + +module _ + {l1 l2 l3 : Level} {A : UU l1} {B : UU l2} {C : UU l3} + where + + comp-coherently-invertible-map : + coherently-invertible-map B C → + coherently-invertible-map A B → + coherently-invertible-map A C + comp-coherently-invertible-map (g , G) (f , F) = + ( g ∘ f , is-coherently-invertible-comp g f G F) + + comp-transpose-coherently-invertible-map : + transpose-coherently-invertible-map B C → + transpose-coherently-invertible-map A B → + transpose-coherently-invertible-map A C + comp-transpose-coherently-invertible-map (g , G) (f , F) = + ( g ∘ f , is-transpose-coherently-invertible-comp g f G F) ``` ## References From f6c096a43b99e6d38bfd865fac5279768d8697a7 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Mon, 12 Feb 2024 15:03:41 +0100 Subject: [PATCH 23/53] `foundation.commuting-squares-of-homotopies` --- .../commuting-squares-of-homotopies.lagda.md | 53 +- ...muting-squares-of-identifications.lagda.md | 31 + src/foundation-core/homotopies.lagda.md | 6 +- .../commuting-squares-of-homotopies.lagda.md | 642 ++++++++++++------ ...muting-squares-of-identifications.lagda.md | 9 +- 5 files changed, 539 insertions(+), 202 deletions(-) diff --git a/src/foundation-core/commuting-squares-of-homotopies.lagda.md b/src/foundation-core/commuting-squares-of-homotopies.lagda.md index 9b688ccdc8..4c95f639c7 100644 --- a/src/foundation-core/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation-core/commuting-squares-of-homotopies.lagda.md @@ -256,6 +256,27 @@ module _ ( H x) ``` +Similarly we may whisker it on the right. + +```agda +module _ + {l1 l2 l3 : Level} {A : UU l1} {B : UU l2} {C : B → UU l3} + {f g h i : (y : B) → C y} + where + + right-whisker-comp-coherence-square-homotopies : + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) → + (F : A → B) → + coherence-square-homotopies top left right bottom → + coherence-square-homotopies + ( top ·r F) + ( left ·r F) + ( right ·r F) + ( bottom ·r F) + right-whisker-comp-coherence-square-homotopies top left right bottom F α = + α ·r F +``` + ### Concatenating homotopies of edges and coherences of commuting squares of homotopies Consider a commuting square of homotopies and a homotopy of one of the four @@ -265,7 +286,7 @@ sides with another homotopy, as for example in the diagram below: top a ---------> b | | | - left | right |=| right' + left | right |~| right' ∨ ∨ ∨ c ---------> d. bottom @@ -736,6 +757,36 @@ module _ ( coh x) ``` +### Double whiskering of commuting squares of homotopies + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h u v i : (x : A) → B x} + where + + double-whisker-coherence-square-homotopies : + (p : f ~ g) + (top : g ~ u) (left : g ~ h) (right : u ~ v) (bottom : h ~ v) + (s : v ~ i) → + coherence-square-homotopies top left right bottom → + coherence-square-homotopies + ( p ∙h top) + ( p ∙h left) + ( right ∙h s) + ( bottom ∙h s) + double-whisker-coherence-square-homotopies p top left right bottom q H = + left-whisker-concat-coherence-square-homotopies p top left + ( right ∙h q) + ( bottom ∙h q) + ( right-whisker-concat-coherence-square-homotopies + ( top) + ( left) + ( right) + ( bottom) + ( H) + ( q)) +``` + #### Left splicing coherences of commuting squares of homotopies For any inverse pair of homotopies `H : g ~ u` and `K : u ~ g` equipped with diff --git a/src/foundation-core/commuting-squares-of-identifications.lagda.md b/src/foundation-core/commuting-squares-of-identifications.lagda.md index 9066afe521..19c3bd6317 100644 --- a/src/foundation-core/commuting-squares-of-identifications.lagda.md +++ b/src/foundation-core/commuting-squares-of-identifications.lagda.md @@ -720,6 +720,37 @@ module _ ( inv right-unit)) ``` +### Double whiskering of commuting squares of identifications + +```agda +module _ + {l : Level} {A : UU l} {x y z u v w : A} + where + + double-whisker-coherence-square-identifications : + (p : x = y) + (top : y = u) (left : y = z) (right : u = v) (bottom : z = v) + (s : v = w) → + coherence-square-identifications top left right bottom → + coherence-square-identifications + ( p ∙ top) + ( p ∙ left) + ( right ∙ s) + ( bottom ∙ s) + double-whisker-coherence-square-identifications + p top left right bottom q H = + left-whisker-concat-coherence-square-identifications p top left + ( right ∙ q) + ( bottom ∙ q) + ( right-whisker-concat-coherence-square-identifications + ( top) + ( left) + ( right) + ( bottom) + ( H) + ( q)) +``` + #### Left splicing coherences of commuting squares of identifications For any inverse pair of identifications `p : y = u` and `q : u = y` equipped diff --git a/src/foundation-core/homotopies.lagda.md b/src/foundation-core/homotopies.lagda.md index 94c20ef65d..9c53f25ce0 100644 --- a/src/foundation-core/homotopies.lagda.md +++ b/src/foundation-core/homotopies.lagda.md @@ -253,11 +253,11 @@ identification `p : x = y` in `A`, we have a ```text ap f p - f x -------- f y + f x -------> f y | | H x | | H y - | | - g x -------- g y. + ∨ ∨ + g x -------> g y. ap g p ``` diff --git a/src/foundation/commuting-squares-of-homotopies.lagda.md b/src/foundation/commuting-squares-of-homotopies.lagda.md index 1f8d3730f8..ce4fbf4e35 100644 --- a/src/foundation/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation/commuting-squares-of-homotopies.lagda.md @@ -9,285 +9,539 @@ open import foundation-core.commuting-squares-of-homotopies public
Imports ```agda +open import foundation.action-on-homotopies-functions open import foundation.commuting-squares-of-identifications -open import foundation.functoriality-dependent-function-types +open import foundation.dependent-pair-types open import foundation.universe-levels -open import foundation.whiskering-homotopies-composition open import foundation-core.equivalences +open import foundation-core.function-types +open import foundation-core.functoriality-dependent-function-types open import foundation-core.homotopies +open import foundation-core.identity-types +open import foundation-core.retractions +open import foundation-core.sections ```
## Idea -A square of [homotopies](foundation-core.homotopies.md) +A square of [homotopies](foundation-core.identity-types.md) ```text - top - f ------> g - | | - left | | right - v v - h ------> i - bottom + top + f -------> g + | | + left | | right + ∨ ∨ + h -------> i + bottom ``` -is said to be a {{#concept "commuting square" Disambiguation="homotopies"}} of -homotopies if there is a homotopy `left ∙h bottom ~ top ∙h right `. Such a -homotopy is called a +is said to be a +{{#concept "commuting square" Disambiguation="homotopies" Agda=coherence-square-homotopies}} +if there is a homotopy `left ∙h bottom ~ top ∙h right`. Such a homotopy is +called a {{#concept "coherence" Disambiguation="commuting square of homotopies" Agda=coherence-square-homotopies}} of the square. -### Right whiskering a commuting square of homotopies with respect to concatenation of homotopies +### Concatenating homotopies of edges and coherences of commuting squares of homotopies -Consider a -[commuting square of homotopies](foundation.commuting-squares-of-homotopies.md) +Consider a commuting square of homotopies and a homotopy of one of the four +sides with another homotopy, as for example in the diagram below: ```text - top - f ------> g - | | - left | | right - v v - h ------> i - bottom + top + a ---------> b + | | | + left | right |~| right' + ∨ ∨ ∨ + c ---------> d. + bottom ``` -and consider a homotopy `H : i ~ j`. Then there is an equivalence of commuting -squares of homotopies +Then any homotopy witnessing that the square commutes can be concatenated with +the homotopy on the side, to obtain a new commuting square of homotopies. + +#### Concatenating homotopies of the top edge with a coherence of a commuting square of homotopies + +Consider a commuting diagram of homotopies ```text - top top - f ------> g f -------------> g - | | | | - left | | right ≃ left | | right ∙h H - ∨ ∨ ∨ ∨ - h ------> i h -------------> j - bottom bottom ∙h H + top' + -------> + f -------> g + | top | + left | | right + ∨ ∨ + h -------> i. + bottom ``` -This is the -{{#concept "right whiskering" Disambiguation="commuting squares of homotopies with respect to concatenation" Agda=right-whisker-concat-coherence-square-homotopies}} -operation of commuting squares of homotopies with respect to concatenation. +with a homotopy `top ~ top'`. Then we get an equivalence + +```text + top top' + f -------> g f -------> g + | | | | + left | | right ≃ left | | right + ∨ ∨ ∨ ∨ + h -------> i h -------> i. + bottom bottom +``` ```agda module _ - { l1 l2 : Level} {A : UU l1} {B : UU l2} - { f g g' h k : A → B} - ( H : f ~ g) (H' : f ~ g') {K : g ~ h} {K' : g' ~ h} (L : h ~ k) + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) + {top' : f ~ g} (s : top ~ top') where - equiv-right-whisker-concat-coherence-square-homotopies : - coherence-square-homotopies H H' K K' ≃ - coherence-square-homotopies H H' (K ∙h L) (K' ∙h L) - equiv-right-whisker-concat-coherence-square-homotopies = - equiv-Π-equiv-family - ( λ a → - equiv-right-whisker-concat-coherence-square-identifications - ( H a) - ( H' a) - ( K a) - ( K' a) - ( L a)) - - right-whisker-concat-coherence-square-homotopies : - coherence-square-homotopies H H' K K' → - coherence-square-homotopies H H' (K ∙h L) (K' ∙h L) - right-whisker-concat-coherence-square-homotopies = - map-equiv equiv-right-whisker-concat-coherence-square-homotopies - - right-unwhisker-concat-htpy-coherence-square-homotopies : - coherence-square-homotopies H H' (K ∙h L) (K' ∙h L) → - coherence-square-homotopies H H' K K' - right-unwhisker-concat-htpy-coherence-square-homotopies = - map-inv-equiv equiv-right-whisker-concat-coherence-square-homotopies + abstract + is-equiv-concat-top-homotopy-coherence-square-homotopies : + is-equiv + ( concat-top-homotopy-coherence-square-homotopies + top left right bottom s) + is-equiv-concat-top-homotopy-coherence-square-homotopies = + is-equiv-map-Π-is-fiberwise-equiv + ( λ x → + is-equiv-concat-top-identification-coherence-square-identifications + ( top x) (left x) (right x) (bottom x) (s x)) + + equiv-concat-top-homotopy-coherence-square-homotopies : + coherence-square-homotopies top left right bottom ≃ + coherence-square-homotopies top' left right bottom + pr1 equiv-concat-top-homotopy-coherence-square-homotopies = + concat-top-homotopy-coherence-square-homotopies top left right bottom s + pr2 equiv-concat-top-homotopy-coherence-square-homotopies = + is-equiv-concat-top-homotopy-coherence-square-homotopies ``` -### Left whiskering a commuting square of homotopies with respect to concatenation of homotopies +#### Concatenating homotopies of the left edge with a coherence of a commuting square of homotopies + +Consider a commuting diagram of homotopies + +```text + top + f -------> g + | | | + left' | | left | right + ∨ ∨ ∨ + h -------> i. + bottom +``` -Consider a -[commuting square of homotopies](foundation.commuting-squares-of-homotopies.md) +with a homotopy `left ~ left'`. Then we get an equivalence ```text - top - f ------> g - | | - left | | right - v v - h ------> i - bottom + top top + f -------> g f -------> g + | | | | + left | | right ≃ left' | | right + ∨ ∨ ∨ ∨ + h -------> i h -------> i. + bottom bottom ``` -and consider a homotopy `H : e ~ f`. Then there is an equivalence of commuting -squares of homotopies +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) + {left' : f ~ h} (s : left ~ left') + where + + abstract + is-equiv-concat-left-homotopy-coherence-square-homotopies : + is-equiv + ( concat-left-homotopy-coherence-square-homotopies + top left right bottom s) + is-equiv-concat-left-homotopy-coherence-square-homotopies = + is-equiv-map-Π-is-fiberwise-equiv + ( λ x → + is-equiv-concat-left-identification-coherence-square-identifications + ( top x) (left x) (right x) (bottom x) (s x)) + + equiv-concat-left-homotopy-coherence-square-homotopies : + coherence-square-homotopies top left right bottom ≃ + coherence-square-homotopies top left' right bottom + pr1 equiv-concat-left-homotopy-coherence-square-homotopies = + concat-left-homotopy-coherence-square-homotopies top left right bottom s + pr2 equiv-concat-left-homotopy-coherence-square-homotopies = + is-equiv-concat-left-homotopy-coherence-square-homotopies +``` + +#### Concatenating homotopies of the right edge with a coherence of a commuting square of homotopies + +Consider a commuting diagram of homotopies ```text - top H ∙h top - f ------> g e ----------> g - | | | | - left | | right ≃ H ∙h left | | right - ∨ ∨ ∨ ∨ - h ------> i h ----------> i - bottom bottom + top + f -------> g + | | | + left | right | | right' + ∨ ∨ ∨ + h -------> i. + bottom ``` -This is the -{{#concept "left whiskering" Disambiguation="commuting squares of homotopies with respect to concatenation" Agda=left-whisker-concat-coherence-square-homotopies}} -operation of commuting squares of homotopies with respect to concatenation. +with a homotopy `right ~ right'`. Then we get an equivalence + +```text + top top + f -------> g f -------> g + | | | | + left | | right ≃ left | | right' + ∨ ∨ ∨ ∨ + h -------> i h -------> i. + bottom bottom +``` ```agda module _ - { l1 l2 : Level} {A : UU l1} {B : UU l2} - { f g g' h k : A → B} - ( L : k ~ f) {H : f ~ g} {H' : f ~ g'} {K : g ~ h} {K' : g' ~ h} + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) + {right' : g ~ i} (s : right ~ right') where - equiv-left-whisker-concat-coherence-square-homotopies : - ( coherence-square-homotopies H H' K K') ≃ - ( coherence-square-homotopies (L ∙h H) (L ∙h H') K K') - equiv-left-whisker-concat-coherence-square-homotopies = - equiv-Π-equiv-family - ( λ a → - equiv-left-whisker-concat-coherence-square-identifications - ( L a) - ( H a) - ( H' a) - ( K a) - ( K' a)) - - left-whisker-concat-coherence-square-homotopies : - coherence-square-homotopies H H' K K' → - coherence-square-homotopies (L ∙h H) (L ∙h H') K K' - left-whisker-concat-coherence-square-homotopies = - map-equiv equiv-left-whisker-concat-coherence-square-homotopies - - left-unwhisker-concat-htpy-coherence-square-homotopies : - coherence-square-homotopies (L ∙h H) (L ∙h H') K K' → - coherence-square-homotopies H H' K K' - left-unwhisker-concat-htpy-coherence-square-homotopies = - map-inv-equiv equiv-left-whisker-concat-coherence-square-homotopies + abstract + is-equiv-concat-right-homotopy-coherence-square-homotopies : + is-equiv + ( concat-right-homotopy-coherence-square-homotopies + top left right bottom s) + is-equiv-concat-right-homotopy-coherence-square-homotopies = + is-equiv-map-Π-is-fiberwise-equiv + ( λ x → + is-equiv-concat-right-identification-coherence-square-identifications + ( top x) (left x) (right x) (bottom x) (s x)) + + equiv-concat-right-homotopy-coherence-square-homotopies : + coherence-square-homotopies top left right bottom ≃ + coherence-square-homotopies top left right' bottom + pr1 equiv-concat-right-homotopy-coherence-square-homotopies = + concat-right-homotopy-coherence-square-homotopies top left right bottom s + pr2 equiv-concat-right-homotopy-coherence-square-homotopies = + is-equiv-concat-right-homotopy-coherence-square-homotopies +``` + +#### Concatenating homotopies of the bottom edge with a coherence of a commuting square of homotopies + +Consider a commuting diagram of homotopies + +```text + top + f -------> g + | | + left | | right + ∨ bottom ∨ + h -------> i. + -------> + bottom' ``` -### Left whiskering a commuting square of homotopies with respect to concatenation of homotopies +with a homotopy `bottom ~ bottom'`. Then we get an equivalence + +```text + top top + f -------> g f -------> g + | | | | + left | | right ≃ left | | right + ∨ ∨ ∨ ∨ + h -------> i h -------> i. + bottom bottom' +``` + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) + {bottom' : h ~ i} (s : bottom ~ bottom') + where + + is-equiv-concat-bottom-homotopy-coherence-square-homotopies : + is-equiv + ( concat-bottom-homotopy-coherence-square-homotopies + top left right bottom s) + is-equiv-concat-bottom-homotopy-coherence-square-homotopies = + is-equiv-map-Π-is-fiberwise-equiv + ( λ x → + is-equiv-concat-bottom-identification-coherence-square-identifications + ( top x) (left x) (right x) (bottom x) (s x)) + + equiv-concat-bottom-homotopy-coherence-square-homotopies : + coherence-square-homotopies top left right bottom ≃ + coherence-square-homotopies top left right bottom' + pr1 equiv-concat-bottom-homotopy-coherence-square-homotopies = + concat-bottom-homotopy-coherence-square-homotopies top left right bottom s + pr2 equiv-concat-bottom-homotopy-coherence-square-homotopies = + is-equiv-concat-bottom-homotopy-coherence-square-homotopies +``` + +### Whiskering and splicing coherences of commuting squares of homotopies + +Given a commuting square of homotopies + +```text + top + f -------> g + | | + left | | right + ∨ ∨ + h -------> i, + bottom +``` + +we may consider four ways of attaching new homotopies to it: + +1. Prepending `p : u ~ f` to the left gives us a commuting square + + ```text + p ∙h top + u -------> g + | | + p ∙h left | | right + ∨ ∨ + h -------> i. + bottom + ``` -Consider a -[commuting square of homotopies](foundation.commuting-squares-of-homotopies.md) + More precisely, we have an equivalence + + ```text + (left ∙h bottom ~ top ∙h right) ≃ ((p ∙h left) ∙h bottom ~ (p ∙h top) ∙h right). + ``` + +2. Appending a homotopy `p : i ~ u` to the right gives a commuting square of + homotopies + + ```text + top + f ------------> g + | | + left | | right ∙h p + ∨ ∨ + h ------------> u. + bottom ∙h p + ``` + + More precisely, we have an equivalence + + ```text + (left ∙h bottom ~ top ∙h right) ≃ (left ∙h (bottom ∙h p) ~ top ∙h (right ∙h p)). + ``` + +3. Splicing a homotopy `p : h ~ u` and its inverse into the middle gives a + commuting square of homotopies + + ```text + top + f --------------> g + | | + left ∙h p | | right + ∨ ∨ + u --------------> i. + p⁻¹ ∙h bottom + ``` + + More precisely, we have an equivalence + + ```text + (left ∙h bottom ~ top ∙h right) ≃ ((left ∙h p) ∙h (p⁻¹ ∙h bottom) ~ top ∙h right). + ``` + + Similarly, we have an equivalence + + ```text + (left ∙h bottom ~ top ∙h right) ≃ ((left ∙h p⁻¹) ∙h (p ∙h bottom) ~ top ∙h right). + ``` + +4. Splicing a homotopy `p : g ~ u` and its inverse into the middle gives a + commuting square of homotopies + + ```text + top ∙h p + f --------> u + | | + left | | p⁻¹ ∙h right + ∨ ∨ + h --------> i. + bottom + ``` + + More precisely, we have an equivalence + + ```text + (left ∙h bottom ~ top ∙h right) ≃ (left ∙h bottom ~ (top ∙h p) ∙h (p⁻¹ ∙h right)). + ``` + + Similarly, we have an equivalence + + ```text + (left ∙h bottom ~ top ∙h right) ≃ (left ∙h bottom ~ (top ∙h p⁻¹) ∙h (p ∙h right)). + ``` + +These operations are useful in proofs involving path algebra, because taking +`equiv-right-whisker-concat-coherence-square-identicications` as an example, it +provides us with two maps: the forward direction states +`(p ∙h r ~ q ∙h s) → (p ∙h (r ∙h t)) ~ q ∙h (s ∙h t))`, which allows one to +append a homotopy without needing to reassociate on the right, and the backwards +direction conversely allows one to cancel out a homotopy in parentheses. + +#### Left whiskering coherences of commuting squares of homotopies + +For any homotopy `p : u ~ f` we obtain an equivalence ```text - top - f ------> g - | | - left | | right - v v - h ------> i - bottom + top p ∙h top + f -------> g u -------> g + | | | | + left | | right ≃ p ∙h left | | right + ∨ ∨ ∨ ∨ + h -------> i h -------> i + bottom bottom ``` -and consider a homotopy `H : e ~ f`. Then there is an equivalence of commuting -squares of homotopies +of coherences of commuting squares of homotopies. + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i u : (x : A) → B x} + where + + equiv-left-whisker-concat-coherence-square-homotopies : + (p : u ~ f) + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) → + coherence-square-homotopies top left right bottom ≃ + coherence-square-homotopies (p ∙h top) (p ∙h left) right bottom + equiv-left-whisker-concat-coherence-square-homotopies + p top left right bottom = + equiv-Π-equiv-family + ( λ x → + equiv-left-whisker-concat-coherence-square-identifications + ( p x) (top x) (left x) (right x) (bottom x)) +``` + +#### Right whiskering coherences of commuting squares of homotopies + +For any homotopy `p : i ~ u` we obtain an equivalence ```text - top H ∙h top - f ------> g e ----------> g - | | | | - left | | right ≃ H ∙h left | | right - ∨ ∨ ∨ ∨ - h ------> i h ----------> i - bottom bottom + top top + f -------> g f ------------> g + | | | | + left | | right ≃ left | | right ∙h p + ∨ ∨ ∨ ∨ + h -------> i h ------------> i + bottom bottom ∙h p ``` -This is the -{{#concept "double whiskering" Disambiguation="commuting squares of homotopies with respect to concatenation" Agda=double-whisker-coherence-square-homotopies}} -operation of commuting squares of homotopies with respect to concatenation. +of coherences of commuting squares of homotopies. ```agda module _ - { l1 l2 : Level} {A : UU l1} {B : UU l2} - { f g h h' k m : A → B} - ( H : f ~ g) {K : g ~ h} {K' : g ~ h'} {L : h ~ k} {L' : h' ~ k} (M : k ~ m) + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) where - equiv-double-whisker-coherence-square-homotopies : - ( coherence-square-homotopies K K' L L') ≃ - ( coherence-square-homotopies (H ∙h K) (H ∙h K') (L ∙h M) (L' ∙h M)) - equiv-double-whisker-coherence-square-homotopies = + equiv-right-whisker-concat-coherence-square-homotopies : + {u : (x : A) → B x} (p : i ~ u) → + coherence-square-homotopies top left right bottom ≃ + coherence-square-homotopies top left (right ∙h p) (bottom ∙h p) + equiv-right-whisker-concat-coherence-square-homotopies p = equiv-Π-equiv-family - ( λ a → - equiv-double-whisker-square-identifications - ( H a) - ( K a) - ( K' a) - ( L a) - ( L' a) - ( M a)) - - double-whisker-coherence-square-homotopies : - ( coherence-square-homotopies K K' L L') → - ( coherence-square-homotopies (H ∙h K) (H ∙h K') (L ∙h M) (L' ∙h M)) - double-whisker-coherence-square-homotopies = - map-equiv equiv-double-whisker-coherence-square-homotopies - - double-unwhisker-concat-htpy-coherence-square-homotopies : - ( coherence-square-homotopies (H ∙h K) (H ∙h K') (L ∙h M) (L' ∙h M)) → - ( coherence-square-homotopies K K' L L') - double-unwhisker-concat-htpy-coherence-square-homotopies = - map-inv-equiv equiv-double-whisker-coherence-square-homotopies + ( λ x → + equiv-right-whisker-concat-coherence-square-identifications + ( top x) (left x) (right x) (bottom x) (p x)) ``` -### Whiskering a square of homotopies by a map +#### Left splicing coherences of commuting squares of homotopies -Given a square of homotopies +For any inverse pair of homotopies `p : g ~ u` and `q : u ~ g` equipped with +`α : inv-htpy p ~ q` we obtain an equivalence ```text - H - g -----> h - | | - H' | ⇗ | K - ∨ ∨ - h' -----> k - K' + top top + f -------> g f -----------> g + | | | | + left | | right ≃ left ∙h p | | right + ∨ ∨ ∨ ∨ + h -------> i u -----------> i + bottom q ∙h bottom ``` -and a map `f`, we may whisker it by a map on the left into a square of -homotopies +of coherences of commuting squares of homotopies. + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) + where + + equiv-left-splice-coherence-square-homotopies : + {u : (x : A) → B x} (p : h ~ u) (q : u ~ h) (α : inv-htpy p ~ q) → + coherence-square-homotopies top left right bottom ≃ + coherence-square-homotopies top (left ∙h p) right (q ∙h bottom) + equiv-left-splice-coherence-square-homotopies p q α = + equiv-Π-equiv-family + ( λ x → + equiv-left-splice-coherence-square-identifications + ( top x) (left x) (right x) (bottom x) (p x) (q x) (α x)) +``` + +#### Right splicing coherences of commuting squares of homotopies + +For any inverse pair of homotopies `p : g ~ u` and `q : u ~ g` equipped with +`α : inv-htpy p ~ q` we obtain an equivalence ```text - f ·l H - fg --------> fh - | | - f ·l H' | ⇗ |f ·l K - ∨ ∨ - fh' --------> fk, - f ·l K' + top top ∙h p + f -------> g f --------> u + | | | | + left | | right ≃ left | | q ∙h right + ∨ ∨ ∨ ∨ + h -------> i h --------> i + bottom bottom ``` +of coherences of commuting squares of homotopies. + ```agda module _ - { l1 l2 l3 : Level} {A : UU l1} {B : UU l2} {C : UU l3} - ( f : B → C) {g h h' k : A → B} - ( H : g ~ h) (H' : g ~ h') {K : h ~ k} {K' : h' ~ k} + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} + (top : f ~ g) (left : f ~ h) (right : g ~ i) (bottom : h ~ i) where - map-coherence-square-homotopies : - coherence-square-homotopies H H' K K' → - coherence-square-homotopies (f ·l H) (f ·l H') (f ·l K) (f ·l K') - map-coherence-square-homotopies α a = - map-coherence-square-identifications f (H a) (H' a) (K a) (K' a) (α a) + equiv-right-splice-coherence-square-homotopies : + {u : (x : A) → B x} (p : g ~ u) (q : u ~ g) (α : inv-htpy p ~ q) → + coherence-square-homotopies top left right bottom ≃ + coherence-square-homotopies (top ∙h p) left (inv-htpy p ∙h right) bottom + equiv-right-splice-coherence-square-homotopies p q α = + equiv-Π-equiv-family + ( λ x → + equiv-right-splice-coherence-square-identifications + ( top x) (left x) (right x) (bottom x) (p x) (q x) (α x)) ``` -And similarly we may whisker it on the right. +### Double whiskering of commuting squares of homotopies ```agda module _ - { l1 l2 l3 : Level} {A : UU l1} {B : UU l2} {C : UU l3} - { g h h' k : B → C} (H : g ~ h) (H' : g ~ h') {K : h ~ k} {K' : h' ~ k} - ( f : A → B) + {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h u v i : (x : A) → B x} where - right-whisker-comp-coherence-square-homotopies : - coherence-square-homotopies H H' K K' → - coherence-square-homotopies (H ·r f) (H' ·r f) (K ·r f) (K' ·r f) - right-whisker-comp-coherence-square-homotopies α = α ·r f + equiv-double-whisker-coherence-square-homotopies : + (p : f ~ g) + (top : g ~ u) (left : g ~ h) (right : u ~ v) (bottom : h ~ v) + (s : v ~ i) → + coherence-square-homotopies top left right bottom ≃ + coherence-square-homotopies + ( p ∙h top) + ( p ∙h left) + ( right ∙h s) + ( bottom ∙h s) + equiv-double-whisker-coherence-square-homotopies p top left right bottom q = + equiv-Π-equiv-family + ( λ x → + equiv-double-whisker-coherence-square-identifications + ( p x) (top x) (left x) (right x) (bottom x) (q x)) ``` diff --git a/src/foundation/commuting-squares-of-identifications.lagda.md b/src/foundation/commuting-squares-of-identifications.lagda.md index e5acc92b99..564b640778 100644 --- a/src/foundation/commuting-squares-of-identifications.lagda.md +++ b/src/foundation/commuting-squares-of-identifications.lagda.md @@ -427,8 +427,8 @@ module _ (top : x = y) (left : x = z) (right : y = w) (bottom : z = w) → coherence-square-identifications top left right bottom ≃ coherence-square-identifications (p ∙ top) (p ∙ left) right bottom - equiv-left-whisker-concat-coherence-square-identifications refl - top left right bottom = + equiv-left-whisker-concat-coherence-square-identifications + refl top left right bottom = id-equiv ``` @@ -552,7 +552,7 @@ module _ {l : Level} {A : UU l} {x y z u v w : A} where - equiv-double-whisker-square-identifications : + equiv-double-whisker-coherence-square-identifications : (p : x = y) (top : y = u) (left : y = z) (right : u = v) (bottom : z = v) (s : v = w) → @@ -562,7 +562,8 @@ module _ ( p ∙ left) ( right ∙ s) ( bottom ∙ s) - equiv-double-whisker-square-identifications p top left right bottom q = + equiv-double-whisker-coherence-square-identifications + p top left right bottom q = equiv-left-whisker-concat-coherence-square-identifications p top left ( right ∙ q) ( bottom ∙ q) ∘e From 458a314c215c0bcee188de7d239257679f1a56d5 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Mon, 12 Feb 2024 15:27:16 +0100 Subject: [PATCH 24/53] make branch type-check --- ...iskering-homotopies-concatenation.lagda.md | 2 +- .../commuting-prisms-of-maps.lagda.md | 11 ++- .../commuting-squares-of-maps.lagda.md | 8 +- ...iskering-homotopies-concatenation.lagda.md | 85 ------------------- 4 files changed, 17 insertions(+), 89 deletions(-) diff --git a/src/foundation-core/whiskering-homotopies-concatenation.lagda.md b/src/foundation-core/whiskering-homotopies-concatenation.lagda.md index b761b11bb4..3bfb7ffcc9 100644 --- a/src/foundation-core/whiskering-homotopies-concatenation.lagda.md +++ b/src/foundation-core/whiskering-homotopies-concatenation.lagda.md @@ -30,7 +30,7 @@ of homotopies with respect to concatenation is a ``` Similarly, we introduce -{{#concept "right whiskering" Disambiguation="homotopies with respect to concatenation' Agda=right-whisker-concat-htpy}} +{{#concept "right whiskering" Disambiguation="homotopies with respect to concatenation" Agda=right-whisker-concat-htpy}} to be an operation ```text diff --git a/src/foundation/commuting-prisms-of-maps.lagda.md b/src/foundation/commuting-prisms-of-maps.lagda.md index de583eb4b9..810596852b 100644 --- a/src/foundation/commuting-prisms-of-maps.lagda.md +++ b/src/foundation/commuting-prisms-of-maps.lagda.md @@ -96,13 +96,22 @@ module _ ( right-whisker-concat-coherence-square-homotopies ( front-bottom ·r hA) ( bottom ·r hA' ·r hA) + ( hC' ·l mid ·r hA) + ( ( pasting-horizontal-coherence-square-maps + h' g' hA' hB' hC' h'' g'' left-bottom right-bottom) ·r + ( hA)) + ( prism-bottom ·r hA) ( hC' ·l ((g' ·l left-top) ∙h (right-top ·r h))) - ( prism-bottom ·r hA)) ∙h + ) ∙h ( ap-concat-htpy ( front-bottom ·r hA) ( ( map-coherence-square-homotopies hC' ( front-top) ( mid ·r hA) + (hC ·l top) + ( pasting-horizontal-coherence-square-maps h g hA hB hC h' g' + ( left-top) + ( right-top)) ( prism-top)) ∙h ( ap-concat-htpy ( hC' ·l front-top) diff --git a/src/foundation/commuting-squares-of-maps.lagda.md b/src/foundation/commuting-squares-of-maps.lagda.md index 3bb13edc53..2ef09ca77e 100644 --- a/src/foundation/commuting-squares-of-maps.lagda.md +++ b/src/foundation/commuting-squares-of-maps.lagda.md @@ -570,8 +570,12 @@ module _ ( sq-left-bottom ·r left-top) ( mid-bottom ·l sq-left-top)) ∙h ( double-whisker-coherence-square-homotopies - ( bottom-right ·l (sq-left-bottom ·r left-top)) - ( right-bottom ·l (sq-right-top ·r top-left)) + ( bottom-right ·l sq-left-bottom ·r left-top) + ( sq-right-bottom ·r mid-left ·r left-top) + ( bottom-right ·l mid-bottom ·l sq-left-top) + ( right-bottom ·l mid-right ·l sq-left-top) + ( sq-right-bottom ·r mid-top ·r top-left) + ( right-bottom ·l sq-right-top ·r top-left) ( inv-htpy ( swap-nat-coherence-square-maps ( top-left) diff --git a/src/foundation/whiskering-homotopies-concatenation.lagda.md b/src/foundation/whiskering-homotopies-concatenation.lagda.md index 7df3b7f2ff..7c6edd9b0e 100644 --- a/src/foundation/whiskering-homotopies-concatenation.lagda.md +++ b/src/foundation/whiskering-homotopies-concatenation.lagda.md @@ -41,50 +41,6 @@ to be an operation {H I : f ~ g} → H ~ I → (J : g ~ h) → H ∙h J ~ I ∙h J. ``` -## Definitions - -### Left whiskering of homotopies with respect to concatenation - -Left whiskering of homotopies with respect to concatenation is an operation - -```text - (H : f ~ g) {I J : g ~ h} → I ~ J → H ∙h I ~ H ∙h K. -``` - -We implement the left whiskering operation of homotopies with respect to -concatenation as an instance of a general left whiskering operation. - -```agda -module _ - {l1 l2 : Level} {A : UU l1} {B : A → UU l2} - where - - left-whisker-concat-htpy : - left-whiskering-operation ((x : A) → B x) (_~_) (_∙h_) (_~_) - left-whisker-concat-htpy H K x = left-whisker-concat (H x) (K x) -``` - -### Right whiskering of homotopies with respect to concatenation - -Right whiskering of homotopies with respect to concatenation is an operation - -```text - {H I : f ~ g} → H ~ I → (J : g ~ h) → H ∙h J ~ I ∙h J. -``` - -We implement the right whiskering operation of homotopies with respect to -concatenation as an instance of a general right whiskering operation. - -```agda -module _ - {l1 l2 : Level} {A : UU l1} {B : A → UU l2} - where - - right-whisker-concat-htpy : - right-whiskering-operation ((x : A) → B x) (_~_) (_∙h_) (_~_) - right-whisker-concat-htpy K J x = right-whisker-concat (K x) (J x) -``` - ## Properties ### Left whiskering of homotopies with respect to concatenation is an equivalence @@ -116,44 +72,3 @@ module _ is-equiv-map-Π-is-fiberwise-equiv ( λ x → is-equiv-right-whisker-concat (J x)) ``` - -### The unit and absorption laws for left whiskering of homotopies with respect to concatenation - -```agda -module _ - {l1 l2 : Level} {A : UU l1} {B : A → UU l2} - where - - left-unit-law-left-whisker-concat-htpy : - {f g : (x : A) → B x} {I J : f ~ g} (K : I ~ J) → - left-whisker-concat-htpy refl-htpy K ~ K - left-unit-law-left-whisker-concat-htpy K x = - left-unit-law-left-whisker-concat (K x) - - right-absorption-law-left-whisker-concat-htpy : - {f g h : (x : A) → B x} (H : f ~ g) {I : g ~ h} → - left-whisker-concat-htpy H (refl-htpy' I) ~ refl-htpy - right-absorption-law-left-whisker-concat-htpy H x = - right-absorption-law-left-whisker-concat (H x) _ -``` - -### The unit and absorption laws for right whiskering of homotopies with respect to concatenation - -```agda -module _ - {l1 l2 : Level} {A : UU l1} {B : A → UU l2} - where - - left-absorption-law-right-whisker-concat-htpy : - {f g h : (x : A) → B x} {H : f ~ g} (J : g ~ h) → - right-whisker-concat-htpy (refl-htpy' H) J ~ refl-htpy - left-absorption-law-right-whisker-concat-htpy J x = - left-absorption-law-right-whisker-concat _ (J x) - - right-unit-law-right-whisker-concat-htpy : - {f g : (x : A) → B x} {I J : f ~ g} (K : I ~ J) → - right-unit-htpy ∙h K ~ - right-whisker-concat-htpy K refl-htpy ∙h right-unit-htpy - right-unit-law-right-whisker-concat-htpy K x = - right-unit-law-right-whisker-concat (K x) -``` From ec945c455ec685bcd0bf19a032b7c357e1fa8f03 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Mon, 12 Feb 2024 15:47:21 +0100 Subject: [PATCH 25/53] make branch type-check --- .../coherently-invertible-maps.lagda.md | 23 ++++++++----------- ...whiskering-homotopies-composition.lagda.md | 4 ++-- ...functoriality-sequential-colimits.lagda.md | 15 ++++++++++-- 3 files changed, 25 insertions(+), 17 deletions(-) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index 61815d3ee4..44ec0aabe1 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -398,15 +398,13 @@ module _ abstract is-section-map-inv-is-coherently-invertible-is-invertible : f ∘ map-inv-is-invertible H ~ id - is-section-map-inv-is-coherently-invertible-is-invertible y = - ( inv - ( is-section-map-inv-is-invertible H (f (map-inv-is-invertible H y)))) ∙ - ( ( ap - ( f) - ( is-retraction-map-inv-is-invertible - ( H) - ( map-inv-is-invertible H y))) ∙ - ( is-section-map-inv-is-invertible H y)) + is-section-map-inv-is-coherently-invertible-is-invertible = + ( ( inv-htpy (is-section-map-inv-is-invertible H)) ·r + ( f ∘ map-inv-is-invertible H)) ∙h + ( ( ( f) ·l + ( is-retraction-map-inv-is-invertible H) ·r + ( map-inv-is-invertible H)) ∙h + ( is-section-map-inv-is-invertible H)) abstract inv-coh-is-coherently-invertible-is-invertible : @@ -430,8 +428,7 @@ module _ ( is-retraction-map-inv-is-invertible H)) ∙h ( left-whisker-comp² ( f) - ( inv-htpy-coh-htpy-id - ( is-retraction-map-inv-is-invertible H)))) + ( inv-coh-htpy-id (is-retraction-map-inv-is-invertible H)))) ( is-section-map-inv-is-invertible H ·r f))) abstract @@ -604,7 +601,7 @@ module _ (g ∘ f ∘ g) ·l S ~ (g ∘ f) ·l R ·r g inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible = ( inv-preserves-comp-left-whisker-comp g (f ∘ g) S) ∙h - ( left-whisker-comp² g (inv-htpy-coh-htpy-id S)) ∙h + ( left-whisker-comp² g (inv-coh-htpy-id S)) ∙h ( lemma-is-coherently-invertible') ``` @@ -675,7 +672,7 @@ module _ ap-concat-htpy (R ·r (g ∘ f ∘ g)) (left-unit-law-left-whisker-comp (R ·r g)) ``` -Pasting the two lemmas along the common edge `Rgfg` +After pasting the two lemmas along the common edge `Rgfg` ```text gfgS gfgS diff --git a/src/foundation/whiskering-homotopies-composition.lagda.md b/src/foundation/whiskering-homotopies-composition.lagda.md index 67bcc797cb..2715167d25 100644 --- a/src/foundation/whiskering-homotopies-composition.lagda.md +++ b/src/foundation/whiskering-homotopies-composition.lagda.md @@ -278,8 +278,8 @@ module _ coh-htpy-id : H ·r f ~ f ·l H coh-htpy-id x = is-injective-concat' (H x) (nat-htpy-id H (H x)) - inv-htpy-coh-htpy-id : f ·l H ~ H ·r f - inv-htpy-coh-htpy-id = inv-htpy coh-htpy-id + inv-coh-htpy-id : f ·l H ~ H ·r f + inv-coh-htpy-id = inv-htpy coh-htpy-id ``` ## See also diff --git a/src/synthetic-homotopy-theory/functoriality-sequential-colimits.lagda.md b/src/synthetic-homotopy-theory/functoriality-sequential-colimits.lagda.md index b03ced31dd..61cd54ef3b 100644 --- a/src/synthetic-homotopy-theory/functoriality-sequential-colimits.lagda.md +++ b/src/synthetic-homotopy-theory/functoriality-sequential-colimits.lagda.md @@ -336,11 +336,22 @@ module _ ( ( map-sequential-colimit-hom-sequential-diagram up-c c'' ( comp-hom-sequential-diagram A B C g f)) ·l ( coherence-cocone-sequential-diagram c n)) - ( _) + ( coherence-cocone-sequential-diagram + ( map-cocone-hom-sequential-diagram + ( comp-hom-sequential-diagram A B C g f) + ( c'')) + ( n)) + ( ( htpy-htpy-cocone-map-sequential-colimit-hom-sequential-diagram + ( up-c) + ( c'') + ( comp-hom-sequential-diagram A B C g f) + ( succ-ℕ n)) ·r + ( map-sequential-diagram A n)) ( coherence-htpy-cocone-map-sequential-colimit-hom-sequential-diagram up-c ( c'') ( comp-hom-sequential-diagram A B C g f) - ( n))) ∙h + ( n)) + ( _)) ∙h ( ap-concat-htpy ( htpy-htpy-cocone-map-sequential-colimit-hom-sequential-diagram up-c c'' ( comp-hom-sequential-diagram A B C g f) From 450cbdf97a242fb083b89ba00e2d512367bf997e Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Mon, 12 Feb 2024 19:24:08 +0100 Subject: [PATCH 26/53] `coh-horizontal-concat-htpy` without funext --- src/foundation-core/invertible-maps.lagda.md | 19 +++++-- ...iskering-homotopies-concatenation.lagda.md | 10 +++- ...ing-identifications-concatenation.lagda.md | 8 +++ src/foundation/homotopy-algebra.lagda.md | 57 ++++++++++++------- src/foundation/invertible-maps.lagda.md | 4 +- .../factorizations-of-maps.lagda.md | 2 +- 6 files changed, 71 insertions(+), 29 deletions(-) diff --git a/src/foundation-core/invertible-maps.lagda.md b/src/foundation-core/invertible-maps.lagda.md index fa38fcdb68..76c7f506b5 100644 --- a/src/foundation-core/invertible-maps.lagda.md +++ b/src/foundation-core/invertible-maps.lagda.md @@ -245,11 +245,22 @@ module _ {l1 l2 : Level} {A : UU l1} {B : UU l2} where + is-section-map-inv-is-invertible-htpy : + {f f' : A → B} (H : f' ~ f) (F : is-invertible f) → + is-section f' (map-inv-is-invertible F) + is-section-map-inv-is-invertible-htpy H (g , S , R) = (H ·r g) ∙h S + + is-retraction-map-inv-is-invertible-htpy : + {f f' : A → B} (H : f' ~ f) (F : is-invertible f) → + is-retraction f' (map-inv-is-invertible F) + is-retraction-map-inv-is-invertible-htpy H (g , S , R) = (g ·l H) ∙h R + is-invertible-htpy : - {f f' : A → B} → f ~ f' → is-invertible f' → is-invertible f - pr1 (is-invertible-htpy H (g , S , R)) = g - pr1 (pr2 (is-invertible-htpy H (g , S , R))) = (H ·r g) ∙h S - pr2 (pr2 (is-invertible-htpy H (g , S , R))) = (g ·l H) ∙h R + {f f' : A → B} → f' ~ f → is-invertible f → is-invertible f' + is-invertible-htpy H F = + ( map-inv-is-invertible F , + is-section-map-inv-is-invertible-htpy H F , + is-retraction-map-inv-is-invertible-htpy H F) is-invertible-inv-htpy : {f f' : A → B} → f ~ f' → is-invertible f → is-invertible f' diff --git a/src/foundation-core/whiskering-homotopies-concatenation.lagda.md b/src/foundation-core/whiskering-homotopies-concatenation.lagda.md index 3bfb7ffcc9..8eae6bc964 100644 --- a/src/foundation-core/whiskering-homotopies-concatenation.lagda.md +++ b/src/foundation-core/whiskering-homotopies-concatenation.lagda.md @@ -44,7 +44,7 @@ to be an operation Left whiskering of homotopies with respect to concatenation is an operation ```text - (H : f ~ g) {I J : g ~ h} → I ~ J → H ∙h I ~ H ∙h K. + (H : f ~ g) {I J : g ~ h} → I ~ J → H ∙h I ~ H ∙h J. ``` We implement the left whiskering operation of homotopies with respect to @@ -58,6 +58,10 @@ module _ left-whisker-concat-htpy : left-whiskering-operation ((x : A) → B x) (_~_) (_∙h_) (_~_) left-whisker-concat-htpy H K x = left-whisker-concat (H x) (K x) + + left-unwhisker-concat-htpy : + {f g h : (x : A) → B x} (H : f ~ g) {I J : g ~ h} → H ∙h I ~ H ∙h J → I ~ J + left-unwhisker-concat-htpy H K x = left-unwhisker-concat (H x) (K x) ``` ### Right whiskering of homotopies with respect to concatenation @@ -79,6 +83,10 @@ module _ right-whisker-concat-htpy : right-whiskering-operation ((x : A) → B x) (_~_) (_∙h_) (_~_) right-whisker-concat-htpy K J x = right-whisker-concat (K x) (J x) + + right-unwhisker-concat-htpy : + {f g h : (x : A) → B x} {H I : f ~ g} (J : g ~ h) → H ∙h J ~ I ∙h J → H ~ I + right-unwhisker-concat-htpy H K x = right-unwhisker-concat (H x) (K x) ``` ## Properties diff --git a/src/foundation-core/whiskering-identifications-concatenation.lagda.md b/src/foundation-core/whiskering-identifications-concatenation.lagda.md index a6b5116b02..3525693baf 100644 --- a/src/foundation-core/whiskering-identifications-concatenation.lagda.md +++ b/src/foundation-core/whiskering-identifications-concatenation.lagda.md @@ -59,6 +59,10 @@ module _ left-whisker-concat : left-whiskering-operation A (_=_) (_∙_) (_=_) left-whisker-concat p β = ap (p ∙_) β + + left-unwhisker-concat : + {x y z : A} (p : x = y) {q r : y = z} → p ∙ q = p ∙ r → q = r + left-unwhisker-concat = is-injective-concat ``` ### Right whiskering of identifications @@ -79,6 +83,10 @@ module _ right-whisker-concat : right-whiskering-operation A (_=_) (_∙_) (_=_) right-whisker-concat α q = ap (_∙ q) α + + right-unwhisker-concat : + {x y z : A} {p q : x = y} (r : y = z) → p ∙ r = q ∙ r → p = q + right-unwhisker-concat r = is-injective-concat' r ``` ### Double whiskering of identifications diff --git a/src/foundation/homotopy-algebra.lagda.md b/src/foundation/homotopy-algebra.lagda.md index 43a59baced..bf563b4dea 100644 --- a/src/foundation/homotopy-algebra.lagda.md +++ b/src/foundation/homotopy-algebra.lagda.md @@ -7,7 +7,6 @@ module foundation.homotopy-algebra where
Imports ```agda -open import foundation.homotopy-induction open import foundation.universe-levels open import foundation.whiskering-homotopies-composition @@ -34,12 +33,12 @@ module _ {f f' : (x : A) → B x} {g g' : {x : A} → B x → C x} where - horizontal-concat-htpy : f ~ f' → ({x : A} → g {x} ~ g' {x}) → g ∘ f ~ g' ∘ f' - horizontal-concat-htpy F G = (g ·l F) ∙h (G ·r f') + horizontal-concat-htpy : ({x : A} → g {x} ~ g' {x}) → f ~ f' → g ∘ f ~ g' ∘ f' + horizontal-concat-htpy G F = (g ·l F) ∙h (G ·r f') horizontal-concat-htpy' : - f ~ f' → ({x : A} → g {x} ~ g' {x}) → g ∘ f ~ g' ∘ f' - horizontal-concat-htpy' F G = (G ·r f) ∙h (g' ·l F) + ({x : A} → g {x} ~ g' {x}) → f ~ f' → g ∘ f ~ g' ∘ f' + horizontal-concat-htpy' G F = (G ·r f) ∙h (g' ·l F) ``` ## Properties @@ -51,27 +50,43 @@ module _ {l1 l2 l3 : Level} {A : UU l1} {B : A → UU l2} {C : A → UU l3} where - coh-left-unit-horizontal-concat-htpy : + coh-right-unit-horizontal-concat-htpy : {f : (x : A) → B x} {g g' : {x : A} → B x → C x} (G : {x : A} → g {x} ~ g' {x}) → - horizontal-concat-htpy (refl-htpy' f) G ~ - horizontal-concat-htpy' (refl-htpy' f) G - coh-left-unit-horizontal-concat-htpy G = inv-htpy-right-unit-htpy + horizontal-concat-htpy G (refl-htpy' f) ~ + horizontal-concat-htpy' G (refl-htpy' f) + coh-right-unit-horizontal-concat-htpy G = inv-htpy-right-unit-htpy - coh-right-unit-horizontal-concat-htpy : + coh-left-unit-horizontal-concat-htpy : {f f' : (x : A) → B x} {g : {x : A} → B x → C x} (F : f ~ f') → - horizontal-concat-htpy F (refl-htpy' g) ~ - horizontal-concat-htpy' F (refl-htpy' g) - coh-right-unit-horizontal-concat-htpy F = right-unit-htpy + horizontal-concat-htpy (refl-htpy' g) F ~ + horizontal-concat-htpy' (refl-htpy' g) F + coh-left-unit-horizontal-concat-htpy F = right-unit-htpy +``` + +For the general case, we must construct a coherence of the square + +```text + gF + gf -------> gf' + | | + Gf | | Gf' + ∨ ∨ + g'f ----> g'f' + g'F +``` + +but this is an instance of naturality of `G` applied to `F`. + +```agda +module _ + {l1 l2 l3 : Level} {A : UU l1} {B : A → UU l2} {C : A → UU l3} + {f f' : (x : A) → B x} {g g' : {x : A} → B x → C x} + (G : {x : A} → g {x} ~ g' {x}) (F : f ~ f') + where coh-horizontal-concat-htpy : - {f f' : (x : A) → B x} {g g' : {x : A} → B x → C x} - (F : f ~ f') (G : {x : A} → g {x} ~ g' {x}) → - horizontal-concat-htpy F G ~ horizontal-concat-htpy' F G - coh-horizontal-concat-htpy {f} F G = - ind-htpy f - ( λ f' F → horizontal-concat-htpy F G ~ horizontal-concat-htpy' F G) - ( coh-left-unit-horizontal-concat-htpy G) - ( F) + horizontal-concat-htpy' G F ~ horizontal-concat-htpy G F + coh-horizontal-concat-htpy = nat-htpy G ·r F ``` diff --git a/src/foundation/invertible-maps.lagda.md b/src/foundation/invertible-maps.lagda.md index 623e969144..dc4dc8c2c1 100644 --- a/src/foundation/invertible-maps.lagda.md +++ b/src/foundation/invertible-maps.lagda.md @@ -148,11 +148,11 @@ module _ ( coherence-triangle-homotopies ( is-section-map-inv-invertible-map s) ( is-section-map-inv-invertible-map t) - ( horizontal-concat-htpy I H)) × + ( horizontal-concat-htpy H I)) × ( coherence-triangle-homotopies ( is-retraction-map-inv-invertible-map s) ( is-retraction-map-inv-invertible-map t) - ( horizontal-concat-htpy H I)) + ( horizontal-concat-htpy I H)) htpy-invertible-map : (s t : invertible-map A B) → UU (l1 ⊔ l2) htpy-invertible-map s t = diff --git a/src/orthogonal-factorization-systems/factorizations-of-maps.lagda.md b/src/orthogonal-factorization-systems/factorizations-of-maps.lagda.md index 860b38a002..8dc962ca58 100644 --- a/src/orthogonal-factorization-systems/factorizations-of-maps.lagda.md +++ b/src/orthogonal-factorization-systems/factorizations-of-maps.lagda.md @@ -161,7 +161,7 @@ module _ UU (l1 ⊔ l2) coherence-htpy-factorization-through F E R L = ( is-factorization-factorization-through F) ~ - ( horizontal-concat-htpy L R ∙h is-factorization-factorization-through E) + ( horizontal-concat-htpy R L ∙h is-factorization-factorization-through E) htpy-factorization-through : (F E : factorization-through f X) → UU (l1 ⊔ l2 ⊔ l3) From e9b85c634d8167e7e4403844db39dfc97a6c627f Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Mon, 12 Feb 2024 19:39:23 +0100 Subject: [PATCH 27/53] prove `is-coherently-invertible-htpy` --- .../coherently-invertible-maps.lagda.md | 129 +++++++++++++++--- ...ing-identifications-concatenation.lagda.md | 4 +- 2 files changed, 112 insertions(+), 21 deletions(-) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index 44ec0aabe1..b0912c3b95 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -10,6 +10,7 @@ module foundation-core.coherently-invertible-maps where open import foundation.action-on-identifications-binary-functions open import foundation.action-on-identifications-functions open import foundation.dependent-pair-types +open import foundation.homotopy-algebra open import foundation.universe-levels open import foundation.whiskering-higher-homotopies-composition open import foundation.whiskering-homotopies-composition @@ -84,7 +85,7 @@ module _ is-coherently-invertible f = Σ ( B → A) ( λ g → - Σ (f ∘ g ~ id) + Σ ( f ∘ g ~ id) ( λ G → Σ ( g ∘ f ~ id) ( λ H → coherence-is-coherently-invertible f g G H))) @@ -216,7 +217,7 @@ module _ ( λ g → Σ ( f ∘ g ~ id) ( λ G → - Σ (g ∘ f ~ id) + Σ ( g ∘ f ~ id) ( λ H → coherence-is-transpose-coherently-invertible f g G H))) module _ @@ -382,8 +383,7 @@ module _ ### Invertible maps are coherently invertible -The construction follows Theorem 4.2.3 in _Homotopy Type Theory – Univalent -Foundations of Mathematics_. +The construction follows Lemma 10.4.5 in _Introduction to Homotopy Type Theory_. ```agda module _ @@ -818,16 +818,109 @@ module _ ### Coherently invertible maps are closed under homotopies +We need to construct a coherence + ```text --- module _ --- {l1 l2 : Level} {A : UU l1} {B : UU l2} {f f' : A → B} (H : f ~ f') --- where - --- is-coherently-invertible-htpy : --- is-coherently-invertible f → is-coherently-invertible f' --- pr1 (is-coherently-invertible-htpy (g , S , R , C)) = g --- pr1 (pr2 (is-coherently-invertible-htpy (g , S , R , C))) = {! !} --- pr2 (pr2 (is-coherently-invertible-htpy (g , S , R , C))) = {! !} + f'gH + f'gf' -----> f'gf + | | + Hgf'| | f'R + ∨ ∨ + fgf' -------> f' + Sf' + + Sf + HgH ------> H⁻¹ + f'gf' -----> fgf f ----> f' + ------> + fR +``` + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} {f f' : A → B} (H : f' ~ f) + (g : B → A) (S : f ∘ g ~ id) (R : g ∘ f ~ id) (coh : S ·r f ~ f ·l R) + where + + my-thing : + horizontal-concat-htpy' (H ·r g) H ∙h ((S ·r f) ∙h inv-htpy H) ~ + horizontal-concat-htpy' (H ·r g) H ∙h ((f ·l R) ∙h inv-htpy H) + my-thing = + left-whisker-concat-htpy + ( horizontal-concat-htpy' (H ·r g) H) + ( right-whisker-concat-htpy coh (inv-htpy H)) + + my-other-nat-lemma : + H ·r (g ∘ f') ∙h f ·l g ·l H ~ f' ·l (g ·l H) ∙h H ·r (g ∘ f) + my-other-nat-lemma = nat-htpy H ·r (g ·l H) + + my-nat-lemma : H ·r (g ∘ f) ∙h f ·l R ~ f' ·l R ∙h H + my-nat-lemma = nat-htpy H ·r R + + my-nat-lemma''' : S ·r f' ∙h H ~ (f ∘ g) ·l H ∙h S ·r f + my-nat-lemma''' = + ( ap-concat-htpy + ( S ·r f') + ( inv-htpy (left-unit-law-left-whisker-comp H))) ∙h + ( nat-htpy S ·r H) + + lemma-upper-coherence : + S ·r f' ~ (f ∘ g) ·l H ∙h S ·r f ∙h inv-htpy H + lemma-upper-coherence = + right-transpose-htpy-concat (S ·r f') H ((f ∘ g) ·l H ∙h S ·r f) my-nat-lemma''' + + upper-coherence : + (H ·r g ∙h S) ·r f' ~ + horizontal-concat-htpy' (H ·r g) H ∙h ((S ·r f) ∙h inv-htpy H) + upper-coherence = + ( left-whisker-concat-htpy (H ·r (g ∘ f')) lemma-upper-coherence) ∙h + ( ( ap-concat-htpy + ( H ·r (g ∘ f')) + ( assoc-htpy ((f ∘ g) ·l H) (S ·r f) (inv-htpy H))) ∙h + ( inv-htpy + ( assoc-htpy (H ·r (g ∘ f')) ((f ∘ g) ·l H) ((S ·r f) ∙h inv-htpy H)))) + + lemma-lower-coherence : + H ·r (g ∘ f) ∙h f ·l R ∙h inv-htpy H ~ f' ·l R + lemma-lower-coherence = + inv-htpy (right-transpose-htpy-concat + ( f' ·l R) H ((H ·r (g ∘ f) ∙h f ·l R)) (inv-htpy my-nat-lemma)) + + lower-coherence : + horizontal-concat-htpy' (H ·r g) H ∙h ((f ·l R) ∙h inv-htpy H) ~ + f' ·l ((g ·l H) ∙h R) + lower-coherence = + ap-concat-htpy' (f ·l R ∙h inv-htpy H) (coh-horizontal-concat-htpy (H ·r g) H) ∙h + assoc-htpy ((f' ∘ g) ·l H) (H ·r (g ∘ f)) (f ·l R ∙h inv-htpy H) ∙h ap-concat-htpy ((f' ∘ g) ·l H) (inv-htpy (assoc-htpy (H ·r (g ∘ f)) (f ·l R) (inv-htpy H))) ∙h + left-whisker-concat-htpy ((f' ∘ g) ·l H) lemma-lower-coherence ∙h + ap-concat-htpy' (f' ·l R) (inv-preserves-comp-left-whisker-comp f' g H) ∙h + inv-htpy (distributive-left-whisker-comp-concat f' (g ·l H) R) + +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} {f f' : A → B} (H : f' ~ f) + (F : is-coherently-invertible f) + where + + coh-is-coherently-invertible-htpy : + coherence-is-coherently-invertible + ( f') + ( map-inv-is-coherently-invertible F) + ( is-section-map-inv-is-invertible-htpy + ( H) + ( is-invertible-is-coherently-invertible F)) + ( is-retraction-map-inv-is-invertible-htpy + ( H) + ( is-invertible-is-coherently-invertible F)) + coh-is-coherently-invertible-htpy = + upper-coherence H (map-inv-is-coherently-invertible F) (is-section-map-inv-is-coherently-invertible F) (is-retraction-map-inv-is-coherently-invertible F) (coh-is-coherently-invertible F) ∙h + my-thing H (map-inv-is-coherently-invertible F) (is-section-map-inv-is-coherently-invertible F) (is-retraction-map-inv-is-coherently-invertible F) (coh-is-coherently-invertible F) ∙h + lower-coherence H (map-inv-is-coherently-invertible F) (is-section-map-inv-is-coherently-invertible F) (is-retraction-map-inv-is-coherently-invertible F) (coh-is-coherently-invertible F) + + is-coherently-invertible-htpy : is-coherently-invertible f' + is-coherently-invertible-htpy = + is-coherently-invertible-coherence-is-invertible + ( is-invertible-htpy H (is-invertible-is-coherently-invertible F)) + ( coh-is-coherently-invertible-htpy) ``` ### The identity map is coherently invertible @@ -891,11 +984,10 @@ module _ ( is-retraction-map-inv-is-coherently-invertible G)) ( f)) ∙h ( ap-binary-concat-htpy - ( inv-htpy - ( preserves-comp-left-whisker-comp + ( inv-preserves-comp-left-whisker-comp ( g ∘ f) ( map-inv-is-coherently-invertible F) - ( is-retraction-map-inv-is-coherently-invertible G ·r f))) + ( is-retraction-map-inv-is-coherently-invertible G ·r f)) ( ( left-whisker-comp² g (coh-is-coherently-invertible F)) ∙h ( preserves-comp-left-whisker-comp g f ( is-retraction-map-inv-is-coherently-invertible F)))) ∙h @@ -970,9 +1062,8 @@ module _ ## References -1. Univalent Foundations Project, _Homotopy Type Theory – Univalent Foundations - of Mathematics_ (2013) ([website](https://homotopytypetheory.org/book/), - [arXiv:1308.0729](https://arxiv.org/abs/1308.0729)) +1. Egbert Rijke, _Introduction to Homotopy Type Theory_ (2022) + ([arXiv:2212.11082](https://arxiv.org/abs/2212.11082)) ## See also diff --git a/src/foundation-core/whiskering-identifications-concatenation.lagda.md b/src/foundation-core/whiskering-identifications-concatenation.lagda.md index 3525693baf..8a02a996b3 100644 --- a/src/foundation-core/whiskering-identifications-concatenation.lagda.md +++ b/src/foundation-core/whiskering-identifications-concatenation.lagda.md @@ -61,7 +61,7 @@ module _ left-whisker-concat p β = ap (p ∙_) β left-unwhisker-concat : - {x y z : A} (p : x = y) {q r : y = z} → p ∙ q = p ∙ r → q = r + {x y z : A} (p : x = y) {q r : y = z} → p ∙ q = p ∙ r → q = r left-unwhisker-concat = is-injective-concat ``` @@ -85,7 +85,7 @@ module _ right-whisker-concat α q = ap (_∙ q) α right-unwhisker-concat : - {x y z : A} {p q : x = y} (r : y = z) → p ∙ r = q ∙ r → p = q + {x y z : A} {p q : x = y} (r : y = z) → p ∙ r = q ∙ r → p = q right-unwhisker-concat r = is-injective-concat' r ``` From d4859e3b461956cf567d34f896e5b004252224dd Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Mon, 12 Feb 2024 21:48:05 +0100 Subject: [PATCH 28/53] cleanup `is-coherently-invertible-htpy` --- .../coherently-invertible-maps.lagda.md | 174 ++++++++++++------ src/foundation-core/invertible-maps.lagda.md | 4 +- .../commuting-triangles-of-maps.lagda.md | 2 +- 3 files changed, 118 insertions(+), 62 deletions(-) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index b0912c3b95..5dff0fc58b 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -40,9 +40,9 @@ following diagram commmutes ```text S ·r f - ~~~~~~~~~~ + ---------> f ∘ g ∘ f f. - ~~~~~~~~~~ + ---------> f ·l R ``` @@ -55,9 +55,9 @@ There is also the alternative coherence condition we could add ```text R ·r g - ~~~~~~~~~~ + ---------> g ∘ f ∘ g g. - ~~~~~~~~~~ + ---------> g ·l S ``` @@ -818,20 +818,35 @@ module _ ### Coherently invertible maps are closed under homotopies -We need to construct a coherence +Assume given a coherently invertible map `f` with inverse `g`, homotopies +`S : f ∘ g ~ id`, `R : g ∘ f ~ id` and coherence `C : Sf ~ fR`. Moreover, assume +the map `f'` is homotopic to `f` with homotopy `H : f' ~ f`. Then `g` is also a +two-sided inverse to `f'` via the homotopies ```text - f'gH + S' := Hg ∙ S : f' ∘ g ~ id and R' := gH ∙ R : g ∘ f' ~ id +``` + +Now, we can also show that these witnesses are part of a coherent inverse to +`f'`. To show this, we must construct a coherence `C'` of the square + +```text + Hgf' f'gf' -----> f'gf | | - Hgf'| | f'R + f'gH | | Sf' ∨ ∨ - fgf' -------> f' - Sf' + f'gf -------> f'. + f'R +``` + +We begin by observing that `C` fits somehere along the diagonal of this square +via the composite - Sf +```text + Sf HgH ------> H⁻¹ - f'gf' -----> fgf f ----> f' + f'gf' -----> fgf C f ----> f'. ------> fR ``` @@ -839,69 +854,92 @@ We need to construct a coherence ```agda module _ {l1 l2 : Level} {A : UU l1} {B : UU l2} {f f' : A → B} (H : f' ~ f) - (g : B → A) (S : f ∘ g ~ id) (R : g ∘ f ~ id) (coh : S ·r f ~ f ·l R) + (g : B → A) (S : f ∘ g ~ id) (R : g ∘ f ~ id) (C : S ·r f ~ f ·l R) where - my-thing : - horizontal-concat-htpy' (H ·r g) H ∙h ((S ·r f) ∙h inv-htpy H) ~ - horizontal-concat-htpy' (H ·r g) H ∙h ((f ·l R) ∙h inv-htpy H) - my-thing = + coh-coh-is-coherently-invertible-htpy : + horizontal-concat-htpy' (H ·r g) H ∙h (S ·r f ∙h inv-htpy H) ~ + horizontal-concat-htpy' (H ·r g) H ∙h (f ·l R ∙h inv-htpy H) + coh-coh-is-coherently-invertible-htpy = left-whisker-concat-htpy ( horizontal-concat-htpy' (H ·r g) H) - ( right-whisker-concat-htpy coh (inv-htpy H)) + ( right-whisker-concat-htpy C (inv-htpy H)) +``` - my-other-nat-lemma : - H ·r (g ∘ f') ∙h f ·l g ·l H ~ f' ·l (g ·l H) ∙h H ·r (g ∘ f) - my-other-nat-lemma = nat-htpy H ·r (g ·l H) +Now the problem is reduced to constructing two homotopies - my-nat-lemma : H ·r (g ∘ f) ∙h f ·l R ~ f' ·l R ∙h H - my-nat-lemma = nat-htpy H ·r R +```text + Hgf' ∙ Sf' ~ HgH ∙ Sf ∙ H⁻¹ and f'gH ∙ f'R ~ HgH ∙ fR ∙ H⁻¹. +``` - my-nat-lemma''' : S ·r f' ∙h H ~ (f ∘ g) ·l H ∙h S ·r f - my-nat-lemma''' = - ( ap-concat-htpy - ( S ·r f') - ( inv-htpy (left-unit-law-left-whisker-comp H))) ∙h - ( nat-htpy S ·r H) +By the two equivalent constructions of the horizontal composite `HgH` + +```text + Hgf' ∙ fgH ~ HgH ~ f'gH ∙ Hgf +``` + +constructing the two homotopies is equivalent to constructing coherences of the +squares - lemma-upper-coherence : - S ·r f' ~ (f ∘ g) ·l H ∙h S ·r f ∙h inv-htpy H - lemma-upper-coherence = - right-transpose-htpy-concat (S ·r f') H ((f ∘ g) ·l H ∙h S ·r f) my-nat-lemma''' +```text + fgH Hgf + fgf' -------> fgf f'gf -------> fgf + | | | | + Sf' | | Sf f'R | | fR + ∨ ∨ ∨ ∨ + f' ---------> f f' ---------> f + H H +``` - upper-coherence : +These squares are naturality squares, however, so we are done. + +```agda + coh-section-is-coherently-invertible-htpy : (H ·r g ∙h S) ·r f' ~ horizontal-concat-htpy' (H ·r g) H ∙h ((S ·r f) ∙h inv-htpy H) - upper-coherence = - ( left-whisker-concat-htpy (H ·r (g ∘ f')) lemma-upper-coherence) ∙h + coh-section-is-coherently-invertible-htpy = + ( left-whisker-concat-htpy + ( H ·r (g ∘ f')) + ( right-transpose-htpy-concat (S ·r f') H ((f ∘ g) ·l H ∙h S ·r f) + ( ( ap-concat-htpy + ( S ·r f') + ( inv-htpy (left-unit-law-left-whisker-comp H))) ∙h + ( nat-htpy S ·r H)))) ∙h ( ( ap-concat-htpy ( H ·r (g ∘ f')) ( assoc-htpy ((f ∘ g) ·l H) (S ·r f) (inv-htpy H))) ∙h ( inv-htpy ( assoc-htpy (H ·r (g ∘ f')) ((f ∘ g) ·l H) ((S ·r f) ∙h inv-htpy H)))) - lemma-lower-coherence : - H ·r (g ∘ f) ∙h f ·l R ∙h inv-htpy H ~ f' ·l R - lemma-lower-coherence = - inv-htpy (right-transpose-htpy-concat - ( f' ·l R) H ((H ·r (g ∘ f) ∙h f ·l R)) (inv-htpy my-nat-lemma)) - - lower-coherence : - horizontal-concat-htpy' (H ·r g) H ∙h ((f ·l R) ∙h inv-htpy H) ~ - f' ·l ((g ·l H) ∙h R) - lower-coherence = - ap-concat-htpy' (f ·l R ∙h inv-htpy H) (coh-horizontal-concat-htpy (H ·r g) H) ∙h - assoc-htpy ((f' ∘ g) ·l H) (H ·r (g ∘ f)) (f ·l R ∙h inv-htpy H) ∙h ap-concat-htpy ((f' ∘ g) ·l H) (inv-htpy (assoc-htpy (H ·r (g ∘ f)) (f ·l R) (inv-htpy H))) ∙h - left-whisker-concat-htpy ((f' ∘ g) ·l H) lemma-lower-coherence ∙h - ap-concat-htpy' (f' ·l R) (inv-preserves-comp-left-whisker-comp f' g H) ∙h - inv-htpy (distributive-left-whisker-comp-concat f' (g ·l H) R) + coh-retraction-is-coherently-invertible-htpy : + horizontal-concat-htpy' (H ·r g) H ∙h ((f ·l R) ∙h inv-htpy H) ~ + f' ·l ((g ·l H) ∙h R) + coh-retraction-is-coherently-invertible-htpy = + ( ap-concat-htpy' + ( f ·l R ∙h inv-htpy H) + ( coh-horizontal-concat-htpy (H ·r g) H)) ∙h + ( assoc-htpy ((f' ∘ g) ·l H) (H ·r (g ∘ f)) (f ·l R ∙h inv-htpy H)) ∙h + ( ap-concat-htpy + ( (f' ∘ g) ·l H) + ( inv-htpy (assoc-htpy (H ·r (g ∘ f)) (f ·l R) (inv-htpy H)))) ∙h + ( left-whisker-concat-htpy + ( (f' ∘ g) ·l H) + ( inv-htpy + ( right-transpose-htpy-concat (f' ·l R) H ((H ·r (g ∘ f) ∙h f ·l R)) + ( inv-htpy (nat-htpy H ·r R))))) ∙h + ( ap-concat-htpy' + ( f' ·l R) + ( inv-preserves-comp-left-whisker-comp f' g H)) ∙h + ( inv-htpy (distributive-left-whisker-comp-concat f' (g ·l H) R)) +``` +```agda module _ - {l1 l2 : Level} {A : UU l1} {B : UU l2} {f f' : A → B} (H : f' ~ f) - (F : is-coherently-invertible f) + {l1 l2 : Level} {A : UU l1} {B : UU l2} {f f' : A → B} where coh-is-coherently-invertible-htpy : + (H : f' ~ f) (F : is-coherently-invertible f) → coherence-is-coherently-invertible ( f') ( map-inv-is-coherently-invertible F) @@ -911,16 +949,34 @@ module _ ( is-retraction-map-inv-is-invertible-htpy ( H) ( is-invertible-is-coherently-invertible F)) - coh-is-coherently-invertible-htpy = - upper-coherence H (map-inv-is-coherently-invertible F) (is-section-map-inv-is-coherently-invertible F) (is-retraction-map-inv-is-coherently-invertible F) (coh-is-coherently-invertible F) ∙h - my-thing H (map-inv-is-coherently-invertible F) (is-section-map-inv-is-coherently-invertible F) (is-retraction-map-inv-is-coherently-invertible F) (coh-is-coherently-invertible F) ∙h - lower-coherence H (map-inv-is-coherently-invertible F) (is-section-map-inv-is-coherently-invertible F) (is-retraction-map-inv-is-coherently-invertible F) (coh-is-coherently-invertible F) + coh-is-coherently-invertible-htpy H F = + ( coh-section-is-coherently-invertible-htpy H + ( map-inv-is-coherently-invertible F) + ( is-section-map-inv-is-coherently-invertible F) + ( is-retraction-map-inv-is-coherently-invertible F) + ( coh-is-coherently-invertible F)) ∙h + ( coh-coh-is-coherently-invertible-htpy H + ( map-inv-is-coherently-invertible F) + ( is-section-map-inv-is-coherently-invertible F) + ( is-retraction-map-inv-is-coherently-invertible F) + ( coh-is-coherently-invertible F)) ∙h + ( coh-retraction-is-coherently-invertible-htpy H + ( map-inv-is-coherently-invertible F) + ( is-section-map-inv-is-coherently-invertible F) + ( is-retraction-map-inv-is-coherently-invertible F) + ( coh-is-coherently-invertible F)) - is-coherently-invertible-htpy : is-coherently-invertible f' - is-coherently-invertible-htpy = + is-coherently-invertible-htpy : + f' ~ f → is-coherently-invertible f → is-coherently-invertible f' + is-coherently-invertible-htpy H F = is-coherently-invertible-coherence-is-invertible ( is-invertible-htpy H (is-invertible-is-coherently-invertible F)) - ( coh-is-coherently-invertible-htpy) + ( coh-is-coherently-invertible-htpy H F) + + is-coherently-invertible-inv-htpy : + f ~ f' → is-coherently-invertible f → is-coherently-invertible f' + is-coherently-invertible-inv-htpy H = + is-coherently-invertible-htpy (inv-htpy H) ``` ### The identity map is coherently invertible diff --git a/src/foundation-core/invertible-maps.lagda.md b/src/foundation-core/invertible-maps.lagda.md index 76c7f506b5..ffaa087fdc 100644 --- a/src/foundation-core/invertible-maps.lagda.md +++ b/src/foundation-core/invertible-maps.lagda.md @@ -248,12 +248,12 @@ module _ is-section-map-inv-is-invertible-htpy : {f f' : A → B} (H : f' ~ f) (F : is-invertible f) → is-section f' (map-inv-is-invertible F) - is-section-map-inv-is-invertible-htpy H (g , S , R) = (H ·r g) ∙h S + is-section-map-inv-is-invertible-htpy H (g , S , R) = H ·r g ∙h S is-retraction-map-inv-is-invertible-htpy : {f f' : A → B} (H : f' ~ f) (F : is-invertible f) → is-retraction f' (map-inv-is-invertible F) - is-retraction-map-inv-is-invertible-htpy H (g , S , R) = (g ·l H) ∙h R + is-retraction-map-inv-is-invertible-htpy H (g , S , R) = g ·l H ∙h R is-invertible-htpy : {f f' : A → B} → f' ~ f → is-invertible f → is-invertible f' diff --git a/src/foundation/commuting-triangles-of-maps.lagda.md b/src/foundation/commuting-triangles-of-maps.lagda.md index d4163b847b..8ee1575c8b 100644 --- a/src/foundation/commuting-triangles-of-maps.lagda.md +++ b/src/foundation/commuting-triangles-of-maps.lagda.md @@ -196,7 +196,7 @@ module _ coherence-htpy-triangle-maps : left ~ left' → right ~ right' → top ~ top' → UU (l1 ⊔ l2) coherence-htpy-triangle-maps L R T = - c ∙h horizontal-concat-htpy T R ~ L ∙h c' + c ∙h horizontal-concat-htpy R T ~ L ∙h c' ``` ### Pasting commuting triangles into commuting squares along homotopic diagonals From bf8b817d7d71b061861e4118340e18b65b801f79 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Mon, 12 Feb 2024 22:25:06 +0100 Subject: [PATCH 29/53] 3-for-2 for coherently invertible maps and friends --- .../coherently-invertible-maps.lagda.md | 252 +++++++++++++++--- src/foundation/equivalences.lagda.md | 4 +- .../descent-circle-function-types.lagda.md | 4 +- 3 files changed, 217 insertions(+), 43 deletions(-) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index 5dff0fc58b..f55d3b7f4e 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -778,44 +778,6 @@ module _ ( f , transposition-is-transpose-coherently-invertible H) ``` -### Inversion of coherently invertible maps - -```agda -module _ - {l1 l2 : Level} {A : UU l1} {B : UU l2} - where - - is-coherently-invertible-map-inv-is-coherently-invertible : - {f : A → B} (H : is-coherently-invertible f) → - is-coherently-invertible (map-inv-is-coherently-invertible H) - is-coherently-invertible-map-inv-is-coherently-invertible H = - is-coherently-invertible-map-inv-is-transpose-coherently-invertible - ( transposition-is-coherently-invertible H) - - is-transpose-coherently-invertible-map-inv-is-transpose-coherently-invertible : - {f : A → B} (H : is-transpose-coherently-invertible f) → - is-transpose-coherently-invertible - ( map-inv-is-transpose-coherently-invertible H) - is-transpose-coherently-invertible-map-inv-is-transpose-coherently-invertible - H = - transposition-is-coherently-invertible - ( is-coherently-invertible-map-inv-is-transpose-coherently-invertible H) - - inv-coherently-invertible-map : - coherently-invertible-map A B → coherently-invertible-map B A - inv-coherently-invertible-map (f , H) = - ( map-inv-is-coherently-invertible H , - is-coherently-invertible-map-inv-is-coherently-invertible H) - - inv-transpose-coherently-invertible-map : - transpose-coherently-invertible-map A B → - transpose-coherently-invertible-map B A - inv-transpose-coherently-invertible-map (f , H) = - ( map-inv-is-transpose-coherently-invertible H , - is-transpose-coherently-invertible-map-inv-is-transpose-coherently-invertible - ( H)) -``` - ### Coherently invertible maps are closed under homotopies Assume given a coherently invertible map `f` with inverse `g`, homotopies @@ -855,7 +817,7 @@ via the composite module _ {l1 l2 : Level} {A : UU l1} {B : UU l2} {f f' : A → B} (H : f' ~ f) (g : B → A) (S : f ∘ g ~ id) (R : g ∘ f ~ id) (C : S ·r f ~ f ·l R) - where + where abstract coh-coh-is-coherently-invertible-htpy : horizontal-concat-htpy' (H ·r g) H ∙h (S ·r f ∙h inv-htpy H) ~ @@ -1007,6 +969,44 @@ module _ ( id , is-transpose-coherently-invertible-id) ``` +### Inversion of coherently invertible maps + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} + where + + is-coherently-invertible-map-inv-is-coherently-invertible : + {f : A → B} (H : is-coherently-invertible f) → + is-coherently-invertible (map-inv-is-coherently-invertible H) + is-coherently-invertible-map-inv-is-coherently-invertible H = + is-coherently-invertible-map-inv-is-transpose-coherently-invertible + ( transposition-is-coherently-invertible H) + + is-transpose-coherently-invertible-map-inv-is-transpose-coherently-invertible : + {f : A → B} (H : is-transpose-coherently-invertible f) → + is-transpose-coherently-invertible + ( map-inv-is-transpose-coherently-invertible H) + is-transpose-coherently-invertible-map-inv-is-transpose-coherently-invertible + H = + transposition-is-coherently-invertible + ( is-coherently-invertible-map-inv-is-transpose-coherently-invertible H) + + inv-coherently-invertible-map : + coherently-invertible-map A B → coherently-invertible-map B A + inv-coherently-invertible-map (f , H) = + ( map-inv-is-coherently-invertible H , + is-coherently-invertible-map-inv-is-coherently-invertible H) + + inv-transpose-coherently-invertible-map : + transpose-coherently-invertible-map A B → + transpose-coherently-invertible-map B A + inv-transpose-coherently-invertible-map (f , H) = + ( map-inv-is-transpose-coherently-invertible H , + is-transpose-coherently-invertible-map-inv-is-transpose-coherently-invertible + ( H)) +``` + ### Composition of coherently invertible maps ```agda @@ -1116,6 +1116,180 @@ module _ ( g ∘ f , is-transpose-coherently-invertible-comp g f G F) ``` +### The 3-for-2 property of coherently invertible maps + +The +{{#concept "3-for-2 property" Disambiguation="of coherently invertible maps"}} +of coherently invertible maps asserts that for any +[commuting triangle](foundation-core.commuting-triangles-of-maps.md) of maps + +```text + h + A ------> B + \ / + f\ /g + \ / + V V + X, +``` + +if two of the three maps are coherently invertible, then so is the third. + +We also record special cases of the 3-for-2 property of coherently invertible +maps, where we only assume maps `g : B → X` and `h : A → B`. In this special +case, we set `f := g ∘ h` and the triangle commutes by `refl-htpy`. + +[André Joyal](https://en.wikipedia.org/wiki/André_Joyal) proposed calling this +property the 3-for-2 property, despite most mathematicians calling it the +_2-out-of-3 property_. The story goes that on the produce market is is common to +advertise a discount as "3-for-2". If you buy two apples, then you get the third +for free. Similarly, if you prove that two maps in a commuting triangle are +equivalences, then you get the third for free. + +#### The left map in a commuting triangle is coherently invertible if the other two maps are + +```agda +module _ + {l1 l2 l3 : Level} {A : UU l1} {B : UU l2} {X : UU l3} + (f : A → X) (g : B → X) (h : A → B) (T : f ~ g ∘ h) + where + + abstract + is-coherently-invertible-left-map-triangle : + is-coherently-invertible h → + is-coherently-invertible g → + is-coherently-invertible f + is-coherently-invertible-left-map-triangle H G = + is-coherently-invertible-htpy T (is-coherently-invertible-comp g h G H) +``` + +#### The right map in a commuting triangle is coherently invertible if the other two maps are + +```agda +module _ + {l1 l2 l3 : Level} {A : UU l1} {B : UU l2} {X : UU l3} + (f : A → X) (g : B → X) (h : A → B) (T : f ~ g ∘ h) + where + + abstract + is-coherently-invertible-right-map-triangle : + is-coherently-invertible f → + is-coherently-invertible h → + is-coherently-invertible g + is-coherently-invertible-right-map-triangle F H = + is-coherently-invertible-htpy + ( ( g ·l inv-htpy (is-section-map-inv-is-coherently-invertible H)) ∙h + ( inv-htpy T ·r map-inv-is-coherently-invertible H)) + ( is-coherently-invertible-comp + ( f) + ( map-inv-is-coherently-invertible H) + ( F) + ( is-coherently-invertible-map-inv-is-coherently-invertible H)) +``` + +#### The top map in a commuting triangle is coherently invertible if the other two maps + +```agda +module _ + {l1 l2 l3 : Level} {A : UU l1} {B : UU l2} {X : UU l3} + (f : A → X) (g : B → X) (h : A → B) (T : f ~ g ∘ h) + where + + abstract + is-coherently-invertible-top-map-triangle : + is-coherently-invertible g → + is-coherently-invertible f → + is-coherently-invertible h + is-coherently-invertible-top-map-triangle G F = + is-coherently-invertible-htpy + ( ( inv-htpy (is-retraction-map-inv-is-coherently-invertible G) ·r h) ∙h + ( map-inv-is-coherently-invertible G ·l inv-htpy T)) + ( is-coherently-invertible-comp + ( map-inv-is-coherently-invertible G) + ( f) + ( is-coherently-invertible-map-inv-is-coherently-invertible G) + ( F)) +``` + +#### If a composite and its right factor are coherently invertible, then so is its left factor + +```agda +module _ + {l1 l2 l3 : Level} {A : UU l1} {B : UU l2} {X : UU l3} + where + + is-coherently-invertible-left-factor : + (g : B → X) (h : A → B) → + is-coherently-invertible (g ∘ h) → + is-coherently-invertible h → + is-coherently-invertible g + is-coherently-invertible-left-factor g h GH H = + is-coherently-invertible-right-map-triangle (g ∘ h) g h refl-htpy GH H +``` + +#### If a composite and its left factor are coherently invertible, then so is its right factor + +```agda +module _ + {l1 l2 l3 : Level} {A : UU l1} {B : UU l2} {X : UU l3} + where + + is-coherently-invertible-right-factor : + (g : B → X) (h : A → B) → + is-coherently-invertible g → + is-coherently-invertible (g ∘ h) → + is-coherently-invertible h + is-coherently-invertible-right-factor g h G GH = + is-coherently-invertible-top-map-triangle (g ∘ h) g h refl-htpy G GH +``` + +### Any retraction of a coherently invertible map is coherently invertible + +```agda +abstract + is-coherently-invertible-is-retraction : + {l1 l2 : Level} {A : UU l1} {B : UU l2} {f : A → B} {g : B → A} → + is-coherently-invertible f → (g ∘ f) ~ id → is-coherently-invertible g + is-coherently-invertible-is-retraction {f = f} {g} F H = + is-coherently-invertible-right-map-triangle id g f + ( inv-htpy H) + ( is-coherently-invertible-id) + ( F) +``` + +### Any section of a coherently invertible map is coherently invertible + +```agda +abstract + is-coherently-invertible-is-section : + {l1 l2 : Level} {A : UU l1} {B : UU l2} {f : A → B} {g : B → A} → + is-coherently-invertible f → f ∘ g ~ id → is-coherently-invertible g + is-coherently-invertible-is-section {f = f} {g} F H = + is-coherently-invertible-top-map-triangle id f g + ( inv-htpy H) + ( F) + ( is-coherently-invertible-id) +``` + +### If a section of `f` is coherently invertible, then `f` is coherently invertible + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} (f : A → B) + where + + abstract + is-coherently-invertible-section-is-coherently-invertible : + ( section-f : section f) → + is-coherently-invertible (pr1 section-f) → is-coherently-invertible f + is-coherently-invertible-section-is-coherently-invertible + ( g , is-section-g) S = + is-coherently-invertible-htpy + ( ( f ·l (inv-htpy (is-section-map-inv-is-coherently-invertible S))) ∙h + ( right-whisker-comp is-section-g (map-inv-is-coherently-invertible S))) + ( is-coherently-invertible-map-inv-is-coherently-invertible S) +``` + ## References 1. Egbert Rijke, _Introduction to Homotopy Type Theory_ (2022) diff --git a/src/foundation/equivalences.lagda.md b/src/foundation/equivalences.lagda.md index 7bdc8ba6a1..4138acee7e 100644 --- a/src/foundation/equivalences.lagda.md +++ b/src/foundation/equivalences.lagda.md @@ -604,8 +604,8 @@ module _ is-pullback-swap-cone' f g c ( is-pullback-is-equiv-vertical-maps g f ( swap-cone f g c) - is-equiv-f - is-equiv-q) + ( is-equiv-f) + ( is-equiv-q)) ``` ## See also diff --git a/src/synthetic-homotopy-theory/descent-circle-function-types.lagda.md b/src/synthetic-homotopy-theory/descent-circle-function-types.lagda.md index 6bf5b5fd8c..c0454fa477 100644 --- a/src/synthetic-homotopy-theory/descent-circle-function-types.lagda.md +++ b/src/synthetic-homotopy-theory/descent-circle-function-types.lagda.md @@ -100,6 +100,7 @@ module _ pr2 eq-descent-data-circle-function-type h = ( eq-htpy ( horizontal-concat-htpy + ( coherence-square-family-with-descent-data-circle B) ( h ·l inv-htpy ( coherence-square-maps-inv-equiv @@ -109,8 +110,7 @@ module _ ( family-family-with-descent-data-circle A) ( loop-free-loop l)) ( equiv-family-with-descent-data-circle A) - ( coherence-square-family-with-descent-data-circle A))) - ( coherence-square-family-with-descent-data-circle B))) ∙ + ( coherence-square-family-with-descent-data-circle A))))) ∙ ( inv ( ( tr-function-type ( family-family-with-descent-data-circle A) From a5eaa882d83ea80f201525692d7259e41ed1b931 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Mon, 12 Feb 2024 22:35:08 +0100 Subject: [PATCH 30/53] everything checks --- src/foundation-core/coherently-invertible-maps.lagda.md | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index f55d3b7f4e..dd9ce5f67f 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -1286,7 +1286,9 @@ module _ ( g , is-section-g) S = is-coherently-invertible-htpy ( ( f ·l (inv-htpy (is-section-map-inv-is-coherently-invertible S))) ∙h - ( right-whisker-comp is-section-g (map-inv-is-coherently-invertible S))) + ( right-whisker-comp + ( is-section-g) + ( map-inv-is-coherently-invertible S))) ( is-coherently-invertible-map-inv-is-coherently-invertible S) ``` From 6f4b6b38aa95a97d4b8147dc10f30222407cdd7d Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Tue, 13 Feb 2024 12:26:41 +0100 Subject: [PATCH 31/53] polish coherently invertible maps core --- .../coherently-invertible-maps.lagda.md | 603 ++++++++++-------- src/foundation-core/equivalences.lagda.md | 26 +- ...amental-theorem-of-identity-types.lagda.md | 2 +- 3 files changed, 360 insertions(+), 271 deletions(-) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index dd9ce5f67f..008a74d71a 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -68,6 +68,21 @@ _transpose coherently invertible maps_. {{#concept "half adjoint equivalences"}} in _Homotopy Type Theory – Univalent Foundations of Mathematics_. +On this page we will prove that every two-sided inverse `g` of `f` can be +promoted to a coherent two-sided inverse. Thus, for most properties of +coherently invertible maps, it suffices to consider the data of a two-sided +inverse. However, this coherence construction requires us to replace the section +homotopy (or retraction homotopy). For this reason we also give alternative +constructions showing + +1. The identity map is coherently invertible. +2. The composite of two coherently invertible maps is coherently invertible. +3. The inverse of a coherently invertible map is coherently invertible. +4. Every map homotopic to a coherently invertible map is coherently invertible. +5. The 3-for-2 property of coherently invertible maps. + +That appropriately preserve the data of the underlying two-sided inverse. + ## Definition ### The predicate of being coherently invertible on maps @@ -381,6 +396,51 @@ module _ ## Properties +### The inverse of a coherently invertible map is transpose coherently invertible + +The inverse of a coherently invertible map is transpose coherently invertible. +Of course, there is also a converse construction, and since these are defined by +simply moving data around, they are strict inverses to one another. + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} + where + + is-transpose-coherently-invertible-map-inv-is-coherently-invertible : + {f : A → B} (H : is-coherently-invertible f) → + is-transpose-coherently-invertible (map-inv-is-coherently-invertible H) + is-transpose-coherently-invertible-map-inv-is-coherently-invertible {f} H = + ( f , + is-retraction-map-inv-is-coherently-invertible H , + is-section-map-inv-is-coherently-invertible H , + coh-is-coherently-invertible H) + + is-coherently-invertible-map-inv-is-transpose-coherently-invertible : + {f : A → B} (H : is-transpose-coherently-invertible f) → + is-coherently-invertible (map-inv-is-transpose-coherently-invertible H) + is-coherently-invertible-map-inv-is-transpose-coherently-invertible {f} H = + ( f , + is-retraction-map-inv-is-transpose-coherently-invertible H , + is-section-map-inv-is-transpose-coherently-invertible H , + coh-is-transpose-coherently-invertible H) + + transpose-coherently-invertible-map-inv-coherently-invertible-map : + coherently-invertible-map A B → transpose-coherently-invertible-map B A + transpose-coherently-invertible-map-inv-coherently-invertible-map e = + ( map-inv-coherently-invertible-map e , + is-transpose-coherently-invertible-map-inv-is-coherently-invertible + ( is-coherently-invertible-map-coherently-invertible-map e)) + + coherently-invertible-map-inv-transpose-coherently-invertible-map : + transpose-coherently-invertible-map A B → coherently-invertible-map B A + coherently-invertible-map-inv-transpose-coherently-invertible-map e = + ( map-inv-transpose-coherently-invertible-map e , + is-coherently-invertible-map-inv-is-transpose-coherently-invertible + ( is-transpose-coherently-invertible-map-transpose-coherently-invertible-map + ( e))) +``` + ### Invertible maps are coherently invertible The construction follows Lemma 10.4.5 in _Introduction to Homotopy Type Theory_. @@ -441,16 +501,31 @@ module _ coh-is-coherently-invertible-is-invertible = inv-htpy inv-coh-is-coherently-invertible-is-invertible - abstract - is-coherently-invertible-is-invertible : is-coherently-invertible f - pr1 is-coherently-invertible-is-invertible = - map-inv-is-invertible H - pr1 (pr2 is-coherently-invertible-is-invertible) = - is-section-map-inv-is-coherently-invertible-is-invertible - pr1 (pr2 (pr2 is-coherently-invertible-is-invertible)) = - is-retraction-map-inv-is-coherently-invertible-is-invertible - pr2 (pr2 (pr2 is-coherently-invertible-is-invertible)) = - coh-is-coherently-invertible-is-invertible + is-coherently-invertible-is-invertible : is-coherently-invertible f + is-coherently-invertible-is-invertible = + ( map-inv-is-invertible H , + is-section-map-inv-is-coherently-invertible-is-invertible , + is-retraction-map-inv-is-coherently-invertible-is-invertible , + coh-is-coherently-invertible-is-invertible) +``` + +This result is known as +[Vogt's lemma](https://ncatlab.org/nlab/show/homotopy+equivalence#vogts_lemma) +in point-set topology. + +We also get the transpose version for free: + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} {f : A → B} (H : is-invertible f) + where + + is-transpose-coherently-invertible-is-invertible : + is-transpose-coherently-invertible f + is-transpose-coherently-invertible-is-invertible = + is-transpose-coherently-invertible-map-inv-is-coherently-invertible + ( is-coherently-invertible-is-invertible + ( is-invertible-map-inv-is-invertible H)) ``` ### Coherently invertible maps are embeddings @@ -459,8 +534,8 @@ We first construct the converse map to the [action on identifications](foundation.action-on-identifications-functions.md). This is a rerun of the proof that maps with [retractions](foundation-core.retractions.md) are -[injective](foundation-core.injective-maps.md) (`is-injective-retraction`), and -we repeat the proof to avoid cyclic dependencies. +[injective](foundation-core.injective-maps.md) (`is-injective-retraction`). We +repeat the proof to avoid cyclic dependencies. ```agda module _ @@ -515,64 +590,19 @@ and retraction of `ap f`. is-retraction-map-inv-ap-is-coherently-invertible refl = left-inv (is-retraction-map-inv-is-coherently-invertible H x) - abstract - is-invertible-ap-is-coherently-invertible : is-invertible (ap f {x} {y}) - pr1 is-invertible-ap-is-coherently-invertible = - map-inv-ap-is-coherently-invertible - pr1 (pr2 is-invertible-ap-is-coherently-invertible) = - is-section-map-inv-ap-is-coherently-invertible - pr2 (pr2 is-invertible-ap-is-coherently-invertible) = - is-retraction-map-inv-ap-is-coherently-invertible - - is-coherently-invertible-ap-is-coherently-invertible : - is-coherently-invertible (ap f {x} {y}) - is-coherently-invertible-ap-is-coherently-invertible = - is-coherently-invertible-is-invertible - ( is-invertible-ap-is-coherently-invertible) -``` - -### The inverse of a coherently invertible map is transpose coherently invertible - -Of course there is also a converse construction, and since these just move data -around, they are strict inverses to one another. - -```agda -module _ - {l1 l2 : Level} {A : UU l1} {B : UU l2} - where - - is-transpose-coherently-invertible-map-inv-is-coherently-invertible : - {f : A → B} (H : is-coherently-invertible f) → - is-transpose-coherently-invertible (map-inv-is-coherently-invertible H) - is-transpose-coherently-invertible-map-inv-is-coherently-invertible {f} H = - ( f , - is-retraction-map-inv-is-coherently-invertible H , - is-section-map-inv-is-coherently-invertible H , - coh-is-coherently-invertible H) - - is-coherently-invertible-map-inv-is-transpose-coherently-invertible : - {f : A → B} (H : is-transpose-coherently-invertible f) → - is-coherently-invertible (map-inv-is-transpose-coherently-invertible H) - is-coherently-invertible-map-inv-is-transpose-coherently-invertible {f} H = - ( f , - is-retraction-map-inv-is-transpose-coherently-invertible H , - is-section-map-inv-is-transpose-coherently-invertible H , - coh-is-transpose-coherently-invertible H) - - transpose-coherently-invertible-map-inv-coherently-invertible-map : - coherently-invertible-map A B → transpose-coherently-invertible-map B A - transpose-coherently-invertible-map-inv-coherently-invertible-map e = - ( map-inv-coherently-invertible-map e , - is-transpose-coherently-invertible-map-inv-is-coherently-invertible - ( is-coherently-invertible-map-coherently-invertible-map e)) - - coherently-invertible-map-inv-transpose-coherently-invertible-map : - transpose-coherently-invertible-map A B → coherently-invertible-map B A - coherently-invertible-map-inv-transpose-coherently-invertible-map e = - ( map-inv-transpose-coherently-invertible-map e , - is-coherently-invertible-map-inv-is-transpose-coherently-invertible - ( is-transpose-coherently-invertible-map-transpose-coherently-invertible-map - ( e))) + is-invertible-ap-is-coherently-invertible : is-invertible (ap f {x} {y}) + pr1 is-invertible-ap-is-coherently-invertible = + map-inv-ap-is-coherently-invertible + pr1 (pr2 is-invertible-ap-is-coherently-invertible) = + is-section-map-inv-ap-is-coherently-invertible + pr2 (pr2 is-invertible-ap-is-coherently-invertible) = + is-retraction-map-inv-ap-is-coherently-invertible + + is-coherently-invertible-ap-is-coherently-invertible : + is-coherently-invertible (ap f {x} {y}) + is-coherently-invertible-ap-is-coherently-invertible = + is-coherently-invertible-is-invertible + ( is-invertible-ap-is-coherently-invertible) ``` ### Coherently invertible maps are coherently invertible in both senses @@ -580,99 +610,50 @@ module _ The proof follows Lemma 4.2.2 in _Homotopy Type Theory – Univalent Foundations of Mathematics_. -```agda -module _ - {l1 l2 : Level} {A : UU l1} {B : UU l2} - (f : A → B) - (g : B → A) - (S : is-section f g) - (R : is-retraction f g) - (H : coherence-is-coherently-invertible f g S R) - where - - lemma-is-coherently-invertible' : - g ·l S ·r (f ∘ g) ~ (g ∘ f) ·l R ·r g - lemma-is-coherently-invertible' = - ( preserves-comp-right-whisker-comp f g (g ·l S)) ∙h - ( double-whisker-comp² g H g) ∙h - ( preserves-comp-left-whisker-comp g f (R ·r g)) - - inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible : - (g ∘ f ∘ g) ·l S ~ (g ∘ f) ·l R ·r g - inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible = - ( inv-preserves-comp-left-whisker-comp g (f ∘ g) S) ∙h - ( left-whisker-comp² g (inv-coh-htpy-id S)) ∙h - ( lemma-is-coherently-invertible') -``` - -By naturality we have +**Proof.** By naturality we have ```text - gfgS + gfRg gfgfg --------------------> gfg | | - Rgfg | nat-htpy (R ·r g) ·r S | Rg + Rgfg | nat-htpy R ·r (R ·r g) | Rg ∨ ∨ - gfg ----------------------> g - gS + gfg ----------------------> g. + Rg ``` -```agda -module _ - {l1 l2 : Level} {A : UU l1} {B : UU l2} - (f : A → B) - (g : B → A) - (S : is-section f g) - (R : is-retraction f g) - where +We can paste the homotopy - naturality-square-is-retraction-is-section : - coherence-square-homotopies - ( (g ∘ f ∘ g) ·l S) - ( R ·r (g ∘ f ∘ g)) - ( R ·r g) - ( g ·l S) - naturality-square-is-retraction-is-section = nat-htpy (R ·r g) ·r S +```text + g(inv-coh-htpy-id S) ∙ gHg : Sgfg ~ gfSg ~ gfRg ``` -TODO Explain +along the top edge of this naturality square obtaining the coherence square ```text - Rgfg + gfgS gfgfg -------> gfg | | - Sgfg | | Rg + Rgfg | | Rg ∨ ∨ - gfg ---------> g + gfg ---------> g. Rg ``` -```agda -module _ - {l1 l2 : Level} {A : UU l1} {B : UU l2} - (f : A → B) - (g : B → A) - (S : is-section f g) - (R : is-retraction f g) - (H : coherence-is-coherently-invertible f g S R) - where +There is also the following naturality square - naturality-square-transposition-coherence-is-coherently-invertible : - coherence-square-homotopies - ( R ·r (g ∘ f ∘ g)) - ( (g ∘ f ∘ g) ·l S) - ( R ·r g) - ( R ·r g) - naturality-square-transposition-coherence-is-coherently-invertible = - ( ap-concat-htpy' - ( R ·r g) - ( inv-coh-is-transpose-coherently-invertible-coherence-is-coherently-invertible - ( f) (g) (S) (R) (H))) ∙h - (inv-htpy (nat-htpy R ·r (R ·r g))) ∙h - ap-concat-htpy (R ·r (g ∘ f ∘ g)) (left-unit-law-left-whisker-comp (R ·r g)) +```text + gfgS + gfgfg --------------------> gfg + | | + Rgfg | nat-htpy (R ·r g) ·r S | Rg + ∨ ∨ + gfg ----------------------> g. + gS ``` -After pasting the two lemmas along the common edge `Rgfg` +Now, by pasting the first square to the second along the common edge `Rgfg`, we +obtain ```text gfgS gfgS @@ -684,8 +665,8 @@ After pasting the two lemmas along the common edge `Rgfg` Rg gS ``` -we observe that the homotopy `gfgS` at the top cancels itself, as well as the -`Rg` on the left, leaving us with a homotopy `Rg ~ gS` as desired. +After cancelling `gfgS` and `Rg` with themselves, we are left with `Rg ~ gS` as +desired. ```agda module _ @@ -695,26 +676,55 @@ module _ (S : is-section f g) (R : is-retraction f g) (H : coherence-is-coherently-invertible f g S R) - where abstract + where - coherence-transposition-coherence-is-coherently-invertible : - coherence-is-transpose-coherently-invertible f g S R - coherence-transposition-coherence-is-coherently-invertible = - ( ap-concat-htpy' (R ·r g) (inv-htpy (left-inv-htpy ((g ∘ f ∘ g) ·l S)))) ∙h - ( assoc-htpy (inv-htpy ((g ∘ f ∘ g) ·l S)) ((g ∘ f ∘ g) ·l S) (R ·r g)) ∙h - ( ap-concat-htpy - ( inv-htpy ((g ∘ f ∘ g) ·l S)) - ( inv-htpy (naturality-square-is-retraction-is-section f g S R))) ∙h - ( inv-htpy - ( assoc-htpy - ( inv-htpy ((g ∘ f ∘ g) ·l S)) (R ·r (g ∘ f ∘ g)) (g ·l S))) ∙h - ( ap-concat-htpy' - ( g ·l S) - ( ( vertical-inv-coherence-square-homotopies - ( R ·r (g ∘ f ∘ g)) ((g ∘ f ∘ g) ·l S) (R ·r g) (R ·r g) - ( naturality-square-transposition-coherence-is-coherently-invertible - ( f) (g) (S) (R) (H))) ∙h - ( right-inv-htpy (R ·r g)))) + abstract + coh-transposition-coherence-is-coherently-invertible : + (g ∘ f ∘ g) ·l S ~ (g ∘ f) ·l R ·r g + coh-transposition-coherence-is-coherently-invertible = + ( inv-preserves-comp-left-whisker-comp g (f ∘ g) S) ∙h + ( left-whisker-comp² g (inv-coh-htpy-id S)) ∙h + ( double-whisker-comp² g H g) ∙h + ( preserves-comp-left-whisker-comp g f (R ·r g)) + + abstract + naturality-square-transposition-coherence-is-coherently-invertible : + coherence-square-homotopies + ( R ·r (g ∘ f ∘ g)) + ( (g ∘ f ∘ g) ·l S) + ( R ·r g) + ( R ·r g) + naturality-square-transposition-coherence-is-coherently-invertible = + ( ap-concat-htpy' + ( R ·r g) + ( coh-transposition-coherence-is-coherently-invertible)) ∙h + ( inv-htpy (nat-htpy R ·r (R ·r g))) ∙h + ( ap-concat-htpy + ( R ·r (g ∘ f ∘ g)) + ( left-unit-law-left-whisker-comp (R ·r g))) + + abstract + coherence-transposition-coherence-is-coherently-invertible : + coherence-is-transpose-coherently-invertible f g S R + coherence-transposition-coherence-is-coherently-invertible = + ( ap-concat-htpy' + ( R ·r g) + ( inv-htpy (left-inv-htpy ((g ∘ f ∘ g) ·l S)))) ∙h + ( assoc-htpy (inv-htpy ((g ∘ f ∘ g) ·l S)) ((g ∘ f ∘ g) ·l S) (R ·r g)) ∙h + ( ap-concat-htpy + ( inv-htpy ((g ∘ f ∘ g) ·l S)) + ( inv-htpy (nat-htpy (R ·r g) ·r S))) ∙h + ( inv-htpy + ( assoc-htpy + ( inv-htpy ((g ∘ f ∘ g) ·l S)) + ( R ·r (g ∘ f ∘ g)) + ( g ·l S))) ∙h + ( ap-concat-htpy' + ( g ·l S) + ( ( vertical-inv-coherence-square-homotopies + ( R ·r (g ∘ f ∘ g)) ((g ∘ f ∘ g) ·l S) (R ·r g) (R ·r g) + ( naturality-square-transposition-coherence-is-coherently-invertible)) ∙h + ( right-inv-htpy (R ·r g)))) ``` ```agda @@ -780,17 +790,17 @@ module _ ### Coherently invertible maps are closed under homotopies -Assume given a coherently invertible map `f` with inverse `g`, homotopies -`S : f ∘ g ~ id`, `R : g ∘ f ~ id` and coherence `C : Sf ~ fR`. Moreover, assume -the map `f'` is homotopic to `f` with homotopy `H : f' ~ f`. Then `g` is also a -two-sided inverse to `f'` via the homotopies +**Proof.** Assume given a coherently invertible map `f` with inverse `g`, +homotopies `S : f ∘ g ~ id`, `R : g ∘ f ~ id` and coherence `C : Sf ~ fR`. +Moreover, assume the map `f'` is homotopic to `f` with homotopy `H : f' ~ f`. +Then `g` is also a two-sided inverse to `f'` via the homotopies ```text S' := Hg ∙ S : f' ∘ g ~ id and R' := gH ∙ R : g ∘ f' ~ id ``` -Now, we can also show that these witnesses are part of a coherent inverse to -`f'`. To show this, we must construct a coherence `C'` of the square +These witnesses are also part of a coherent inverse to `f'`. To show this, we +must construct a coherence `C'` of the square ```text Hgf' @@ -802,7 +812,7 @@ Now, we can also show that these witnesses are part of a coherent inverse to f'R ``` -We begin by observing that `C` fits somehere along the diagonal of this square +We begin by observing that `C` fits somewhere along the diagonal of this square via the composite ```text @@ -817,7 +827,7 @@ via the composite module _ {l1 l2 : Level} {A : UU l1} {B : UU l2} {f f' : A → B} (H : f' ~ f) (g : B → A) (S : f ∘ g ~ id) (R : g ∘ f ~ id) (C : S ·r f ~ f ·l R) - where abstract + where coh-coh-is-coherently-invertible-htpy : horizontal-concat-htpy' (H ·r g) H ∙h (S ·r f ∙h inv-htpy H) ~ @@ -853,7 +863,7 @@ squares H H ``` -These squares are naturality squares, however, so we are done. +However, these squares are naturality squares, so we are done. ```agda coh-section-is-coherently-invertible-htpy : @@ -895,38 +905,41 @@ These squares are naturality squares, however, so we are done. ( inv-htpy (distributive-left-whisker-comp-concat f' (g ·l H) R)) ``` +Finally, we concatenate the three coherences to obtain our desired result. + ```agda module _ {l1 l2 : Level} {A : UU l1} {B : UU l2} {f f' : A → B} where - coh-is-coherently-invertible-htpy : - (H : f' ~ f) (F : is-coherently-invertible f) → - coherence-is-coherently-invertible - ( f') - ( map-inv-is-coherently-invertible F) - ( is-section-map-inv-is-invertible-htpy - ( H) - ( is-invertible-is-coherently-invertible F)) - ( is-retraction-map-inv-is-invertible-htpy - ( H) - ( is-invertible-is-coherently-invertible F)) - coh-is-coherently-invertible-htpy H F = - ( coh-section-is-coherently-invertible-htpy H - ( map-inv-is-coherently-invertible F) - ( is-section-map-inv-is-coherently-invertible F) - ( is-retraction-map-inv-is-coherently-invertible F) - ( coh-is-coherently-invertible F)) ∙h - ( coh-coh-is-coherently-invertible-htpy H - ( map-inv-is-coherently-invertible F) - ( is-section-map-inv-is-coherently-invertible F) - ( is-retraction-map-inv-is-coherently-invertible F) - ( coh-is-coherently-invertible F)) ∙h - ( coh-retraction-is-coherently-invertible-htpy H - ( map-inv-is-coherently-invertible F) - ( is-section-map-inv-is-coherently-invertible F) - ( is-retraction-map-inv-is-coherently-invertible F) - ( coh-is-coherently-invertible F)) + abstract + coh-is-coherently-invertible-htpy : + (H : f' ~ f) (F : is-coherently-invertible f) → + coherence-is-coherently-invertible + ( f') + ( map-inv-is-coherently-invertible F) + ( is-section-map-inv-is-invertible-htpy + ( H) + ( is-invertible-is-coherently-invertible F)) + ( is-retraction-map-inv-is-invertible-htpy + ( H) + ( is-invertible-is-coherently-invertible F)) + coh-is-coherently-invertible-htpy H F = + ( coh-section-is-coherently-invertible-htpy H + ( map-inv-is-coherently-invertible F) + ( is-section-map-inv-is-coherently-invertible F) + ( is-retraction-map-inv-is-coherently-invertible F) + ( coh-is-coherently-invertible F)) ∙h + ( coh-coh-is-coherently-invertible-htpy H + ( map-inv-is-coherently-invertible F) + ( is-section-map-inv-is-coherently-invertible F) + ( is-retraction-map-inv-is-coherently-invertible F) + ( coh-is-coherently-invertible F)) ∙h + ( coh-retraction-is-coherently-invertible-htpy H + ( map-inv-is-coherently-invertible F) + ( is-section-map-inv-is-coherently-invertible F) + ( is-retraction-map-inv-is-coherently-invertible F) + ( coh-is-coherently-invertible F)) is-coherently-invertible-htpy : f' ~ f → is-coherently-invertible f → is-coherently-invertible f' @@ -939,6 +952,24 @@ module _ f ~ f' → is-coherently-invertible f → is-coherently-invertible f' is-coherently-invertible-inv-htpy H = is-coherently-invertible-htpy (inv-htpy H) + +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} {f : A → B} + where + + is-coherently-invertible-htpy-coherently-invertible-map : + (e : coherently-invertible-map A B) → + f ~ map-coherently-invertible-map e → + is-coherently-invertible f + is-coherently-invertible-htpy-coherently-invertible-map (e , E) H = + is-coherently-invertible-htpy H E + + is-coherently-invertible-inv-htpy-coherently-invertible-map : + (e : coherently-invertible-map A B) → + map-coherently-invertible-map e ~ f → + is-coherently-invertible f + is-coherently-invertible-inv-htpy-coherently-invertible-map (e , E) H = + is-coherently-invertible-inv-htpy H E ``` ### The identity map is coherently invertible @@ -1144,7 +1175,7 @@ property the 3-for-2 property, despite most mathematicians calling it the _2-out-of-3 property_. The story goes that on the produce market is is common to advertise a discount as "3-for-2". If you buy two apples, then you get the third for free. Similarly, if you prove that two maps in a commuting triangle are -equivalences, then you get the third for free. +coherently invertible, then you get the third proof for free. #### The left map in a commuting triangle is coherently invertible if the other two maps are @@ -1154,13 +1185,12 @@ module _ (f : A → X) (g : B → X) (h : A → B) (T : f ~ g ∘ h) where - abstract - is-coherently-invertible-left-map-triangle : - is-coherently-invertible h → - is-coherently-invertible g → - is-coherently-invertible f - is-coherently-invertible-left-map-triangle H G = - is-coherently-invertible-htpy T (is-coherently-invertible-comp g h G H) + is-coherently-invertible-left-map-triangle : + is-coherently-invertible h → + is-coherently-invertible g → + is-coherently-invertible f + is-coherently-invertible-left-map-triangle H G = + is-coherently-invertible-htpy T (is-coherently-invertible-comp g h G H) ``` #### The right map in a commuting triangle is coherently invertible if the other two maps are @@ -1171,23 +1201,22 @@ module _ (f : A → X) (g : B → X) (h : A → B) (T : f ~ g ∘ h) where - abstract - is-coherently-invertible-right-map-triangle : - is-coherently-invertible f → - is-coherently-invertible h → - is-coherently-invertible g - is-coherently-invertible-right-map-triangle F H = - is-coherently-invertible-htpy - ( ( g ·l inv-htpy (is-section-map-inv-is-coherently-invertible H)) ∙h - ( inv-htpy T ·r map-inv-is-coherently-invertible H)) - ( is-coherently-invertible-comp - ( f) - ( map-inv-is-coherently-invertible H) - ( F) - ( is-coherently-invertible-map-inv-is-coherently-invertible H)) + is-coherently-invertible-right-map-triangle : + is-coherently-invertible f → + is-coherently-invertible h → + is-coherently-invertible g + is-coherently-invertible-right-map-triangle F H = + is-coherently-invertible-htpy + ( ( g ·l inv-htpy (is-section-map-inv-is-coherently-invertible H)) ∙h + ( inv-htpy T ·r map-inv-is-coherently-invertible H)) + ( is-coherently-invertible-comp + ( f) + ( map-inv-is-coherently-invertible H) + ( F) + ( is-coherently-invertible-map-inv-is-coherently-invertible H)) ``` -#### The top map in a commuting triangle is coherently invertible if the other two maps +#### The top map in a commuting triangle is coherently invertible if the other two maps are ```agda module _ @@ -1195,20 +1224,19 @@ module _ (f : A → X) (g : B → X) (h : A → B) (T : f ~ g ∘ h) where - abstract - is-coherently-invertible-top-map-triangle : - is-coherently-invertible g → - is-coherently-invertible f → - is-coherently-invertible h - is-coherently-invertible-top-map-triangle G F = - is-coherently-invertible-htpy - ( ( inv-htpy (is-retraction-map-inv-is-coherently-invertible G) ·r h) ∙h - ( map-inv-is-coherently-invertible G ·l inv-htpy T)) - ( is-coherently-invertible-comp - ( map-inv-is-coherently-invertible G) - ( f) - ( is-coherently-invertible-map-inv-is-coherently-invertible G) - ( F)) + is-coherently-invertible-top-map-triangle : + is-coherently-invertible g → + is-coherently-invertible f → + is-coherently-invertible h + is-coherently-invertible-top-map-triangle G F = + is-coherently-invertible-htpy + ( ( inv-htpy (is-retraction-map-inv-is-coherently-invertible G) ·r h) ∙h + ( map-inv-is-coherently-invertible G ·l inv-htpy T)) + ( is-coherently-invertible-comp + ( map-inv-is-coherently-invertible G) + ( f) + ( is-coherently-invertible-map-inv-is-coherently-invertible G) + ( F)) ``` #### If a composite and its right factor are coherently invertible, then so is its left factor @@ -1243,12 +1271,32 @@ module _ is-coherently-invertible-top-map-triangle (g ∘ h) g h refl-htpy G GH ``` +### Any section of a coherently invertible map is coherently invertible + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} + where + + is-coherently-invertible-is-section : + {f : A → B} {g : B → A} → + is-coherently-invertible f → f ∘ g ~ id → is-coherently-invertible g + is-coherently-invertible-is-section {f = f} {g} F H = + is-coherently-invertible-top-map-triangle id f g + ( inv-htpy H) + ( F) + ( is-coherently-invertible-id) +``` + ### Any retraction of a coherently invertible map is coherently invertible ```agda -abstract +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} + where + is-coherently-invertible-is-retraction : - {l1 l2 : Level} {A : UU l1} {B : UU l2} {f : A → B} {g : B → A} → + {f : A → B} {g : B → A} → is-coherently-invertible f → (g ∘ f) ~ id → is-coherently-invertible g is-coherently-invertible-is-retraction {f = f} {g} F H = is-coherently-invertible-right-map-triangle id g f @@ -1257,21 +1305,21 @@ abstract ( F) ``` -### Any section of a coherently invertible map is coherently invertible +### If a section of `f` is coherently invertible, then `f` is coherently invertible ```agda -abstract - is-coherently-invertible-is-section : - {l1 l2 : Level} {A : UU l1} {B : UU l2} {f : A → B} {g : B → A} → - is-coherently-invertible f → f ∘ g ~ id → is-coherently-invertible g - is-coherently-invertible-is-section {f = f} {g} F H = - is-coherently-invertible-top-map-triangle id f g - ( inv-htpy H) - ( F) - ( is-coherently-invertible-id) +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} (f : A → B) + where + + is-coherently-invertible-is-coherently-invertible-section : + (s : section f) → + is-coherently-invertible (map-section f s) → is-coherently-invertible f + is-coherently-invertible-is-coherently-invertible-section (g , G) S = + is-coherently-invertible-is-retraction S G ``` -### If a section of `f` is coherently invertible, then `f` is coherently invertible +### If a retraction of `f` is coherently invertible, then `f` is coherently invertible ```agda module _ @@ -1279,23 +1327,52 @@ module _ where abstract - is-coherently-invertible-section-is-coherently-invertible : - ( section-f : section f) → - is-coherently-invertible (pr1 section-f) → is-coherently-invertible f - is-coherently-invertible-section-is-coherently-invertible - ( g , is-section-g) S = - is-coherently-invertible-htpy - ( ( f ·l (inv-htpy (is-section-map-inv-is-coherently-invertible S))) ∙h - ( right-whisker-comp - ( is-section-g) - ( map-inv-is-coherently-invertible S))) - ( is-coherently-invertible-map-inv-is-coherently-invertible S) + is-coherently-invertible-is-coherently-invertible-retraction : + (r : retraction f) → + is-coherently-invertible (map-retraction f r) → is-coherently-invertible f + is-coherently-invertible-is-coherently-invertible-retraction (g , G) R = + is-coherently-invertible-is-section R G +``` + +### Any section of a coherently invertible map is homotopic to its inverse + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} (e : coherently-invertible-map A B) + where + + htpy-map-inv-coherently-invertible-map-section : + (f : section (map-coherently-invertible-map e)) → + map-inv-coherently-invertible-map e ~ + map-section (map-coherently-invertible-map e) f + htpy-map-inv-coherently-invertible-map-section (f , H) = + ( map-inv-coherently-invertible-map e ·l inv-htpy H) ∙h + ( is-retraction-map-inv-coherently-invertible-map e ·r f) +``` + +### Any retraction of a coherently invertible map is homotopic to its inverse + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} (e : coherently-invertible-map A B) + where + + htpy-map-inv-coherently-invertible-map-retraction : + (f : retraction (map-coherently-invertible-map e)) → + map-inv-coherently-invertible-map e ~ + map-retraction (map-coherently-invertible-map e) f + htpy-map-inv-coherently-invertible-map-retraction (f , H) = + ( inv-htpy H ·r map-inv-coherently-invertible-map e) ∙h + ( f ·l is-section-map-inv-coherently-invertible-map e) ``` ## References 1. Egbert Rijke, _Introduction to Homotopy Type Theory_ (2022) ([arXiv:2212.11082](https://arxiv.org/abs/2212.11082)) +2. Univalent Foundations Project, _Homotopy Type Theory – Univalent Foundations + of Mathematics_ (2013) ([website](https://homotopytypetheory.org/book/), + [arXiv:1308.0729](https://arxiv.org/abs/1308.0729)) ## See also @@ -1305,3 +1382,9 @@ module _ [`foundation.contractible-maps`](foundation.contractible-maps.md). - For the notion of path-split maps see [`foundation.path-split-maps`](foundation.path-split-maps.md). + +## External links + +- [Adjoint equivalences](https://1lab.dev/1Lab.Equiv.HalfAdjoint.html) at 1lab +- [adjoint equivalence](https://ncatlab.org/nlab/show/adjoint+equivalence) at + $n$Lab diff --git a/src/foundation-core/equivalences.lagda.md b/src/foundation-core/equivalences.lagda.md index 08b8af5854..489d67c647 100644 --- a/src/foundation-core/equivalences.lagda.md +++ b/src/foundation-core/equivalences.lagda.md @@ -524,16 +524,22 @@ module _ where abstract - is-equiv-section-is-equiv : - ( section-f : section f) → is-equiv (pr1 section-f) → is-equiv f - is-equiv-section-is-equiv (g , is-section-g) is-equiv-section-f = - is-equiv-htpy h - ( ( f ·l (inv-htpy (is-section-map-inv-is-equiv is-equiv-section-f))) ∙h - ( right-whisker-comp is-section-g h)) - ( is-equiv-map-inv-is-equiv is-equiv-section-f) - where - h : A → B - h = map-inv-is-equiv is-equiv-section-f + is-equiv-is-equiv-section : + (s : section f) → is-equiv (map-section f s) → is-equiv f + is-equiv-is-equiv-section (g , G) S = is-equiv-is-retraction S G +``` + +### If a retraction of `f` is an equivalence, then `f` is an equivalence + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} (f : A → B) + where + + abstract + is-equiv-is-equiv-retraction : + (r : retraction f) → is-equiv (map-retraction f r) → is-equiv f + is-equiv-is-equiv-retraction (g , G) R = is-equiv-is-section R G ``` ### Any section of an equivalence is homotopic to its inverse diff --git a/src/foundation/fundamental-theorem-of-identity-types.lagda.md b/src/foundation/fundamental-theorem-of-identity-types.lagda.md index 9614810977..a82990327e 100644 --- a/src/foundation/fundamental-theorem-of-identity-types.lagda.md +++ b/src/foundation/fundamental-theorem-of-identity-types.lagda.md @@ -145,7 +145,7 @@ module _ ((x : A) → section (f x)) → is-fiberwise-equiv f fundamental-theorem-id-section f section-f x = - is-equiv-section-is-equiv + is-equiv-is-equiv-section ( f x) ( section-f x) ( fundamental-theorem-id-retraction From 7801574929e702a79a91e7639f39efc7024b65ac Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Tue, 13 Feb 2024 13:01:28 +0100 Subject: [PATCH 32/53] slight proof optimization `is-proof-irrelevant-is-coherently-invertible` --- .../coherently-invertible-maps.lagda.md | 24 +++++++--- .../contractible-maps.lagda.md | 7 ++- src/foundation-core/equivalences.lagda.md | 15 ++++++- src/foundation-core/invertible-maps.lagda.md | 32 +++++++++++++ .../coherently-invertible-maps.lagda.md | 45 ++++++++++++++++--- 5 files changed, 106 insertions(+), 17 deletions(-) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index 008a74d71a..f9bbf88a32 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -213,6 +213,12 @@ module _ is-invertible-map-coherently-invertible-map = is-invertible-is-coherently-invertible ( is-coherently-invertible-map-coherently-invertible-map) + + invertible-map-coherently-invertible-map : invertible-map A B + pr1 invertible-map-coherently-invertible-map = + map-coherently-invertible-map + pr2 invertible-map-coherently-invertible-map = + is-invertible-map-coherently-invertible-map ``` ### The predicate of being transpose coherently invertible on maps @@ -351,6 +357,12 @@ module _ is-invertible-map-transpose-coherently-invertible-map = is-invertible-is-transpose-coherently-invertible ( is-transpose-coherently-invertible-map-transpose-coherently-invertible-map) + + invertible-map-transpose-coherently-invertible-map : invertible-map A B + pr1 invertible-map-transpose-coherently-invertible-map = + map-transpose-coherently-invertible-map + pr2 invertible-map-transpose-coherently-invertible-map = + is-invertible-map-transpose-coherently-invertible-map ``` ### Invertible maps that are coherent are coherently invertible maps @@ -1345,9 +1357,9 @@ module _ (f : section (map-coherently-invertible-map e)) → map-inv-coherently-invertible-map e ~ map-section (map-coherently-invertible-map e) f - htpy-map-inv-coherently-invertible-map-section (f , H) = - ( map-inv-coherently-invertible-map e ·l inv-htpy H) ∙h - ( is-retraction-map-inv-coherently-invertible-map e ·r f) + htpy-map-inv-coherently-invertible-map-section = + htpy-map-inv-invertible-map-section + ( invertible-map-coherently-invertible-map e) ``` ### Any retraction of a coherently invertible map is homotopic to its inverse @@ -1361,9 +1373,9 @@ module _ (f : retraction (map-coherently-invertible-map e)) → map-inv-coherently-invertible-map e ~ map-retraction (map-coherently-invertible-map e) f - htpy-map-inv-coherently-invertible-map-retraction (f , H) = - ( inv-htpy H ·r map-inv-coherently-invertible-map e) ∙h - ( f ·l is-section-map-inv-coherently-invertible-map e) + htpy-map-inv-coherently-invertible-map-retraction = + htpy-map-inv-invertible-map-retraction + ( invertible-map-coherently-invertible-map e) ``` ## References diff --git a/src/foundation-core/contractible-maps.lagda.md b/src/foundation-core/contractible-maps.lagda.md index bdab98b6f0..624c850cd4 100644 --- a/src/foundation-core/contractible-maps.lagda.md +++ b/src/foundation-core/contractible-maps.lagda.md @@ -66,10 +66,9 @@ module _ ( ( inv ( contraction ( H (f x)) - ( pair - ( map-inv-is-contr-map H (f x)) + ( ( map-inv-is-contr-map H (f x)) , ( is-section-map-inv-is-contr-map H (f x))))) ∙ - ( contraction (H (f x)) (pair x refl))) + ( contraction (H (f x)) (x , refl))) abstract is-equiv-is-contr-map : is-contr-map f → is-equiv f @@ -98,7 +97,7 @@ module _ contraction-fiber-is-coherently-invertible : (H : is-coherently-invertible f) → (y : B) → (t : fiber f y) → (center-fiber-is-coherently-invertible H y) = t - contraction-fiber-is-coherently-invertible H y (pair x refl) = + contraction-fiber-is-coherently-invertible H y (x , refl) = eq-Eq-fiber f y ( is-retraction-map-inv-is-coherently-invertible H x) ( ( right-unit) ∙ diff --git a/src/foundation-core/equivalences.lagda.md b/src/foundation-core/equivalences.lagda.md index 489d67c647..37167decfe 100644 --- a/src/foundation-core/equivalences.lagda.md +++ b/src/foundation-core/equivalences.lagda.md @@ -209,15 +209,26 @@ module _ where abstract - is-coherently-invertible-is-equiv : is-equiv f → is-coherently-invertible f + is-coherently-invertible-is-equiv : + is-equiv f → is-coherently-invertible f is-coherently-invertible-is-equiv = is-coherently-invertible-is-invertible ∘ is-invertible-is-equiv - abstract is-equiv-is-coherently-invertible : is-coherently-invertible f → is-equiv f is-equiv-is-coherently-invertible H = is-equiv-is-invertible' (is-invertible-is-coherently-invertible H) + + is-transpose-coherently-invertible-is-equiv : + is-equiv f → is-transpose-coherently-invertible f + is-transpose-coherently-invertible-is-equiv = + is-transpose-coherently-invertible-is-invertible ∘ is-invertible-is-equiv + + is-equiv-is-transpose-coherently-invertible : + is-transpose-coherently-invertible f → is-equiv f + is-equiv-is-transpose-coherently-invertible H = + is-equiv-is-invertible' + ( is-invertible-is-transpose-coherently-invertible H) ``` ### Structure obtained from being coherently invertible diff --git a/src/foundation-core/invertible-maps.lagda.md b/src/foundation-core/invertible-maps.lagda.md index ffaa087fdc..7f27ae6c22 100644 --- a/src/foundation-core/invertible-maps.lagda.md +++ b/src/foundation-core/invertible-maps.lagda.md @@ -267,6 +267,38 @@ module _ is-invertible-inv-htpy H = is-invertible-htpy (inv-htpy H) ``` +### Any section of an invertible map is homotopic to its inverse + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} (e : invertible-map A B) + where + + htpy-map-inv-invertible-map-section : + (f : section (map-invertible-map e)) → + map-inv-invertible-map e ~ + map-section (map-invertible-map e) f + htpy-map-inv-invertible-map-section (f , H) = + ( map-inv-invertible-map e ·l inv-htpy H) ∙h + ( is-retraction-map-inv-invertible-map e ·r f) +``` + +### Any retraction of an invertible map is homotopic to its inverse + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} (e : invertible-map A B) + where + + htpy-map-inv-invertible-map-retraction : + (f : retraction (map-invertible-map e)) → + map-inv-invertible-map e ~ + map-retraction (map-invertible-map e) f + htpy-map-inv-invertible-map-retraction (f , H) = + ( inv-htpy H ·r map-inv-invertible-map e) ∙h + ( f ·l is-section-map-inv-invertible-map e) +``` + ## See also - For the coherent notion of invertible maps see diff --git a/src/foundation/coherently-invertible-maps.lagda.md b/src/foundation/coherently-invertible-maps.lagda.md index c0c6c6c1c7..55cc87baf0 100644 --- a/src/foundation/coherently-invertible-maps.lagda.md +++ b/src/foundation/coherently-invertible-maps.lagda.md @@ -26,6 +26,7 @@ open import foundation-core.function-types open import foundation-core.functoriality-dependent-pair-types open import foundation-core.homotopies open import foundation-core.propositions +open import foundation-core.retractions open import foundation-core.sections open import foundation-core.type-theoretic-principle-of-choice ``` @@ -34,6 +35,42 @@ open import foundation-core.type-theoretic-principle-of-choice ## Properties +### Coherently invertible maps have a contractible type of sections + +**Proof:** Since coherently invertible maps are +[contractible maps](foundation.contractible-maps.md), and products of +[contractible types](foundation-core.contractible-types.md) are contractible, it +follows that the type + +```text + (b : B) → fiber f b +``` + +is contractible, for any coherently invertible map `f`. However, by the +[type theoretic principle of choice](foundation.type-theoretic-principle-of-choice.md) +it follows that this type is equivalent to the type + +```text + Σ (B → A) (λ g → (b : B) → f (g b) = b), +``` + +which is the type of [sections](foundation.sections.md) of `f`. + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} + where + + abstract + is-contr-section-is-coherently-invertible : + {f : A → B} → is-coherently-invertible f → is-contr (section f) + is-contr-section-is-coherently-invertible {f} F = + is-contr-equiv' + ( (b : B) → fiber f b) + ( distributive-Π-Σ) + ( is-contr-Π (is-contr-map-is-coherently-invertible F)) +``` + ### Being coherently invertible is a property ```agda @@ -49,7 +86,7 @@ module _ ( _) ( associative-Σ _ _ _) ( is-contr-Σ - ( is-contr-section-is-equiv (is-equiv-is-coherently-invertible H)) + ( is-contr-section-is-coherently-invertible H) ( section-is-coherently-invertible H) ( is-contr-equiv' ( _) @@ -63,10 +100,8 @@ module _ equiv-inv ( ap f p) ( is-section-map-inv-is-coherently-invertible H (f x)))) - ( is-contr-map-is-equiv - ( is-emb-is-equiv - ( is-equiv-is-coherently-invertible H) - ( map-inv-is-coherently-invertible H (f x)) x) + ( is-contr-map-is-coherently-invertible + ( is-coherently-invertible-ap-is-coherently-invertible H) ( is-section-map-inv-is-coherently-invertible H (f x))))))) abstract From 77bfaaadb5ae05f11bc6363b8d8d389db971064b Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Tue, 13 Feb 2024 13:01:59 +0100 Subject: [PATCH 33/53] it remains to be formalized that being transpose coherently invertible is a property --- src/foundation/coherently-invertible-maps.lagda.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/src/foundation/coherently-invertible-maps.lagda.md b/src/foundation/coherently-invertible-maps.lagda.md index 55cc87baf0..c87e434bba 100644 --- a/src/foundation/coherently-invertible-maps.lagda.md +++ b/src/foundation/coherently-invertible-maps.lagda.md @@ -119,6 +119,10 @@ module _ ( is-equiv-is-coherently-invertible) ``` +### Being transpose coherently invertible is a property + +This remains to be formalized. + ## References 1. Univalent Foundations Project, _Homotopy Type Theory – Univalent Foundations From 89562dfafd50d826e34983cbe7e4de0b8fe6454f Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Tue, 13 Feb 2024 13:02:45 +0100 Subject: [PATCH 34/53] pre-commit --- src/foundation-core/coherently-invertible-maps.lagda.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index f9bbf88a32..dd0e3bc298 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -1375,7 +1375,7 @@ module _ map-retraction (map-coherently-invertible-map e) f htpy-map-inv-coherently-invertible-map-retraction = htpy-map-inv-invertible-map-retraction - ( invertible-map-coherently-invertible-map e) + ( invertible-map-coherently-invertible-map e) ``` ## References From 5d7997312d8b96dfc1d5f28ef95cd21f0a59a6f0 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Tue, 13 Feb 2024 13:27:22 +0100 Subject: [PATCH 35/53] remove unused imports --- .../commuting-squares-of-homotopies.lagda.md | 2 -- .../commuting-squares-of-identifications.lagda.md | 1 - src/foundation-core/equivalences.lagda.md | 1 - src/foundation-core/invertible-maps.lagda.md | 2 -- .../whiskering-identifications-concatenation.lagda.md | 2 -- .../action-on-higher-identifications-functions.lagda.md | 2 +- src/foundation/action-on-homotopies-functions.lagda.md | 2 +- src/foundation/coherently-invertible-maps.lagda.md | 4 +--- src/foundation/commuting-cubes-of-maps.lagda.md | 2 +- src/foundation/commuting-prisms-of-maps.lagda.md | 2 +- src/foundation/commuting-squares-of-homotopies.lagda.md | 4 ---- .../commuting-squares-of-identifications.lagda.md | 4 ---- src/foundation/commuting-squares-of-maps.lagda.md | 9 ++++----- .../commuting-triangles-of-homotopies.lagda.md | 2 +- src/foundation/commuting-triangles-of-maps.lagda.md | 2 +- src/foundation/embeddings.lagda.md | 2 +- src/foundation/equivalences.lagda.md | 4 +--- src/foundation/homotopies.lagda.md | 4 ++-- src/foundation/invertible-maps.lagda.md | 2 +- src/foundation/path-algebra.lagda.md | 4 ++-- .../whiskering-higher-homotopies-composition.lagda.md | 1 - .../whiskering-homotopies-concatenation.lagda.md | 2 +- 22 files changed, 19 insertions(+), 41 deletions(-) diff --git a/src/foundation-core/commuting-squares-of-homotopies.lagda.md b/src/foundation-core/commuting-squares-of-homotopies.lagda.md index 4c95f639c7..b974dd72ef 100644 --- a/src/foundation-core/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation-core/commuting-squares-of-homotopies.lagda.md @@ -12,8 +12,6 @@ open import foundation.whiskering-homotopies-composition open import foundation-core.commuting-squares-of-identifications open import foundation-core.homotopies -open import foundation-core.retractions -open import foundation-core.sections open import foundation-core.whiskering-homotopies-concatenation ``` diff --git a/src/foundation-core/commuting-squares-of-identifications.lagda.md b/src/foundation-core/commuting-squares-of-identifications.lagda.md index 19c3bd6317..1d9e3c6f05 100644 --- a/src/foundation-core/commuting-squares-of-identifications.lagda.md +++ b/src/foundation-core/commuting-squares-of-identifications.lagda.md @@ -8,7 +8,6 @@ module foundation-core.commuting-squares-of-identifications where ```agda open import foundation.action-on-identifications-functions -open import foundation.dependent-pair-types open import foundation.universe-levels open import foundation-core.function-types diff --git a/src/foundation-core/equivalences.lagda.md b/src/foundation-core/equivalences.lagda.md index 37167decfe..9945173a8f 100644 --- a/src/foundation-core/equivalences.lagda.md +++ b/src/foundation-core/equivalences.lagda.md @@ -7,7 +7,6 @@ module foundation-core.equivalences where
Imports ```agda -open import foundation.action-on-identifications-binary-functions open import foundation.action-on-identifications-functions open import foundation.dependent-pair-types open import foundation.universe-levels diff --git a/src/foundation-core/invertible-maps.lagda.md b/src/foundation-core/invertible-maps.lagda.md index 7f27ae6c22..b48b8a5938 100644 --- a/src/foundation-core/invertible-maps.lagda.md +++ b/src/foundation-core/invertible-maps.lagda.md @@ -7,8 +7,6 @@ module foundation-core.invertible-maps where
Imports ```agda -open import foundation.action-on-identifications-binary-functions -open import foundation.action-on-identifications-functions open import foundation.dependent-pair-types open import foundation.universe-levels open import foundation.whiskering-homotopies-composition diff --git a/src/foundation-core/whiskering-identifications-concatenation.lagda.md b/src/foundation-core/whiskering-identifications-concatenation.lagda.md index 8a02a996b3..9710a2cb0e 100644 --- a/src/foundation-core/whiskering-identifications-concatenation.lagda.md +++ b/src/foundation-core/whiskering-identifications-concatenation.lagda.md @@ -8,11 +8,9 @@ module foundation-core.whiskering-identifications-concatenation where ```agda open import foundation.action-on-identifications-functions -open import foundation.dependent-pair-types open import foundation.universe-levels open import foundation.whiskering-operations -open import foundation-core.function-types open import foundation-core.homotopies open import foundation-core.identity-types ``` diff --git a/src/foundation/action-on-higher-identifications-functions.lagda.md b/src/foundation/action-on-higher-identifications-functions.lagda.md index 1553a81b60..b09a5cf131 100644 --- a/src/foundation/action-on-higher-identifications-functions.lagda.md +++ b/src/foundation/action-on-higher-identifications-functions.lagda.md @@ -8,10 +8,10 @@ module foundation.action-on-higher-identifications-functions where ```agda open import foundation.action-on-identifications-functions -open import foundation.commuting-squares-of-identifications open import foundation.path-algebra open import foundation.universe-levels +open import foundation-core.commuting-squares-of-identifications open import foundation-core.constant-maps open import foundation-core.function-types open import foundation-core.homotopies diff --git a/src/foundation/action-on-homotopies-functions.lagda.md b/src/foundation/action-on-homotopies-functions.lagda.md index cd4c2023db..0bb5100c4c 100644 --- a/src/foundation/action-on-homotopies-functions.lagda.md +++ b/src/foundation/action-on-homotopies-functions.lagda.md @@ -11,13 +11,13 @@ open import foundation.action-on-higher-identifications-functions open import foundation.action-on-identifications-functions open import foundation.dependent-pair-types open import foundation.function-extensionality -open import foundation.homotopies open import foundation.homotopy-induction open import foundation.universe-levels open import foundation-core.constant-maps open import foundation-core.contractible-types open import foundation-core.function-types +open import foundation-core.homotopies open import foundation-core.identity-types ``` diff --git a/src/foundation/coherently-invertible-maps.lagda.md b/src/foundation/coherently-invertible-maps.lagda.md index c87e434bba..d43a5f5702 100644 --- a/src/foundation/coherently-invertible-maps.lagda.md +++ b/src/foundation/coherently-invertible-maps.lagda.md @@ -10,19 +10,17 @@ open import foundation-core.coherently-invertible-maps public ```agda open import foundation.action-on-identifications-functions -open import foundation.commuting-squares-of-homotopies open import foundation.dependent-pair-types open import foundation.equivalences open import foundation.identity-types open import foundation.type-arithmetic-dependent-pair-types open import foundation.universe-levels open import foundation.whiskering-higher-homotopies-composition -open import foundation.whiskering-homotopies-composition +open import foundation-core.commuting-squares-of-homotopies open import foundation-core.contractible-maps open import foundation-core.contractible-types open import foundation-core.fibers-of-maps -open import foundation-core.function-types open import foundation-core.functoriality-dependent-pair-types open import foundation-core.homotopies open import foundation-core.propositions diff --git a/src/foundation/commuting-cubes-of-maps.lagda.md b/src/foundation/commuting-cubes-of-maps.lagda.md index 47d6b48201..13e4c00e42 100644 --- a/src/foundation/commuting-cubes-of-maps.lagda.md +++ b/src/foundation/commuting-cubes-of-maps.lagda.md @@ -16,11 +16,11 @@ open import foundation.function-extensionality open import foundation.homotopies open import foundation.universe-levels open import foundation.whiskering-homotopies-composition -open import foundation.whiskering-identifications-concatenation open import foundation-core.function-types open import foundation-core.identity-types open import foundation-core.precomposition-functions +open import foundation-core.whiskering-identifications-concatenation ```
diff --git a/src/foundation/commuting-prisms-of-maps.lagda.md b/src/foundation/commuting-prisms-of-maps.lagda.md index 810596852b..0c374973c9 100644 --- a/src/foundation/commuting-prisms-of-maps.lagda.md +++ b/src/foundation/commuting-prisms-of-maps.lagda.md @@ -10,7 +10,6 @@ open import foundation-core.commuting-prisms-of-maps public ```agda open import foundation.action-on-identifications-functions -open import foundation.commuting-squares-of-homotopies open import foundation.commuting-squares-of-maps open import foundation.commuting-triangles-of-maps open import foundation.composition-algebra @@ -22,6 +21,7 @@ open import foundation.precomposition-functions open import foundation.universe-levels open import foundation.whiskering-homotopies-composition +open import foundation-core.commuting-squares-of-homotopies open import foundation-core.equivalences open import foundation-core.function-types open import foundation-core.functoriality-dependent-function-types diff --git a/src/foundation/commuting-squares-of-homotopies.lagda.md b/src/foundation/commuting-squares-of-homotopies.lagda.md index ce4fbf4e35..dc4e5412ce 100644 --- a/src/foundation/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation/commuting-squares-of-homotopies.lagda.md @@ -9,18 +9,14 @@ open import foundation-core.commuting-squares-of-homotopies public
Imports ```agda -open import foundation.action-on-homotopies-functions open import foundation.commuting-squares-of-identifications open import foundation.dependent-pair-types open import foundation.universe-levels open import foundation-core.equivalences -open import foundation-core.function-types open import foundation-core.functoriality-dependent-function-types open import foundation-core.homotopies open import foundation-core.identity-types -open import foundation-core.retractions -open import foundation-core.sections ```
diff --git a/src/foundation/commuting-squares-of-identifications.lagda.md b/src/foundation/commuting-squares-of-identifications.lagda.md index 564b640778..4f9fb6f982 100644 --- a/src/foundation/commuting-squares-of-identifications.lagda.md +++ b/src/foundation/commuting-squares-of-identifications.lagda.md @@ -9,15 +9,11 @@ open import foundation-core.commuting-squares-of-identifications public
Imports ```agda -open import foundation.action-on-identifications-functions open import foundation.dependent-pair-types open import foundation.universe-levels open import foundation-core.equivalences -open import foundation-core.function-types open import foundation-core.identity-types -open import foundation-core.retractions -open import foundation-core.sections ```
diff --git a/src/foundation/commuting-squares-of-maps.lagda.md b/src/foundation/commuting-squares-of-maps.lagda.md index 2ef09ca77e..cb2b53f6f1 100644 --- a/src/foundation/commuting-squares-of-maps.lagda.md +++ b/src/foundation/commuting-squares-of-maps.lagda.md @@ -9,26 +9,25 @@ open import foundation-core.commuting-squares-of-maps public
Imports ```agda -open import foundation.action-on-higher-identifications-functions open import foundation.action-on-identifications-binary-functions open import foundation.action-on-identifications-functions -open import foundation.commuting-squares-of-homotopies -open import foundation.commuting-squares-of-identifications open import foundation.commuting-triangles-of-maps open import foundation.function-extensionality -open import foundation.identity-types open import foundation.postcomposition-functions open import foundation.precomposition-functions open import foundation.transposition-identifications-along-equivalences open import foundation.universe-levels open import foundation.whiskering-higher-homotopies-composition open import foundation.whiskering-homotopies-composition -open import foundation.whiskering-identifications-concatenation open import foundation-core.commuting-prisms-of-maps +open import foundation-core.commuting-squares-of-homotopies +open import foundation-core.commuting-squares-of-identifications open import foundation-core.equivalences open import foundation-core.function-types open import foundation-core.homotopies +open import foundation-core.identity-types +open import foundation-core.whiskering-identifications-concatenation ```
diff --git a/src/foundation/commuting-triangles-of-homotopies.lagda.md b/src/foundation/commuting-triangles-of-homotopies.lagda.md index 381b508986..d3f3b61b72 100644 --- a/src/foundation/commuting-triangles-of-homotopies.lagda.md +++ b/src/foundation/commuting-triangles-of-homotopies.lagda.md @@ -11,11 +11,11 @@ open import foundation.action-on-identifications-functions open import foundation.commuting-triangles-of-identifications open import foundation.universe-levels open import foundation.whiskering-homotopies-composition -open import foundation.whiskering-identifications-concatenation open import foundation-core.function-types open import foundation-core.homotopies open import foundation-core.identity-types +open import foundation-core.whiskering-identifications-concatenation ```
diff --git a/src/foundation/commuting-triangles-of-maps.lagda.md b/src/foundation/commuting-triangles-of-maps.lagda.md index 8ee1575c8b..742618605e 100644 --- a/src/foundation/commuting-triangles-of-maps.lagda.md +++ b/src/foundation/commuting-triangles-of-maps.lagda.md @@ -17,11 +17,11 @@ open import foundation.identity-types open import foundation.postcomposition-functions open import foundation.precomposition-functions open import foundation.universe-levels -open import foundation.whiskering-identifications-concatenation open import foundation-core.commuting-squares-of-maps open import foundation-core.equivalences open import foundation-core.function-types +open import foundation-core.whiskering-identifications-concatenation ```
diff --git a/src/foundation/embeddings.lagda.md b/src/foundation/embeddings.lagda.md index 38bd69b1da..31ac2aad1d 100644 --- a/src/foundation/embeddings.lagda.md +++ b/src/foundation/embeddings.lagda.md @@ -10,7 +10,6 @@ open import foundation-core.embeddings public ```agda open import foundation.action-on-identifications-functions -open import foundation.commuting-squares-of-maps open import foundation.cones-over-cospan-diagrams open import foundation.dependent-pair-types open import foundation.equivalences @@ -23,6 +22,7 @@ open import foundation.truncated-maps open import foundation.universe-levels open import foundation-core.cartesian-product-types +open import foundation-core.commuting-squares-of-maps open import foundation-core.commuting-triangles-of-maps open import foundation-core.contractible-types open import foundation-core.fibers-of-maps diff --git a/src/foundation/equivalences.lagda.md b/src/foundation/equivalences.lagda.md index 4138acee7e..9ebb42a77a 100644 --- a/src/foundation/equivalences.lagda.md +++ b/src/foundation/equivalences.lagda.md @@ -15,13 +15,10 @@ open import foundation.dependent-pair-types open import foundation.equivalence-extensionality open import foundation.function-extensionality open import foundation.functoriality-fibers-of-maps -open import foundation.identity-types -open import foundation.path-algebra open import foundation.transposition-identifications-along-equivalences open import foundation.truncated-maps open import foundation.universal-property-equivalences open import foundation.universe-levels -open import foundation.whiskering-identifications-concatenation open import foundation-core.commuting-triangles-of-maps open import foundation-core.contractible-maps @@ -31,6 +28,7 @@ open import foundation-core.fibers-of-maps open import foundation-core.function-types open import foundation-core.functoriality-dependent-pair-types open import foundation-core.homotopies +open import foundation-core.identity-types open import foundation-core.injective-maps open import foundation-core.propositions open import foundation-core.pullbacks diff --git a/src/foundation/homotopies.lagda.md b/src/foundation/homotopies.lagda.md index f047aafe53..124dac3bbf 100644 --- a/src/foundation/homotopies.lagda.md +++ b/src/foundation/homotopies.lagda.md @@ -13,7 +13,6 @@ open import foundation.action-on-higher-identifications-functions open import foundation.action-on-identifications-dependent-functions open import foundation.action-on-identifications-functions open import foundation.binary-equivalences -open import foundation.commuting-squares-of-identifications open import foundation.dependent-pair-types open import foundation.function-extensionality open import foundation.homotopy-induction @@ -21,13 +20,14 @@ open import foundation.identity-types open import foundation.path-algebra open import foundation.universe-levels open import foundation.whiskering-homotopies-composition -open import foundation.whiskering-identifications-concatenation +open import foundation-core.commuting-squares-of-identifications open import foundation-core.dependent-identifications open import foundation-core.equivalences open import foundation-core.function-types open import foundation-core.functoriality-dependent-function-types open import foundation-core.transport-along-identifications +open import foundation-core.whiskering-identifications-concatenation ```
diff --git a/src/foundation/invertible-maps.lagda.md b/src/foundation/invertible-maps.lagda.md index dc4dc8c2c1..bd03f1316a 100644 --- a/src/foundation/invertible-maps.lagda.md +++ b/src/foundation/invertible-maps.lagda.md @@ -23,7 +23,6 @@ open import foundation.homotopies open import foundation.homotopy-algebra open import foundation.homotopy-induction open import foundation.postcomposition-functions -open import foundation.propositions open import foundation.retractions open import foundation.sections open import foundation.structure-identity-principle @@ -36,6 +35,7 @@ open import foundation-core.coherently-invertible-maps open import foundation-core.function-types open import foundation-core.functoriality-dependent-pair-types open import foundation-core.identity-types +open import foundation-core.propositions open import foundation-core.torsorial-type-families open import foundation-core.truncated-types open import foundation-core.truncation-levels diff --git a/src/foundation/path-algebra.lagda.md b/src/foundation/path-algebra.lagda.md index bb110a0312..acd69ff4b6 100644 --- a/src/foundation/path-algebra.lagda.md +++ b/src/foundation/path-algebra.lagda.md @@ -11,16 +11,16 @@ open import foundation.action-on-identifications-binary-functions open import foundation.action-on-identifications-functions open import foundation.binary-embeddings open import foundation.binary-equivalences -open import foundation.commuting-squares-of-identifications open import foundation.dependent-pair-types open import foundation.identity-types open import foundation.universe-levels -open import foundation.whiskering-identifications-concatenation +open import foundation-core.commuting-squares-of-identifications open import foundation-core.constant-maps open import foundation-core.equivalences open import foundation-core.function-types open import foundation-core.homotopies +open import foundation-core.whiskering-identifications-concatenation ```
diff --git a/src/foundation/whiskering-higher-homotopies-composition.lagda.md b/src/foundation/whiskering-higher-homotopies-composition.lagda.md index 68f4e6a54f..2970a34a1e 100644 --- a/src/foundation/whiskering-higher-homotopies-composition.lagda.md +++ b/src/foundation/whiskering-higher-homotopies-composition.lagda.md @@ -12,7 +12,6 @@ open import foundation.universe-levels open import foundation.whiskering-homotopies-composition open import foundation-core.homotopies -open import foundation-core.identity-types ``` diff --git a/src/foundation/whiskering-homotopies-concatenation.lagda.md b/src/foundation/whiskering-homotopies-concatenation.lagda.md index 7c6edd9b0e..dffb6ea28b 100644 --- a/src/foundation/whiskering-homotopies-concatenation.lagda.md +++ b/src/foundation/whiskering-homotopies-concatenation.lagda.md @@ -9,12 +9,12 @@ open import foundation-core.whiskering-homotopies-concatenation public
Imports ```agda -open import foundation.functoriality-dependent-function-types open import foundation.universe-levels open import foundation.whiskering-identifications-concatenation open import foundation.whiskering-operations open import foundation-core.equivalences +open import foundation-core.functoriality-dependent-function-types open import foundation-core.homotopies ``` From d8ca4b8c4c19dd8cb7300a1d8d1625b0488a7b0d Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Tue, 13 Feb 2024 19:57:20 +0100 Subject: [PATCH 36/53] lemmas `transpose-eq` --- src/foundation/retractions.lagda.md | 57 +++++++++++++++++++++------ src/foundation/sections.lagda.md | 50 ++++++++++++++++++----- src/group-theory/conjugation.lagda.md | 8 ++-- 3 files changed, 88 insertions(+), 27 deletions(-) diff --git a/src/foundation/retractions.lagda.md b/src/foundation/retractions.lagda.md index a58a62b32d..d090915972 100644 --- a/src/foundation/retractions.lagda.md +++ b/src/foundation/retractions.lagda.md @@ -11,6 +11,8 @@ open import foundation-core.retractions public ```agda open import foundation.action-on-identifications-functions open import foundation.coslice +open import foundation.function-extensionality +open import foundation.multivariable-homotopies open import foundation.dependent-pair-types open import foundation.retracts-of-types open import foundation.universe-levels @@ -97,25 +99,54 @@ pr2 ```agda abstract is-injective-retraction : - {l1 l2 : Level} {A : UU l1} {B : UU l2} (f : A → B) → retraction f → - is-injective f - is-injective-retraction f (h , H) {x} {y} p = (inv (H x)) ∙ (ap h p ∙ H y) + {l1 l2 : Level} {A : UU l1} {B : UU l2} (f : A → B) → + retraction f → is-injective f + is-injective-retraction f (h , H) {x} {y} p = inv (H x) ∙ (ap h p ∙ H y) ``` ### Transposing identifications along retractions ```agda module _ - {l1 l2 : Level} {A : UU l1} {B : UU l2} (f : A → B) + {l1 l2 : Level} {A : UU l1} {B : UU l2} (f : A → B) (g : B → A) where - transpose-eq-retraction : - (g : B → A) (H : (g ∘ f) ~ id) {x : B} {y : A} → - x = f y → g x = y - transpose-eq-retraction g H refl = H _ - - transpose-eq-retraction' : - (g : B → A) (H : (g ∘ f) ~ id) {x : A} {y : B} → - f x = y → x = g y - transpose-eq-retraction' g H refl = inv (H _) + transpose-eq-is-retraction : + g ∘ f ~ id → {x : B} {y : A} → x = f y → g x = y + transpose-eq-is-retraction H {x} {y} p = ap g p ∙ H y + + transpose-eq-is-retraction' : + g ∘ f ~ id → {x : A} {y : B} → f x = y → x = g y + transpose-eq-is-retraction' H {x} refl = inv (H x) + + is-retraction-transpose-eq : + ({x : B} {y : A} → x = f y → g x = y) → g ∘ f ~ id + is-retraction-transpose-eq H x = H refl + + is-retraction-transpose-eq' : + ({x : A} {y : B} → f x = y → x = g y) → g ∘ f ~ id + is-retraction-transpose-eq' H x = inv (H refl) + + is-retraction-is-retraction-transpose-eq : + is-retraction-transpose-eq ∘ transpose-eq-is-retraction ~ id + is-retraction-is-retraction-transpose-eq H = refl + + abstract + is-section-is-retraction-transpose-eq : + transpose-eq-is-retraction ∘ is-retraction-transpose-eq ~ id + is-section-is-retraction-transpose-eq H = + eq-multivariable-htpy-implicit 2 (λ x y → eq-htpy (λ where refl → refl)) + + is-equiv-transpose-eq-is-retraction : + is-equiv transpose-eq-is-retraction + is-equiv-transpose-eq-is-retraction = + is-equiv-is-invertible + ( is-retraction-transpose-eq) + ( is-section-is-retraction-transpose-eq) + ( is-retraction-is-retraction-transpose-eq) + + equiv-transpose-eq-is-retraction : + (g ∘ f ~ id) ≃ ({x : B} {y : A} → x = f y → g x = y) + equiv-transpose-eq-is-retraction = + (transpose-eq-is-retraction , is-equiv-transpose-eq-is-retraction) ``` diff --git a/src/foundation/sections.lagda.md b/src/foundation/sections.lagda.md index 15ba000b59..a6ff221556 100644 --- a/src/foundation/sections.lagda.md +++ b/src/foundation/sections.lagda.md @@ -14,6 +14,7 @@ open import foundation.commuting-triangles-of-homotopies open import foundation.dependent-pair-types open import foundation.function-extensionality open import foundation.retracts-of-types +open import foundation.multivariable-homotopies open import foundation.structure-identity-principle open import foundation.type-arithmetic-dependent-pair-types open import foundation.universe-levels @@ -192,16 +193,45 @@ is-injective-map-section-family b = ap pr1 ```agda module _ - {l1 l2 : Level} {A : UU l1} {B : UU l2} (f : A → B) + {l1 l2 : Level} {A : UU l1} {B : UU l2} (f : A → B) (g : B → A) where - transpose-eq-section : - (g : B → A) (H : (f ∘ g) ~ id) {x : A} {y : B} → - x = g y → f x = y - transpose-eq-section g H refl = H _ - - transpose-eq-section' : - (g : B → A) (H : (f ∘ g) ~ id) {x : B} {y : A} → - g x = y → x = f y - transpose-eq-section' g H refl = inv (H _) + transpose-eq-is-section : + f ∘ g ~ id → {x : A} {y : B} → x = g y → f x = y + transpose-eq-is-section H {x} {y} p = ap f p ∙ H y + + transpose-eq-is-section' : + f ∘ g ~ id → {x : B} {y : A} → g x = y → x = f y + transpose-eq-is-section' H {x} refl = inv (H x) + + is-section-transpose-eq : + ({x : A} {y : B} → x = g y → f x = y) → f ∘ g ~ id + is-section-transpose-eq H x = H refl + + is-section-transpose-eq' : + ({x : B} {y : A} → g x = y → x = f y) → f ∘ g ~ id + is-section-transpose-eq' H x = inv (H refl) + + is-retraction-is-section-transpose-eq : + is-section-transpose-eq ∘ transpose-eq-is-section ~ id + is-retraction-is-section-transpose-eq H = refl + + abstract + is-section-is-section-transpose-eq : + transpose-eq-is-section ∘ is-section-transpose-eq ~ id + is-section-is-section-transpose-eq H = + eq-multivariable-htpy-implicit 2 (λ x y → eq-htpy (λ where refl → refl)) + + is-equiv-transpose-eq-is-section : + is-equiv transpose-eq-is-section + is-equiv-transpose-eq-is-section = + is-equiv-is-invertible + ( is-section-transpose-eq) + ( is-section-is-section-transpose-eq) + ( is-retraction-is-section-transpose-eq) + + equiv-transpose-eq-is-section : + (f ∘ g ~ id) ≃ ({x : A} {y : B} → x = g y → f x = y) + equiv-transpose-eq-is-section = + (transpose-eq-is-section , is-equiv-transpose-eq-is-section) ``` diff --git a/src/group-theory/conjugation.lagda.md b/src/group-theory/conjugation.lagda.md index e07bdb3b39..8ab1d3121c 100644 --- a/src/group-theory/conjugation.lagda.md +++ b/src/group-theory/conjugation.lagda.md @@ -333,7 +333,7 @@ module _ {x y z : type-Group G} → y = conjugation-Group G (inv-Group G x) z → conjugation-Group G x y = z transpose-eq-conjugation-Group {x} {y} {z} = - transpose-eq-section + transpose-eq-is-section ( conjugation-Group G x) ( conjugation-Group G (inv-Group G x)) ( is-section-conjugation-inv-Group x) @@ -342,7 +342,7 @@ module _ {x y z : type-Group G} → conjugation-Group G (inv-Group G x) y = z → y = conjugation-Group G x z transpose-eq-conjugation-Group' {x} {y} {z} = - transpose-eq-section' + transpose-eq-is-section' ( conjugation-Group G x) ( conjugation-Group G (inv-Group G x)) ( is-section-conjugation-inv-Group x) @@ -351,7 +351,7 @@ module _ {x y z : type-Group G} → y = conjugation-Group G x z → conjugation-Group G (inv-Group G x) y = z transpose-eq-conjugation-inv-Group {x} {y} {z} = - transpose-eq-retraction + transpose-eq-is-retraction ( conjugation-Group G x) ( conjugation-Group G (inv-Group G x)) ( is-retraction-conjugation-inv-Group x) @@ -360,7 +360,7 @@ module _ {x y z : type-Group G} → conjugation-Group G x y = z → y = conjugation-Group G (inv-Group G x) z transpose-eq-conjugation-inv-Group' {x} {y} {z} = - transpose-eq-retraction' + transpose-eq-is-retraction' ( conjugation-Group G x) ( conjugation-Group G (inv-Group G x)) ( is-retraction-conjugation-inv-Group x) From 36a37e25285af0ebb272ef6e27fc6397803ecb41 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Tue, 13 Feb 2024 19:57:24 +0100 Subject: [PATCH 37/53] more nitpickery --- src/foundation-core/equivalences.lagda.md | 29 +++++++++----------- src/foundation-core/invertible-maps.lagda.md | 11 ++++++++ 2 files changed, 24 insertions(+), 16 deletions(-) diff --git a/src/foundation-core/equivalences.lagda.md b/src/foundation-core/equivalences.lagda.md index 9945173a8f..7e25d0177f 100644 --- a/src/foundation-core/equivalences.lagda.md +++ b/src/foundation-core/equivalences.lagda.md @@ -180,18 +180,16 @@ module _ pr2 (pr2 (is-equiv-is-invertible' (g , H , K))) = K is-equiv-is-invertible : - (g : B → A) (H : (f ∘ g) ~ id) (K : (g ∘ f) ~ id) → is-equiv f + (g : B → A) (H : f ∘ g ~ id) (K : g ∘ f ~ id) → is-equiv f is-equiv-is-invertible g H K = is-equiv-is-invertible' (g , H , K) is-retraction-map-section-is-equiv : (H : is-equiv f) → is-retraction f (map-section-is-equiv H) is-retraction-map-section-is-equiv H = - ( ( ( inv-htpy - ( ( is-retraction-map-retraction-is-equiv H) ·r - ( map-section-is-equiv H))) ∙h - ( map-retraction-is-equiv H ·l is-section-map-section-is-equiv H)) ·r - ( f)) ∙h + ( ( inv-htpy ( is-retraction-map-retraction-is-equiv H)) ·r + ( map-section-is-equiv H ∘ f) ∙h + ( map-retraction-is-equiv H ·l is-section-map-section-is-equiv H ·r f)) ∙h ( is-retraction-map-retraction-is-equiv H) is-invertible-is-equiv : is-equiv f → is-invertible f @@ -427,12 +425,12 @@ module _ pr2 (is-equiv-comp g h (sh , rh) (sg , rg)) = retraction-comp g h rg rh - equiv-comp : (B ≃ X) → (A ≃ B) → (A ≃ X) - pr1 (equiv-comp g h) = (map-equiv g) ∘ (map-equiv h) + equiv-comp : B ≃ X → A ≃ B → A ≃ X + pr1 (equiv-comp g h) = map-equiv g ∘ map-equiv h pr2 (equiv-comp g h) = is-equiv-comp (pr1 g) (pr1 h) (pr2 h) (pr2 g) infixr 15 _∘e_ - _∘e_ : (B ≃ X) → (A ≃ B) → (A ≃ X) + _∘e_ : B ≃ X → A ≃ B → A ≃ X _∘e_ = equiv-comp ``` @@ -495,13 +493,12 @@ module _ is-equiv-htpy' (map-equiv e) H (is-equiv-map-equiv e) htpy-map-inv-is-equiv : - {f g : A → B} (G : f ~ g) (H : is-equiv f) (K : is-equiv g) → - map-inv-is-equiv H ~ map-inv-is-equiv K - htpy-map-inv-is-equiv G H K b = - ( inv (is-retraction-map-inv-is-equiv K (map-inv-is-equiv H b))) ∙ - ( ap - ( map-inv-is-equiv K) - ( inv (G (map-inv-is-equiv H b)) ∙ is-section-map-inv-is-equiv H b)) + {f g : A → B} (H : f ~ g) (F : is-equiv f) (G : is-equiv g) → + map-inv-is-equiv F ~ map-inv-is-equiv G + htpy-map-inv-is-equiv H F G = + htpy-map-inv-is-invertible H + ( is-invertible-is-equiv F) + ( is-invertible-is-equiv G) ``` ### Any retraction of an equivalence is an equivalence diff --git a/src/foundation-core/invertible-maps.lagda.md b/src/foundation-core/invertible-maps.lagda.md index b48b8a5938..ceed2999f8 100644 --- a/src/foundation-core/invertible-maps.lagda.md +++ b/src/foundation-core/invertible-maps.lagda.md @@ -9,6 +9,7 @@ module foundation-core.invertible-maps where ```agda open import foundation.dependent-pair-types open import foundation.universe-levels +open import foundation.action-on-identifications-functions open import foundation.whiskering-homotopies-composition open import foundation-core.cartesian-product-types @@ -263,6 +264,16 @@ module _ is-invertible-inv-htpy : {f f' : A → B} → f ~ f' → is-invertible f → is-invertible f' is-invertible-inv-htpy H = is-invertible-htpy (inv-htpy H) + + htpy-map-inv-is-invertible : + {f g : A → B} (H : f ~ g) (F : is-invertible f) (G : is-invertible g) → + map-inv-is-invertible F ~ map-inv-is-invertible G + htpy-map-inv-is-invertible H F G = + ( ( inv-htpy (is-retraction-map-inv-is-invertible G)) ·r + ( map-inv-is-invertible F)) ∙h + ( ( map-inv-is-invertible G) ·l + ( ( inv-htpy H ·r map-inv-is-invertible F) ∙h + ( is-section-map-inv-is-invertible F))) ``` ### Any section of an invertible map is homotopic to its inverse From c2962bf80e3a9ef76d7ad0d68592c60eafe1da93 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Tue, 13 Feb 2024 19:57:44 +0100 Subject: [PATCH 38/53] post commit pre-commit --- src/foundation-core/invertible-maps.lagda.md | 2 +- src/foundation/automorphisms.lagda.md | 2 +- src/foundation/retractions.lagda.md | 2 +- src/foundation/sections.lagda.md | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/src/foundation-core/invertible-maps.lagda.md b/src/foundation-core/invertible-maps.lagda.md index ceed2999f8..c7cdb17315 100644 --- a/src/foundation-core/invertible-maps.lagda.md +++ b/src/foundation-core/invertible-maps.lagda.md @@ -7,9 +7,9 @@ module foundation-core.invertible-maps where
Imports ```agda +open import foundation.action-on-identifications-functions open import foundation.dependent-pair-types open import foundation.universe-levels -open import foundation.action-on-identifications-functions open import foundation.whiskering-homotopies-composition open import foundation-core.cartesian-product-types diff --git a/src/foundation/automorphisms.lagda.md b/src/foundation/automorphisms.lagda.md index bc5d12d351..183752d129 100644 --- a/src/foundation/automorphisms.lagda.md +++ b/src/foundation/automorphisms.lagda.md @@ -8,10 +8,10 @@ module foundation.automorphisms where ```agda open import foundation.dependent-pair-types -open import foundation.sets open import foundation.universe-levels open import foundation-core.equivalences +open import foundation-core.sets open import structured-types.pointed-types ``` diff --git a/src/foundation/retractions.lagda.md b/src/foundation/retractions.lagda.md index d090915972..34eae2363e 100644 --- a/src/foundation/retractions.lagda.md +++ b/src/foundation/retractions.lagda.md @@ -11,9 +11,9 @@ open import foundation-core.retractions public ```agda open import foundation.action-on-identifications-functions open import foundation.coslice +open import foundation.dependent-pair-types open import foundation.function-extensionality open import foundation.multivariable-homotopies -open import foundation.dependent-pair-types open import foundation.retracts-of-types open import foundation.universe-levels open import foundation.whiskering-homotopies-composition diff --git a/src/foundation/sections.lagda.md b/src/foundation/sections.lagda.md index a6ff221556..6cd4265764 100644 --- a/src/foundation/sections.lagda.md +++ b/src/foundation/sections.lagda.md @@ -13,8 +13,8 @@ open import foundation.action-on-identifications-functions open import foundation.commuting-triangles-of-homotopies open import foundation.dependent-pair-types open import foundation.function-extensionality -open import foundation.retracts-of-types open import foundation.multivariable-homotopies +open import foundation.retracts-of-types open import foundation.structure-identity-principle open import foundation.type-arithmetic-dependent-pair-types open import foundation.universe-levels From dc989bb0b3aa8c212768e7eb9fe8e9a1ff24fd51 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Fri, 16 Feb 2024 20:00:28 +0100 Subject: [PATCH 39/53] wip review --- .../delooping-sign-homomorphism.lagda.md | 2 +- .../coherently-invertible-maps.lagda.md | 107 ++++++++++-------- .../commuting-squares-of-homotopies.lagda.md | 15 ++- ...muting-squares-of-identifications.lagda.md | 2 +- .../commuting-squares-of-homotopies.lagda.md | 4 +- ...muting-squares-of-identifications.lagda.md | 2 +- ...ting-triangles-of-identifications.lagda.md | 2 +- src/foundation/homotopy-algebra.lagda.md | 14 +-- src/foundation/invertible-maps.lagda.md | 2 +- 9 files changed, 78 insertions(+), 72 deletions(-) diff --git a/src/finite-group-theory/delooping-sign-homomorphism.lagda.md b/src/finite-group-theory/delooping-sign-homomorphism.lagda.md index dbcbe3991e..cd43fb75bf 100644 --- a/src/finite-group-theory/delooping-sign-homomorphism.lagda.md +++ b/src/finite-group-theory/delooping-sign-homomorphism.lagda.md @@ -85,7 +85,7 @@ open import univalent-combinatorics.standard-finite-types ## Ideas The delooping of a group homomorphism `f : G → H` is a pointed map -`Bf : BG → BH` equiped with an homotopy witnessing that the following square +`Bf : BG → BH` equiped with a homotopy witnessing that the following square commutes : ```text diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index dd0e3bc298..2d0d0f79b7 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -72,7 +72,7 @@ On this page we will prove that every two-sided inverse `g` of `f` can be promoted to a coherent two-sided inverse. Thus, for most properties of coherently invertible maps, it suffices to consider the data of a two-sided inverse. However, this coherence construction requires us to replace the section -homotopy (or retraction homotopy). For this reason we also give alternative +homotopy (or retraction homotopy). For this reason we also give direct constructions showing 1. The identity map is coherently invertible. @@ -81,11 +81,12 @@ constructions showing 4. Every map homotopic to a coherently invertible map is coherently invertible. 5. The 3-for-2 property of coherently invertible maps. -That appropriately preserve the data of the underlying two-sided inverse. +Each of these constructions appropriately preserve the data of the underlying +two-sided inverse. ## Definition -### The predicate of being coherently invertible on maps +### The predicate of being a coherently invertible map ```agda module _ @@ -114,11 +115,11 @@ module _ map-inv-is-coherently-invertible = pr1 H is-section-map-inv-is-coherently-invertible : - f ∘ map-inv-is-coherently-invertible ~ id + is-section f map-inv-is-coherently-invertible is-section-map-inv-is-coherently-invertible = pr1 (pr2 H) is-retraction-map-inv-is-coherently-invertible : - map-inv-is-coherently-invertible ∘ f ~ id + is-retraction f map-inv-is-coherently-invertible is-retraction-map-inv-is-coherently-invertible = pr1 (pr2 (pr2 H)) coh-is-coherently-invertible : @@ -196,21 +197,21 @@ module _ coh-is-coherently-invertible ( is-coherently-invertible-map-coherently-invertible-map) - section-map-coherently-invertible-map : + section-coherently-invertible-map : section map-coherently-invertible-map - section-map-coherently-invertible-map = + section-coherently-invertible-map = section-is-coherently-invertible ( is-coherently-invertible-map-coherently-invertible-map) - retraction-map-coherently-invertible-map : + retraction-coherently-invertible-map : retraction map-coherently-invertible-map - retraction-map-coherently-invertible-map = + retraction-coherently-invertible-map = retraction-is-coherently-invertible ( is-coherently-invertible-map-coherently-invertible-map) - is-invertible-map-coherently-invertible-map : + is-invertible-coherently-invertible-map : is-invertible map-coherently-invertible-map - is-invertible-map-coherently-invertible-map = + is-invertible-coherently-invertible-map = is-invertible-is-coherently-invertible ( is-coherently-invertible-map-coherently-invertible-map) @@ -218,10 +219,10 @@ module _ pr1 invertible-map-coherently-invertible-map = map-coherently-invertible-map pr2 invertible-map-coherently-invertible-map = - is-invertible-map-coherently-invertible-map + is-invertible-coherently-invertible-map ``` -### The predicate of being transpose coherently invertible on maps +### The predicate of being a transpose coherently invertible map ```agda module _ @@ -340,21 +341,21 @@ module _ coh-is-transpose-coherently-invertible ( is-transpose-coherently-invertible-map-transpose-coherently-invertible-map) - section-map-transpose-coherently-invertible-map : + section-transpose-coherently-invertible-map : section map-transpose-coherently-invertible-map - section-map-transpose-coherently-invertible-map = + section-transpose-coherently-invertible-map = section-is-transpose-coherently-invertible ( is-transpose-coherently-invertible-map-transpose-coherently-invertible-map) - retraction-map-transpose-coherently-invertible-map : + retraction-transpose-coherently-invertible-map : retraction map-transpose-coherently-invertible-map - retraction-map-transpose-coherently-invertible-map = + retraction-transpose-coherently-invertible-map = retraction-is-transpose-coherently-invertible ( is-transpose-coherently-invertible-map-transpose-coherently-invertible-map) - is-invertible-map-transpose-coherently-invertible-map : + is-invertible-transpose-coherently-invertible-map : is-invertible map-transpose-coherently-invertible-map - is-invertible-map-transpose-coherently-invertible-map = + is-invertible-transpose-coherently-invertible-map = is-invertible-is-transpose-coherently-invertible ( is-transpose-coherently-invertible-map-transpose-coherently-invertible-map) @@ -362,7 +363,7 @@ module _ pr1 invertible-map-transpose-coherently-invertible-map = map-transpose-coherently-invertible-map pr2 invertible-map-transpose-coherently-invertible-map = - is-invertible-map-transpose-coherently-invertible-map + is-invertible-transpose-coherently-invertible-map ``` ### Invertible maps that are coherent are coherently invertible maps @@ -408,11 +409,12 @@ module _ ## Properties -### The inverse of a coherently invertible map is transpose coherently invertible +### The inverse of a coherently invertible map is transpose coherently invertible and vice versa The inverse of a coherently invertible map is transpose coherently invertible. -Of course, there is also a converse construction, and since these are defined by -simply moving data around, they are strict inverses to one another. +Conversely, the inverse of a transpose coherently invertible map is coherently +invertible. Since these are defined by simply moving data around, they are +strict inverses to one another. ```agda module _ @@ -455,7 +457,10 @@ module _ ### Invertible maps are coherently invertible -The construction follows Lemma 10.4.5 in _Introduction to Homotopy Type Theory_. +This result is known as +[Vogt's lemma](https://ncatlab.org/nlab/show/homotopy+equivalence#vogts_lemma) +in point-set topology. The construction follows Lemma 10.4.5 in _Introduction to +Homotopy Type Theory_. ```agda module _ @@ -521,10 +526,6 @@ module _ coh-is-coherently-invertible-is-invertible) ``` -This result is known as -[Vogt's lemma](https://ncatlab.org/nlab/show/homotopy+equivalence#vogts_lemma) -in point-set topology. - We also get the transpose version for free: ```agda @@ -540,11 +541,11 @@ module _ ( is-invertible-map-inv-is-invertible H)) ``` -### Coherently invertible maps are embeddings +### Coherently invertible maps are injective -We first construct the converse map to the -[action on identifications](foundation.action-on-identifications-functions.md). -This is a rerun of the proof that maps with +The construction of the converse map of the +[action on identifications](foundation.action-on-identifications-functions.md) +is a rerun of the proof that maps with [retractions](foundation-core.retractions.md) are [injective](foundation-core.injective-maps.md) (`is-injective-retraction`). We repeat the proof to avoid cyclic dependencies. @@ -555,21 +556,23 @@ module _ (H : is-coherently-invertible f) {x y : A} where - map-inv-ap-is-coherently-invertible : f x = f y → x = y - map-inv-ap-is-coherently-invertible p = + is-injective-is-coherently-invertible : f x = f y → x = y + is-injective-is-coherently-invertible p = ( inv (is-retraction-map-inv-is-coherently-invertible H x)) ∙ ( ( ap (map-inv-is-coherently-invertible H) p) ∙ ( is-retraction-map-inv-is-coherently-invertible H y)) ``` -Next, we show that this converse map is a [section](foundation-core.sections.md) -and retraction of `ap f`. +### Coherently invertible maps are embeddings + +We show that `is-injective-is-coherently-invertible` is a +[section](foundation-core.sections.md) and retraction of `ap f`. ```agda abstract - is-section-map-inv-ap-is-coherently-invertible : - ap f ∘ map-inv-ap-is-coherently-invertible ~ id - is-section-map-inv-ap-is-coherently-invertible p = + is-section-is-injective-is-coherently-invertible : + ap f ∘ is-injective-is-coherently-invertible ~ id + is-section-is-injective-is-coherently-invertible p = ( ap-concat f ( inv (is-retraction-map-inv-is-coherently-invertible H x)) ( ( ap (map-inv-is-coherently-invertible H) p) ∙ @@ -597,18 +600,18 @@ and retraction of `ap f`. ( nat-htpy (is-section-map-inv-is-coherently-invertible H) p))))) abstract - is-retraction-map-inv-ap-is-coherently-invertible : - map-inv-ap-is-coherently-invertible ∘ ap f ~ id - is-retraction-map-inv-ap-is-coherently-invertible refl = + is-retraction-is-injective-is-coherently-invertible : + is-injective-is-coherently-invertible ∘ ap f ~ id + is-retraction-is-injective-is-coherently-invertible refl = left-inv (is-retraction-map-inv-is-coherently-invertible H x) is-invertible-ap-is-coherently-invertible : is-invertible (ap f {x} {y}) pr1 is-invertible-ap-is-coherently-invertible = - map-inv-ap-is-coherently-invertible + is-injective-is-coherently-invertible pr1 (pr2 is-invertible-ap-is-coherently-invertible) = - is-section-map-inv-ap-is-coherently-invertible + is-section-is-injective-is-coherently-invertible pr2 (pr2 is-invertible-ap-is-coherently-invertible) = - is-retraction-map-inv-ap-is-coherently-invertible + is-retraction-is-injective-is-coherently-invertible is-coherently-invertible-ap-is-coherently-invertible : is-coherently-invertible (ap f {x} {y}) @@ -617,12 +620,12 @@ and retraction of `ap f`. ( is-invertible-ap-is-coherently-invertible) ``` -### Coherently invertible maps are coherently invertible in both senses +### Coherently invertible maps are transpose coherently invertible The proof follows Lemma 4.2.2 in _Homotopy Type Theory – Univalent Foundations of Mathematics_. -**Proof.** By naturality we have +**Proof.** By naturality of homotopies we have ```text gfRg @@ -637,7 +640,7 @@ of Mathematics_. We can paste the homotopy ```text - g(inv-coh-htpy-id S) ∙ gHg : Sgfg ~ gfSg ~ gfRg + g (inv-coh-htpy-id S) ∙ gHg : Sgfg ~ gfSg ~ gfRg ``` along the top edge of this naturality square obtaining the coherence square @@ -671,9 +674,9 @@ obtain gfgS gfgS gfg <------- gfgfg -------> gfg | | | - Rg | Rgfg | Rg + Rg | | Rgfg | Rg ∨ ∨ ∨ - g <--------- gfg ---------> gm + g <--------- gfg --------> gm Rg gS ``` @@ -762,7 +765,11 @@ module _ is-transpose-coherently-invertible-transpose-coherence-is-invertible ( is-invertible-is-coherently-invertible H) ( coherence-transposition-is-coherently-invertible H) +``` +### Transpose coherently invertible maps are coherently invertible + +```agda module _ {l1 l2 : Level} {A : UU l1} {B : UU l2} {f : A → B} where diff --git a/src/foundation-core/commuting-squares-of-homotopies.lagda.md b/src/foundation-core/commuting-squares-of-homotopies.lagda.md index b974dd72ef..41c0ca1e79 100644 --- a/src/foundation-core/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation-core/commuting-squares-of-homotopies.lagda.md @@ -324,6 +324,9 @@ with a homotopy `top ~ top'`. Then we get an equivalence bottom bottom ``` +We record that this construction is an equivalence in +[`foundation.commuting-squares-of-homotopies`](foundation.commuting-squares-of-homotopies.md). + ```agda module _ {l1 l2 : Level} {A : UU l1} {B : A → UU l2} {f g h i : (x : A) → B x} @@ -356,9 +359,6 @@ module _ ( H x) ``` -We record that this construction is an equivalence in -[`foundation.commuting-squares-of-homotopies`](foundation.commuting-squares-of-homotopies.md). - #### Concatenating homotopies of the left edge with a coherence of a commuting square of homotopies Consider a commuting diagram of homotopies @@ -646,13 +646,12 @@ we may consider four ways of attaching new homotopies to it: (left ∙h bottom ~ top ∙h right) ≃ (left ∙h bottom ~ (top ∙h H⁻¹) ∙h (H ∙h right)). ``` -These operations are useful in proofs involving path algebra, because taking -`equiv-right-whisker-concat-coherence-square-identicications` as an example, it +These operations are useful in proofs involving homotopy algebra, because taking +`equiv-right-whisker-concat-coherence-square-homotopies` as an example, it provides us with two maps: the forward direction states `(H ∙h r ~ K ∙h s) → (H ∙h (r ∙h t)) ~ K ∙h (s ∙h t))`, which allows one to -append an homotopy without needing to reassociate on the right, and the -backwards direction conversely allows one to cancel out a homotopy in -parentheses. +append a homotopy without needing to reassociate on the right, and the backwards +direction conversely allows one to cancel out a homotopy in parentheses. #### Left whiskering coherences of commuting squares of homotopies diff --git a/src/foundation-core/commuting-squares-of-identifications.lagda.md b/src/foundation-core/commuting-squares-of-identifications.lagda.md index 1d9e3c6f05..a3d8f14744 100644 --- a/src/foundation-core/commuting-squares-of-identifications.lagda.md +++ b/src/foundation-core/commuting-squares-of-identifications.lagda.md @@ -613,7 +613,7 @@ we may consider four ways of attaching new identifications to it: ``` These operations are useful in proofs involving path algebra, because taking -`equiv-right-whisker-concat-coherence-square-identicications` as an example, it +`equiv-right-whisker-concat-coherence-square-identifications` as an example, it provides us with two maps: the forward direction states `(p ∙ r = q ∙ s) → (p ∙ (r ∙ t)) = q ∙ (s ∙ t))`, which allows one to append an identification without needing to reassociate on the right, and the backwards diff --git a/src/foundation/commuting-squares-of-homotopies.lagda.md b/src/foundation/commuting-squares-of-homotopies.lagda.md index dc4e5412ce..fa4657be1f 100644 --- a/src/foundation/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation/commuting-squares-of-homotopies.lagda.md @@ -376,8 +376,8 @@ we may consider four ways of attaching new homotopies to it: (left ∙h bottom ~ top ∙h right) ≃ (left ∙h bottom ~ (top ∙h p⁻¹) ∙h (p ∙h right)). ``` -These operations are useful in proofs involving path algebra, because taking -`equiv-right-whisker-concat-coherence-square-identicications` as an example, it +These operations are useful in proofs involving homotopy algebra, because taking +`equiv-right-whisker-concat-coherence-square-homotopies` as an example, it provides us with two maps: the forward direction states `(p ∙h r ~ q ∙h s) → (p ∙h (r ∙h t)) ~ q ∙h (s ∙h t))`, which allows one to append a homotopy without needing to reassociate on the right, and the backwards diff --git a/src/foundation/commuting-squares-of-identifications.lagda.md b/src/foundation/commuting-squares-of-identifications.lagda.md index 4f9fb6f982..75891f4367 100644 --- a/src/foundation/commuting-squares-of-identifications.lagda.md +++ b/src/foundation/commuting-squares-of-identifications.lagda.md @@ -391,7 +391,7 @@ we may consider four ways of attaching new identifications to it: ``` These operations are useful in proofs involving path algebra, because taking -`equiv-right-whisker-concat-coherence-square-identicications` as an example, it +`equiv-right-whisker-concat-coherence-square-identifications` as an example, it provides us with two maps: the forward direction states `(p ∙ r = q ∙ s) → (p ∙ (r ∙ t)) = q ∙ (s ∙ t))`, which allows one to append an identification without needing to reassociate on the right, and the backwards diff --git a/src/foundation/commuting-triangles-of-identifications.lagda.md b/src/foundation/commuting-triangles-of-identifications.lagda.md index 27301a5608..071dbaa96f 100644 --- a/src/foundation/commuting-triangles-of-identifications.lagda.md +++ b/src/foundation/commuting-triangles-of-identifications.lagda.md @@ -137,7 +137,7 @@ transformations are equivalences. These operations are useful in proofs involving [path algebra](foundation.path-algebra.md), because taking -`equiv-right-whisker-triangle-identicications` as an example, it provides us +`equiv-right-whisker-triangle-identifications` as an example, it provides us with two maps: the forward direction states `(p = q ∙ r) → (p ∙ s = q ∙ (r ∙ s))`, which allows one to append an identification without needing to reassociate on the right, and the backwards diff --git a/src/foundation/homotopy-algebra.lagda.md b/src/foundation/homotopy-algebra.lagda.md index bf563b4dea..80e83db492 100644 --- a/src/foundation/homotopy-algebra.lagda.md +++ b/src/foundation/homotopy-algebra.lagda.md @@ -68,13 +68,13 @@ module _ For the general case, we must construct a coherence of the square ```text - gF - gf -------> gf' - | | - Gf | | Gf' - ∨ ∨ - g'f ----> g'f' - g'F + g ·r F + gf -------> gf' + | | + G ·r f | | G ·r f' + ∨ ∨ + g'f ------> g'f' + g' ·r F ``` but this is an instance of naturality of `G` applied to `F`. diff --git a/src/foundation/invertible-maps.lagda.md b/src/foundation/invertible-maps.lagda.md index bd03f1316a..47fb7cca31 100644 --- a/src/foundation/invertible-maps.lagda.md +++ b/src/foundation/invertible-maps.lagda.md @@ -377,7 +377,7 @@ module _ equiv-free-loop-equivalence-invertible-equivalence ``` -### Invertible maps are embeddings +### The action of invertible maps on identifications is invertible ```agda module _ From a604c34710d603c7e64181ac826cc7107e1fd6d5 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Fri, 16 Feb 2024 20:00:55 +0100 Subject: [PATCH 40/53] Update src/foundation-core/commuting-squares-of-homotopies.lagda.md Co-authored-by: Egbert Rijke --- src/foundation-core/commuting-squares-of-homotopies.lagda.md | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/src/foundation-core/commuting-squares-of-homotopies.lagda.md b/src/foundation-core/commuting-squares-of-homotopies.lagda.md index 41c0ca1e79..e0d8a6c451 100644 --- a/src/foundation-core/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation-core/commuting-squares-of-homotopies.lagda.md @@ -312,17 +312,16 @@ Consider a commuting diagram of homotopies bottom ``` -with a homotopy `top ~ top'`. Then we get an equivalence +with a homotopy `top ~ top'`. Then we get maps back and forth ```text top top' f -------> g f -------> g | | | | - left | | right ≃ left | | right + left | | right ↔ left | | right ∨ ∨ ∨ ∨ h -------> i h -------> i. bottom bottom -``` We record that this construction is an equivalence in [`foundation.commuting-squares-of-homotopies`](foundation.commuting-squares-of-homotopies.md). From e8720e1fac5b7c276fa23ea58acc79c4a6381ce8 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Fri, 16 Feb 2024 20:01:05 +0100 Subject: [PATCH 41/53] Update src/foundation-core/commuting-squares-of-homotopies.lagda.md Co-authored-by: Egbert Rijke --- src/foundation-core/commuting-squares-of-homotopies.lagda.md | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/src/foundation-core/commuting-squares-of-homotopies.lagda.md b/src/foundation-core/commuting-squares-of-homotopies.lagda.md index e0d8a6c451..e075fc71b2 100644 --- a/src/foundation-core/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation-core/commuting-squares-of-homotopies.lagda.md @@ -433,17 +433,16 @@ Consider a commuting diagram of homotopies bottom ``` -with a homotopy `right ~ right'`. Then we get an equivalence +with a homotopy `right ~ right'`. Then we get maps back and forth ```text top top f -------> g f -------> g | | | | - left | | right ≃ left | | right' + left | | right ↔ left | | right' ∨ ∨ ∨ ∨ h -------> i h -------> i. bottom bottom -``` ```agda module _ From b5e5daf8f313ca09aa8dcc1eeaf71be0e6b585f5 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Fri, 16 Feb 2024 20:01:13 +0100 Subject: [PATCH 42/53] Update src/foundation-core/commuting-squares-of-homotopies.lagda.md Co-authored-by: Egbert Rijke --- .../commuting-squares-of-homotopies.lagda.md | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/src/foundation-core/commuting-squares-of-homotopies.lagda.md b/src/foundation-core/commuting-squares-of-homotopies.lagda.md index e075fc71b2..b71546e179 100644 --- a/src/foundation-core/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation-core/commuting-squares-of-homotopies.lagda.md @@ -653,19 +653,20 @@ direction conversely allows one to cancel out a homotopy in parentheses. #### Left whiskering coherences of commuting squares of homotopies -For any homotopy `H : u ~ f` we obtain an equivalence +For any homotopy `H : u ~ f` we obtain maps back and forth ```text top H ∙h top f -------> g u -------> g | | | | - left | | right ≃ H ∙h left | | right + left | | right ↔ H ∙h left | | right ∨ ∨ ∨ ∨ h -------> i h -------> i bottom bottom ``` -of coherences of commuting squares of homotopies. +of coherences of commuting squares of homotopies. We show in ... that these maps are equivalences. + ```agda module _ From 43c314993ec9b6a9eb5a14b03f1708939b14ee2d Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Fri, 16 Feb 2024 20:01:25 +0100 Subject: [PATCH 43/53] Update src/foundation-core/equivalences.lagda.md Co-authored-by: Egbert Rijke --- src/foundation-core/equivalences.lagda.md | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/src/foundation-core/equivalences.lagda.md b/src/foundation-core/equivalences.lagda.md index 7e25d0177f..843b2ae090 100644 --- a/src/foundation-core/equivalences.lagda.md +++ b/src/foundation-core/equivalences.lagda.md @@ -187,8 +187,9 @@ module _ is-retraction-map-section-is-equiv : (H : is-equiv f) → is-retraction f (map-section-is-equiv H) is-retraction-map-section-is-equiv H = - ( ( inv-htpy ( is-retraction-map-retraction-is-equiv H)) ·r - ( map-section-is-equiv H ∘ f) ∙h + ( ( inv-htpy + ( ( is-retraction-map-retraction-is-equiv H) ·r + ( map-section-is-equiv H ∘ f))) ∙h ( map-retraction-is-equiv H ·l is-section-map-section-is-equiv H ·r f)) ∙h ( is-retraction-map-retraction-is-equiv H) From b8e565700ccf6a6fb46a511ae5986be4b7b792b5 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Fri, 16 Feb 2024 20:01:36 +0100 Subject: [PATCH 44/53] Update src/foundation-core/commuting-squares-of-homotopies.lagda.md Co-authored-by: Egbert Rijke --- .../commuting-squares-of-homotopies.lagda.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/foundation-core/commuting-squares-of-homotopies.lagda.md b/src/foundation-core/commuting-squares-of-homotopies.lagda.md index b71546e179..9b63c409ed 100644 --- a/src/foundation-core/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation-core/commuting-squares-of-homotopies.lagda.md @@ -786,19 +786,19 @@ module _ #### Left splicing coherences of commuting squares of homotopies For any inverse pair of homotopies `H : g ~ u` and `K : u ~ g` equipped with -`α : inv-htpy H ~ K` we obtain an equivalence +`α : inv-htpy H ~ K` we obtain maps back and forth ```text top top f -------> g f -----------> g | | | | - left | | right ≃ left ∙h H | | right + left | | right ↔ left ∙h H | | right ∨ ∨ ∨ ∨ h -------> i u -----------> i bottom K ∙h bottom ``` -of coherences of commuting squares of homotopies. +of coherences of commuting squares of homotopies. We show in ... that these maps are equivalences. ```agda module _ From b22f7e7fa63458e1c9876fc3bd03aec3b570fdf4 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Fri, 16 Feb 2024 20:01:50 +0100 Subject: [PATCH 45/53] Update src/foundation-core/commuting-squares-of-homotopies.lagda.md Co-authored-by: Egbert Rijke --- src/foundation-core/commuting-squares-of-homotopies.lagda.md | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/src/foundation-core/commuting-squares-of-homotopies.lagda.md b/src/foundation-core/commuting-squares-of-homotopies.lagda.md index 9b63c409ed..b632c551e5 100644 --- a/src/foundation-core/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation-core/commuting-squares-of-homotopies.lagda.md @@ -372,17 +372,16 @@ Consider a commuting diagram of homotopies bottom ``` -with a homotopy `left ~ left'`. Then we get an equivalence +with a homotopy `left ~ left'`. Then we get maps back and forth ```text top top f -------> g f -------> g | | | | - left | | right ≃ left' | | right + left | | right ↔ left' | | right ∨ ∨ ∨ ∨ h -------> i h -------> i. bottom bottom -``` ```agda module _ From ae172cf1d5fa508786834a247d015b3ae439f618 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Fri, 16 Feb 2024 20:01:59 +0100 Subject: [PATCH 46/53] Update src/foundation-core/commuting-squares-of-homotopies.lagda.md Co-authored-by: Egbert Rijke --- src/foundation-core/commuting-squares-of-homotopies.lagda.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/foundation-core/commuting-squares-of-homotopies.lagda.md b/src/foundation-core/commuting-squares-of-homotopies.lagda.md index b632c551e5..2c6cd2b567 100644 --- a/src/foundation-core/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation-core/commuting-squares-of-homotopies.lagda.md @@ -540,7 +540,7 @@ module _ We record that this construction is an equivalence in [`foundation.commuting-squares-of-homotopies`](foundation.commuting-squares-of-homotopies.md). -### Whiskering and splicing coherences of commuting squares of homotopies +### Whiskering and splicing coherences of commuting squares of homotopies with respect to concatenation of homotopies Given a commuting square of homotopies From 9f6f6583c9ec628f577b302cee99421ae707f7a6 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Fri, 16 Feb 2024 20:02:06 +0100 Subject: [PATCH 47/53] Update src/foundation-core/commuting-squares-of-homotopies.lagda.md Co-authored-by: Egbert Rijke --- src/foundation-core/commuting-squares-of-homotopies.lagda.md | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/src/foundation-core/commuting-squares-of-homotopies.lagda.md b/src/foundation-core/commuting-squares-of-homotopies.lagda.md index 2c6cd2b567..172325d473 100644 --- a/src/foundation-core/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation-core/commuting-squares-of-homotopies.lagda.md @@ -493,17 +493,16 @@ Consider a commuting diagram of homotopies bottom' ``` -with a homotopy `bottom ~ bottom'`. Then we get an equivalence +with a homotopy `bottom ~ bottom'`. Then we get maps back and forth ```text top top f -------> g f -------> g | | | | - left | | right ≃ left | | right + left | | right ↔ left | | right ∨ ∨ ∨ ∨ h -------> i h -------> i. bottom bottom' -``` ```agda module _ From ced73e9a9cd62f68b007bb934ec427ec6241aa2c Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Fri, 16 Feb 2024 20:02:13 +0100 Subject: [PATCH 48/53] Update src/foundation-core/commuting-squares-of-homotopies.lagda.md Co-authored-by: Egbert Rijke --- .../commuting-squares-of-homotopies.lagda.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/foundation-core/commuting-squares-of-homotopies.lagda.md b/src/foundation-core/commuting-squares-of-homotopies.lagda.md index 172325d473..ebc9d02bf1 100644 --- a/src/foundation-core/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation-core/commuting-squares-of-homotopies.lagda.md @@ -704,19 +704,19 @@ module _ #### Right whiskering coherences of commuting squares of homotopies -For any homotopy `H : i ~ u` we obtain an equivalence +For any homotopy `H : i ~ u` we obtain maps back and forth ```text top top f -------> g f ------------> g | | | | - left | | right ≃ left | | right ∙h H + left | | right ↔ left | | right ∙h H ∨ ∨ ∨ ∨ h -------> i h ------------> i bottom bottom ∙h H ``` -of coherences of commuting squares of homotopies. +of coherences of commuting squares of homotopies. We show in ... that these maps are equivalences. ```agda module _ From 5c455b22ab1b0235a7ded329913ddbbbcd2965b1 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Fri, 16 Feb 2024 20:02:19 +0100 Subject: [PATCH 49/53] Update src/foundation-core/commuting-squares-of-homotopies.lagda.md Co-authored-by: Egbert Rijke --- .../commuting-squares-of-homotopies.lagda.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/foundation-core/commuting-squares-of-homotopies.lagda.md b/src/foundation-core/commuting-squares-of-homotopies.lagda.md index ebc9d02bf1..59c85bb111 100644 --- a/src/foundation-core/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation-core/commuting-squares-of-homotopies.lagda.md @@ -838,19 +838,19 @@ module _ #### Right splicing coherences of commuting squares of homotopies For any inverse pair of homotopies `H : g ~ u` and `K : u ~ g` equipped with -`α : inv-htpy H ~ K` we obtain an equivalence +`α : inv-htpy H ~ K` we obtain maps back and forth ```text top top ∙h H f -------> g f --------> u | | | | - left | | right ≃ left | | K ∙h right + left | | right ↔ left | | K ∙h right ∨ ∨ ∨ ∨ h -------> i h --------> i bottom bottom ``` -of coherences of commuting squares of homotopies. +of coherences of commuting squares of homotopies. We show in ... that these maps are equivalences. ```agda module _ From db3bafa6a63d80e768b52305fe2f92436ccb73e2 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Fri, 16 Feb 2024 20:37:34 +0100 Subject: [PATCH 50/53] wip review --- .../commuting-squares-of-homotopies.lagda.md | 27 +++++++++++++------ 1 file changed, 19 insertions(+), 8 deletions(-) diff --git a/src/foundation-core/commuting-squares-of-homotopies.lagda.md b/src/foundation-core/commuting-squares-of-homotopies.lagda.md index 59c85bb111..7c3e1c6877 100644 --- a/src/foundation-core/commuting-squares-of-homotopies.lagda.md +++ b/src/foundation-core/commuting-squares-of-homotopies.lagda.md @@ -322,6 +322,7 @@ with a homotopy `top ~ top'`. Then we get maps back and forth ∨ ∨ ∨ ∨ h -------> i h -------> i. bottom bottom +``` We record that this construction is an equivalence in [`foundation.commuting-squares-of-homotopies`](foundation.commuting-squares-of-homotopies.md). @@ -382,6 +383,10 @@ with a homotopy `left ~ left'`. Then we get maps back and forth ∨ ∨ ∨ ∨ h -------> i h -------> i. bottom bottom +``` + +We record that this construction is an equivalence in +[`foundation.commuting-squares-of-homotopies`](foundation.commuting-squares-of-homotopies.md). ```agda module _ @@ -415,9 +420,6 @@ module _ ( H x) ``` -We record that this construction is an equivalence in -[`foundation.commuting-squares-of-homotopies`](foundation.commuting-squares-of-homotopies.md). - #### Concatenating homotopies of the right edge with a coherence of a commuting square of homotopies Consider a commuting diagram of homotopies @@ -442,6 +444,7 @@ with a homotopy `right ~ right'`. Then we get maps back and forth ∨ ∨ ∨ ∨ h -------> i h -------> i. bottom bottom +``` ```agda module _ @@ -503,6 +506,7 @@ with a homotopy `bottom ~ bottom'`. Then we get maps back and forth ∨ ∨ ∨ ∨ h -------> i h -------> i. bottom bottom' +``` ```agda module _ @@ -663,8 +667,9 @@ For any homotopy `H : u ~ f` we obtain maps back and forth bottom bottom ``` -of coherences of commuting squares of homotopies. We show in ... that these maps are equivalences. - +of coherences of commuting squares of homotopies. We show in +[`foundation.commuting-squares-of-homotopies`](foundation.commuting-squares-of-homotopies.md) +that these maps are equivalences. ```agda module _ @@ -716,7 +721,9 @@ For any homotopy `H : i ~ u` we obtain maps back and forth bottom bottom ∙h H ``` -of coherences of commuting squares of homotopies. We show in ... that these maps are equivalences. +of coherences of commuting squares of homotopies. We show in +[`foundation.commuting-squares-of-homotopies`](foundation.commuting-squares-of-homotopies.md) +that these maps are equivalences. ```agda module _ @@ -796,7 +803,9 @@ For any inverse pair of homotopies `H : g ~ u` and `K : u ~ g` equipped with bottom K ∙h bottom ``` -of coherences of commuting squares of homotopies. We show in ... that these maps are equivalences. +of coherences of commuting squares of homotopies. We show in +[`foundation.commuting-squares-of-homotopies`](foundation.commuting-squares-of-homotopies.md) +that these maps are equivalences. ```agda module _ @@ -850,7 +859,9 @@ For any inverse pair of homotopies `H : g ~ u` and `K : u ~ g` equipped with bottom bottom ``` -of coherences of commuting squares of homotopies. We show in ... that these maps are equivalences. +of coherences of commuting squares of homotopies. We show in +[`foundation.commuting-squares-of-homotopies`](foundation.commuting-squares-of-homotopies.md) +that these maps are equivalences. ```agda module _ From 002cb6ed3b9409239969c452ffb7549af5c1ea33 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Fri, 16 Feb 2024 20:52:48 +0100 Subject: [PATCH 51/53] edits --- src/foundation-core/coherently-invertible-maps.lagda.md | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index 2d0d0f79b7..203b38d00a 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -815,11 +815,11 @@ Moreover, assume the map `f'` is homotopic to `f` with homotopy `H : f' ~ f`. Then `g` is also a two-sided inverse to `f'` via the homotopies ```text - S' := Hg ∙ S : f' ∘ g ~ id and R' := gH ∙ R : g ∘ f' ~ id + S' := Hg ∙ S : f' ∘ g ~ id and R' := gH ∙ R : g ∘ f' ~ id. ``` -These witnesses are also part of a coherent inverse to `f'`. To show this, we -must construct a coherence `C'` of the square +Moreover, these witnesses are part of a coherent inverse to `f'`. To show this, +we must construct a coherence `C'` of the square ```text Hgf' @@ -836,7 +836,7 @@ via the composite ```text Sf - HgH ------> H⁻¹ + HgH ------> H⁻¹ f'gf' -----> fgf C f ----> f'. ------> fR From 9b4838fc188aea16191db20b714d6f7cdec355be Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Sat, 17 Feb 2024 11:02:51 +0100 Subject: [PATCH 52/53] retractions and sections --- src/foundation/retractions.lagda.md | 13 +++++++++++-- src/foundation/sections.lagda.md | 13 +++++++++++-- 2 files changed, 22 insertions(+), 4 deletions(-) diff --git a/src/foundation/retractions.lagda.md b/src/foundation/retractions.lagda.md index 34eae2363e..3c51b23ceb 100644 --- a/src/foundation/retractions.lagda.md +++ b/src/foundation/retractions.lagda.md @@ -13,7 +13,6 @@ open import foundation.action-on-identifications-functions open import foundation.coslice open import foundation.dependent-pair-types open import foundation.function-extensionality -open import foundation.multivariable-homotopies open import foundation.retracts-of-types open import foundation.universe-levels open import foundation.whiskering-homotopies-composition @@ -131,11 +130,21 @@ module _ is-retraction-transpose-eq ∘ transpose-eq-is-retraction ~ id is-retraction-is-retraction-transpose-eq H = refl + htpy-is-section-is-retraction-transpose-eq : + (H : {x : B} {y : A} → x = f y → g x = y) + (x : B) (y : A) → + transpose-eq-is-retraction (is-retraction-transpose-eq H) {x} {y} ~ + H {x} {y} + htpy-is-section-is-retraction-transpose-eq H x y refl = refl + abstract is-section-is-retraction-transpose-eq : transpose-eq-is-retraction ∘ is-retraction-transpose-eq ~ id is-section-is-retraction-transpose-eq H = - eq-multivariable-htpy-implicit 2 (λ x y → eq-htpy (λ where refl → refl)) + eq-htpy-implicit + ( λ x → + eq-htpy-implicit + ( λ y → eq-htpy (htpy-is-section-is-retraction-transpose-eq H x y))) is-equiv-transpose-eq-is-retraction : is-equiv transpose-eq-is-retraction diff --git a/src/foundation/sections.lagda.md b/src/foundation/sections.lagda.md index 6cd4265764..ca2ce02401 100644 --- a/src/foundation/sections.lagda.md +++ b/src/foundation/sections.lagda.md @@ -13,7 +13,6 @@ open import foundation.action-on-identifications-functions open import foundation.commuting-triangles-of-homotopies open import foundation.dependent-pair-types open import foundation.function-extensionality -open import foundation.multivariable-homotopies open import foundation.retracts-of-types open import foundation.structure-identity-principle open import foundation.type-arithmetic-dependent-pair-types @@ -216,11 +215,21 @@ module _ is-section-transpose-eq ∘ transpose-eq-is-section ~ id is-retraction-is-section-transpose-eq H = refl + htpy-is-section-is-section-transpose-eq : + (H : {x : A} {y : B} → x = g y → f x = y) → + (x : A) (y : B) → + transpose-eq-is-section (is-section-transpose-eq H) {x} {y} ~ H {x} {y} + htpy-is-section-is-section-transpose-eq H x y refl = refl + abstract is-section-is-section-transpose-eq : transpose-eq-is-section ∘ is-section-transpose-eq ~ id is-section-is-section-transpose-eq H = - eq-multivariable-htpy-implicit 2 (λ x y → eq-htpy (λ where refl → refl)) + eq-htpy-implicit + ( λ x → + eq-htpy-implicit + ( λ y → + eq-htpy (htpy-is-section-is-section-transpose-eq H x y))) is-equiv-transpose-eq-is-section : is-equiv transpose-eq-is-section From ac490be23159127453dea41a55b4ede67d76a0a5 Mon Sep 17 00:00:00 2001 From: Fredrik Bakke Date: Sat, 17 Feb 2024 11:35:15 +0100 Subject: [PATCH 53/53] more nitpickery --- .../coherently-invertible-maps.lagda.md | 96 +++++++++---------- src/foundation-core/invertible-maps.lagda.md | 22 +++++ 2 files changed, 70 insertions(+), 48 deletions(-) diff --git a/src/foundation-core/coherently-invertible-maps.lagda.md b/src/foundation-core/coherently-invertible-maps.lagda.md index 203b38d00a..596c722080 100644 --- a/src/foundation-core/coherently-invertible-maps.lagda.md +++ b/src/foundation-core/coherently-invertible-maps.lagda.md @@ -526,7 +526,7 @@ module _ coh-is-coherently-invertible-is-invertible) ``` -We also get the transpose version for free: +We get the transpose version for free: ```agda module _ @@ -543,75 +543,77 @@ module _ ### Coherently invertible maps are injective -The construction of the converse map of the -[action on identifications](foundation.action-on-identifications-functions.md) -is a rerun of the proof that maps with -[retractions](foundation-core.retractions.md) are -[injective](foundation-core.injective-maps.md) (`is-injective-retraction`). We -repeat the proof to avoid cyclic dependencies. - ```agda module _ {l1 l2 : Level} {A : UU l1} {B : UU l2} {f : A → B} - (H : is-coherently-invertible f) {x y : A} where - is-injective-is-coherently-invertible : f x = f y → x = y - is-injective-is-coherently-invertible p = - ( inv (is-retraction-map-inv-is-coherently-invertible H x)) ∙ - ( ( ap (map-inv-is-coherently-invertible H) p) ∙ - ( is-retraction-map-inv-is-coherently-invertible H y)) + is-injective-is-coherently-invertible : + (H : is-coherently-invertible f) {x y : A} → f x = f y → x = y + is-injective-is-coherently-invertible H = + is-injective-is-invertible + ( is-invertible-is-coherently-invertible H) + + is-injective-is-transpose-coherently-invertible : + (H : is-transpose-coherently-invertible f) {x y : A} → f x = f y → x = y + is-injective-is-transpose-coherently-invertible H = + is-injective-is-invertible + ( is-invertible-is-transpose-coherently-invertible H) ``` ### Coherently invertible maps are embeddings We show that `is-injective-is-coherently-invertible` is a -[section](foundation-core.sections.md) and retraction of `ap f`. +[section](foundation-core.sections.md) and +[retraction](foundation-core.retractions.md) of `ap f`. ```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} {f : A → B} + (H : is-coherently-invertible f) {x y : A} + where + abstract is-section-is-injective-is-coherently-invertible : - ap f ∘ is-injective-is-coherently-invertible ~ id + ap f {x} {y} ∘ is-injective-is-coherently-invertible H ~ id is-section-is-injective-is-coherently-invertible p = ( ap-concat f ( inv (is-retraction-map-inv-is-coherently-invertible H x)) ( ( ap (map-inv-is-coherently-invertible H) p) ∙ ( is-retraction-map-inv-is-coherently-invertible H y))) ∙ - ( ( ap-binary - ( _∙_) - ( ap-inv f (is-retraction-map-inv-is-coherently-invertible H x)) - ( ( ap-concat f - ( ap (map-inv-is-coherently-invertible H) p) - ( is-retraction-map-inv-is-coherently-invertible H y)) ∙ - ( ap-binary + ( ap-binary + ( _∙_) + ( ap-inv f (is-retraction-map-inv-is-coherently-invertible H x)) + ( ( ap-concat f + ( ap (map-inv-is-coherently-invertible H) p) + ( is-retraction-map-inv-is-coherently-invertible H y)) ∙ + ( ap-binary + ( _∙_) + ( inv (ap-comp f (map-inv-is-coherently-invertible H) p)) + ( inv (coh-is-coherently-invertible H y))))) ∙ + ( inv + ( left-transpose-eq-concat + ( ap f (is-retraction-map-inv-is-coherently-invertible H x)) + ( p) + ( ( ap (f ∘ map-inv-is-coherently-invertible H) p) ∙ + ( is-section-map-inv-is-coherently-invertible H (f y))) + ( ( ap-binary ( _∙_) - ( inv (ap-comp f (map-inv-is-coherently-invertible H) p)) - ( inv (coh-is-coherently-invertible H y))))) ∙ - ( inv - ( left-transpose-eq-concat - ( ap f (is-retraction-map-inv-is-coherently-invertible H x)) - ( p) - ( ( ap (f ∘ map-inv-is-coherently-invertible H) p) ∙ - ( is-section-map-inv-is-coherently-invertible H (f y))) - ( ( ap-binary - ( _∙_) - ( inv (coh-is-coherently-invertible H x)) - ( inv (ap-id p))) ∙ - ( nat-htpy (is-section-map-inv-is-coherently-invertible H) p))))) + ( inv (coh-is-coherently-invertible H x)) + ( inv (ap-id p))) ∙ + ( nat-htpy (is-section-map-inv-is-coherently-invertible H) p)))) abstract is-retraction-is-injective-is-coherently-invertible : - is-injective-is-coherently-invertible ∘ ap f ~ id + is-injective-is-coherently-invertible H ∘ ap f {x} {y} ~ id is-retraction-is-injective-is-coherently-invertible refl = left-inv (is-retraction-map-inv-is-coherently-invertible H x) is-invertible-ap-is-coherently-invertible : is-invertible (ap f {x} {y}) - pr1 is-invertible-ap-is-coherently-invertible = - is-injective-is-coherently-invertible - pr1 (pr2 is-invertible-ap-is-coherently-invertible) = - is-section-is-injective-is-coherently-invertible - pr2 (pr2 is-invertible-ap-is-coherently-invertible) = - is-retraction-is-injective-is-coherently-invertible + is-invertible-ap-is-coherently-invertible = + ( is-injective-is-coherently-invertible H , + is-section-is-injective-is-coherently-invertible , + is-retraction-is-injective-is-coherently-invertible) is-coherently-invertible-ap-is-coherently-invertible : is-coherently-invertible (ap f {x} {y}) @@ -655,7 +657,7 @@ along the top edge of this naturality square obtaining the coherence square Rg ``` -There is also the following naturality square +There is also the naturality square ```text gfgS @@ -667,8 +669,7 @@ There is also the following naturality square gS ``` -Now, by pasting the first square to the second along the common edge `Rgfg`, we -obtain +Now, by pasting these along the common edge `Rgfg`, we obtain ```text gfgS gfgS @@ -756,8 +757,7 @@ module _ ( is-retraction-map-inv-is-coherently-invertible H) coherence-transposition-is-coherently-invertible ( g , S , R , H) = - coherence-transposition-coherence-is-coherently-invertible - f g S R H + coherence-transposition-coherence-is-coherently-invertible f g S R H transposition-is-coherently-invertible : is-coherently-invertible f → is-transpose-coherently-invertible f diff --git a/src/foundation-core/invertible-maps.lagda.md b/src/foundation-core/invertible-maps.lagda.md index c7cdb17315..0b7ba10a4c 100644 --- a/src/foundation-core/invertible-maps.lagda.md +++ b/src/foundation-core/invertible-maps.lagda.md @@ -308,6 +308,28 @@ module _ ( f ·l is-section-map-inv-invertible-map e) ``` +### Invertible maps are injective + +The construction of the converse map of the +[action on identifications](foundation.action-on-identifications-functions.md) +is a rerun of the proof that maps with +[retractions](foundation-core.retractions.md) are +[injective](foundation-core.injective-maps.md) (`is-injective-retraction`). We +repeat the proof to avoid cyclic dependencies. + +```agda +module _ + {l1 l2 : Level} {A : UU l1} {B : UU l2} {f : A → B} + (H : is-invertible f) {x y : A} + where + + is-injective-is-invertible : f x = f y → x = y + is-injective-is-invertible p = + ( inv (is-retraction-map-inv-is-invertible H x)) ∙ + ( ( ap (map-inv-is-invertible H) p) ∙ + ( is-retraction-map-inv-is-invertible H y)) +``` + ## See also - For the coherent notion of invertible maps see