-
Notifications
You must be signed in to change notification settings - Fork 355
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Trigger CI for leanprover-community/batteries#1007
- Loading branch information
Showing
28 changed files
with
368 additions
and
97 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
/- | ||
Copyright (c) 2024 Eric Wieser. All rights reserved. | ||
Released under Apache 2.0 license as described in the file LICENSE. | ||
Authors: Eric Wieser | ||
-/ | ||
import Mathlib.Algebra.Order.Star.Basic | ||
import Mathlib.Algebra.Star.Prod | ||
import Mathlib.Algebra.Ring.Prod | ||
|
||
/-! | ||
# Products of star-ordered rings | ||
-/ | ||
|
||
variable {α β : Type*} | ||
|
||
open AddSubmonoid in | ||
instance Prod.instStarOrderedRing | ||
[NonUnitalSemiring α] [NonUnitalSemiring β] [PartialOrder α] [PartialOrder β] | ||
[StarRing α] [StarRing β] [StarOrderedRing α] [StarOrderedRing β] : | ||
StarOrderedRing (α × β) where | ||
le_iff := Prod.forall.2 fun xa xy => Prod.forall.2 fun ya yb => by | ||
have : | ||
closure (Set.range fun s : α × β ↦ star s * s) = | ||
(closure <| Set.range fun s : α ↦ star s * s).prod | ||
(closure <| Set.range fun s : β ↦ star s * s) := by | ||
rw [← closure_prod (Set.mem_range.2 ⟨0, by simp⟩) (Set.mem_range.2 ⟨0, by simp⟩), | ||
Set.prod_range_range_eq] | ||
simp_rw [Prod.mul_def, Prod.star_def] | ||
simp only [mk_le_mk, Prod.exists, mk_add_mk, mk.injEq, StarOrderedRing.le_iff, this, | ||
AddSubmonoid.mem_prod, exists_and_exists_comm, and_and_and_comm] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,109 @@ | ||
/- | ||
Copyright (c) 2024 Michael Stoll. All rights reserved. | ||
Released under Apache 2.0 license as described in the file LICENSE. | ||
Authors: Chris Birkbeck, David Loeffler, Michael Stoll | ||
-/ | ||
import Mathlib.Analysis.Complex.TaylorSeries | ||
import Mathlib.Analysis.Complex.Positivity | ||
import Mathlib.NumberTheory.ArithmeticFunction | ||
import Mathlib.NumberTheory.LSeries.Deriv | ||
|
||
/-! | ||
# Positivity of values of L-series | ||
The main results of this file are as follows. | ||
* If `a : ℕ → ℂ` takes nonnegative real values and `a 1 > 0`, then `L a x > 0` | ||
when `x : ℝ` is in the open half-plane of absolute convergence; see | ||
`LSeries.positive` and `ArithmeticFunction.LSeries_positive`. | ||
* If in addition the L_series of `a` agrees on some open right half-plane where it | ||
converges with an entire function `f`, then `f` is positive on the real axis; | ||
see `LSeries.positive_of_eq_differentiable` and | ||
`ArithmeticFunction.LSeries_positive_of_eq_differentiable`. | ||
-/ | ||
|
||
open scoped ComplexOrder | ||
|
||
open Complex | ||
|
||
namespace LSeries | ||
|
||
/-- If all values of a `ℂ`-valued arithmetic function are nonnegative reals and `x` is a | ||
real number in the domain of absolute convergence, then the `n`th iterated derivative | ||
of the associated L-series is nonnegative real when `n` is even and nonpositive real | ||
when `n` is odd. -/ | ||
lemma iteratedDeriv_alternating {a : ℕ → ℂ} (hn : 0 ≤ a) {x : ℝ} | ||
(h : LSeries.abscissaOfAbsConv a < x) (n : ℕ) : | ||
0 ≤ (-1) ^ n * iteratedDeriv n (LSeries a) x := by | ||
rw [LSeries_iteratedDeriv _ h, LSeries, ← mul_assoc, ← pow_add, Even.neg_one_pow ⟨n, rfl⟩, | ||
one_mul] | ||
refine tsum_nonneg fun k ↦ ?_ | ||
rw [LSeries.term_def] | ||
split | ||
· exact le_rfl | ||
· refine mul_nonneg ?_ <| (inv_natCast_cpow_ofReal_pos (by assumption) x).le | ||
induction n with | ||
| zero => simpa only [Function.iterate_zero, id_eq] using hn k | ||
| succ n IH => | ||
rw [Function.iterate_succ_apply'] | ||
refine mul_nonneg ?_ IH | ||
simp only [← natCast_log, zero_le_real, Real.log_natCast_nonneg] | ||
|
||
/-- If all values of `a : ℕ → ℂ` are nonnegative reals and `a 1` is positive, | ||
then `L a x` is positive real for all real `x` larger than `abscissaOfAbsConv a`. -/ | ||
lemma positive {a : ℕ → ℂ} (ha₀ : 0 ≤ a) (ha₁ : 0 < a 1) {x : ℝ} (hx : abscissaOfAbsConv a < x) : | ||
0 < LSeries a x := by | ||
rw [LSeries] | ||
refine tsum_pos ?_ (fun n ↦ term_nonneg (ha₀ n) x) 1 <| term_pos one_ne_zero ha₁ x | ||
exact LSeriesSummable_of_abscissaOfAbsConv_lt_re <| by simpa only [ofReal_re] using hx | ||
|
||
/-- If all values of `a : ℕ → ℂ` are nonnegative reals and `a 1` | ||
is positive, and the L-series of `a` agrees with an entire function `f` on some open | ||
right half-plane where it converges, then `f` is real and positive on `ℝ`. -/ | ||
lemma positive_of_differentiable_of_eqOn {a : ℕ → ℂ} (ha₀ : 0 ≤ a) (ha₁ : 0 < a 1) {f : ℂ → ℂ} | ||
(hf : Differentiable ℂ f) {x : ℝ} (hx : abscissaOfAbsConv a ≤ x) | ||
(hf' : {s | x < s.re}.EqOn f (LSeries a)) (y : ℝ) : | ||
0 < f y := by | ||
have hxy : x < max x y + 1 := (le_max_left x y).trans_lt (lt_add_one _) | ||
have hxy' : abscissaOfAbsConv a < max x y + 1 := hx.trans_lt <| mod_cast hxy | ||
have hys : (max x y + 1 : ℂ) ∈ {s | x < s.re} := by | ||
simp only [Set.mem_setOf_eq, add_re, ofReal_re, one_re, hxy] | ||
have hfx : 0 < f (max x y + 1) := by | ||
simpa only [hf' hys, ofReal_add, ofReal_one] using positive ha₀ ha₁ hxy' | ||
refine (hfx.trans_le <| hf.apply_le_of_iteratedDeriv_alternating (fun n _ ↦ ?_) ?_) | ||
· have hs : IsOpen {s : ℂ | x < s.re} := continuous_re.isOpen_preimage _ isOpen_Ioi | ||
simpa only [hf'.iteratedDeriv_of_isOpen hs n hys, ofReal_add, ofReal_one] using | ||
iteratedDeriv_alternating ha₀ hxy' n | ||
· exact_mod_cast (le_max_right x y).trans (lt_add_one _).le | ||
|
||
end LSeries | ||
|
||
namespace ArithmeticFunction | ||
|
||
/-- If all values of a `ℂ`-valued arithmetic function are nonnegative reals and `x` is a | ||
real number in the domain of absolute convergence, then the `n`th iterated derivative | ||
of the associated L-series is nonnegative real when `n` is even and nonpositive real | ||
when `n` is odd. -/ | ||
lemma iteratedDeriv_LSeries_alternating (a : ArithmeticFunction ℂ) (hn : ∀ n, 0 ≤ a n) {x : ℝ} | ||
(h : LSeries.abscissaOfAbsConv a < x) (n : ℕ) : | ||
0 ≤ (-1) ^ n * iteratedDeriv n (LSeries (a ·)) x := | ||
LSeries.iteratedDeriv_alternating hn h n | ||
|
||
/-- If all values of a `ℂ`-valued arithmetic function `a` are nonnegative reals and `a 1` is | ||
positive, then `L a x` is positive real for all real `x` larger than `abscissaOfAbsConv a`. -/ | ||
lemma LSeries_positive {a : ℕ → ℂ} (ha₀ : 0 ≤ a) (ha₁ : 0 < a 1) {x : ℝ} | ||
(hx : LSeries.abscissaOfAbsConv a < x) : | ||
0 < LSeries a x := | ||
LSeries.positive ha₀ ha₁ hx | ||
|
||
/-- If all values of a `ℂ`-valued arithmetic function `a` are nonnegative reals and `a 1` | ||
is positive, and the L-series of `a` agrees with an entire function `f` on some open | ||
right half-plane where it converges, then `f` is real and positive on `ℝ`. -/ | ||
lemma LSeries_positive_of_differentiable_of_eqOn {a : ArithmeticFunction ℂ} (ha₀ : 0 ≤ (a ·)) | ||
(ha₁ : 0 < a 1) {f : ℂ → ℂ} (hf : Differentiable ℂ f) {x : ℝ} | ||
(hx : LSeries.abscissaOfAbsConv a ≤ x) (hf' : {s | x < s.re}.EqOn f (LSeries a)) (y : ℝ) : | ||
0 < f y := | ||
LSeries.positive_of_differentiable_of_eqOn ha₀ ha₁ hf hx hf' y | ||
|
||
end ArithmeticFunction |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.