module Cat.Regular where
Regular categories🔗
A regular category is a category with pullback-stable image factorisations. To define regular categories, we use the theory of orthogonal morphisms, specifically strong epimorphisms: A regular category is one where every morphism factors as a strong epimorphism followed by a monomorphism, and strong epimorphisms are stable under pullback.
At face value, it’s a bit weird to take the definition of regular categories to talk about strong, rather than regular, epimorphisms. But it turns out that strong epimorphisms correspond pretty directly to the idea of an image factorisation, or at least much more directly than regular epimorphisms do. As we shall see, in a regular category, every strong epimorphism is regular.
record is-regular : Type (o ⊔ ℓ) where
field
: ∀ {a b} (f : C.Hom a b) → Factorisation 𝒞 StrongEpi Mono f
factor : is-pullback-stable 𝒞 (is-strong-epi 𝒞)
stable : Finitely-complete 𝒞
has-is-lex
module factor {a b} (f : C.Hom a b) = Factorisation (factor f)
module lex = Finitely-complete has-is-lex
We also introduce some more palatable names for the components of the
provided factorisations: Letting
be a map and
its image factorisation, we refer to
as
to
as a↠im[_]
,
and
as im[_]↪b
.
These latter two names have a placeholder for the morphism we are
factoring.
_] : ∀ {a b} (f : C.Hom a b) → C.Ob
im[= factor f .Factorisation.mediating
im[ f ]
_]↪b : ∀ {a b} (f : C.Hom a b) → im[ f ] C.↪ b
im[= record { monic = □-out! (factor f .Factorisation.forget∈M) }
im[ f ]↪b
_] : ∀ {a b} (f : C.Hom a b) → C.Hom a im[ f ]
a↠im[= factor f .Factorisation.mediate a↠im[ f ]
Motivation🔗
Regular categories are interesting in the study of categorical logic since they have exactly the structure required for their subobject fibrations to interpret existential quantifiers, and for these to commute with substitution which, in this case, is interpreted as pullback.
We’ve already seen that, in a category with pullbacks, arbitrary morphisms induce an adjunction between the right adjoint models the substitution (base change) along and the left adjoint models the dependent sum over Between subobject categories, though, pullbacks are not enough structure: this can be seen type-theoretically by noting that, even if is a family of propositions, the sum will generally not be.
Instead, the existential quantifier must be truncated to work correctly, and it is this truncation that the pullback-stable image factorisations in a regular category exist to model. In a category with pullbacks and images, we have adjunctions now between However, the existence of images is not enough to guarantee they behave type-theoretically. In a regular category, since images are stable under pullback, the equation
holds as long as and fit into a pullback square, expressing that existential quantification commutes with substitution.
Another reason to be interested in regular categories is their well-behaved calculus of relations: any category with pullbacks has an associated bicategory of spans, but images are precisely what’s missing to interpret composition of relations. Indeed, the existential quantifier in a regular category allows us to interpret the formula for relational composition,
internally to an arbitrary category. Regularity comes in when we want to show that composition of relations is associative: indeed, associativity in the formula above, modulo associativity of the conjunction is exactly a question of commutativity between and substitution. It follows, but we do not establish here, that a category is regular exactly when its composition of relations is associative.
As a universe for interpreting logic, regular categories allow us to talk about formulae (in arbitrary contexts) consisting of conjunction, equality, truth, and existential quantification, and all of these connectives commute with substitution. This subset of logic is, unsurprisingly, called regular logic. For working with regular categories, one notes that is regular, and that regularity is preserved by slicing.
Strong epis are regular🔗
This section formalises the proof of A1.3.4 from (Johnstone 2002), which says that every strong epimorphism1 in a regular category is regular. Actually, we’ll show that every strong epimorphism in a regular category is effective: it’s the coequaliser of its kernel pair.
-- Johnstone, A.1.3.4
module _ (r : is-regular) {A B} (f : C.Hom A B) (is-s : is-strong-epi 𝒞 f) where
private
module r = is-regular r
module kp = Pullback (r.lex.pullback f f)
renaming (apex to R ; p₁ to a ; p₂ to b)
For a strong epimorphism start by pulling back along itself to form the kernel pair We want to show that coequalises and which means that any morphism satisfying should have a unique factorisation through So, quantify over such morphisms and let’s get started.
private module Make {C} {c : C.Hom A C} (w : c C.∘ a ≡ c C.∘ b) where
We start by calculating the image factorisation of
: Factorisation 𝒞 StrongEpi Mono ⟨ f , c ⟩
dgh = r.factor ⟨ f , c ⟩
dgh module dgh = Factorisation dgh
renaming (mediating to D ; forget to gh ; mediate to d)
open dgh using (D ; d ; gh)
: C.Hom D B
g = π₁ C.∘ gh
g
: C.Hom D C
h = π₂ C.∘ gh h
Following Johnstone, we show that is an isomorphism, so that is the factorisation we’re looking for.2 Since is an extremal epimorphism, any monomorphism through which it factors must be an iso. And since we have
it will suffice to show that is a monomorphism. So assume you’re given with Let’s show that Start by pulling back along obtaining
: C.is-monic g
g-monic {e} k l w' = □-out! dgh.forget∈M _ _ rem₈ where
g-monic = ×-functor .F₁ (d , d)
d×d module pb = Pullback (r.lex.pullback ⟨ k , l ⟩ d×d)
renaming (p₁ to p ; apex to P ; p₂ to mn ; square to sq'-)
open pb using (p ; P ; mn ; sq'-)
= π₁ C.∘ mn
m = π₂ C.∘ mn
n : ⟨ k C.∘ p , l C.∘ p ⟩ ≡ ⟨ d C.∘ m , d C.∘ n ⟩
sq' = sym (⟨⟩∘ _) ∙ sq'- ∙ ⟨⟩-unique (C.pulll π₁∘⟨⟩ ∙ C.pullr refl)
sq' (C.pulll π₂∘⟨⟩ ∙ C.pullr refl)
We define a map
into the kernel pair of
factoring
through
Using this morphism we may conclude that
(rem₁
).
: C.Hom P R
q = kp.universal $
q .pushl (extend-π₁ dgh.factors ∙ C.pulll refl) ⟩
f ∘ m ≡⟨ C
g ∘ d ∘ m ≡˘⟨ refl⟩∘⟨ by-π₁ sq' ⟩.extendl w' ⟩
g ∘ k ∘ p ≡⟨ C
g ∘ l ∘ p ≡⟨ refl⟩∘⟨ by-π₂ sq' ⟩.pushl (extend-π₁ dgh.factors ∙ C.pulll refl) ⟩
g ∘ d ∘ n ≡˘⟨ C
f ∘ n ∎
= h ∘ k ∘ p ≡⟨ refl⟩∘⟨ by-π₁ sq' ⟩
rem₁ (pullr (sym dgh.factors) ∙ π₂∘⟨⟩) ⟩
h ∘ d ∘ m ≡⟨ pulll .p₁∘universal ⟩
c ∘ m ≡˘⟨ refl⟩∘⟨ kp
c ∘ a ∘ q ≡⟨ extendl w ⟩.p₂∘universal ⟩
c ∘ b ∘ q ≡⟨ refl⟩∘⟨ kp(pullr (sym dgh.factors) ∙ π₂∘⟨⟩) ⟩
c ∘ n ≡˘⟨ pulll
h ∘ d ∘ n ≡˘⟨ refl⟩∘⟨ by-π₂ sq' ⟩ h ∘ l ∘ p ∎
We want to show that for which it will suffice for to be an epimorphism. Since we’re working in a regular category, we can show that is a strong epimorphism by showing that is a composite of strong epis. But is the composite and both of those maps are pullbacks of which is a strong epimorphism since it arises from an image factorisation.
This <details>
tag contains the proof that
and
are pullbacks of
You may choose to unfold or skip it.
open is-pullback
: is-strong-epi 𝒞 (×-functor .F₁ (d , id))
rem₂ = r.stable d π₁ {p2 = π₁} (□-out! dgh.mediate∈E) λ where
rem₂ .square → π₁∘⟨⟩
.universal {p₁' = p₁'} {p₂'} p → ⟨ p₂' , π₂ ∘ p₁' ⟩
.p₁∘universal {p₁' = p₁'} {p₂'} {p = p} → ⟨⟩∘ _
_,_⟩ (pullr π₁∘⟨⟩ ∙ sym p) (pullr π₂∘⟨⟩ ∙ idl _)
·· ap₂ ⟨(⟨⟩-unique refl refl)
·· sym .p₂∘universal → π₁∘⟨⟩
.unique {p = p} {lim'} q r → ⟨⟩-unique r $ sym $
(π₂ ∘_) (sym q) ∙ pulll π₂∘⟨⟩ ∙ ap (_∘ lim') (idl _)
ap
: is-strong-epi 𝒞 (×-functor .F₁ (id , d))
rem₃ = r.stable d π₂ {p2 = π₂} (□-out! dgh.mediate∈E) λ where
rem₃ .square → π₂∘⟨⟩
.universal {p₁' = p₁'} {p₂'} p → ⟨ π₁ ∘ p₁' , p₂' ⟩
.p₁∘universal {p = p} → ⟨⟩∘ _
_,_⟩ (pullr π₁∘⟨⟩ ∙ idl _) (pullr π₂∘⟨⟩)
·· ap₂ ⟨(⟨⟩-unique refl p)
·· sym .p₂∘universal → π₂∘⟨⟩
.unique {p = p} {lim'} q r → ⟨⟩-unique
(sym (ap (π₁ ∘_) (sym q) ∙ pulll π₁∘⟨⟩ ∙ ap (_∘ lim') (idl _)))
r
= sym (×-functor .F-∘ _ _)
rem₄ (×-functor .F₁) (Σ-pathp (idl _) (idr _)) ∙ ap
So
is a strong epimorphism by the above remarks, and
is a pullback of
so it is also strong epic (rem₆
);
We obtain
(rem₇
). By pushing some symbols,
this gives
(rem₈
), but
is a monomorphism by construction, so
— so
is also monic.
: is-strong-epi 𝒞 d×d
rem₅ = subst (is-strong-epi 𝒞) rem₄ (strong-epi-compose 𝒞 _ _ rem₂ rem₃)
rem₅
: is-strong-epi 𝒞 p
rem₆ = r.stable _ _ rem₅ pb.has-is-pb
rem₆
: h ∘ k ≡ h ∘ l
rem₇ = rem₆ .fst _ _ $
rem₇ (h ∘ k) ∘ p ≡⟨ sym (assoc _ _ _) ∙ rem₁ ⟩
h ∘ l ∘ p ≡⟨ pulll refl ⟩(h ∘ l) ∘ p ∎
: gh C.∘ k ≡ gh C.∘ l
rem₈ =
rem₈
gh ∘ k ≡⟨ ⟨⟩-unique refl refl ⟩∘⟨refl ⟩_ ⟩
⟨ g , h ⟩ ∘ k ≡⟨ ⟨⟩∘ _,_⟩ w' rem₇ ⟩
⟨ g ∘ k , h ∘ k ⟩ ≡⟨ ap₂ ⟨_ ⟩
⟨ g ∘ l , h ∘ l ⟩ ≡˘⟨ ⟨⟩∘
⟨ g , h ⟩ ∘ l ≡˘⟨ ⟨⟩-unique refl refl ⟩∘⟨refl ⟩ gh ∘ l ∎
Having shown that
is monic, and knowing that
— a strong (thus extremal) epimorphism — factors through it, we conclude
that
is an isomorphism. It remains to compute
that
which we do below.
=
compute (h ∘ g.from) ∘ f ≡⟨ pullr refl ∙ pullr refl ⟩
.gh ∘ g.from ∘ f ≡⟨ refl ⟩∘⟨ ⟨⟩-unique refl refl ⟩∘⟨ refl ⟩
π₂ ∘ dgh.from ∘ f ≡⟨ refl⟩∘⟨ ⟨⟩∘ _ ⟩
π₂ ∘ ⟨ g , h ⟩ ∘ g.from ∘ f , h ∘ g.from ∘ f ⟩ ≡⟨ π₂∘⟨⟩ ⟩
π₂ ∘ ⟨ g ∘ g.from ∘ f ≡⟨ refl⟩∘⟨ g-ortho.p .centre .snd .fst ⟩
h ∘ g.d ≡⟨ pullr (sym dgh.factors) ⟩
h ∘ dgh
π₂ ∘ ⟨ f , c ⟩ ≡⟨ π₂∘⟨⟩ ⟩ c ∎
This proves that an arbitrary strong epi, coequalises its kernel pair. It’s an effective epimorphism! So it’s definitely the case that it coequalises some pair of maps.
open is-regular-epi renaming (r to Kp)
open is-coequaliser
: is-regular-epi 𝒞 f
is-strong-epi→is-regular-epi = go where
is-strong-epi→is-regular-epi : is-regular-epi 𝒞 f
go .Kp = kp.R
go .arr₁ = kp.a
go .arr₂ = kp.b
go .has-is-coeq .coequal = kp.square
go .has-is-coeq .universal w = Make.h w ∘ Make.g.from w
go .has-is-coeq .factors {e' = e'} {p = w} = Make.compute w
go .has-is-coeq .unique {e' = e'} {p = p} {colim} q = is-s .fst _ _ $
go
colim ∘ f ≡⟨ q ⟩.compute p ⟩
e' ≡˘⟨ Make(Make.h p ∘ Make.g.from p) ∘ f ∎
Note: Johnstone prefers to work with “covers” instead, which in our lingo are extremal epimorphisms. In a finitely complete category, strong and extremal epimorphisms coincide↩︎
Johnstone says it’s clearly unique, but the tiny calculation is included at the end of the proof since it wasn’t clear to me↩︎
References
- Johnstone, Peter T. 2002. Sketches of an Elephant: a Topos Theory Compendium. Oxford Logic Guides. New York, NY: Oxford Univ. Press. https://cds.cern.ch/record/592033.