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: have you seen this operation before?


view this post on Zulip Matteo Capucci (he/him) (Nov 26 2024 at 16:14):

Have you ever seen the binary operation ab=alogba \odot b = a^{-\log b} before? It's a commutative monoid structure on [0,][0,\infty] which distributes over multiplication. You get it by conjugating * by log-\log, as I learnt from an offhand remark in the intro of this paper.
A similar trick can be used to find an operation on [,+][-\infty, +\infty] which ++ distributes over, conjugating by 1/exp1/\exp now, you get the much more notorious softplus (or log-sum-exp) operation ab=log(ea+eb)a \oplus b = -\log(e^{-a}+e^{-b}).

view this post on Zulip John Baez (Nov 26 2024 at 16:34):

I feel I've almost thought about these but chickened out. So can we iterate this trick indefinitely, getting commutative monoid operations n\ast_n such that 0\ast_0 is ordinary addition and n\ast_n distributes over n1\ast_{n-1} for all nZn \in \mathbb{Z}?

view this post on Zulip Mike Stay (Nov 26 2024 at 16:34):

Yes

view this post on Zulip Mike Stay (Nov 26 2024 at 16:35):

And the limit is the tropical rig.

view this post on Zulip John Baez (Nov 26 2024 at 16:36):

I was just thinking about similar things recently when I learned that in the 1300s Thomas Bradwardine would call something like (5/2)1/2(5/2)^{1/2} "half" of 5/25/2, but in a deliberately extended sense of "half".

view this post on Zulip John Baez (Nov 26 2024 at 16:37):

The Nicole Oresme extended this idea to work out a general theory of fractional exponents.

view this post on Zulip Mike Stay (Nov 26 2024 at 16:37):

The particular operation Matteo is looking at is (up to sign) also the one the Diffie–Hellman key exchange uses. In that setup, Alice and Bob pick a large prime pp and a generator gg and do all their computations modulo pp. Each of them picks a secret exponent (say aa and bb, respectively). They compute A=gaA=g^a and B=gbB=g^b respectively and publish them. To communicate, Alice computes Ba=BloggAB^a = B^{\log_g A} and Bob computes Ab=AloggBA^b = A^{\log_g B}. Since computing the discrete log to the base gg is hard, no one else can figure out their shared secret.

view this post on Zulip Mike Stay (Nov 26 2024 at 16:38):

Thanks, fixed.

view this post on Zulip John Baez (Nov 26 2024 at 16:48):

You've told me this more than once before, @Mike Stay, but I tend to forget it - maybe because I never spend any time thinking about cryptography in general or Diffie-Hellman in particular. I must have the instincts of a pure mathematician, because instead of cryptography I actually find it more interesting to think about the idea of a "meta-ring" RR with operations 0,1,2\ast_0, \ast_1, \ast_2 such that (R,0,1)(R, \ast_0, \ast_1) is a ring and also (R,1,2)(R, \ast_1, \ast_2) is a ring. (And so on, with even more operations.)

view this post on Zulip Matteo Capucci (he/him) (Nov 26 2024 at 16:57):

John Baez said:

I feel I've almost thought about these but chickened out. So can we iterate this trick indefinitely, getting commutative monoid operations n\ast_n such that 0\ast_0 is ordinary addition and n\ast_n distributes over n1\ast_{n-1} for all nZn \in \mathbb{Z}?

There should be such a hierarchy of operations if you continue conjugating and maybe I'm just getting bamboozled by exponents, but it seems 3=1*_3 = \odot_1 isn't associative?

view this post on Zulip Matteo Capucci (he/him) (Nov 26 2024 at 16:58):

Mike Stay said:

And the limit is the tropical rig.

Why? :O

view this post on Zulip Mike Stay (Nov 26 2024 at 17:16):

We're exponentiating a bunch of times, adding, then taking the log a bunch of times. Whichever parameter starts larger gets much larger after exponentiating, at which point adding the two doesn't make much difference to the size of the larger, and then you take logs to bring them back down. So we have this hierarchy:
ab=amaxba *_{-\infty} b = a \max b
...
anb=ln(ln(expexpa+expexpb))a *_{-n} b = \ln(\cdots \ln(\exp\cdots \exp a + \exp \cdots \exp b)\cdots)
...
a2b=ln(expa1expb)a *_{-2} b = \ln(\exp a *_{-1} \exp b)
a1b=ln(expa0expb)a *_{-1} b = \ln(\exp a *_0 \exp b)
a0b=a+ba *_0 b = a + b
a1b=exp(lna0lnb)=aba *_1 b = \exp(\ln a *_0 \ln b) = a * b
a2b=exp(lna1lnb)a *_2 b = \exp(\ln a *_1 \ln b)
...
anb=exp(exp(lnlna+lnlnb))a *_n b = \exp(\cdots \exp(\ln\cdots \ln a + \ln \cdots \ln b)\cdots)

view this post on Zulip Mike Stay (Nov 26 2024 at 17:26):

Diffie–Hellman is analogous to 2*_2.

view this post on Zulip Mike Stay (Nov 26 2024 at 17:36):

Distributivity for 2*_2:
a2(b1c)=exp(lna1ln(b1c))a *_2 (b *_1 c) = \exp(\ln a *_1 \ln (b *_1 c))
=exp(lna1(lnb0lnc))= \exp(\ln a *_1 (\ln b *_0 \ln c))
=exp(lna(lnb+lnc))= \exp(\ln a * (\ln b + \ln c))
=exp(lnalnb+lnalnc)= \exp(\ln a * \ln b + \ln a * \ln c)
=exp(lna1lnb)1exp(lna1lnc)= \exp(\ln a *_1 \ln b) *_1 \exp(\ln a *_1 \ln c)
=(a2b)1(a2c)= (a *_2 b) *_1 (a *_2 c)

The other cases (nn distributing over n1n-1) work by induction, and everything distributes over max\max.

view this post on Zulip Mike Stay (Nov 26 2024 at 17:42):

Associativity of 2*_2:
(a2b)2c=exp(ln(a2b)1lnc)(a *_2 b) *_2 c = \exp(\ln (a *_2 b) *_1 \ln c)
=exp(lnexp(lna1lnb)1lnc)= \exp(\ln \exp(\ln a *_1 \ln b) *_1 \ln c)
=exp(lna1lnb1lnc)= \exp(\ln a *_1 \ln b *_1 \ln c)
=exp(lnalnblnc)= \exp(\ln a * \ln b * \ln c) and * is associative, so
=a2(b2c)= a *_2 (b *_2 c)
All other nn work similarly.

view this post on Zulip Mike Stay (Nov 26 2024 at 17:51):

Note that the arguments to n*_n for n>2n > 2 have to be larger than eeee^{e^{⋰^e}} (of height n2n-2) so that the iterated logarithm doesn't try to take the log of a negative number.

view this post on Zulip Mike Stay (Nov 26 2024 at 18:27):

Because Matteo's operation has a minus sign, it's not associative, for the same reason minus isn't. We can recover his operation by defining ab=(1/a)2b=a2(1/b)a \odot b = (1/a) *_2 b = a *_2 (1/b).

view this post on Zulip John Baez (Nov 26 2024 at 18:34):

Mike Stay said:

Note that the arguments to n*_n for n>2n > 2 have to be larger than eeee^{e^{⋰^e}} (of height n2n-2) so that the iterated logarithm doesn't try to take the log of a negative number.

Yes, so I was wrong in my description since I guess the unit for 0\ast_0, namely ordinary addition, isn't in the domain of 2\ast_2, or maybe 3\ast_3, and so on.

view this post on Zulip Mike Stay (Nov 26 2024 at 18:48):

I think your meta-ring still exists, just going in the other direction. (R,0,1)(\mathbb{R}, *_0, *_1) is a ring, (R,1,0)(\mathbb{R}, *_{-1}, *_0) is a ring, (R,2,1)(\mathbb{R}, *_{-2}, *_{-1}) is a ring, etc.

view this post on Zulip Clémence Chanavat (Nov 26 2024 at 19:04):

I remember seeing this youtube video about that (or almost that). This is apparently called "Commutative hyperoperation"

view this post on Zulip Matteo Capucci (he/him) (Nov 27 2024 at 13:42):

Matteo Capucci (he/him) said:

John Baez said:

I feel I've almost thought about these but chickened out. So can we iterate this trick indefinitely, getting commutative monoid operations n\ast_n such that 0\ast_0 is ordinary addition and n\ast_n distributes over n1\ast_{n-1} for all nZn \in \mathbb{Z}?

There should be such a hierarchy of operations if you continue conjugating and maybe I'm just getting bamboozled by exponents, but it seems 3=1*_3 = \odot_1 isn't associative?

In hindsight I had to be wrong because conjugation by an isomorphism always yields a well-defined operation inheriting all the properties, including distributivity

view this post on Zulip Matteo Capucci (he/him) (Nov 27 2024 at 13:43):

Mike Stay said:

We're exponentiating a bunch of times, adding, then taking the log a bunch of times. Whichever parameter starts larger gets much larger after exponentiating, at which point adding the two doesn't make much difference to the size of the larger, and then you take logs to bring them back down.

Make sense! It's interesting that also varying the base of exp/log yields the same behaviour

view this post on Zulip Mike Stay (Nov 27 2024 at 16:12):

I wonder if there's a continuous version of the hierarchy. It should be related to "tetration" since we're looking at power towers like eeee^{e^{⋰^e}}...

Ah, looks like there's a solution to Abel's functional equation for exp\exp letting you do tetration at real heights. So it at least makes sense to say 1.5*_{1.5}. I don't know if λ*_\lambda distributes over λ1*_{\lambda - 1} for all λ\lambda or just for λZ\lambda \in \mathbb{Z}.

view this post on Zulip Daniel Geisler (Nov 27 2024 at 17:51):

See Tetration for Complex Bases by Paulsen for extending tetration to the complex numbers. For a more general treatment of fractionally iterated functions see Some formulas for fractional iteration.

Note: I'm currently reviewing how solid the foundations are for the main papers in extending tetration.

view this post on Zulip Ryo Suzuki (Nov 30 2024 at 09:44):

I have seen a categorification of the operation (a,b) |-> a^log b. It is defined as Adj(C,D^op)^op, here Adj(C,D^op) is the category of left adjoint functor F:C→D^op. This operation behaves distributively with respect to the product of categories. I learned this from https://alg-d.com/math/kan_extension/log.pdf, but this is unfortunately written in Japanese.

view this post on Zulip Mike Stay (Dec 05 2024 at 14:18):

@Ryo Suzuki Can you sketch the decategorification?

view this post on Zulip Ryuya Hora (Dec 06 2024 at 09:42):

Ryo Suzuki said:

I have seen a categorification of the operation (a,b) |-> a^log b. It is defined as Adj(C,D^op)^op, here Adj(C,D^op) is the category of left adjoint functor F:C→D^op.

For presentable categories, this is [the tensor product] . I don't know whether there is a numerical decategorification.

view this post on Zulip Sridhar Ramesh (Dec 07 2024 at 19:33):

Mike Stay said:

Because Matteo's operation has a minus sign, it's not associative, for the same reason minus isn't. We can recover his operation by defining ab=(1/a)2b=a2(1/b)a \odot b = (1/a) *_2 b = a *_2 (1/b).

I don't see how the minus sign can break associativity, as it just amounts to changing the base of the logarithm (and its inverse exponential). Are we sure associativity breaks and it isn't just a negation getting lost in calculation somewhere?

view this post on Zulip Matteo Capucci (he/him) (Dec 12 2024 at 18:19):

I just got lost indeed

view this post on Zulip Mike Stay (Dec 12 2024 at 19:51):

Sridhar Ramesh said:

Mike Stay said:

Because Matteo's operation has a minus sign, it's not associative, for the same reason minus isn't. We can recover his operation by defining ab=(1/a)2b=a2(1/b)a \odot b = (1/a) *_2 b = a *_2 (1/b).

I don't see how the minus sign can break associativity, as it just amounts to changing the base of the logarithm (and its inverse exponential). Are we sure associativity breaks and it isn't just a negation getting lost in calculation somewhere?

Sorry, you're right. I got it confused with what turned out to be division, which isn't associative for the same reason subtraction isn't. There will be some inverse operation for 2*_2, but it's not \odot.

view this post on Zulip Mike Stay (Dec 12 2024 at 19:54):

Since a2b=e(lna)(lnb),a *_2 b = e^{(\ln a) (\ln b)}, the inverse operation would be a/2b=a1/lnb=e(lna)/(lnb)a \, /_2 \, b = a^{1/\ln b} = e^{(\ln a)/(\ln b)}.