Zulip Chat Archive

Stream: general

Topic: Polynomial Functors


view this post on Zulip Kevin Buzzard (Feb 26 2018 at 17:59):

Can someone remind me why have I got a 429 page pdf about polynomial functors open on my desktop?

view this post on Zulip Kevin Buzzard (Feb 26 2018 at 18:00):

I think it was something to do with something someone said in the old chat

view this post on Zulip Andrew Ashworth (Feb 26 2018 at 18:02):

@Tim Carstens the coolest thing about w-types (imho) is that they give an account of the whole "derivative of a type" thing (eg zippers), by way of their use of polynomial endofunctors, which themselves have a differential theory (best notes i've seen: http://mat.uab.es/~kock/cat/polynomial.pdf)
this is one of the things i wanted to show when i was studying the category of lean types last year, but i didn't make it all the way :(

view this post on Zulip Kevin Buzzard (Feb 26 2018 at 18:04):

What is a zipper?

view this post on Zulip Andrew Ashworth (Feb 26 2018 at 18:06):

that's a good question. I found this paper: https://www.st.cs.uni-saarland.de/edu/seminare/2005/advanced-fp/docs/huet-zipper.pdf

view this post on Zulip Simon Hudon (Feb 26 2018 at 18:07):

The short version is that it's a data structure that allows you to record the state of traversal of another data structure. For instance, if you traverse a list, you can record the state of that traversal by keeping the list of elements you already visited, the current element and the list of elements to come.

view this post on Zulip Kevin Buzzard (Feb 26 2018 at 18:08):

Oh I knew I'd heard the phrase before. It's the very end bit of learnyouahaskell

view this post on Zulip Tim Carstens (Feb 26 2018 at 18:41):

sorry, i was in a meeting. yeah, years ago i read some stuff by Conor McBride about derivatives of types. basically, if you have a type T (X : Type) : Type (like T = list or T = binarytree or whatever), the derivative of T wrt X gives a new type that's "shaped like T but with an X-shaped hole." The derivative of T can be used to describe strategies for traversing data of type T.

view this post on Zulip Kevin Buzzard (Feb 26 2018 at 18:50):

That's crazy stuff. I am hoping as a mathematician that I don't need to think too hard about these things...

view this post on Zulip Kevin Buzzard (Feb 26 2018 at 18:50):

I am not used to traversing data

view this post on Zulip Tim Carstens (Feb 26 2018 at 18:53):

The combinatorialists have a similar thing going on with generating functions and a thing they call "combinatorial schemes" (not related to scheme theory from algebraic geometry). It turns out that in this formulation, generating functions correspond to certain "analytic functors," and you can take a sort of formal derivative of such things. Turns out that analytic functors are examples of polynomial endofunctors, and the formal derivative of an analytic functor coincidences with the derivative of a polynomial endofunctor.

view this post on Zulip Kevin Buzzard (Feb 26 2018 at 18:54):

That sounds like some crazy analogue of differentiating a power series term by term.

view this post on Zulip Kevin Buzzard (Feb 26 2018 at 18:55):

We were talking about that back in the old days on gitter, with a ring theory result which needed differentiation term by term although @Reid Barton came up with a neat suggestion which I didn't fully chase up yet but which must surely work.

view this post on Zulip Tim Carstens (Feb 26 2018 at 18:59):

So anyway, by definition every W-type T is the initial algebra of some functor F : C -> C. In Lean or similar environments, this functor will be polynomial (iirc it'll be functor adjoint to pullback along the coproduct of the term constructors, or something like that), and the derivative of the type T is none other than the initial algebra of the derivative of F

view this post on Zulip Tim Carstens (Feb 26 2018 at 19:01):

this level of abstract nonsense is not useful for actually writing programs as far as I can tell; certainly it's a horrible way to work with inductive types in Lean, which already has good syntax for working with inductives


Last updated: May 09 2021 at 20:11 UTC