module Cat.Instances.Shape.Terminal where

The terminal category is the category with a single object, and only trivial morphisms.

⊤Cat : Precategory lzero lzero
⊤Cat .Ob =
⊤Cat .Hom _ _ =
⊤Cat .Hom-set _ _ _ _ _ _ _ _ = tt
⊤Cat .Precategory.id = tt
⊤Cat .Precategory.__ _ _ = tt
⊤Cat .idr _ _ = tt
⊤Cat .idl _ _ = tt
⊤Cat .assoc _ _ _ _ = tt

The ony morphism in the terminal category is the identity, so the terminal category is a pregroupoid.

⊤Cat-is-pregroupoid : is-pregroupoid ⊤Cat
⊤Cat-is-pregroupoid _ = id-invertible ⊤Cat

There is a unique functor from any category into the terminal category.

  !F : Functor C ⊤Cat
  !F .F₀ _ = tt
  !F .F₁ _ = tt
  !F .F-id = refl
  !F .F-∘ _ _ = refl

  !F-unique :  {F : Functor C ⊤Cat}  F ≡ !F
  !F-unique = Functor-path  _  refl)  _  refl)

Conversely, functors are determined by their behaviour on a single object.

  !Const : C.Ob  Functor ⊤Cat C
  !Const c .F₀ _ = c
  !Const c .F₁ _ = C.id
  !Const c .F-id = refl
  !Const c .F-∘ _ _ = sym (C.idl _)

  !Const-η :  (F G : Functor ⊤Cat C)  F .F₀ tt ≡ G .F₀ tt  F ≡ G
  !Const-η F G p =
    Functor-path
       _  p)
       _ i  hcomp (∂ i) λ where
        j (i = i0)  F .F-id (~ j)
        j (i = i1)  G .F-id (~ j)
        j (j = i0)  C.id)

Natural isomorphisms between functors correspond to isomorphisms in

  !constⁿ
    :  {F G : Functor ⊤Cat C}
     C.Hom (F .F₀ tt) (G .F₀ tt)
     F => G
  !constⁿ {F = F} {G = G} f .η _ = f
  !constⁿ {F = F} {G = G} f .is-natural _ _ _ =
    C.elimr (F .F-id) ∙ C.introl (G .F-id)

  !const-isoⁿ
    :  {F G : Functor ⊤Cat C}
     F .F₀ tt C.≅ G .F₀ tt
     F ≅ⁿ G
  !const-isoⁿ {F = F} {G = G} f =
    iso→isoⁿ  _  f)  _  C.eliml (G .F-id) ∙ C.intror (F .F-id))