module Cat.Diagram.Initial where
module _ {o h} (C : Precategory o h) where
open Cat.Morphism C
Initial objects🔗
An object of a category is said to be initial if there exists a unique map to any other object:
: Ob → Type _
is-initial = ∀ x → is-contr (Hom ob x)
is-initial ob
record Initial : Type (o ⊔ h) where
field
: Ob
bot : is-initial bot has⊥
We refer to the centre of contraction as ¡
. Since it inhabits a contractible type,
it is unique.
: ∀ {x} → Hom bot x
¡ = has⊥ _ .centre
¡
: ∀ {x} (h : Hom bot x) → ¡ ≡ h
¡-unique = has⊥ _ .paths
¡-unique
: ∀ {x} (f g : Hom bot x) → f ≡ g
¡-unique₂ = is-contr→is-prop (has⊥ _)
¡-unique₂
open Initial
Intuition🔗
The intuition here is that we ought to think about an initial object
as having “the least amount of structure possible”, insofar that it can
be mapped into any other object. For the category of Sets
, this is the empty set; there is no
required structure beyond “being a set”, so the empty set sufficies.
In more structured categories, the situation becomes a bit more
interesting. Once our category has enough structure that we can’t build
maps from a totally trivial thing, the initial object begins to behave
like a notion of Syntax for our category. The idea here
is that we have a unique means of interpreting our syntax into
any other object, which is exhibited by the universal map ¡
Uniqueness🔗
One important fact about initial objects is that they are unique up to isomorphism:
: (i i' : Initial) → bot i ≅ bot i'
⊥-unique = make-iso (¡ i) (¡ i') (¡-unique₂ i' _ _) (¡-unique₂ i _ _) ⊥-unique i i'
Additionally, if is a category, then the space of initial objects is a proposition:
: is-category C → is-prop Initial
⊥-is-prop .bot =
⊥-is-prop ccat x1 x2 i .iso→path ccat (⊥-unique x1 x2) i
Univalent
.has⊥ ob =
⊥-is-prop ccat x1 x2 i
is-prop→pathp(λ i → is-contr-is-prop
{A = Hom (Univalent.iso→path ccat (⊥-unique x1 x2) i) _})
(x1 .has⊥ ob) (x2 .has⊥ ob) i
Strictness🔗
An initial object is said to be strict if every morphism into it is an isomorphism. This is a categorical generalization of the fact that if one can write a function then must itself be empty.
This is an instance of the more general notion of van Kampen colimits.
: Initial → Type _
is-strict-initial = ∀ x → (f : Hom x (i .bot)) → is-invertible f
is-strict-initial i
record Strict-initial : Type (o ⊔ h) where
field
: Initial
initial : is-strict-initial initial has-is-strict
Strictness is a property of, not structure on, an initial object.
: ∀ i → is-prop (is-strict-initial i)
is-strict-initial-is-prop = hlevel 1 is-strict-initial-is-prop i
As maps out of initial objects are unique, it suffices to show that every map for every to establish that is a strict initial object.
make-is-strict-initial: (i : Initial)
→ (∀ x → (f : Hom x (i .bot)) → (¡ i) ∘ f ≡ id)
→ is-strict-initial i
=
make-is-strict-initial i p x f (¡ i) (¡-unique₂ i (f ∘ ¡ i) id) (p x f) make-invertible
module _ {o h} {C : Precategory o h} where
open Cat.Morphism C
private unquoteDecl eqv = declare-record-iso eqv (quote Initial)
instance
Extensional-Initial: ∀ {ℓr}
→ ⦃ sa : Extensional Ob ℓr ⦄
→ Extensional (Initial C) ℓr
=
Extensional-Initial ⦃ sa ⦄
embedding→extensional(Iso→Embedding eqv ∙emb (fst , Subset-proj-embedding λ _ → hlevel 1))
sa