Category Theory
Zulip Server
Archive

You're reading the public-facing archive of the Category Theory Zulip server.
To join the server you need an invite. Anybody can get an invite by contacting Matteo Capucci at name dot surname at gmail dot com.
For all things related to this archive refer to the same person.


Stream: learning: questions

Topic: Co Yoneda vs Yoneda Lemma


view this post on Zulip John Onstead (Jan 06 2025 at 12:26):

I hope everyone had an amazing holidays and a great start to 2025! I wanted to return with a "warmup" question that would get me back into discussion about sheaves and related matters, which is what I what to start off with. This question is inspired by the previous discussion (namely, that related to the topological topos) in which some of the elements were touched on but not explicitly brought up, but now I want to fully clear the air about this!

The Yoneda lemma gives us a clear view on what the objects of a category of presheaves are: they are those that are "testable" or "probeable" by the objects of the original category. This means presheaves can be seen as "generalized objects" of the original category that can be described by being probed by maps into them from "test objects", and thus by the maps into it from the representables in the full presheaf category. On the other hand, the "co-Yoneda lemma" gives us a completely and entirely different perspective on what the objects are: they are objects that are "locally modeled" on "test objects" of the original category; that is, they are the objects of the original category "glued together". So we have two different perspectives: the Yoneda perspective based on maps out of representables, and the co-Yoneda perspective based on taking colimits of representables.

These two perspectives seem completely irreconcilable on face value: what does maps out of an object have anything to do with taking colimits of those objects? But the recent discussion on the topological topos made me realize some things. One can think of the objects in the topological topos as sequences "glued together", and every morphism out of the representable can be thought of as "picking out" a sequence in the object. This made me wonder if there's any connection between the canonical projection morphisms out of the representables produced by taking the colimit, and the Yoneda perspective on what the maps out of a representable are supposed to be doing. So that's my question: is there any connection between these, and more generally, how am I supposed to reconcile the Yoneda and co-Yoneda lemma on both a mathematical and conceptual/philosophical level? Thanks for your help!

view this post on Zulip Josselin Poiret (Jan 06 2025 at 15:21):

John Onstead said:

I hope everyone had an amazing holidays and a great start to 2025! I wanted to return with a "warmup" question that would get me back into discussion about sheaves and related matters, which is what I what to start off with. This question is inspired by the previous discussion (namely, that related to the topological topos) in which some of the elements were touched on but not explicitly brought up, but now I want to fully clear the air about this!

The Yoneda lemma gives us a clear view on what the objects of a category of presheaves are: they are those that are "testable" or "probeable" by the objects of the original category. This means presheaves can be seen as "generalized objects" of the original category that can be described by being probed by maps into them from "test objects", and thus by the maps into it from the representables in the full presheaf category. On the other hand, the "co-Yoneda lemma" gives us a completely and entirely different perspective on what the objects are: they are objects that are "locally modeled" on "test objects" of the original category; that is, they are the objects of the original category "glued together". So we have two different perspectives: the Yoneda perspective based on maps out of representables, and the co-Yoneda perspective based on taking colimits of representables.

These two perspectives seem completely irreconcilable on face value: what does maps out of an object have anything to do with taking colimits of those objects? But the recent discussion on the topological topos made me realize some things. One can think of the objects in the topological topos as sequences "glued together", and every morphism out of the representable can be thought of as "picking out" a sequence in the object. This made me wonder if there's any connection between the canonical projection morphisms out of the representables produced by taking the colimit, and the Yoneda perspective on what the maps out of a representable are supposed to be doing. So that's my question: is there any connection between these, and more generally, how am I supposed to reconcile the Yoneda and co-Yoneda lemma on both a mathematical and conceptual/philosophical level? Thanks for your help!

I actually do find these two perspective to be extremely consistent with each other.

first, the statement of the co-yoneda lemma as usually mentioned is very unsatisfactory to me, as it says that every presheaf is a colimit of representables, but not what the colimit is. Here's my pov: for a presheaf P P , you get P(X) P(X) its X X -shaped points for X X an object of the base category. If you have a morphism of shapes XY X → Y , then you can transform Y Y points in X X points by reparametrization. This is all stuff you already know, but I always like to insist on the notion of shaped points.

The yoneda lemma says that the universal X X -point exists as an object, and is just yX yX . The co-yoneda lemma then simply says that if you have an object, it is just the gluing of all its points seen as their own standalone spaces, whatever their shapes. You take the colimit over the category of elements of P P ; in that category morphisms represent equality of points up to reparametrization.

view this post on Zulip John Onstead (Jan 06 2025 at 19:42):

Ok, I think I'm following. So it seems it's about points: a presheaf can be determined by gluing all of its points together (not sure what that follows from, maybe some basic property), and since a universal "point" for some object is given by the representable (Yoneda), it means that a presheaf can be determined by a colimit over representables (co-Yoneda). Since we are gluing one representable for each point of the presheaf, it means that the sum total of all canonical projection morphisms from the diagram of the colimit will be the same as the sum total of all the points of the presheaf. Yoneda then tells us that these are in correspondence with all natural transformations from representables to the presheaf. So that would confirm that the projection morphisms from co-Yoneda do align with morphisms out of representables from Yoneda. Anyways I hope I am understanding!

view this post on Zulip Peva Blanchard (Jan 07 2025 at 08:39):

Oh this is very interesting, I didn't know we could interpret Yoneda this way.
Let me unfold the idea to see if I understand correctly.

Generally speaking, a morphism XYX \to Y is thought as a XX-shaped point of YY (a general element).
A presheaf PP on some category CC can be understood as a generalized space.
An element xP(X)x \in P(X) is thought as a map x:XPx : X \to P. Hence, P(X)P(X) is the set of XX-shaped points of PP.

With this interpretation, the presheaf yXyX is a generalized space.
The Yoneda lemma states that the maps yXPyX \to P (i.e. natural transformations from yXyX to PP) naturally correspond to elements of P(X)P(X).
In other words, the generalized space yXyX classifies the XX-shaped points. I.e., yXyX is the universal XX-shaped point.

The category of elements of PP can be seen as a sort of "over category of PP".
The elements of PP are the XX-shaped points of PP, with XX varying among the objects of CC.
In the picture, xPXx \in PX, yPYy \in PY, f:XYf : X \to Y is an arrow in CC, and commutativity of the diagram means that P(f):yxP(f): y \mapsto x.
image.png

This makes PP look like a cocone over CC.
The co-Yoneda lemma can be interpreted as saying that this "cocone" is actually a colimit.
I think this can be made a bit more rigorous by considering the diagram of presheaves
image.png

In other words, PP, seen as a generalized space, is the gluing of all its XX-shaped points.

Am I making a mistake somewhere?

view this post on Zulip Peva Blanchard (Jan 07 2025 at 09:20):

If we take CC to be the "walking graph category"
image.png

then a presheaf GG on CC is a graph.

The Yoneda lemma says that the vertices (resp. edges) of GG naturally correspond to the graph morphisms yVGyV \to G (resp. yEGyE \to G). On the other hand, the co-Yoneda lemma says that any graph GG is made by gluing vertices and edges together.

This is so nice!

view this post on Zulip John Onstead (Jan 07 2025 at 09:25):

Yes, I admit I was also keeping the topos of directed graphs as a running example in the back of my mind when trying to think through this. It's a very simple yet powerful example of these principles!

view this post on Zulip David Egolf (Jan 07 2025 at 19:35):

I've only worked through part of this thread, but just wanted to say - this thread is really helping me intuitively understand the Yoneda lemma in way I hadn't managed before!

view this post on Zulip David Egolf (Jan 07 2025 at 19:49):

For example, I think I've learned that we have [Cop,Set](y(),X)X[C^{\mathrm{op}},\mathsf{Set}](y(-),X) \cong X in [Cop,Set][C^{\mathrm{op}}, \mathsf{Set}]. Intuitively this says that an arbitrary presheaf XX on a locally small category CC is determined up to isomorphism by how it relates to the objects in the image of the Yoneda embedding yy.

view this post on Zulip David Egolf (Jan 07 2025 at 19:52):

This is especially helpful, because we can think of y(c)y(c) as being in many ways like cc. That's reasonable to do because the objects in the image of the Yoneda embedding relate to one another in the same way their corresponding objects in CC relate in CC. (We have [Cop,Set](y(c),y(d))C(c,d)[C^{\mathrm{op}}, \mathsf{Set}](y(c), y(d)) \cong C(c,d) in Set\mathsf{Set} for all objects c,dCc,d \in C).

view this post on Zulip David Egolf (Jan 07 2025 at 19:58):

(And I haven't even worked through the discussion on the co-Yoneda lemma yet! I'm excited to read through all this!)

view this post on Zulip David Egolf (Jan 07 2025 at 20:33):

I also love the idea that we can gradually learn what some X:CopSetX:C^{\mathrm{op}} \to \mathsf{Set} is like by studying natural transformations to it from objects in the image of the Yoneda embedding. That suggests there might be a way to gradually build up an understanding of XX in a way parametrized by the objects of CC. (This especially catches my attention for possible application to imaging!)

view this post on Zulip Peva Blanchard (Jan 07 2025 at 21:28):

@David Egolf I got this "aha" moment this morning, so much that I want to apply this point of view to every situation :smile:

So let's try with imaging. Let's say we are analyzing a radiography.
As a radiologist, I am looking for the presence of specific shapes.
Let CC be the category of those shapes I am interested in. For instance, there is a shape "human skeleton", "hand skeleton", "long bone", "small bone", "joints", and so on. These shapes are related by morphisms: a skeleton contains bones, a long bone has two ends, etc.

When doing a radiography analysis, I record for every shape XX the set PXPX of instances of XX in the image.

And I have functions between those sets, e.g.,P(long bone)P(hand skeleton)P(\text{long bone}) \to P(\text{hand skeleton}) that specifies which long bones belong to which hand skeleton.

Hence, the presheaf PP is really a structured summary of the actual image.

Now, I also have, say, the presheaf yhand skeletony_{\text{hand skeleton}} (yoneda embedding of the shape "hand skeleton").
We can think of it as the structured summary of an image of a hand skeleton.
A natural transformation yhand skeletonPy_{\text{hand skeleton}} \to P is a way to map this image of hand skeleton to my first image. The Yoneda lemma states that there are as many such natural transformations as there are hand skeleta in my first image.

Finally, the co-Yoneda lemma states that the structured summary of my image is made of instances of those bones and joints glued together.

view this post on Zulip Peva Blanchard (Jan 07 2025 at 21:32):

Oh, this category CC should be called the "walking human skeleton".

view this post on Zulip Matteo Capucci (he/him) (Jan 07 2025 at 22:31):

Note Yoneda lemma holds in much greater generality than presheaves, while CoYoneda is a bit more characteristic. Indeed, consider your category CC presented as a monad in span C1C0C_1 \rightrightarrows C_0. Equivalently, this induces a monad YY on Set/C0\textbf{Set}/C_0, sending a bunch of C0C_0-indexed data to the free presheaf obtained by freely adding all the functorial action coming from the morphisms of CC. Notice that Y(1xC0)Y(1 \xrightarrow{x} C_0), is exactly the representable presheaf at xCx \in C, so the representable are the free presheaves on the very particular generators given by elements of C0C_0. These are particular because they generate Set/C0{\bf Set}/C_0, meaning that, obviously, one can distinguish C0C_0-indexed sets by looking at their value at each element. So Set/C0(x,P)=P(x){\bf Set}/C_0(x, P) = P(x) already at this level. Then algebras of any monad TT on Set/C0{\bf Set}/C_0 inherit the same property, since Alg(T)(Fx,Q)=Set/C0(x,UQ)=UQ(x){\bf Alg}(T)(Fx, Q) = {\bf Set}/C_0(x, UQ) = UQ(x). So Yoneda is not so much about categories as it is about general algebra over a base.

Similarly, co-Yoneda already holds for Set/C0{\bf Set}/C_0, since P=xC0PxxP = \sum_{x \in C_0} Px \cdot x where \cdot is [[copower]] and xx denotes again the generator 1xC01 \xrightarrow{x} C_0. Given any monad on Set/C0{\bf Set}/C_0, we know that any algebra is a reflexive coequalizer of free algebras, i.e. Q=coeq(T2QTQ)Q = {\rm coeq} (T^2Q \rightrightarrows TQ) but, crucially, the free presheaf monad Y=C1×C0Y = C_1 \times_{C_0} - commutes with coproducts because Set\bf Set is [[extensive]], hence the fact TQ=xQxy(x)TQ = \sum_x Qx \cdot y(x) makes the above a presentation of QQ as a colimit of representables!

view this post on Zulip Matteo Capucci (he/him) (Jan 07 2025 at 22:51):

In fact I believe the only monads with this property are free presheaf monads, ie the ones arising by pull-push along the graph of a category, thus characterizing categories!
Indeed, a coproduct-preserving monad on Set/C0{\bf Set}/C_0 is determined by its value on the generators, thus we can write TP=xPxTxTP = \sum_x Px \cdot Tx. Now we want to construct a category out of this. We thus let C1=xyTy(x)C_1 = \sum_x \sum_y Ty(x), basically imposing that C(x,y)=Ty(x)C(x,y) = Ty(x). Source and target are given by the two projections out of the sums. Identities are given by the unit ηx:xTx\eta_x : x \to Tx, thus picking an element of Tx(x)Tx(x). Multiplication: μx:TTxTx\mu_x : TTx \to Tx is given by maps yTx(y)Ty(z)Tx(z)\sum_y Tx(y) \cdot Ty(z) \to Tx(z) for every zC0z \in C_0, thus giving composition of morphisms. Associativity and unitality follow by construction, and thus we can conclude that C1×C0=TC_1 \times_{ C_0} - = T. Neat!

view this post on Zulip Josselin Poiret (Jan 08 2025 at 10:49):

Matteo Capucci (he/him) said:

quivalently, this induces a monad Y on Set/C0​, sending a bunch of C0​-indexed data to the free presheaf obtained by freely adding all the functorial action coming from the morphisms of C

I'd rather talk about Psh(C0) \mathrm{Psh}(C_0) than Set/C0 \mathrm{Set}_{/C_0} , then we can see the relation with the usual induced adjunction on presheaves: if you have F:CD F : C → D a functor on base categories, F:Psh(D)Psh(C) F^* : \mathrm{Psh}(D) → \mathrm{Psh}(C) is the "forgetful" functor forgetting the DD-action through FF, and its left adjoint F! F_! simply creates the free D D -action from a C C -action with respect to FF.

view this post on Zulip Matteo Capucci (he/him) (Jan 08 2025 at 11:33):

Well you can get that adjunction in the other form too! I'd say a better reason to work with SetC0{\bf Set}^{C_0} is that it readily generalizes to the enriched case, so that the part of my message concerning Yoneda still stands when replacing Set\bf Set with an arbitrary base V\cal V. I wonder what can be said about the second part? CoYoneda still holds in the enriched case, provided enough colimits are around...