2024-10-24 14:05:16 +02:00
|
|
|
|
import Nevanlinna.stronglyMeromorphicAt
|
2024-11-20 16:08:59 +01:00
|
|
|
|
import Mathlib.Algebra.BigOperators.Finprod
|
2024-10-24 14:05:16 +02:00
|
|
|
|
|
|
|
|
|
open Topology
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/- Strongly MeromorphicOn -/
|
|
|
|
|
def StronglyMeromorphicOn
|
|
|
|
|
(f : ℂ → ℂ)
|
|
|
|
|
(U : Set ℂ) :=
|
|
|
|
|
∀ z ∈ U, StronglyMeromorphicAt f z
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/- Strongly MeromorphicAt is Meromorphic -/
|
|
|
|
|
theorem StronglyMeromorphicOn.meromorphicOn
|
|
|
|
|
{f : ℂ → ℂ}
|
|
|
|
|
{U : Set ℂ}
|
|
|
|
|
(hf : StronglyMeromorphicOn f U) :
|
|
|
|
|
MeromorphicOn f U := by
|
|
|
|
|
intro z hz
|
|
|
|
|
exact StronglyMeromorphicAt.meromorphicAt (hf z hz)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/- Strongly MeromorphicOn of non-negative order is analytic -/
|
|
|
|
|
theorem StronglyMeromorphicOn.analytic
|
|
|
|
|
{f : ℂ → ℂ}
|
|
|
|
|
{U : Set ℂ}
|
|
|
|
|
(h₁f : StronglyMeromorphicOn f U)
|
|
|
|
|
(h₂f : ∀ x, (hx : x ∈ U) → 0 ≤ (h₁f x hx).meromorphicAt.order):
|
|
|
|
|
∀ z ∈ U, AnalyticAt ℂ f z := by
|
|
|
|
|
intro z hz
|
|
|
|
|
apply StronglyMeromorphicAt.analytic
|
|
|
|
|
exact h₂f z hz
|
|
|
|
|
exact h₁f z hz
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/- Analytic functions are strongly meromorphic -/
|
|
|
|
|
theorem AnalyticOn.stronglyMeromorphicOn
|
|
|
|
|
{f : ℂ → ℂ}
|
|
|
|
|
{U : Set ℂ}
|
2024-10-24 14:37:27 +02:00
|
|
|
|
(h₁f : AnalyticOnNhd ℂ f U) :
|
2024-10-24 14:05:16 +02:00
|
|
|
|
StronglyMeromorphicOn f U := by
|
|
|
|
|
intro z hz
|
|
|
|
|
apply AnalyticAt.stronglyMeromorphicAt
|
|
|
|
|
exact h₁f z hz
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/- Make strongly MeromorphicAt -/
|
2024-10-24 14:37:27 +02:00
|
|
|
|
noncomputable def MeromorphicOn.makeStronglyMeromorphicOn
|
2024-10-24 14:05:16 +02:00
|
|
|
|
{f : ℂ → ℂ}
|
2024-10-24 14:37:27 +02:00
|
|
|
|
{U : Set ℂ}
|
|
|
|
|
(hf : MeromorphicOn f U) :
|
2024-10-24 14:05:16 +02:00
|
|
|
|
ℂ → ℂ := by
|
|
|
|
|
intro z
|
2024-10-24 14:37:27 +02:00
|
|
|
|
by_cases hz : z ∈ U
|
|
|
|
|
· exact (hf z hz).makeStronglyMeromorphicAt z
|
2024-10-24 14:05:16 +02:00
|
|
|
|
· exact f z
|
|
|
|
|
|
|
|
|
|
|
2024-10-30 16:53:32 +01:00
|
|
|
|
theorem makeStronglyMeromorphicOn_changeDiscrete
|
|
|
|
|
{f : ℂ → ℂ}
|
|
|
|
|
{U : Set ℂ}
|
|
|
|
|
{z₀ : ℂ}
|
|
|
|
|
(hf : MeromorphicOn f U)
|
|
|
|
|
(hz₀ : z₀ ∈ U) :
|
|
|
|
|
hf.makeStronglyMeromorphicOn =ᶠ[𝓝[≠] z₀] f := by
|
|
|
|
|
apply Filter.eventually_iff_exists_mem.2
|
|
|
|
|
let A := (hf z₀ hz₀).eventually_analyticAt
|
|
|
|
|
obtain ⟨V, h₁V, h₂V⟩ := Filter.eventually_iff_exists_mem.1 A
|
|
|
|
|
use V
|
|
|
|
|
constructor
|
|
|
|
|
· assumption
|
|
|
|
|
· intro v hv
|
|
|
|
|
unfold MeromorphicOn.makeStronglyMeromorphicOn
|
|
|
|
|
by_cases h₂v : v ∈ U
|
|
|
|
|
· simp [h₂v]
|
2024-11-19 11:31:24 +01:00
|
|
|
|
rw [← StronglyMeromorphicAt.makeStronglyMeromorphic_id]
|
2024-10-30 16:53:32 +01:00
|
|
|
|
exact AnalyticAt.stronglyMeromorphicAt (h₂V v hv)
|
|
|
|
|
· simp [h₂v]
|
|
|
|
|
|
|
|
|
|
|
2024-11-20 16:08:59 +01:00
|
|
|
|
theorem stronglyMeromorphicOn_ratlPolynomial
|
|
|
|
|
{U : Set ℂ}
|
|
|
|
|
(d : ℂ → ℤ) :
|
|
|
|
|
StronglyMeromorphicOn (∏ᶠ u, fun z ↦ (z - u) ^ d u) U := by
|
|
|
|
|
by_cases hd : (Function.mulSupport fun u z => (z - u) ^ d u).Finite
|
|
|
|
|
· rw [finprod_eq_prod _ hd]
|
|
|
|
|
intro z h₁z
|
|
|
|
|
by_cases h₂z : d z = 0
|
|
|
|
|
· apply AnalyticAt.stronglyMeromorphicAt
|
|
|
|
|
rw [Finset.prod_fn]
|
|
|
|
|
apply Finset.analyticAt_prod
|
|
|
|
|
intro u hu
|
|
|
|
|
by_cases huz : u = z
|
|
|
|
|
· rw [← huz] at h₂z
|
|
|
|
|
rw [h₂z]
|
|
|
|
|
simp
|
|
|
|
|
exact analyticAt_const
|
|
|
|
|
· apply AnalyticAt.zpow
|
|
|
|
|
apply AnalyticAt.sub
|
|
|
|
|
apply analyticAt_id
|
|
|
|
|
apply analyticAt_const
|
|
|
|
|
rwa [sub_ne_zero, ne_comm]
|
|
|
|
|
· have : z ∈ hd.toFinset := by
|
|
|
|
|
simp
|
|
|
|
|
by_contra hCon
|
|
|
|
|
have A : 0 ≠ (1 : ℂ → ℂ) z := by simp
|
|
|
|
|
rw [← hCon] at A
|
|
|
|
|
simp only [sub_self] at A
|
|
|
|
|
rw [ne_comm] at A
|
|
|
|
|
rw [zpow_ne_zero_iff] at A
|
|
|
|
|
tauto
|
|
|
|
|
exact h₂z
|
|
|
|
|
rw [← Finset.mul_prod_erase hd.toFinset _ this]
|
|
|
|
|
right
|
|
|
|
|
use d z
|
|
|
|
|
use ∏ x ∈ hd.toFinset.erase z, fun z => (z - x) ^ d x
|
|
|
|
|
constructor
|
|
|
|
|
· rw [Finset.prod_fn]
|
|
|
|
|
apply Finset.analyticAt_prod
|
|
|
|
|
intro u hu
|
|
|
|
|
apply AnalyticAt.zpow
|
|
|
|
|
apply AnalyticAt.sub
|
|
|
|
|
apply analyticAt_id
|
|
|
|
|
apply analyticAt_const
|
|
|
|
|
rw [sub_ne_zero, ne_comm]
|
|
|
|
|
by_contra hCon
|
|
|
|
|
simp at hu
|
|
|
|
|
tauto
|
|
|
|
|
· constructor
|
|
|
|
|
· simp only [Finset.prod_apply]
|
|
|
|
|
rw [Finset.prod_ne_zero_iff]
|
|
|
|
|
intro u hu
|
|
|
|
|
rw [zpow_ne_zero_iff]
|
|
|
|
|
rw [sub_ne_zero]
|
|
|
|
|
by_contra hCon
|
|
|
|
|
rw [hCon] at hu
|
|
|
|
|
let A := Finset.not_mem_erase u hd.toFinset
|
|
|
|
|
tauto
|
|
|
|
|
--
|
|
|
|
|
have : u ∈ hd.toFinset := by
|
|
|
|
|
exact Finset.mem_of_mem_erase hu
|
|
|
|
|
simp at this
|
|
|
|
|
by_contra hCon
|
|
|
|
|
rw [hCon] at this
|
|
|
|
|
simp at this
|
|
|
|
|
tauto
|
|
|
|
|
· exact Filter.Eventually.of_forall (congrFun rfl)
|
|
|
|
|
|
|
|
|
|
· rw [finprod_of_infinite_mulSupport hd]
|
|
|
|
|
apply AnalyticOn.stronglyMeromorphicOn
|
|
|
|
|
apply analyticOnNhd_const
|
2024-11-12 16:58:07 +01:00
|
|
|
|
|
|
|
|
|
|
2024-10-30 16:53:32 +01:00
|
|
|
|
theorem makeStronglyMeromorphicOn_changeDiscrete'
|
|
|
|
|
{f : ℂ → ℂ}
|
|
|
|
|
{U : Set ℂ}
|
|
|
|
|
{z₀ : ℂ}
|
|
|
|
|
(hf : MeromorphicOn f U)
|
|
|
|
|
(hz₀ : z₀ ∈ U) :
|
|
|
|
|
hf.makeStronglyMeromorphicOn =ᶠ[𝓝 z₀] (hf z₀ hz₀).makeStronglyMeromorphicAt := by
|
|
|
|
|
apply Mnhds
|
|
|
|
|
let A := makeStronglyMeromorphicOn_changeDiscrete hf hz₀
|
|
|
|
|
apply Filter.EventuallyEq.trans A
|
|
|
|
|
exact m₂ (hf z₀ hz₀)
|
|
|
|
|
unfold MeromorphicOn.makeStronglyMeromorphicOn
|
|
|
|
|
simp [hz₀]
|
|
|
|
|
|
|
|
|
|
|
2024-10-24 14:37:27 +02:00
|
|
|
|
theorem StronglyMeromorphicOn_of_makeStronglyMeromorphicOn
|
2024-10-24 14:05:16 +02:00
|
|
|
|
{f : ℂ → ℂ}
|
2024-10-24 14:37:27 +02:00
|
|
|
|
{U : Set ℂ}
|
|
|
|
|
(hf : MeromorphicOn f U) :
|
|
|
|
|
StronglyMeromorphicOn hf.makeStronglyMeromorphicOn U := by
|
2024-10-30 16:53:32 +01:00
|
|
|
|
intro z₀ hz₀
|
|
|
|
|
rw [stronglyMeromorphicAt_congr (makeStronglyMeromorphicOn_changeDiscrete' hf hz₀)]
|
|
|
|
|
exact StronglyMeromorphicAt_of_makeStronglyMeromorphic (hf z₀ hz₀)
|