2024-09-10 10:45:53 +02:00
|
|
|
|
import Mathlib.Analysis.Analytic.IsolatedZeros
|
|
|
|
|
import Mathlib.Analysis.Complex.Basic
|
2024-09-11 15:48:43 +02:00
|
|
|
|
import Mathlib.Analysis.Analytic.Linear
|
2024-09-10 10:45:53 +02:00
|
|
|
|
|
|
|
|
|
|
2024-09-14 08:38:04 +02:00
|
|
|
|
theorem AnalyticAt.order_neq_top_iff
|
|
|
|
|
{f : ℂ → ℂ}
|
|
|
|
|
{z₀ : ℂ}
|
|
|
|
|
(hf : AnalyticAt ℂ f z₀) :
|
|
|
|
|
hf.order ≠ ⊤ ↔ ∃ (g : ℂ → ℂ), AnalyticAt ℂ g z₀ ∧ g z₀ ≠ 0 ∧ ∀ᶠ (z : ℂ) in nhds z₀, f z = (z - z₀) ^ (hf.order.toNat) • g z := by
|
|
|
|
|
rw [← hf.order_eq_nat_iff]
|
|
|
|
|
constructor
|
|
|
|
|
· intro h₁f
|
|
|
|
|
exact Eq.symm (ENat.coe_toNat h₁f)
|
|
|
|
|
· intro h₁f
|
|
|
|
|
exact ENat.coe_toNat_eq_self.mp (id (Eq.symm h₁f))
|
|
|
|
|
|
2024-09-11 16:57:16 +02:00
|
|
|
|
|
2024-09-10 10:45:53 +02:00
|
|
|
|
theorem AnalyticAt.order_mul
|
|
|
|
|
{f₁ f₂ : ℂ → ℂ}
|
|
|
|
|
{z₀ : ℂ}
|
|
|
|
|
(hf₁ : AnalyticAt ℂ f₁ z₀)
|
|
|
|
|
(hf₂ : AnalyticAt ℂ f₂ z₀) :
|
2024-09-11 16:57:16 +02:00
|
|
|
|
(hf₁.mul hf₂).order = hf₁.order + hf₂.order := by
|
2024-09-10 10:45:53 +02:00
|
|
|
|
by_cases h₂f₁ : hf₁.order = ⊤
|
|
|
|
|
· simp [h₂f₁]
|
|
|
|
|
rw [AnalyticAt.order_eq_top_iff, eventually_nhds_iff]
|
|
|
|
|
rw [AnalyticAt.order_eq_top_iff, eventually_nhds_iff] at h₂f₁
|
|
|
|
|
obtain ⟨t, h₁t, h₂t, h₃t⟩ := h₂f₁
|
|
|
|
|
use t
|
|
|
|
|
constructor
|
|
|
|
|
· intro y hy
|
|
|
|
|
rw [h₁t y hy]
|
|
|
|
|
ring
|
|
|
|
|
· exact ⟨h₂t, h₃t⟩
|
|
|
|
|
· by_cases h₂f₂ : hf₂.order = ⊤
|
|
|
|
|
· simp [h₂f₂]
|
|
|
|
|
rw [AnalyticAt.order_eq_top_iff, eventually_nhds_iff]
|
|
|
|
|
rw [AnalyticAt.order_eq_top_iff, eventually_nhds_iff] at h₂f₂
|
|
|
|
|
obtain ⟨t, h₁t, h₂t, h₃t⟩ := h₂f₂
|
|
|
|
|
use t
|
|
|
|
|
constructor
|
|
|
|
|
· intro y hy
|
|
|
|
|
rw [h₁t y hy]
|
|
|
|
|
ring
|
|
|
|
|
· exact ⟨h₂t, h₃t⟩
|
|
|
|
|
· obtain ⟨g₁, h₁g₁, h₂g₁, h₃g₁⟩ := (AnalyticAt.order_eq_nat_iff hf₁ ↑hf₁.order.toNat).1 (eq_comm.1 (ENat.coe_toNat h₂f₁))
|
|
|
|
|
obtain ⟨g₂, h₁g₂, h₂g₂, h₃g₂⟩ := (AnalyticAt.order_eq_nat_iff hf₂ ↑hf₂.order.toNat).1 (eq_comm.1 (ENat.coe_toNat h₂f₂))
|
|
|
|
|
rw [← ENat.coe_toNat h₂f₁, ← ENat.coe_toNat h₂f₂, ← ENat.coe_add]
|
|
|
|
|
rw [AnalyticAt.order_eq_nat_iff (AnalyticAt.mul hf₁ hf₂) ↑(hf₁.order.toNat + hf₂.order.toNat)]
|
|
|
|
|
use g₁ * g₂
|
|
|
|
|
constructor
|
|
|
|
|
· exact AnalyticAt.mul h₁g₁ h₁g₂
|
|
|
|
|
· constructor
|
|
|
|
|
· simp; tauto
|
|
|
|
|
· obtain ⟨t₁, h₁t₁, h₂t₁, h₃t₁⟩ := eventually_nhds_iff.1 h₃g₁
|
|
|
|
|
obtain ⟨t₂, h₁t₂, h₂t₂, h₃t₂⟩ := eventually_nhds_iff.1 h₃g₂
|
|
|
|
|
rw [eventually_nhds_iff]
|
|
|
|
|
use t₁ ∩ t₂
|
|
|
|
|
constructor
|
|
|
|
|
· intro y hy
|
|
|
|
|
rw [h₁t₁ y hy.1, h₁t₂ y hy.2]
|
|
|
|
|
simp; ring
|
|
|
|
|
· constructor
|
|
|
|
|
· exact IsOpen.inter h₂t₁ h₂t₂
|
|
|
|
|
· exact Set.mem_inter h₃t₁ h₃t₂
|
2024-09-10 14:21:08 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
theorem AnalyticAt.order_eq_zero_iff
|
|
|
|
|
{f : ℂ → ℂ}
|
|
|
|
|
{z₀ : ℂ}
|
|
|
|
|
(hf : AnalyticAt ℂ f z₀) :
|
|
|
|
|
hf.order = 0 ↔ f z₀ ≠ 0 := by
|
|
|
|
|
|
|
|
|
|
have : (0 : ENat) = (0 : Nat) := by rfl
|
|
|
|
|
rw [this, AnalyticAt.order_eq_nat_iff hf 0]
|
|
|
|
|
|
|
|
|
|
constructor
|
|
|
|
|
· intro hz
|
|
|
|
|
obtain ⟨g, _, h₂g, h₃g⟩ := hz
|
|
|
|
|
simp at h₃g
|
|
|
|
|
rw [Filter.Eventually.self_of_nhds h₃g]
|
|
|
|
|
tauto
|
|
|
|
|
· intro hz
|
|
|
|
|
use f
|
|
|
|
|
constructor
|
|
|
|
|
· exact hf
|
|
|
|
|
· constructor
|
|
|
|
|
· exact hz
|
|
|
|
|
· simp
|
2024-09-10 14:43:28 +02:00
|
|
|
|
|
|
|
|
|
|
2024-09-11 16:57:16 +02:00
|
|
|
|
theorem AnalyticAt.order_pow
|
|
|
|
|
{f : ℂ → ℂ}
|
|
|
|
|
{z₀ : ℂ}
|
|
|
|
|
{n : ℕ}
|
|
|
|
|
(hf : AnalyticAt ℂ f z₀) :
|
|
|
|
|
(hf.pow n).order = n * hf.order := by
|
|
|
|
|
|
|
|
|
|
induction' n with n hn
|
|
|
|
|
· simp; rw [AnalyticAt.order_eq_zero_iff]; simp
|
|
|
|
|
· simp
|
|
|
|
|
simp_rw [add_mul, pow_add]
|
|
|
|
|
simp
|
|
|
|
|
rw [AnalyticAt.order_mul (hf.pow n) hf]
|
|
|
|
|
rw [hn]
|
|
|
|
|
|
|
|
|
|
|
2024-09-10 14:43:28 +02:00
|
|
|
|
theorem AnalyticAt.supp_order_toNat
|
|
|
|
|
{f : ℂ → ℂ}
|
|
|
|
|
{z₀ : ℂ}
|
|
|
|
|
(hf : AnalyticAt ℂ f z₀) :
|
|
|
|
|
hf.order.toNat ≠ 0 → f z₀ = 0 := by
|
|
|
|
|
|
|
|
|
|
contrapose
|
|
|
|
|
intro h₁f
|
|
|
|
|
simp [hf.order_eq_zero_iff.2 h₁f]
|
2024-09-11 15:48:43 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
theorem ContinuousLinearEquiv.analyticAt
|
|
|
|
|
(ℓ : ℂ ≃L[ℂ] ℂ) (z₀ : ℂ) : AnalyticAt ℂ (⇑ℓ) z₀ := ℓ.toContinuousLinearMap.analyticAt z₀
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
theorem eventually_nhds_comp_composition
|
|
|
|
|
{f₁ f₂ ℓ : ℂ → ℂ}
|
|
|
|
|
{z₀ : ℂ}
|
|
|
|
|
(hf : ∀ᶠ (z : ℂ) in nhds (ℓ z₀), f₁ z = f₂ z)
|
|
|
|
|
(hℓ : Continuous ℓ) :
|
|
|
|
|
∀ᶠ (z : ℂ) in nhds z₀, (f₁ ∘ ℓ) z = (f₂ ∘ ℓ) z := by
|
|
|
|
|
obtain ⟨t, h₁t, h₂t, h₃t⟩ := eventually_nhds_iff.1 hf
|
|
|
|
|
apply eventually_nhds_iff.2
|
|
|
|
|
use ℓ⁻¹' t
|
|
|
|
|
constructor
|
|
|
|
|
· intro y hy
|
|
|
|
|
exact h₁t (ℓ y) hy
|
|
|
|
|
· constructor
|
|
|
|
|
· apply IsOpen.preimage
|
2024-09-12 07:04:00 +02:00
|
|
|
|
exact hℓ
|
2024-09-11 15:48:43 +02:00
|
|
|
|
exact h₂t
|
|
|
|
|
· exact h₃t
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
theorem AnalyticAt.order_congr
|
|
|
|
|
{f₁ f₂ : ℂ → ℂ}
|
|
|
|
|
{z₀ : ℂ}
|
|
|
|
|
(hf₁ : AnalyticAt ℂ f₁ z₀)
|
2024-09-12 07:04:00 +02:00
|
|
|
|
(hf : f₁ =ᶠ[nhds z₀] f₂) :
|
|
|
|
|
hf₁.order = (hf₁.congr hf).order := by
|
|
|
|
|
|
2024-09-12 07:12:03 +02:00
|
|
|
|
by_cases h₁f₁ : hf₁.order = ⊤
|
|
|
|
|
rw [h₁f₁, eq_comm, AnalyticAt.order_eq_top_iff]
|
|
|
|
|
rw [AnalyticAt.order_eq_top_iff] at h₁f₁
|
|
|
|
|
exact Filter.EventuallyEq.rw h₁f₁ (fun x => Eq (f₂ x)) (id (Filter.EventuallyEq.symm hf))
|
|
|
|
|
--
|
|
|
|
|
let n := hf₁.order.toNat
|
|
|
|
|
have hn : hf₁.order = n := Eq.symm (ENat.coe_toNat h₁f₁)
|
|
|
|
|
rw [hn, eq_comm, AnalyticAt.order_eq_nat_iff]
|
|
|
|
|
rw [AnalyticAt.order_eq_nat_iff] at hn
|
|
|
|
|
obtain ⟨g, h₁g, h₂g, h₃g⟩ := hn
|
|
|
|
|
use g
|
|
|
|
|
constructor
|
|
|
|
|
· assumption
|
|
|
|
|
· constructor
|
|
|
|
|
· assumption
|
|
|
|
|
· exact Filter.EventuallyEq.rw h₃g (fun x => Eq (f₂ x)) (id (Filter.EventuallyEq.symm hf))
|
2024-09-11 15:48:43 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
theorem AnalyticAt.order_comp_CLE
|
|
|
|
|
(ℓ : ℂ ≃L[ℂ] ℂ)
|
|
|
|
|
{f : ℂ → ℂ}
|
|
|
|
|
{z₀ : ℂ}
|
|
|
|
|
(hf : AnalyticAt ℂ f (ℓ z₀)) :
|
|
|
|
|
hf.order = (hf.comp (ℓ.analyticAt z₀)).order := by
|
|
|
|
|
|
|
|
|
|
by_cases h₁f : hf.order = ⊤
|
|
|
|
|
· rw [h₁f]
|
|
|
|
|
rw [AnalyticAt.order_eq_top_iff] at h₁f
|
|
|
|
|
let A := eventually_nhds_comp_composition h₁f ℓ.continuous
|
|
|
|
|
simp at A
|
2024-09-12 07:04:00 +02:00
|
|
|
|
rw [AnalyticAt.order_congr (hf.comp (ℓ.analyticAt z₀)) A]
|
2024-09-11 15:48:43 +02:00
|
|
|
|
|
2024-09-12 07:12:03 +02:00
|
|
|
|
have : AnalyticAt ℂ (0 : ℂ → ℂ) z₀ := by
|
|
|
|
|
apply analyticAt_const
|
2024-09-11 15:48:43 +02:00
|
|
|
|
have : this.order = ⊤ := by
|
|
|
|
|
rw [AnalyticAt.order_eq_top_iff]
|
|
|
|
|
simp
|
|
|
|
|
rw [this]
|
|
|
|
|
· let n := hf.order.toNat
|
|
|
|
|
have hn : hf.order = n := Eq.symm (ENat.coe_toNat h₁f)
|
|
|
|
|
rw [hn]
|
|
|
|
|
rw [AnalyticAt.order_eq_nat_iff] at hn
|
|
|
|
|
obtain ⟨g, h₁g, h₂g, h₃g⟩ := hn
|
|
|
|
|
have A := eventually_nhds_comp_composition h₃g ℓ.continuous
|
2024-09-11 16:57:16 +02:00
|
|
|
|
|
2024-09-12 06:58:43 +02:00
|
|
|
|
have t₁ : AnalyticAt ℂ (fun z => ℓ z - ℓ z₀) z₀ := by
|
|
|
|
|
apply AnalyticAt.sub
|
|
|
|
|
exact ContinuousLinearEquiv.analyticAt ℓ z₀
|
|
|
|
|
exact analyticAt_const
|
|
|
|
|
have t₀ : AnalyticAt ℂ (fun z => (ℓ z - ℓ z₀) ^ n) z₀ := by
|
|
|
|
|
exact pow t₁ n
|
2024-09-11 16:57:16 +02:00
|
|
|
|
have : AnalyticAt ℂ (fun z ↦ (ℓ z - ℓ z₀) ^ n • g (ℓ z) : ℂ → ℂ) z₀ := by
|
2024-09-12 06:58:43 +02:00
|
|
|
|
apply AnalyticAt.mul
|
|
|
|
|
exact t₀
|
|
|
|
|
apply AnalyticAt.comp h₁g
|
|
|
|
|
exact ContinuousLinearEquiv.analyticAt ℓ z₀
|
2024-09-12 07:04:00 +02:00
|
|
|
|
rw [AnalyticAt.order_congr (hf.comp (ℓ.analyticAt z₀)) A]
|
2024-09-11 15:48:43 +02:00
|
|
|
|
simp
|
2024-09-11 16:57:16 +02:00
|
|
|
|
|
|
|
|
|
rw [AnalyticAt.order_mul t₀ ((h₁g.comp (ℓ.analyticAt z₀)))]
|
2024-09-11 15:48:43 +02:00
|
|
|
|
|
2024-09-11 16:57:16 +02:00
|
|
|
|
have : t₁.order = (1 : ℕ) := by
|
|
|
|
|
rw [AnalyticAt.order_eq_nat_iff]
|
2024-09-12 06:58:43 +02:00
|
|
|
|
use (fun _ ↦ ℓ 1)
|
2024-09-11 16:57:16 +02:00
|
|
|
|
simp
|
|
|
|
|
constructor
|
|
|
|
|
· exact analyticAt_const
|
|
|
|
|
· apply Filter.Eventually.of_forall
|
|
|
|
|
intro x
|
2024-09-12 06:58:43 +02:00
|
|
|
|
calc ℓ x - ℓ z₀
|
|
|
|
|
_ = ℓ (x - z₀) := by
|
|
|
|
|
exact Eq.symm (ContinuousLinearEquiv.map_sub ℓ x z₀)
|
|
|
|
|
_ = ℓ ((x - z₀) * 1) := by
|
|
|
|
|
simp
|
|
|
|
|
_ = (x - z₀) * ℓ 1 := by
|
|
|
|
|
rw [← smul_eq_mul, ← smul_eq_mul]
|
|
|
|
|
exact ContinuousLinearEquiv.map_smul ℓ (x - z₀) 1
|
2024-09-11 15:48:43 +02:00
|
|
|
|
|
2024-09-11 16:57:16 +02:00
|
|
|
|
have : t₀.order = n := by
|
|
|
|
|
rw [AnalyticAt.order_pow t₁, this]
|
|
|
|
|
simp
|
2024-09-11 15:48:43 +02:00
|
|
|
|
|
2024-09-11 16:57:16 +02:00
|
|
|
|
rw [this]
|
2024-09-11 15:48:43 +02:00
|
|
|
|
|
2024-09-11 16:57:16 +02:00
|
|
|
|
have : (comp h₁g (ContinuousLinearEquiv.analyticAt ℓ z₀)).order = 0 := by
|
|
|
|
|
rwa [AnalyticAt.order_eq_zero_iff]
|
|
|
|
|
rw [this]
|
|
|
|
|
|
|
|
|
|
simp
|