module Cat.Instances.Localisation where
Localisationsπ
A problem in category theory which sounds simple but turns out to be surprisingly tricky is localisation: constructing universal solutions to the problem of inverting a given class of morphisms. More precisely, suppose that we have a category and a wide subcategory . The localisation , if it exists, should satisfy the following universal property:
There is a functor which inverts every morphsim in , in the sense that, if , then is an isomorphism in ; and
If weβre given a category , and a functor which also inverts every morphism in (i.e., if , then is an isomorphism in ), then there is a unique functor which satisfies .
The construction we present here is similar to that of the free category on a graph. However, instead of paths, we will use structures called zigzags. The idea is simple: in a path, all edges must be oriented the same way; but in a zigzag, we have edges going forward, and edges going backward! The backwards edges are formal inverses for the morphisms from . We can picture a general zigzag as follows:
The diagram represents a zigzag from to . But pay attention to the orientation of the pink edges: theyβre backwards! This zigzag represents a morphism that did not necessarily exist in : composing the inverse of , , and the inverse of . If and were not isomorphisms before, we would have nothing to fill the pink edges with!
data Zigzag : Ob β Ob β Type (o β β β w) where
: Zigzag a a
[] : Hom b c β Zigzag a b β Zigzag a c
zig : (f : Hom c b) β f β W β Zigzag a b β Zigzag a c zag
However, if we treat zigzags as plain data, things go wrong. We must also impose relations, corresponding to functoriality of , and to make the formal inverses into⦠inverses. Using a higher inductive type makes this extremely natural: we can add these relations as higher constructors, which saves us from defining the least congruence generated by the relations we want.
First, we have functoriality: these are straightforward. Note that we only need functoriality in the forwards direction; functoriality of the inverses will follow by uniqueness.
: (h : Zigzag a b) β zig id h β‘ h
zig-id : (f : Hom c d) (g : Hom b c) (h : Zigzag a b)
zig-β β zig f (zig g h) β‘ zig (f β g) h
Next, we need laws that allow us to collapse zigzags. These say that if we have a zigzag starting with
then we can get rid of the extra βroofβ , standing for the composition of and its inverse; We have the symmetric rule in case the inverse comes second, too. Note that since these are generators for the identity type in zigzags, we can apply them anywhere, not just at the start: any context in which a zig-zag or zag-zig could appear will respect this identity.
zig-zag: (f : Hom c b) (w : f β W) (h : Zigzag a b)
β zig f (zag f w h) β‘ h
zag-zig: (f : Hom b c) (w : f β W) (h : Zigzag a b)
β zag f w (zig f h) β‘ h
Finally, we must ensure that the type of zigzags is a set, by truncating it. This is unlike the case with the category of paths in a graph, which worked out to be a set due to the careful setup: there are no relations imposed, and the vertices in a graph must be drawn from a set, unlike the objects in a general precategory.
: β {a b} β is-set (Zigzag a b) squash
The localisation of a locally small category at a class is not necessarily locally small! This is because the data of a zigzag technically includes the names of the objects in the intermediate steps, and objects may live at a higher universe level than morphisms. However, if was small, then all of its localisations will be, as well.
It follows from uniqueness of isomorphisms that the inclusion of into is also functorial. The calculations are not particularly terrifying, but they are standard, so weβll skip over them for time.
abstract
: β {a b} (fs : Zigzag a b) β zag id P-id fs β‘ fs
zag-id =
zag-id fs (zig-id fs) β©
zag id P-id β fs β β‘Λβ¨ apΒ‘ (zig id fs) β‘β¨ zag-zig id _ fs β©
zag id P-id
fs β
zag-β: β {a b c d} {f : Hom c d} {g : Hom b c} (hs : Zigzag a d)
β (hf : f β W) (hg : g β W)
β zag (f β g) (P-β hf hg) hs β‘ zag g hg (zag f hf hs)
{f = f} {g} hs hf hg =
zag-β (f β g) (P-β hf hg) β hs β β‘Λβ¨ apΒ‘ (ap (zig f) (zig-zag _ _ _) β zig-zag _ _ _) β©
zag (f β g) (P-β hf hg) β zig f (zig g (zag g hg (zag f hf hs))) β β‘β¨ ap! (zig-β f g _) β©
zag (f β g) (P-β hf hg) (zig (f β g) (zag g hg (zag f hf hs))) β‘β¨ zag-zig (f β g) _ _ β©
zag (zag f hf hs) β zag g hg
Composition of zigzags is perfectly straightforward. On the data, itβs exactly concatenation of lists, or composition of paths. Since composition sinks to the right when presented with explicit constructors, respect for the imposed relations also very nicely mirrors the definition of concatenation itself.
_++_ : β {a b c} β Zigzag C W b c β Zigzag C W a b β Zigzag C W a c
= f
[] ++ f = zig g (h ++ f)
zig g h ++ f = zag g hg (h ++ f)
zag g hg h ++ f = zig-id (g ++ f) i
zig-id g i ++ f = zig-β g g' (h ++ f) i
zig-β g g' h i ++ f = zig-zag g hg (h ++ f) i
zig-zag g hg h i ++ f = zag-zig g hg (h ++ f) i
zag-zig g hg h i ++ f = squash
squash x y p q i j ++ f (x ++ f) (y ++ f) (Ξ» i β p i ++ f) (Ξ» i β q i ++ f) i j
The definition above is definitionally unital on the left; We must show that this is also the case on the right. Since weβre showing identity of zigzags, which is a proposition, it suffices to cover the data; the relations are automatically respected. While the proofs are slightly obfuscated due to the higher-order nature of eliminators, they once again mirror precisely the proofs for lists, or simple paths.
abstract
: β {a b} (fs : Zigzag C W a b) β fs ++ [] β‘ fs
++-nil = Zigzag-elim-prop (Ξ» h β h ++ [] β‘ h) (Ξ» h β hlevel 1)
++-nil (Ξ» f h p β ap (zig f) p) (Ξ» f hf h p β ap (zag f hf) p)
refl
++-assoc: β {a b c d} (fs : Zigzag C W c d) (gs : Zigzag C W b c) (hs : Zigzag C W a b)
β (fs ++ gs) ++ hs β‘ fs ++ (gs ++ hs)
= Zigzag-elim-prop (Ξ» fs β β gs hs β (fs ++ gs) ++ hs β‘ fs ++ (gs ++ hs))
++-assoc (Ξ» h β hlevel 1)
(Ξ» gs hs β refl)
(Ξ» f h p gs hs β ap (zig f) (p gs hs))
(Ξ» f hf h p gs hs β ap (zag f hf) (p gs hs))
We thus have the localisation as a precategory. The localisation functor sends a morphism to the singleton zigzag consisting of pointing forwards. Finally, if , then weβre also allowed to draw it backards; and this inverts . Since weβre just writing down things weβve already shown, thereβs a bit of code with not much more we could say:
: Precategory o (β β o β w)
Localisation .Ob = C.Ob
Localisation .Hom = Zigzag C W
Localisation .Hom-set _ _ = hlevel 2
Localisation
.id = []
Localisation ._β_ = _++_
Localisation
.idr f = ++-nil f
Localisation .idl f = refl
Localisation .assoc f g h = sym (++-assoc f g h)
Localisation
module Localisation = Cat.Reasoning Localisation
: Functor C Localisation
Localise .Fβ X = X
Localise .Fβ f = zig f []
Localise .F-id = zig-id []
Localise .F-β f g = sym (zig-β f g [])
Localise
: β {a b} (f : C.Hom a b) β f β W? β Localisation.is-invertible (zig f [])
inverted = record
inverted f hf { inv = zag f hf []
; inverses = record
{ invl = zig-zag f hf [] ; invr = zag-zig f hf [] } }
The universal propertyπ
Having constructed the localisation as a higher-inductive type, proving the proper universal property becomes a straightforward exercise in rearranging data. Thatβs because the data of a functor which inverts , together with the data of the category , gives us exactly what we need to handle each of the constructors:
private
: β {a b} (f : C.Hom a b) (hf : f β W?) β D.Hom (F.β b) (F.β a)
Fβ»ΒΉ = D.is-invertible.inv (f-invs f hf)
Fβ»ΒΉ f hf
: β {a b} β Zigzag C W a b β D.Hom (F.β a) (F.β b)
Zigzag-univ = D.id
Zigzag-univ [] (zig f h) = F.β f D.β Zigzag-univ h
Zigzag-univ (zag f hf h) = Fβ»ΒΉ f hf D.β Zigzag-univ h Zigzag-univ
Composing in the forwards direction uses the normal action of the functor ; Composing backwards uses the proof that sends to an isomorphism, so we have a choice of inverse . The relations need a bit of re-arranging, to deal with associativity, but they are also very pleasant:
(zig-id h i) = D.eliml F.F-id {f = Zigzag-univ h} i
Zigzag-univ (zig-β f g h i) = D.pushl (F.F-β f g) {f = Zigzag-univ h} (~ i)
Zigzag-univ (zig-zag f w h i) = D.cancell (D.is-invertible.invl (f-invs f w)) {f = Zigzag-univ h} i
Zigzag-univ (zag-zig f w h i) = D.cancell (D.is-invertible.invr (f-invs f w)) {f = Zigzag-univ h} i
Zigzag-univ (squash x y p q i j) = D.Hom-set _ _
Zigzag-univ (Zigzag-univ x) (Zigzag-univ y) (Ξ» i β Zigzag-univ (p i)) (Ξ» i β Zigzag-univ (q i)) i j
Finally, a straightforward inductive proof establishes that this procedure preserves composition of zigzags. It preserves the identity definitionally.
abstract
Zigzag-univ-++: β {a b c} (f : Zigzag C W b c) (g : Zigzag C W a b)
β Zigzag-univ (f ++ g) β‘ Zigzag-univ f D.β Zigzag-univ g
= Zigzag-elim-prop
Zigzag-univ-++ (Ξ» f β β g β Zigzag-univ (f ++ g) β‘ Zigzag-univ f D.β Zigzag-univ g)
(Ξ» _ β hlevel 1)
(Ξ» g β D.introl refl)
(Ξ» f h p g β ap (F.β f D.β_) (p g) β D.pulll refl)
(Ξ» f hf h p g β ap (Fβ»ΒΉ f hf D.β_) (p g) β D.pulll refl)
Since Zigzag-univ
computes so
nicely, the proof of the universal property is incredibly
straightforward, and we actually get a stronger result than we bargained
for: not only do we have a natural isomorphism
,
itβs actually an identity, even if the categories involved are
not univalent
categories.
: Functor Localisation D
Localisation-univ .Fβ = F.β
Localisation-univ .Fβ = Zigzag-univ
Localisation-univ .F-id = refl
Localisation-univ .F-β = Zigzag-univ-++
Localisation-univ
: F β‘ Localisation-univ Fβ Localise
Localisation-univ-Ξ² = Functor-path (Ξ» _ β refl) (Ξ» _ β D.intror refl) Localisation-univ-Ξ²
We can also show a uniqueness principle, saying that extending the localisation functor results in the identity.
: Localisation-univ Localise inverted β‘ Id
Localisation-univ-Ξ· = Functor-path (Ξ» _ β refl) $ Zigzag-elim-prop
Localisation-univ-Ξ· (Ξ» h β Zigzag-univ Localise inverted h β‘ h)
(Ξ» h β squash _ _)
(Ξ» f h p β ap (zig f) p) (Ξ» f hf h p β ap (zag f hf) p) refl
To conclude this section, we make note of a slight triviality: if every morphism in was already invertible, then we can map from the localisation back to :
Localisation-fold: (β {a b} (f : C.Hom a b) β f β W? β C.is-invertible f)
β Functor Localisation C
= Localisation-univ Id invs Localisation-fold invs
Total localisationsπ
An important special case of localisation is the total localisation , which computes the free groupoid on a category: the universal solution to inverting every morphism in . To make it clear what weβre talking about, weβll refer to zigzags in the total localisation as meanders. The setup is the same: weβre just allowing ourselves to draw every morphism backwards.
: Ob β Ob β Type _
Meander = Zigzag C Total Meander
To show that the total localisation is a pregroupoid, weβll have to
compute the inverse of an arbitrary meander. Following standard
functional programming practice, we first define a reverse
append operation, which composes against the inverse of
its first argument, and then define reverse
by appending onto the empty
zigzag.
_r++_ : β {a b c} β Meander c b β Meander a b β Meander a c
= f
[] r++ f = h r++ zag g tt f
zig g h r++ f = h r++ zig g f
zag g hg h r++ f = g r++ zag-id _ _ f i
zig-id g i r++ f = h r++ zag-β C Total {f = g} {g'} f tt tt (~ i)
zig-β g g' h i r++ f = h r++ zig-zag g tt f i
zig-zag g hg h i r++ f = h r++ zag-zig g tt f i
zag-zig g hg h i r++ f = squash (x r++ f) (y r++ f) (Ξ» i β p i r++ f) (Ξ» i β q i r++ f) i j
squash x y p q i j r++ f
: β {a b} β Meander a b β Meander b a
reverse = fs r++ [] reverse fs
We then have a battery of lemmas connecting these two operations with the standard composition, all shown by straightforward induction.
abstract
r++-assoc: β {a b c d} (fs : Meander d c) (gs : Meander b c) (hs : Meander a b)
β (fs r++ gs) ++ hs β‘ fs r++ (gs ++ hs)
= Zigzag-elim-prop (Ξ» fs β β gs hs β (fs r++ gs) ++ hs β‘ fs r++ (gs ++ hs))
r++-assoc (Ξ» _ β hlevel 1)
(Ξ» _ _ β refl)
(Ξ» f fs rec gs hs β rec _ _)
(Ξ» f hf fs rec gs hs β rec _ _)
r++-assoc': β {a b c d} (fs : Meander b c) (gs : Meander d c) (hs : Meander a b)
β (fs r++ gs) r++ hs β‘ gs r++ (fs ++ hs)
= Zigzag-elim-prop (Ξ» f β β g h β (f r++ g) r++ h β‘ g r++ (f ++ h))
r++-assoc' (Ξ» _ β hlevel 1)
(Ξ» _ _ β refl)
(Ξ» f fs rec gs hs β rec _ _)
(Ξ» f h fs rec gs hs β rec _ _)
r++-reverse: β {a b c} (fs : Meander c b) (gs : Meander a b)
β reverse fs ++ gs β‘ fs r++ gs
= r++-assoc fs [] gs r++-reverse fs gs
Finally, we can show that inverse-appending
onto
gives the identity. With the lemmas proved in the <details>
block above, we can conclude that the reverse
of a zigzag is actually its
categorical inverse in the total localisation
.
: β {a b} (fs : Meander a b) β fs r++ fs β‘ []
r++-cancel = Zigzag-elim-prop (Ξ» fs β fs r++ fs β‘ [])
r++-cancel (Ξ» _ β hlevel 1)
refl(Ξ» f fs rec β ap (fs r++_) (zag-zig _ _ _) β rec)
(Ξ» f tt fs rec β ap (fs r++_) (zig-zag _ _ _) β rec)
: β {a b} (fs : Meander a b) β reverse (reverse fs) β‘ fs
reverse-invo = r++-assoc' fs [] [] β ++-nil fs
reverse-invo fs
: β {a b} (fs : Meander a b) β reverse fs ++ fs β‘ []
reverse-invl = r++-reverse fs fs β r++-cancel fs
reverse-invl fs
: β {a b} (fs : Meander a b) β fs ++ reverse fs β‘ []
reverse-invr = ap (_++ reverse fs) (sym (reverse-invo fs))
reverse-invr fs (reverse fs) β reverse-invl
As we put together the construction of the Free-groupoid
, we should note the
following rephrasing of its universal property: it is the left adjoint to the
inclusion of groupoids into categories,1
which fits into an adjoint triple
with the right adjoint being the core functor β the cofree groupoid on a category.
: Precategory o (o β β)
Free-groupoid = Localisation C Total
Free-groupoid
: is-pregroupoid Free-groupoid
Free-groupoid-is-groupoid = record
Free-groupoid-is-groupoid f { inv = reverse f
; inverses = record
{ invl = reverse-invr f
; invr = reverse-invl f
}
}
Finally, weβll show the universal property of the free groupoid as a special case of mapping any localisation into a groupoid . Since any functor sends everything to an isomorphism, including the class , weβre always allowed to extend to map from , instead.
Localisation-univ-groupoid: β {o β w o' β'} {C : Precategory o β} {W : Wide-subcat C w}
β {D : Precategory o' β'} (d-grpd : is-pregroupoid D)
β Functor C D
β Functor (Localisation C W) D
= Localisation-univ _ _ F Ξ» f _ β dg _ Localisation-univ-groupoid dg F
Specialising the universal property to thin groupoids (i.e.Β congruences), we obtain useful recursion principles for showing that objects connected by zigzags are related.
Meander-rec-congruence: β {β'} (R : Congruence Ob β') (open Congruence R)
β (β {a b} β Hom a b β a βΌ b)
β β {x y} β Meander C x y β x βΌ y
= Localisation-univ-groupoid (congruenceβgroupoid R)
Meander-rec-congruence R h (congruence-functor R (Ξ» x β x) h) .Functor.Fβ
Meander-rec-β‘: β {β'} (D : Set β')
β (f : Ob β β£ D β£)
β (β {x y} β Hom x y β f x β‘ f y)
β β {x y} β Meander C x y β f x β‘ f y
= Meander-rec-congruence (Kernel-pair (D .is-tr) f) Meander-rec-β‘ D f
Technically speaking, the inclusion of into is a pseudofunctor, and so this should be a biadjoint cylinder. However, biadjunctions are very complicated objects, so itβs fine β though slightly inaccurate β to work intuitively at the level of 1-categories.β©οΈ