module Cat.Functor.Amnestic where
private variable
: Level
o ℓ o' ℓ' : Precategory o ℓ C D
Amnestic functors🔗
The notion of amnestic functor was introduced by Adámek, Herrlich and Strecker in their book “The Joy of Cats”1 as a way to make precise the vibes-based notion of forgetful functor. Classically, the definition reads
A functor is amnestic if an isomorphism is an identity whenever is,
but what does it mean for an isomorphism to be an identity? The obvious translation would be that comes from an identification of objects, but this is just rephrasing the condition that is univalent, whereas we want a condition on the functor So, we define:
An isomorphism
is an identity if it is an identity in the total space
of Hom
, i.e. if there is an object
s.t.
in the type
Every isomorphism in a univalent category is
an identity, since we can take
and the identification in Arrows
follows from univalence.
module _ (F : Functor C D) where
private
module C = Cat C
module D = Cat D
module F = Func F
Let
be an identity, i.e. it is such that
Any functor
induces an identification
meaning that it preserves being an identity. A functor is
amnestic if it additionally reflects being an
identity: the natural map we have implicitly defined above (called action
) is an equivalence.
: ∀ {a b : C.Ob} (f : C.Hom a b)
action → Σ[ c ∈ C ] (Hom→Arrow C (C.id {x = c}) ≡ Hom→Arrow C f)
→ Σ[ c ∈ D ] (Hom→Arrow D (D.id {x = c}) ≡ Hom→Arrow D (F.₁ f))
(c , p) = F.₀ c , q where
action f : Hom→Arrow D D.id ≡ Hom→Arrow D (F.₁ f)
q .fst = F.₀ (p i .fst)
q i .snd .fst = F.₀ (p i .snd .fst)
q i .snd .snd = hcomp (∂ i) λ where
q i (j = i0) → F.₁ (p i .snd .snd)
j (i = i1) → F.₁ f
j (i = i0) → F.F-id j
j
: Type _
is-amnestic = ∀ {a b : C.Ob} (f : C.Hom a b)
is-amnestic → C.is-invertible f → is-equiv (action f)
Who cares?🔗
The amnestic functors are interesting to consider in HoTT because they are exactly those that reflect univalence: If is an amnestic functor and is a univalent category, then is univalent, too!
: is-category D → is-amnestic → is-category C
reflect-category = record { to-path = A≡B ; to-path-over = q } where
reflect-category d-cat forget module _ {A} {B} isom where
= F-map-iso F isom isom'
For suppose that is an isomorphism. preserves this isomorphism, meaning we have an iso now in But because is a univalent category, is an identity, and by amnesia, so is
: Σ[ c ∈ C ] Path (Arrows C) (c , c , C.id) (A , B , isom .C.to)
p = equiv→inverse (forget (isom .C.to) (C.iso→invertible isom)) $ F.₀ A ,
p (d-cat .to-path isom')
Arrows-path D refl (Univalent.Hom-pathp-reflr-iso d-cat (D.idr _))
Unfolding, we have an object and an identification We may construct an identification from the components of and this induces an identification over in a straightforward way. We’re done!
= sym (ap fst (p .snd)) ∙ ap (fst ⊙ snd) (p .snd)
A≡B
: PathP (λ i → A C.≅ A≡B i) C.id-iso isom
q = C.≅-pathp refl A≡B $ Hom-pathp-reflr C $
q .idr _
C_ _
·· path→to-∙ C ._∘_ refl (sym (path→to-sym C (ap fst (p .snd))))
·· ap₂ C(ap (snd ⊙ snd) (p .snd)) ∙ Hom-pathp-id C
Cats are, indeed, very joyful↩︎