Zulip Chat Archive
Stream: PrimeNumberTheorem+
Topic: L-series
Michael Stoll (Feb 19 2024 at 19:53):
I have started PRing material on L-series from EulerProducts to Mathlib: #10725, #10728. Reviews welcome!
Terence Tao (Feb 19 2024 at 20:45):
One thing we might start doing in parallel with the main contour integration stuff is to lay the groundwork for the PNT in arithmetic progressions by showing that  and  for Dirichlet characters , and that  has a holomorphic continuation into the critical strip.  Do you have material from EulerProducts that might be helpful for these purposes? For instance, we could use Euler products to prove the inequality
for , which already demonstrates nonvanishing of  in the complex case, and similarly
for  and real , which also demonstrates nonvanishing of  for non-zero .
For the non-vanishing of for real there are a number of options. There are some elementary proofs that don't look too challenging (other than having to do a bunch of asymptotic estimation), such as the one based on the divergence of , or one can be much more algebraic and shoot for the class number formula (which would be independently valuable for Mathlib I imagine). The latter is more complicated may be worth doing anyway as a warmup to Chebotarev.
Terence Tao (Feb 19 2024 at 20:52):
p.s. an intermediate proof is to argue by contradiction: if then has an analytic continuation into the strip, hence by Perron's formula will converge, contradiction. This proof is terrible for quantitative bounds, but may be relatively "cheap" given that we will likely have most of the Perron formula infrastructure in place already.
Michael Stoll (Feb 19 2024 at 20:56):
Some of this is in PNT.lean in the EulerProducts repository.
I was waiting for @David Loeffler to provide the analytic continuation of Dirichlet L-series in order to add a proof that (for quadratic ; for the other ones one can deduce it from the lower bound on the power product).
Michael Stoll (Feb 19 2024 at 20:59):
My idea for this proof was to use that is entire (if ) and then argue that its derivatives at a convenient real point (say ) are alternating in sign, forcing the values on the real axis to the left of it to be positive, which contradicts .
Terence Tao (Feb 19 2024 at 21:10):
OK, that works as well, though it requires analytic continuation well to the left of the critical strip, which I guess is worth doing but sounds like more work.
I see that you have indeed already demonstrated in PNT.lean, which is great! Actually on setting I see this also shows non-vanishing of in the complex case, so there is no need to bring in the alternate inequality .
David Loeffler (Feb 19 2024 at 21:13):
I have a complete proof formalised of analytic continuation of Hurwitz zeta functions for any ; I will begin PR'ing this later this week. Deducing analytic continuation of Dirichlet L-functions is an easy step from this (taking weighted sum over for ).
David Loeffler (Feb 20 2024 at 08:46):
By the way, I have a (totally content-free) question about conventions for zeta functions, and I'd like to run it past you guys to determine what is the preferred spelling. The issue is how to most simply formulate the naive sum definition of L-functions, given that in mathlib (but for ).
David Loeffler (Feb 20 2024 at 08:47):
/poll How should the Riemann zeta function be written?
∑' n : ℕ, 1 / (n : ℂ) ^ s
∑' n : ℕ, 1 / (n + 1 : ℂ) ^ s
∑' n : ℕ, if n = 0 then 0 else 1 / (n : ℂ) ^ s
Something else
Yaël Dillies (Feb 20 2024 at 08:48):
(my vote is from past experience with similar issues, maybe I am missing zeta-specific subtleties)
David Loeffler (Feb 20 2024 at 08:51):
@Alex Kontorovich @Michael Stoll I'm particularly interested in which of these options will most easily link up with the code you have written / are writing.
Vincent Beffara (Feb 20 2024 at 11:06):
How about ∑' n : ℕ+, 1 / (n : ℂ) ^ s ?
Yaël Dillies (Feb 20 2024 at 11:08):
That's more annoying to work with in practice, I found
Michael Stoll (Feb 20 2024 at 11:33):
The first option is easiest to work with, I would think, and is used in docs#zeta_eq_tsum_one_div_nat_cpow. The second one is used in docs#zeta_eq_tsum_one_div_nat_add_one_cpow. The third one agrees with LSeries ζ(where ζ is the arithmetic function ). They probably all have advantages and disadvantages. I would suggest to have both (1) and (2) (also for Dirichlet L-series perhaps) as is already the case, so that one can easily use whatever is more convenient (and also (3) in the form LSeries ArithmeticFunction.zeta s = riemannZeta s for 1 < s.re; see LSeries.zeta_eq_riemannZeta in DirichletLSeries.lean).
Alex Kontorovich (Feb 20 2024 at 14:46):
I wonder how useful ArithmeticFunction is for Dirichlet series... Precisely because Mathlib chose to define 1/0 = 0, we just might be able to get away with doing everything over , and indexing it the "natural" way... (Perhaps there's an issue with  and  ? But then the tsum should not converge, so the whole series should anyway be defined to be zero... There's a kind of magic here with junk values perfectly balancing each other...?)
Michael Stoll (Feb 20 2024 at 14:58):
It is actually pretty useful, since arithmetic functions are defined on ℕ, but with value zero at zero. So you can just take ∑' n : ℕ, f n / n ^ s (modulo coercions).
Alex Kontorovich (Feb 20 2024 at 15:08):
Yes I see the utility of ArithmeticFunction in other contexts, but for Dirichlet series, won't ∑' n : ℕ, f n / n ^ s work just as well for f that are not defined to be zero at zero, because dividing by  will anyway kill that term...?
Michael Stoll (Feb 20 2024 at 15:10):
Well, there are cases where the series converges at s = 0, and then the special case 0^0 = 1 is a problem.
Michael Stoll (Feb 20 2024 at 15:10):
For Dirichlet L-series, it is of course OK.
David Loeffler (Feb 20 2024 at 15:14):
Michael Stoll said:
Well, there are cases where the series converges at
s = 0, and then the special case0^0 = 1is a problem.
Are there, though? I spent a while trying to think of an example of an "arithmetically interesting" function such that converges and , and didn't find any.
Michael Stoll (Feb 20 2024 at 15:17):
Is 2^(-n) arithmetically interesting?
David Loeffler (Feb 20 2024 at 15:40):
Does have any arithmetic significance? If so, I'm not aware of it.
Michael Stoll (Feb 20 2024 at 15:46):
What I want to say is, we should not make unnecessary assumptions regarding the coefficient sequences that might show up.
Michael Stoll (Feb 20 2024 at 15:48):
And defining a coercion from Dirichlet characters to arithmetic functions so that we can write LSeries χ when χ is a Dirichlet character works reasonably well.
Alex Kontorovich (Feb 20 2024 at 18:39):
I guess my question is whether it would go through equally well if we just coerced Dirichlet characters to functions on Nat...?
Michael Stoll (Feb 20 2024 at 18:40):
Not without changing LSeries (which eats a complex-valued arithmetic function).
Last updated: May 02 2025 at 03:31 UTC