Categorical images #
We define the categorical image of f as a factorisation f = e ≫ m through a monomorphism m,
so that m factors through the m' in any other such factorisation.
Main definitions #
- A - MonoFactorisationis a factorisation- f = e ≫ m, where- mis a monomorphism
- IsImage Fmeans that a given mono factorisation- Fhas the universal property of the image.
- HasImage fmeans that there is some image factorization for the morphism- f : X ⟶ Y.
- HasImages Cmeans that every morphism in- Chas an image.
- Let - f : X ⟶ Yand- g : P ⟶ Qbe morphisms in- C, which we will represent as objects of the arrow category- Arrow C. Then- sq : f ⟶ gis a commutative square in- C. If- fand- ghave images, then- HasImageMap sqrepresents the fact that there is a morphism- i : image f ⟶ image gmaking the diagram- X ----→ image f ----→ Y | | | | | | ↓ ↓ ↓ P ----→ image g ----→ Q - commute, where the top row is the image factorisation of - f, the bottom row is the image factorisation of- g, and the outer rectangle is the commutative square- sq.
- If a category - HasImages, then- HasImageMapsmeans that every commutative square admits an image map.
- If a category - HasImages, then- HasStrongEpiImagesmeans that the morphism to the image is always a strong epimorphism.
Main statements #
- When Chas equalizers, the morphismeappearing in an image factorisation is an epimorphism.
- When Chas strong epi images, then these images admit image maps.
Future work #
- TODO: coimages, and abelian categories.
- TODO: connect this with existing working in the group theory and ring theory libraries.
A factorisation of a morphism f = e ≫ m, with m monic.
- I : C
Instances For
The obvious factorisation of a monomorphism through itself.
Equations
- CategoryTheory.Limits.MonoFactorisation.self f = { I := X, m := f, m_mono := inst✝, e := CategoryTheory.CategoryStruct.id X, fac := ⋯ }
Instances For
Equations
The morphism m in a factorisation f = e ≫ m through a monomorphism is uniquely
determined.
Any mono factorisation of f gives a mono factorisation of f ≫ g when g is a mono.
Equations
Instances For
A mono factorisation of f ≫ g, where g is an isomorphism,
gives a mono factorisation of f.
Equations
- F.ofCompIso = { I := F.I, m := CategoryTheory.CategoryStruct.comp F.m (CategoryTheory.inv g), m_mono := ⋯, e := F.e, fac := ⋯ }
Instances For
Any mono factorisation of f gives a mono factorisation of g ≫ f.
Equations
Instances For
A mono factorisation of g ≫ f, where g is an isomorphism,
gives a mono factorisation of f.
Equations
- CategoryTheory.Limits.MonoFactorisation.ofIsoComp g F = { I := F.I, m := F.m, m_mono := ⋯, e := CategoryTheory.CategoryStruct.comp (CategoryTheory.inv g) F.e, fac := ⋯ }
Instances For
If f and g are isomorphic arrows, then a mono factorisation of f
gives a mono factorisation of g
Equations
- F.ofArrowIso sq = { I := F.I, m := CategoryTheory.CategoryStruct.comp F.m sq.right, m_mono := ⋯, e := CategoryTheory.CategoryStruct.comp (CategoryTheory.inv sq.left) F.e, fac := ⋯ }
Instances For
Data exhibiting that a given factorisation through a mono is initial.
- Data exhibiting that a given factorisation through a mono is initial. 
- Data exhibiting that a given factorisation through a mono is initial. 
Instances For
The trivial factorisation of a monomorphism satisfies the universal property.
Equations
- CategoryTheory.Limits.IsImage.self f = { lift := fun (F' : CategoryTheory.Limits.MonoFactorisation f) => F'.e, lift_fac := ⋯ }
Instances For
Equations
Two factorisations through monomorphisms satisfying the universal property must factor through isomorphic objects.
Instances For
If f and g are isomorphic arrows, then a mono factorisation of f that is an image
gives a mono factorisation of g that is an image
Equations
- hF.ofArrowIso sq = { lift := fun (F' : CategoryTheory.Limits.MonoFactorisation g.hom) => hF.lift (F'.ofArrowIso (CategoryTheory.inv sq)), lift_fac := ⋯ }
Instances For
Data exhibiting that a morphism f has an image.
- F : MonoFactorisation fData exhibiting that a morphism fhas an image.
- Data exhibiting that a morphism - fhas an image.
Instances For
Equations
- CategoryTheory.Limits.ImageFactorisation.instInhabitedOfMono f = { default := { F := CategoryTheory.Limits.MonoFactorisation.self f, isImage := CategoryTheory.Limits.IsImage.self f } }
If f and g are isomorphic arrows, then an image factorisation of f
gives an image factorisation of g
Equations
- F.ofArrowIso sq = { F := F.F.ofArrowIso sq, isImage := F.isImage.ofArrowIso sq }
Instances For
HasImage f means that there exists an image factorisation of f.
- mk' :: (
- exists_image : Nonempty (ImageFactorisation f)HasImage fmeans that there exists an image factorisation off.
- )
Instances
Some factorisation of f through a monomorphism (selected with choice).
Equations
Instances For
The witness of the universal property for the chosen factorisation of f through
a monomorphism.
Equations
Instances For
The categorical image of a morphism.
Instances For
The inclusion of the image of a morphism into the target.
Instances For
The map from the source to the image of a morphism.
Equations
Instances For
Rewrite in terms of the factorThruImage interface.
Any other factorisation of the morphism f through a monomorphism receives a map from the
image.
Equations
Instances For
If has_image g, then has_image (f ≫ g) when f is an isomorphism.
The image of a monomorphism is isomorphic to the source.
Equations
Instances For
An equation between morphisms gives a comparison map between the images (which momentarily we prove is an iso).
Equations
- One or more equations did not get rendered due to their size.
Instances For
An equation between morphisms gives an isomorphism between the images.
Equations
Instances For
As long as the category has equalizers,
the image inclusion maps commute with image.eqToIso.
The comparison map image (f ≫ g) ⟶ image g.
Equations
- One or more equations did not get rendered due to their size.
Instances For
image.preComp f g is a monomorphism.
The two step comparison map
image (f ≫ (g ≫ h)) ⟶ image (g ≫ h) ⟶ image h
agrees with the one step comparison map
image (f ≫ (g ≫ h)) ≅ image ((f ≫ g) ≫ h) ⟶ image h.
image.preComp f g is an epimorphism when f is an epimorphism
(we need C to have equalizers to prove this).
image.preComp f g is an isomorphism when f is an isomorphism
(we need C to have equalizers to prove this).
Postcomposing by an isomorphism induces an isomorphism on the image.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- CategoryTheory.Limits.inhabitedImageMap = { default := { map := CategoryTheory.CategoryStruct.id (CategoryTheory.Limits.image f.hom), map_ι := ⋯ } }
To give an image map for a commutative square with f at the top and g at the bottom, it
suffices to give a map between any mono factorisation of f and any image factorisation of g.
Equations
- One or more equations did not get rendered due to their size.
Instances For
HasImageMap sq means that there is an ImageMap for the square sq.
- mk' :: (
- HasImageMap sqmeans that there is an- ImageMapfor the square- sq.
- )
Instances
Obtain an ImageMap from a HasImageMap instance.
Equations
Instances For
@[simp]-normal form of ImageMap.mk.injEq.
The map on images induced by a commutative square.
Equations
Instances For
Image maps for composable commutative squares induce an image map in the composite square.
Equations
- CategoryTheory.Limits.imageMapComp sq sq' = { map := CategoryTheory.CategoryStruct.comp (CategoryTheory.Limits.image.map sq) (CategoryTheory.Limits.image.map sq'), map_ι := ⋯ }
Instances For
The identity image f ⟶ image f fits into the commutative square represented by the identity
morphism 𝟙 f in the arrow category.
Equations
- CategoryTheory.Limits.imageMapId f = { map := CategoryTheory.CategoryStruct.id (CategoryTheory.Limits.image f.hom), map_ι := ⋯ }
Instances For
If a category has_image_maps, then all commutative squares induce morphisms on images.
Instances
The functor from the arrow category of C to C itself that maps a morphism to its image
and a commutative square to the induced morphism on images.
Equations
- One or more equations did not get rendered due to their size.
Instances For
A strong epi-mono factorisation is a decomposition f = e ≫ m with e a strong epimorphism
and m a monomorphism.
- I : C
Instances For
Satisfying the inhabited linter
Equations
- CategoryTheory.Limits.strongEpiMonoFactorisationInhabited f = { default := { I := Y, m := CategoryTheory.CategoryStruct.id Y, m_mono := ⋯, e := f, fac := ⋯, e_strong_epi := inst✝ } }
A mono factorisation coming from a strong epi-mono factorisation always has the universal property of the image.
Equations
- F.toMonoIsImage = { lift := fun (G : CategoryTheory.Limits.MonoFactorisation f) => ⋯.lift, lift_fac := ⋯ }
Instances For
A category has strong epi-mono factorisations if every morphism admits a strong epi-mono factorisation.
- mk' :: (
- A category has strong epi-mono factorisations if every morphism admits a strong epi-mono factorisation. 
- )
Instances
A category has strong epi images if it has all images and factorThruImage f is a strong
epimorphism for all f.
Instances
If there is a single strong epi-mono factorisation of f, then every image factorisation is a
strong epi-mono factorisation.
If we constructed our images from strong epi-mono factorisations, then these images are strong epi images.
A category with strong epi images has image maps.
If a category has images, equalizers and pullbacks, then images are automatically strong epi images.
If C has strong epi mono factorisations, then the image is unique up to isomorphism, in that if
f factors as a strong epi followed by a mono, this factorisation is essentially the image
factorisation.
Equations
- One or more equations did not get rendered due to their size.
Instances For
A category with strong epi mono factorisations admits functorial epi/mono factorizations.
Equations
- One or more equations did not get rendered due to their size.