Documentation

Mathlib.NumberTheory.LSeries.HurwitzZetaValues

Special values of Hurwitz and Riemann zeta functions #

This file gives the formula for ζ (2 * k), for k a non-zero integer, in terms of Bernoulli numbers. More generally, we give formulae for any Hurwitz zeta functions at any (strictly) negative integer in terms of Bernoulli polynomials.

(Note that most of the actual work for these formulae is done elsewhere, in Mathlib.NumberTheory.ZetaValues. This file has only those results which really need the definition of Hurwitz zeta and related functions, rather than working directly with the defining sums in the convergence range.)

Main results #

TODO #

theorem HurwitzZeta.cosZeta_two_mul_nat {k : } {x : } (hk : k 0) (hx : x Set.Icc 0 1) :
cosZeta (↑x) (2 * k) = (-1) ^ (k + 1) * (2 * Real.pi) ^ (2 * k) / 2 / (2 * k).factorial * Polynomial.eval (↑x) (Polynomial.map (algebraMap ) (Polynomial.bernoulli (2 * k)))

Express the value of cosZeta at a positive even integer as a value of the Bernoulli polynomial.

theorem HurwitzZeta.sinZeta_two_mul_nat_add_one {k : } {x : } (hk : k 0) (hx : x Set.Icc 0 1) :
sinZeta (↑x) (2 * k + 1) = (-1) ^ (k + 1) * (2 * Real.pi) ^ (2 * k + 1) / 2 / (2 * k + 1).factorial * Polynomial.eval (↑x) (Polynomial.map (algebraMap ) (Polynomial.bernoulli (2 * k + 1)))

Express the value of sinZeta at an odd integer > 1 as a value of the Bernoulli polynomial.

Note that this formula is also correct for k = 0 (i.e. for the value at s = 1), but we do not prove it in this case, owing to the additional difficulty of working with series that are only conditionally convergent.

theorem HurwitzZeta.cosZeta_two_mul_nat' {k : } {x : } (hk : k 0) (hx : x Set.Icc 0 1) :
cosZeta (↑x) (2 * k) = (-1) ^ (k + 1) / (2 * k) / (2 * k).Gammaℂ * Polynomial.eval (↑x) (Polynomial.map (algebraMap ) (Polynomial.bernoulli (2 * k)))

Reformulation of cosZeta_two_mul_nat using Gammaℂ.

theorem HurwitzZeta.sinZeta_two_mul_nat_add_one' {k : } {x : } (hk : k 0) (hx : x Set.Icc 0 1) :
sinZeta (↑x) (2 * k + 1) = (-1) ^ (k + 1) / (2 * k + 1) / (2 * k + 1).Gammaℂ * Polynomial.eval (↑x) (Polynomial.map (algebraMap ) (Polynomial.bernoulli (2 * k + 1)))

Reformulation of sinZeta_two_mul_nat_add_one using Gammaℂ.

theorem HurwitzZeta.hurwitzZetaEven_one_sub_two_mul_nat {k : } {x : } (hk : k 0) (hx : x Set.Icc 0 1) :
hurwitzZetaEven (↑x) (1 - 2 * k) = -1 / (2 * k) * Polynomial.eval (↑x) (Polynomial.map (algebraMap ) (Polynomial.bernoulli (2 * k)))
theorem HurwitzZeta.hurwitzZetaOdd_neg_two_mul_nat {k : } {x : } (hk : k 0) (hx : x Set.Icc 0 1) :
hurwitzZetaOdd (↑x) (-(2 * k)) = -1 / (2 * k + 1) * Polynomial.eval (↑x) (Polynomial.map (algebraMap ) (Polynomial.bernoulli (2 * k + 1)))
theorem HurwitzZeta.hurwitzZeta_neg_nat {k : } {x : } (hk : k 0) (hx : x Set.Icc 0 1) :
hurwitzZeta (↑x) (-k) = -1 / (k + 1) * Polynomial.eval (↑x) (Polynomial.map (algebraMap ) (Polynomial.bernoulli (k + 1)))

Values of Hurwitz zeta functions at (strictly) negative integers.

TODO: This formula is also correct for k = 0; but our current proof does not work in this case.

theorem riemannZeta_two_mul_nat {k : } (hk : k 0) :
riemannZeta (2 * k) = (-1) ^ (k + 1) * 2 ^ (2 * k - 1) * Real.pi ^ (2 * k) * (bernoulli (2 * k)) / (2 * k).factorial

Explicit formula for ζ (2 * k), for k ∈ ℕ with k ≠ 0, in terms of the Bernoulli number bernoulli (2 * k).

Compare hasSum_zeta_nat for a version formulated in terms of a sum over 1 / n ^ (2 * k), and riemannZeta_neg_nat_eq_bernoulli for values at negative integers (equivalent to the above via the functional equation).

theorem riemannZeta_neg_nat_eq_bernoulli' (k : ) :
riemannZeta (-k) = -(bernoulli' (k + 1)) / (k + 1)

Value of Riemann zeta at -ℕ in terms of bernoulli'.

theorem riemannZeta_neg_nat_eq_bernoulli (k : ) :
riemannZeta (-k) = (-1) ^ k * (bernoulli (k + 1)) / (k + 1)

Value of Riemann zeta at -ℕ in terms of bernoulli.