module 1Lab.Equiv.Fibrewise where
Fibrewise equivalences🔗
In HoTT, a type family P : A → Type
can be seen as a fibration
with total space Σ P
, with the fibration being the
projection fst
. Because of this, a
function with type (X : _) → P x → Q x
can be referred as a
fibrewise map.
A function like this can be lifted to a function on total spaces:
private variable
: Level
ℓ : Type ℓ
A B : A → Type ℓ P Q
: ((x : A) → P x → Q x)
total → Σ A P → Σ A Q
(x , y) = x , f x y total f
Furthermore, the fibres of total f
correspond to fibres
of f, in the following manner:
: {f : (x : A) → P x → Q x} {x : A} {v : Q x}
total-fibres → Iso (fibre (f x) v) (fibre (total f) (x , v))
{A = A} {P = P} {Q = Q} {f = f} {x = x} {v = v} = the-iso where
total-fibres open is-iso
to : {x : A} {v : Q x} → fibre (f x) v → fibre (total f) (x , v)
to (v' , p) = (_ , v') , λ i → _ , p i
: {x : A} {v : Q x} → fibre (total f) (x , v) → fibre (f x) v
from ((x , v) , p) = transport (λ i → fibre (f (p i .fst)) (p i .snd)) (v , refl)
from
: {x : A} {v : Q x} → Iso (fibre (f x) v) (fibre (total f) (x , v))
the-iso .fst = to
the-iso .snd .is-iso.inv = from
the-iso .snd .is-iso.rinv ((x , v) , p) =
the-iso (λ { _ p → to (from ((x , v) , p)) ≡ ((x , v) , p) })
J (ap to (J-refl {A = Σ A Q} (λ { (x , v) _ → fibre (f x) v } ) (v , refl)))
p.snd .is-iso.linv (v , p) =
the-iso (λ { _ p → from (to (v , p)) ≡ (v , p) })
J (J-refl {A = Σ A Q} (λ { (x , v) _ → fibre (f x) v } ) (v , refl))
p
From this, we immediately get that a fibrewise transformation is an
equivalence iff. it induces an equivalence of total spaces by
total
.
: {f : (x : A) → P x → Q x}
total→equiv → is-equiv (total f)
→ {x : A} → is-equiv (f x)
{x} .is-eqv y =
total→equiv eqv 0 (total-fibres .snd .is-iso.inv)
iso→is-hlevel (is-iso.inverse (total-fibres .snd))
(eqv .is-eqv (x , y))
: {f : (x : A) → P x → Q x}
equiv→total → ({x : A} → is-equiv (f x))
→ is-equiv (total f)
.is-eqv y =
equiv→total always-eqv 0
iso→is-hlevel (total-fibres .fst)
(total-fibres .snd)
(always-eqv .is-eqv (y .snd))
Equivalences over🔗
We can generalise the notion of fibrewise equivalence to families over different base types, provided we have an equivalence In that case, we say that and are equivalent over if whenever and are identified over
Using univalence, we can see this as a special case of dependent paths, where the base type is taken to be the universe and the type family sends a type to the type of type families over However, the following explicit definition is easier to work with.
module _ {ℓa ℓb} {A : Type ℓa} {B : Type ℓb} where
_≃[_]_ : ∀ {ℓp ℓq} (P : A → Type ℓp) (e : A ≃ B) (Q : B → Type ℓq) → Type _
= ∀ (a : A) (b : B) → e .fst a ≡ b → P a ≃ Q b P ≃[ e ] Q
While this definition is convenient to use, we provide helpers that make it easier to build equivalences over.
module _ {ℓp ℓq} {P : A → Type ℓp} {Q : B → Type ℓq} (e : A ≃ B) where
private module e = Equiv e
: (∀ (a : A) → P a ≃ Q (e.to a)) → P ≃[ e ] Q
over-left→over = e' a ∙e line→equiv (λ i → Q (p i))
over-left→over e' a b p
: (∀ (b : B) → P (e.from b) ≃ Q b) → P ≃[ e ] Q
over-right→over = line→equiv (λ i → P (e.adjunctl p i)) ∙e e' b
over-right→over e' a b p
prop-over-ext: (∀ {a} → is-prop (P a))
→ (∀ {b} → is-prop (Q b))
→ (∀ (a : A) → P a → Q (e.to a))
→ (∀ (b : B) → Q b → P (e.from b))
→ P ≃[ e ] Q
= prop-ext propP propQ
prop-over-ext propP propQ P→Q Q→P a b p (subst Q p ∘ P→Q a)
(subst P (sym (e.adjunctl p)) ∘ Q→P b)
An equivalence over induces an equivalence of total spaces:
: P ≃[ e ] Q → Σ A P ≃ Σ B Q
over→total = Σ-ap e λ a → e' a (e.to a) refl over→total e'
subst-fibrewise: ∀ {ℓ ℓ' ℓ''} {A : Type ℓ} {B : A → Type ℓ'} {B' : A → Type ℓ''} (g : ∀ x → B x → B' x)
→ {x y : A} (p : x ≡ y) (h : B x) → subst B' p (g x h) ≡ g y (subst B p h)
{B = B} {B'} g {x} p h = J (λ y p → subst B' p (g x h) ≡ g y (subst B p h)) (transport-refl _ ∙ ap (g x) (sym (transport-refl _))) p subst-fibrewise