module 1Lab.Equiv.FromPath {ℓ} (P : (i : I) → Type ℓ) whereTransport is an equivalence🔗
Showing that transport is an equivalence could be done
essentially by path induction, since the transp function associated to a line of
types
is identical to the identity function over
This is a very straightforward argument:
private
bad-transport-is-equiv : is-equiv (transp P i0)
bad-transport-is-equiv = transp (λ i → is-equiv (coe0→i P i)) i0 id-equivWhile is-equiv is a proposition
— and thus the particular proof does not matter propositionally — Agda
is still a programming language, the data of an equivalence includes the
inverse function, and the inverse we obtain from this construction is
not simply transport along the inverse of
it has an extra reflexive transport along
which does not compute away when
is neutral.
_ : equiv→inverse bad-transport-is-equiv
≡ transport refl ∘ transp (λ i → P (~ i)) i0
_ = reflWe can instead construct the proof that transp along
is an equivalence directly. We start by naming all the relevant
endpoints:
A B : Type ℓ
A = P i0
B = P i1
f : A → B
f x = coe0→1 P x
g : B → A
g y = coe1→0 P yWe can then directly prove that and are inverses, fixing the computation of the inverse. Since having a two-sided inverse is enough to imply that a function is an equivalence, we would be done; however, that general theorem relies on replacing the unit by something which satisfies the triangle identities, whereas in this case we can show by a direct cubical argument that our already satisfies the triangle identities.
ε : (y : B) → f (g y) ≡ y
ε y i = coe P i i1 (coe P i1 i y)
η : (x : A) → g (f x) ≡ x
η x i = coe P (~ i) i0 (coe P i0 (~ i) x)It will suffice to give a square
with the boundary below, since in that case (assuming we have
and the data
of a fibre
we can construct
as the composite
and glue
along ∙-filler' to give us the
necessary square identifying
and
module _ (y : B) (x : A) (α : f x ≡ y) where
β : g y ≡ x
β = ap g (sym α) ∙ η x
Gluing ζ₁ to obtain the
necessary ζ is simple enough.
ζ₁ : Square (ap f (η x)) (ε (f x)) refl refl
ζ : Square (ap f β) (ε y) α refl
ζ i j = hcomp (∂ i ∨ ∂ j) λ where
k (k = i0) → ζ₁ i j
k (i = i0) → ε (α k) j
k (i = i1) → α (k ∧ j)
k (j = i0) → f (∙-filler' (ap g (sym α)) (η x) k i)
k (j = i1) → α k
However, since constructing ζ₁
boils down to slapping together an absurd number of coes, we leave it in this <details>
tag for the curious reader.
ζ₁ to obtain the
necessary ζ is simple enough. ζ₁ : Square (ap f (η x)) (ε (f x)) refl refl
ζ : Square (ap f β) (ε y) α refl
ζ i j = hcomp (∂ i ∨ ∂ j) λ where
k (k = i0) → ζ₁ i j
k (i = i0) → ε (α k) j
k (i = i1) → α (k ∧ j)
k (j = i0) → f (∙-filler' (ap g (sym α)) (η x) k i)
k (j = i1) → α k ζ₁ i j = comp P (∂ i ∨ ∂ j) λ where
k (k = i0) → η x (i ∨ ~ j)
k (i = i0) → coe P j k (coe-path P (λ j → coe0→i P j x) k j i)
k (j = i0) → coe P j k (coe-path P (λ j → coe0→i P j x) k j i)
k (i = i1) → coe P i0 k x
k (j = i1) → hcomp (∂ i ∨ ∂ k) λ where
j (j = i0) → coe-path P (λ j → coe P k j (coe0→i P k x)) i1 k i
j (i = i1) → coei→i P k (coe0→i P k x) j
j (i = i0) → coe P i1 k (coe P k i1 (coe0→i P k x))
j (k = i0) → η x i
j (k = i1) → f xWe can now simply package the components up.
transp-is-equiv : is-equiv (transp P i0)
transp-is-equiv .is-eqv y .centre = record { snd = ε y }
transp-is-equiv .is-eqv y .paths (x , α) i = record
{ snd = ζ y x α i }
line→equiv : A ≃ B
line→equiv .fst = transp P i0
line→equiv .snd = transp-is-equivAt the level of points and paths, this construction computes very
nicely, with the only hitch being a stray reflexivity path added to the
unit. The witness for the triangle identity is our ζ, and so made up of quite a few hcomps, but still much better (by virtue
of the unit and counit being simpler) than is possible by simply
transporting the proof that the identity is an equivalence.
_ : equiv→inverse transp-is-equiv ≡ g
_ = refl
_ : equiv→counit transp-is-equiv ≡ transport⁻transport (λ i → P (~ i))
_ = refl
_ : ∀ {x}
→ equiv→unit transp-is-equiv x
≡ refl ∙ transport⁻transport (λ i → P i) x
_ = refl