2024-05-07 09:49:56 +02:00
|
|
|
|
import Mathlib.Analysis.Calculus.FDeriv.Basic
|
|
|
|
|
import Mathlib.Analysis.Calculus.FDeriv.Symmetric
|
2024-05-09 08:18:55 +02:00
|
|
|
|
import Mathlib.Analysis.Calculus.ContDiff.Basic
|
2024-06-03 12:56:30 +02:00
|
|
|
|
import Mathlib.Topology.Basic
|
|
|
|
|
import Mathlib.Topology.Defs.Filter
|
2024-05-09 08:18:55 +02:00
|
|
|
|
|
2024-05-07 09:49:56 +02:00
|
|
|
|
|
2024-05-07 17:32:41 +02:00
|
|
|
|
variable {𝕜 : Type*} [NontriviallyNormedField 𝕜]
|
2024-05-08 15:59:56 +02:00
|
|
|
|
variable {E : Type*} [NormedAddCommGroup E] [NormedSpace 𝕜 E]
|
|
|
|
|
variable {F : Type*} [NormedAddCommGroup F] [NormedSpace 𝕜 F]
|
2024-05-13 09:48:16 +02:00
|
|
|
|
variable {G : Type*} [NormedAddCommGroup G] [NormedSpace 𝕜 G]
|
2024-05-08 15:59:56 +02:00
|
|
|
|
variable (𝕜)
|
2024-05-07 09:49:56 +02:00
|
|
|
|
|
|
|
|
|
|
2024-05-08 15:59:56 +02:00
|
|
|
|
noncomputable def partialDeriv : E → (E → F) → (E → F) :=
|
|
|
|
|
fun v ↦ (fun f ↦ (fun w ↦ fderiv 𝕜 f w v))
|
2024-05-07 09:49:56 +02:00
|
|
|
|
|
2024-05-08 15:59:56 +02:00
|
|
|
|
|
2024-06-05 12:03:05 +02:00
|
|
|
|
theorem partialDeriv_eventuallyEq'
|
|
|
|
|
{f₁ f₂ : E → F}
|
|
|
|
|
{x : E}
|
|
|
|
|
(h : f₁ =ᶠ[nhds x] f₂) :
|
|
|
|
|
∀ v : E, partialDeriv 𝕜 v f₁ =ᶠ[nhds x] partialDeriv 𝕜 v f₂ := by
|
2024-06-05 06:42:05 +02:00
|
|
|
|
unfold partialDeriv
|
|
|
|
|
intro v
|
|
|
|
|
apply Filter.EventuallyEq.comp₂
|
|
|
|
|
exact Filter.EventuallyEq.fderiv h
|
|
|
|
|
simp
|
|
|
|
|
|
|
|
|
|
|
2024-06-10 10:58:57 +02:00
|
|
|
|
theorem partialDeriv_eventuallyEq
|
|
|
|
|
{f₁ f₂ : E → F}
|
|
|
|
|
{x : E}
|
|
|
|
|
(h : f₁ =ᶠ[nhds x] f₂) :
|
|
|
|
|
∀ v : E, partialDeriv 𝕜 v f₁ x = partialDeriv 𝕜 v f₂ x := by
|
|
|
|
|
unfold partialDeriv
|
|
|
|
|
rw [Filter.EventuallyEq.fderiv_eq h]
|
|
|
|
|
exact fun v => rfl
|
|
|
|
|
|
|
|
|
|
|
2024-08-08 12:36:06 +02:00
|
|
|
|
theorem partialDeriv_smul₁
|
2024-07-29 15:50:51 +02:00
|
|
|
|
{f : E → F}
|
|
|
|
|
{a : 𝕜}
|
2024-08-08 12:36:06 +02:00
|
|
|
|
{v : E} :
|
2024-07-29 15:50:51 +02:00
|
|
|
|
partialDeriv 𝕜 (a • v) f = a • partialDeriv 𝕜 v f := by
|
2024-05-08 15:59:56 +02:00
|
|
|
|
unfold partialDeriv
|
2024-05-07 16:50:57 +02:00
|
|
|
|
conv =>
|
|
|
|
|
left
|
|
|
|
|
intro w
|
|
|
|
|
rw [map_smul]
|
2024-07-25 15:52:16 +02:00
|
|
|
|
funext w
|
|
|
|
|
simp
|
2024-05-07 16:50:57 +02:00
|
|
|
|
|
|
|
|
|
|
2024-05-08 15:59:56 +02:00
|
|
|
|
theorem partialDeriv_add₁ {f : E → F} {v₁ v₂ : E} : partialDeriv 𝕜 (v₁ + v₂) f = (partialDeriv 𝕜 v₁ f) + (partialDeriv 𝕜 v₂ f) := by
|
|
|
|
|
unfold partialDeriv
|
2024-05-07 16:50:57 +02:00
|
|
|
|
conv =>
|
|
|
|
|
left
|
|
|
|
|
intro w
|
|
|
|
|
rw [map_add]
|
2024-07-25 15:52:16 +02:00
|
|
|
|
funext w
|
|
|
|
|
simp
|
2024-05-07 16:50:57 +02:00
|
|
|
|
|
|
|
|
|
|
2024-05-31 16:06:42 +02:00
|
|
|
|
theorem partialDeriv_smul₂ {f : E → F} {a : 𝕜} {v : E} : partialDeriv 𝕜 v (a • f) = a • partialDeriv 𝕜 v f := by
|
2024-05-08 15:59:56 +02:00
|
|
|
|
unfold partialDeriv
|
2024-05-31 16:06:42 +02:00
|
|
|
|
funext w
|
2024-05-07 09:49:56 +02:00
|
|
|
|
have : a • f = fun y ↦ a • f y := by rfl
|
|
|
|
|
rw [this]
|
2024-05-31 16:06:42 +02:00
|
|
|
|
by_cases ha : a = 0
|
|
|
|
|
· rw [ha]
|
|
|
|
|
simp
|
|
|
|
|
· by_cases hf : DifferentiableAt 𝕜 f w
|
|
|
|
|
· rw [fderiv_const_smul hf]
|
|
|
|
|
simp
|
|
|
|
|
· have : ¬DifferentiableAt 𝕜 (fun y => a • f y) w := by
|
|
|
|
|
by_contra contra
|
|
|
|
|
let ZZ := DifferentiableAt.const_smul contra a⁻¹
|
|
|
|
|
have : (fun y => a⁻¹ • a • f y) = f := by
|
|
|
|
|
funext i
|
2024-08-23 09:26:58 +02:00
|
|
|
|
rw [← smul_assoc, smul_eq_mul, mul_comm, mul_inv_cancel₀ ha]
|
2024-05-31 16:06:42 +02:00
|
|
|
|
simp
|
|
|
|
|
rw [this] at ZZ
|
|
|
|
|
exact hf ZZ
|
|
|
|
|
simp
|
|
|
|
|
rw [fderiv_zero_of_not_differentiableAt hf]
|
|
|
|
|
rw [fderiv_zero_of_not_differentiableAt this]
|
|
|
|
|
simp
|
2024-05-07 09:49:56 +02:00
|
|
|
|
|
|
|
|
|
|
2024-06-05 09:06:25 +02:00
|
|
|
|
theorem partialDeriv_add₂ {f₁ f₂ : E → F} (h₁ : Differentiable 𝕜 f₁) (h₂ : Differentiable 𝕜 f₂) : ∀ v : E, partialDeriv 𝕜 v (f₁ + f₂) = (partialDeriv 𝕜 v f₁) + (partialDeriv 𝕜 v f₂) := by
|
2024-05-08 15:59:56 +02:00
|
|
|
|
unfold partialDeriv
|
2024-06-05 09:06:25 +02:00
|
|
|
|
intro v
|
2024-05-07 12:13:28 +02:00
|
|
|
|
have : f₁ + f₂ = fun y ↦ f₁ y + f₂ y := by rfl
|
|
|
|
|
rw [this]
|
|
|
|
|
conv =>
|
|
|
|
|
left
|
|
|
|
|
intro w
|
|
|
|
|
left
|
|
|
|
|
rw [fderiv_add (h₁ w) (h₂ w)]
|
2024-07-25 15:52:16 +02:00
|
|
|
|
funext w
|
|
|
|
|
simp
|
2024-05-07 12:13:28 +02:00
|
|
|
|
|
|
|
|
|
|
2024-08-08 12:36:06 +02:00
|
|
|
|
theorem partialDeriv_add₂_differentiableAt
|
|
|
|
|
{f₁ f₂ : E → F}
|
|
|
|
|
{v : E}
|
|
|
|
|
{x : E}
|
|
|
|
|
(h₁ : DifferentiableAt 𝕜 f₁ x)
|
|
|
|
|
(h₂ : DifferentiableAt 𝕜 f₂ x) :
|
|
|
|
|
partialDeriv 𝕜 v (f₁ + f₂) x = (partialDeriv 𝕜 v f₁) x + (partialDeriv 𝕜 v f₂) x := by
|
|
|
|
|
|
|
|
|
|
unfold partialDeriv
|
|
|
|
|
have : f₁ + f₂ = fun y ↦ f₁ y + f₂ y := by rfl
|
|
|
|
|
rw [this]
|
|
|
|
|
rw [fderiv_add h₁ h₂]
|
|
|
|
|
rfl
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
theorem partialDeriv_add₂_contDiffAt
|
|
|
|
|
{f₁ f₂ : E → F}
|
|
|
|
|
{v : E}
|
|
|
|
|
{x : E}
|
|
|
|
|
(h₁ : ContDiffAt 𝕜 1 f₁ x)
|
|
|
|
|
(h₂ : ContDiffAt 𝕜 1 f₂ x) :
|
|
|
|
|
partialDeriv 𝕜 v (f₁ + f₂) =ᶠ[nhds x] (partialDeriv 𝕜 v f₁) + (partialDeriv 𝕜 v f₂) := by
|
|
|
|
|
|
|
|
|
|
obtain ⟨f₁', u₁, hu₁, _, hf₁'⟩ := contDiffAt_one_iff.1 h₁
|
|
|
|
|
obtain ⟨f₂', u₂, hu₂, _, hf₂'⟩ := contDiffAt_one_iff.1 h₂
|
|
|
|
|
|
|
|
|
|
apply Filter.eventuallyEq_iff_exists_mem.2
|
|
|
|
|
use u₁ ∩ u₂
|
|
|
|
|
constructor
|
|
|
|
|
· exact Filter.inter_mem hu₁ hu₂
|
|
|
|
|
· intro x hx
|
|
|
|
|
simp
|
|
|
|
|
apply partialDeriv_add₂_differentiableAt 𝕜
|
|
|
|
|
exact (hf₁' x (Set.mem_of_mem_inter_left hx)).differentiableAt
|
|
|
|
|
exact (hf₂' x (Set.mem_of_mem_inter_right hx)).differentiableAt
|
|
|
|
|
|
|
|
|
|
|
2024-07-30 10:52:12 +02:00
|
|
|
|
theorem partialDeriv_sub₂ {f₁ f₂ : E → F} (h₁ : Differentiable 𝕜 f₁) (h₂ : Differentiable 𝕜 f₂) : ∀ v : E, partialDeriv 𝕜 v (f₁ - f₂) = (partialDeriv 𝕜 v f₁) - (partialDeriv 𝕜 v f₂) := by
|
|
|
|
|
unfold partialDeriv
|
|
|
|
|
intro v
|
|
|
|
|
have : f₁ - f₂ = fun y ↦ f₁ y - f₂ y := by rfl
|
|
|
|
|
rw [this]
|
|
|
|
|
conv =>
|
|
|
|
|
left
|
|
|
|
|
intro w
|
|
|
|
|
left
|
|
|
|
|
rw [fderiv_sub (h₁ w) (h₂ w)]
|
|
|
|
|
funext w
|
|
|
|
|
simp
|
|
|
|
|
|
|
|
|
|
|
2024-08-08 12:36:06 +02:00
|
|
|
|
theorem partialDeriv_sub₂_differentiableAt
|
2024-05-31 09:21:35 +02:00
|
|
|
|
{f₁ f₂ : E → F}
|
|
|
|
|
{v : E}
|
|
|
|
|
{x : E}
|
|
|
|
|
(h₁ : DifferentiableAt 𝕜 f₁ x)
|
2024-05-31 16:06:42 +02:00
|
|
|
|
(h₂ : DifferentiableAt 𝕜 f₂ x) :
|
2024-08-08 12:36:06 +02:00
|
|
|
|
partialDeriv 𝕜 v (f₁ - f₂) x = (partialDeriv 𝕜 v f₁) x - (partialDeriv 𝕜 v f₂) x := by
|
2024-05-31 09:21:35 +02:00
|
|
|
|
|
|
|
|
|
unfold partialDeriv
|
2024-08-08 12:36:06 +02:00
|
|
|
|
have : f₁ - f₂ = fun y ↦ f₁ y - f₂ y := by rfl
|
2024-05-31 09:21:35 +02:00
|
|
|
|
rw [this]
|
2024-08-08 12:36:06 +02:00
|
|
|
|
rw [fderiv_sub h₁ h₂]
|
2024-06-04 12:30:25 +02:00
|
|
|
|
rfl
|
|
|
|
|
|
|
|
|
|
|
2024-08-08 12:36:06 +02:00
|
|
|
|
theorem partialDeriv_sub₂_contDiffAt
|
2024-06-04 12:30:25 +02:00
|
|
|
|
{f₁ f₂ : E → F}
|
|
|
|
|
{v : E}
|
|
|
|
|
{x : E}
|
2024-06-05 06:42:05 +02:00
|
|
|
|
(h₁ : ContDiffAt 𝕜 1 f₁ x)
|
|
|
|
|
(h₂ : ContDiffAt 𝕜 1 f₂ x) :
|
2024-08-08 12:36:06 +02:00
|
|
|
|
partialDeriv 𝕜 v (f₁ - f₂) =ᶠ[nhds x] (partialDeriv 𝕜 v f₁) - (partialDeriv 𝕜 v f₂) := by
|
2024-06-04 12:30:25 +02:00
|
|
|
|
|
2024-06-05 06:42:05 +02:00
|
|
|
|
obtain ⟨f₁', u₁, hu₁, _, hf₁'⟩ := contDiffAt_one_iff.1 h₁
|
|
|
|
|
obtain ⟨f₂', u₂, hu₂, _, hf₂'⟩ := contDiffAt_one_iff.1 h₂
|
2024-05-31 09:21:35 +02:00
|
|
|
|
|
2024-06-05 06:42:05 +02:00
|
|
|
|
apply Filter.eventuallyEq_iff_exists_mem.2
|
|
|
|
|
use u₁ ∩ u₂
|
|
|
|
|
constructor
|
|
|
|
|
· exact Filter.inter_mem hu₁ hu₂
|
|
|
|
|
· intro x hx
|
|
|
|
|
simp
|
2024-08-08 12:36:06 +02:00
|
|
|
|
apply partialDeriv_sub₂_differentiableAt 𝕜
|
2024-06-05 06:42:05 +02:00
|
|
|
|
exact (hf₁' x (Set.mem_of_mem_inter_left hx)).differentiableAt
|
|
|
|
|
exact (hf₂' x (Set.mem_of_mem_inter_right hx)).differentiableAt
|
|
|
|
|
|
2024-06-05 09:06:25 +02:00
|
|
|
|
|
|
|
|
|
theorem partialDeriv_compContLin
|
|
|
|
|
{f : E → F}
|
|
|
|
|
{l : F →L[𝕜] G}
|
|
|
|
|
{v : E}
|
|
|
|
|
(h : Differentiable 𝕜 f) :
|
2024-06-05 06:42:05 +02:00
|
|
|
|
partialDeriv 𝕜 v (l ∘ f) = l ∘ partialDeriv 𝕜 v f := by
|
2024-05-08 15:59:56 +02:00
|
|
|
|
unfold partialDeriv
|
2024-05-07 12:13:28 +02:00
|
|
|
|
|
|
|
|
|
conv =>
|
|
|
|
|
left
|
|
|
|
|
intro w
|
|
|
|
|
left
|
2024-11-12 13:14:11 +01:00
|
|
|
|
rw [fderiv_comp w (ContinuousLinearMap.differentiableAt l) (h w)]
|
2024-05-07 12:13:28 +02:00
|
|
|
|
simp
|
|
|
|
|
rfl
|
|
|
|
|
|
|
|
|
|
|
2024-05-29 16:33:32 +02:00
|
|
|
|
theorem partialDeriv_compContLinAt {f : E → F} {l : F →L[𝕜] G} {v : E} {x : E} (h : DifferentiableAt 𝕜 f x) : (partialDeriv 𝕜 v (l ∘ f)) x = (l ∘ partialDeriv 𝕜 v f) x:= by
|
|
|
|
|
unfold partialDeriv
|
2024-11-12 13:14:11 +01:00
|
|
|
|
rw [fderiv_comp x (ContinuousLinearMap.differentiableAt l) h]
|
2024-05-29 16:33:32 +02:00
|
|
|
|
simp
|
|
|
|
|
|
|
|
|
|
|
2024-05-31 16:06:42 +02:00
|
|
|
|
theorem partialDeriv_compCLE {f : E → F} {l : F ≃L[𝕜] G} {v : E} : partialDeriv 𝕜 v (l ∘ f) = l ∘ partialDeriv 𝕜 v f := by
|
|
|
|
|
funext x
|
|
|
|
|
by_cases hyp : DifferentiableAt 𝕜 f x
|
|
|
|
|
· let lCLM : F →L[𝕜] G := l
|
|
|
|
|
suffices shyp : partialDeriv 𝕜 v (lCLM ∘ f) x = (lCLM ∘ partialDeriv 𝕜 v f) x from by tauto
|
|
|
|
|
apply partialDeriv_compContLinAt
|
|
|
|
|
exact hyp
|
|
|
|
|
· unfold partialDeriv
|
|
|
|
|
rw [fderiv_zero_of_not_differentiableAt]
|
|
|
|
|
simp
|
|
|
|
|
rw [fderiv_zero_of_not_differentiableAt]
|
|
|
|
|
simp
|
|
|
|
|
exact hyp
|
|
|
|
|
rw [ContinuousLinearEquiv.comp_differentiableAt_iff]
|
|
|
|
|
exact hyp
|
|
|
|
|
|
|
|
|
|
|
2024-05-08 15:59:56 +02:00
|
|
|
|
theorem partialDeriv_contDiff {n : ℕ} {f : E → F} (h : ContDiff 𝕜 (n + 1) f) : ∀ v : E, ContDiff 𝕜 n (partialDeriv 𝕜 v f) := by
|
|
|
|
|
unfold partialDeriv
|
2024-05-07 09:49:56 +02:00
|
|
|
|
intro v
|
|
|
|
|
|
|
|
|
|
let A := (contDiff_succ_iff_fderiv.1 h).right
|
|
|
|
|
simp at A
|
|
|
|
|
|
2024-05-08 15:59:56 +02:00
|
|
|
|
have : (fun w => (fderiv 𝕜 f w) v) = (fun f => f v) ∘ (fun w => (fderiv 𝕜 f w)) := by
|
2024-05-07 09:49:56 +02:00
|
|
|
|
rfl
|
|
|
|
|
|
|
|
|
|
rw [this]
|
|
|
|
|
refine ContDiff.comp ?hg A
|
|
|
|
|
refine ContDiff.of_succ ?hg.h
|
|
|
|
|
refine ContDiff.clm_apply ?hg.h.hf ?hg.h.hg
|
|
|
|
|
exact contDiff_id
|
|
|
|
|
exact contDiff_const
|
2024-05-07 10:16:23 +02:00
|
|
|
|
|
|
|
|
|
|
2024-06-10 10:58:57 +02:00
|
|
|
|
theorem partialDeriv_contDiffAt
|
|
|
|
|
{n : ℕ}
|
|
|
|
|
{f : E → F}
|
|
|
|
|
{x : E}
|
|
|
|
|
(h : ContDiffAt 𝕜 (n + 1) f x) :
|
|
|
|
|
∀ v : E, ContDiffAt 𝕜 n (partialDeriv 𝕜 v f) x := by
|
2024-05-30 09:57:36 +02:00
|
|
|
|
|
2024-05-29 16:33:32 +02:00
|
|
|
|
unfold partialDeriv
|
|
|
|
|
intro v
|
|
|
|
|
|
2024-05-31 09:21:35 +02:00
|
|
|
|
let eval_at_v : (E →L[𝕜] F) →L[𝕜] F :=
|
2024-05-30 09:57:36 +02:00
|
|
|
|
{
|
|
|
|
|
toFun := fun l ↦ l v
|
|
|
|
|
map_add' := by simp
|
|
|
|
|
map_smul' := by simp
|
|
|
|
|
}
|
2024-05-29 16:33:32 +02:00
|
|
|
|
|
2024-05-30 09:57:36 +02:00
|
|
|
|
have : (fun w => (fderiv 𝕜 f w) v) = eval_at_v ∘ (fun w => (fderiv 𝕜 f w)) := by
|
2024-05-29 16:33:32 +02:00
|
|
|
|
rfl
|
|
|
|
|
rw [this]
|
|
|
|
|
|
2024-05-30 09:57:36 +02:00
|
|
|
|
apply ContDiffAt.continuousLinearMap_comp
|
|
|
|
|
-- ContDiffAt 𝕜 (↑n) (fun w => fderiv 𝕜 f w) x
|
|
|
|
|
apply ContDiffAt.fderiv_right h
|
|
|
|
|
rfl
|
2024-05-29 16:33:32 +02:00
|
|
|
|
|
|
|
|
|
|
2024-05-08 15:59:56 +02:00
|
|
|
|
lemma partialDeriv_fderiv {f : E → F} (hf : ContDiff 𝕜 2 f) (z a b : E) :
|
|
|
|
|
fderiv 𝕜 (fderiv 𝕜 f) z b a = partialDeriv 𝕜 b (partialDeriv 𝕜 a f) z := by
|
2024-05-07 12:13:28 +02:00
|
|
|
|
|
2024-05-08 15:59:56 +02:00
|
|
|
|
unfold partialDeriv
|
2024-05-07 10:16:23 +02:00
|
|
|
|
rw [fderiv_clm_apply]
|
|
|
|
|
· simp
|
2024-12-02 17:46:48 +01:00
|
|
|
|
· apply Differentiable.differentiableAt
|
|
|
|
|
rw [← one_add_one_eq_two] at hf
|
|
|
|
|
rw [contDiff_succ_iff_fderiv] at hf
|
|
|
|
|
apply hf.2.2.differentiable
|
|
|
|
|
simp
|
2024-05-07 10:16:23 +02:00
|
|
|
|
· simp
|
|
|
|
|
|
|
|
|
|
|
2024-06-03 12:56:30 +02:00
|
|
|
|
lemma partialDeriv_fderivOn
|
|
|
|
|
{s : Set E}
|
|
|
|
|
{f : E → F}
|
|
|
|
|
(hs : IsOpen s)
|
|
|
|
|
(hf : ContDiffOn 𝕜 2 f s) (a b : E) :
|
|
|
|
|
∀ z ∈ s, fderiv 𝕜 (fderiv 𝕜 f) z b a = partialDeriv 𝕜 b (partialDeriv 𝕜 a f) z := by
|
|
|
|
|
|
|
|
|
|
intro z hz
|
|
|
|
|
unfold partialDeriv
|
|
|
|
|
rw [fderiv_clm_apply]
|
|
|
|
|
· simp
|
|
|
|
|
· convert DifferentiableOn.differentiableAt _ (IsOpen.mem_nhds hs hz)
|
2024-09-09 06:50:28 +02:00
|
|
|
|
apply ContDiffOn.differentiableOn _ (Preorder.le_refl 1)
|
2024-12-02 17:46:48 +01:00
|
|
|
|
rw [← one_add_one_eq_two] at hf
|
|
|
|
|
rw [contDiffOn_succ_iff_fderiv_of_isOpen hs] at hf
|
|
|
|
|
exact hf.2.2
|
2024-06-03 12:56:30 +02:00
|
|
|
|
· simp
|
|
|
|
|
|
|
|
|
|
|
2024-06-05 16:31:55 +02:00
|
|
|
|
lemma partialDeriv_fderivAt
|
|
|
|
|
{z : E}
|
|
|
|
|
{f : E → F}
|
|
|
|
|
(hf : ContDiffAt 𝕜 2 f z)
|
|
|
|
|
(a b : E) :
|
|
|
|
|
fderiv 𝕜 (fderiv 𝕜 f) z b a = partialDeriv 𝕜 b (partialDeriv 𝕜 a f) z := by
|
|
|
|
|
|
|
|
|
|
unfold partialDeriv
|
|
|
|
|
rw [fderiv_clm_apply]
|
|
|
|
|
simp
|
|
|
|
|
|
|
|
|
|
-- DifferentiableAt 𝕜 (fun w => fderiv 𝕜 f w) z
|
|
|
|
|
obtain ⟨f', ⟨u, h₁u, h₂u⟩, hf' ⟩ := contDiffAt_succ_iff_hasFDerivAt.1 hf
|
|
|
|
|
have t₁ : (fun w ↦ fderiv 𝕜 f w) =ᶠ[nhds z] f' := by
|
|
|
|
|
apply Filter.eventuallyEq_iff_exists_mem.2
|
|
|
|
|
use u
|
|
|
|
|
constructor
|
|
|
|
|
· exact h₁u
|
|
|
|
|
· intro x hx
|
|
|
|
|
exact HasFDerivAt.fderiv (h₂u x hx)
|
|
|
|
|
rw [Filter.EventuallyEq.differentiableAt_iff t₁]
|
|
|
|
|
exact hf'.differentiableAt le_rfl
|
|
|
|
|
|
|
|
|
|
-- DifferentiableAt 𝕜 (fun w => a) z
|
|
|
|
|
exact differentiableAt_const a
|
|
|
|
|
|
|
|
|
|
|
2024-05-09 10:39:40 +02:00
|
|
|
|
section restrictScalars
|
|
|
|
|
|
2024-05-31 16:06:42 +02:00
|
|
|
|
theorem partialDeriv_smul'₂
|
|
|
|
|
(𝕜 : Type*) [NontriviallyNormedField 𝕜]
|
|
|
|
|
{𝕜' : Type*} [NontriviallyNormedField 𝕜'] [NormedAlgebra 𝕜 𝕜']
|
|
|
|
|
{E : Type*} [NormedAddCommGroup E] [NormedSpace 𝕜 E]
|
|
|
|
|
{F : Type*} [NormedAddCommGroup F] [NormedSpace 𝕜 F] [NormedSpace 𝕜' F]
|
|
|
|
|
[IsScalarTower 𝕜 𝕜' F]
|
|
|
|
|
{f : E → F} {a : 𝕜'} {v : E} :
|
|
|
|
|
partialDeriv 𝕜 v (a • f) = a • partialDeriv 𝕜 v f := by
|
|
|
|
|
|
|
|
|
|
funext w
|
|
|
|
|
by_cases ha : a = 0
|
|
|
|
|
· unfold partialDeriv
|
|
|
|
|
have : a • f = fun y ↦ a • f y := by rfl
|
|
|
|
|
rw [this, ha]
|
|
|
|
|
simp
|
|
|
|
|
· -- Now a is not zero. We present scalar multiplication with a as a continuous linear equivalence.
|
|
|
|
|
let smulCLM : F ≃L[𝕜] F :=
|
|
|
|
|
{
|
|
|
|
|
toFun := fun x ↦ a • x
|
|
|
|
|
map_add' := fun x y => DistribSMul.smul_add a x y
|
|
|
|
|
map_smul' := fun m x => (smul_comm ((RingHom.id 𝕜) m) a x).symm
|
|
|
|
|
invFun := fun x ↦ a⁻¹ • x
|
|
|
|
|
left_inv := by
|
|
|
|
|
intro x
|
|
|
|
|
simp
|
2024-08-23 09:26:58 +02:00
|
|
|
|
rw [← smul_assoc, smul_eq_mul, mul_comm, mul_inv_cancel₀ ha, one_smul]
|
2024-05-31 16:06:42 +02:00
|
|
|
|
right_inv := by
|
|
|
|
|
intro x
|
|
|
|
|
simp
|
2024-08-23 09:26:58 +02:00
|
|
|
|
rw [← smul_assoc, smul_eq_mul, mul_inv_cancel₀ ha, one_smul]
|
2024-05-31 16:06:42 +02:00
|
|
|
|
continuous_toFun := continuous_const_smul a
|
|
|
|
|
continuous_invFun := continuous_const_smul a⁻¹
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
have : a • f = smulCLM ∘ f := by tauto
|
|
|
|
|
rw [this]
|
|
|
|
|
rw [partialDeriv_compCLE]
|
|
|
|
|
tauto
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
theorem partialDeriv_restrictScalars
|
|
|
|
|
(𝕜 : Type*) [NontriviallyNormedField 𝕜]
|
|
|
|
|
{𝕜' : Type*} [NontriviallyNormedField 𝕜'] [NormedAlgebra 𝕜 𝕜']
|
|
|
|
|
{E : Type*} [NormedAddCommGroup E] [NormedSpace 𝕜 E] [NormedSpace 𝕜' E]
|
|
|
|
|
[IsScalarTower 𝕜 𝕜' E]
|
|
|
|
|
{F : Type*} [NormedAddCommGroup F] [NormedSpace 𝕜 F] [NormedSpace 𝕜' F]
|
|
|
|
|
[IsScalarTower 𝕜 𝕜' F]
|
|
|
|
|
{f : E → F} {v : E} :
|
2024-05-09 10:39:40 +02:00
|
|
|
|
Differentiable 𝕜' f → partialDeriv 𝕜 v f = partialDeriv 𝕜' v f := by
|
|
|
|
|
intro hf
|
|
|
|
|
unfold partialDeriv
|
|
|
|
|
funext x
|
|
|
|
|
rw [(hf x).fderiv_restrictScalars 𝕜]
|
|
|
|
|
simp
|
|
|
|
|
|
|
|
|
|
|
2024-05-08 15:59:56 +02:00
|
|
|
|
theorem partialDeriv_comm
|
|
|
|
|
{E : Type*} [NormedAddCommGroup E] [NormedSpace ℝ E]
|
|
|
|
|
{F : Type*} [NormedAddCommGroup F] [NormedSpace ℝ F]
|
|
|
|
|
{f : E → F} (h : ContDiff ℝ 2 f) :
|
|
|
|
|
∀ v₁ v₂ : E, partialDeriv ℝ v₁ (partialDeriv ℝ v₂ f) = partialDeriv ℝ v₂ (partialDeriv ℝ v₁ f) := by
|
2024-05-07 10:16:23 +02:00
|
|
|
|
|
|
|
|
|
intro v₁ v₂
|
|
|
|
|
funext z
|
|
|
|
|
|
2024-05-07 12:13:28 +02:00
|
|
|
|
have derivSymm :
|
|
|
|
|
(fderiv ℝ (fun w => fderiv ℝ f w) z) v₁ v₂ = (fderiv ℝ (fun w => fderiv ℝ f w) z) v₂ v₁ := by
|
2024-05-07 10:16:23 +02:00
|
|
|
|
|
2024-05-07 12:13:28 +02:00
|
|
|
|
let f' := fderiv ℝ f
|
|
|
|
|
have h₀ : ∀ y, HasFDerivAt f (f' y) y := by
|
|
|
|
|
intro y
|
|
|
|
|
exact DifferentiableAt.hasFDerivAt ((h.differentiable one_le_two) y)
|
2024-05-07 10:16:23 +02:00
|
|
|
|
|
2024-05-07 12:13:28 +02:00
|
|
|
|
let f'' := (fderiv ℝ f' z)
|
|
|
|
|
have h₁ : HasFDerivAt f' f'' z := by
|
|
|
|
|
apply DifferentiableAt.hasFDerivAt
|
2024-12-02 17:46:48 +01:00
|
|
|
|
rw [← one_add_one_eq_two] at h
|
|
|
|
|
apply (contDiff_succ_iff_fderiv.1 h).2.2.differentiable (Preorder.le_refl 1)
|
2024-05-07 12:13:28 +02:00
|
|
|
|
|
|
|
|
|
apply second_derivative_symmetric h₀ h₁ v₁ v₂
|
|
|
|
|
|
2024-05-08 15:59:56 +02:00
|
|
|
|
rw [← partialDeriv_fderiv ℝ h z v₂ v₁]
|
2024-05-07 12:13:28 +02:00
|
|
|
|
rw [derivSymm]
|
2024-05-08 15:59:56 +02:00
|
|
|
|
rw [partialDeriv_fderiv ℝ h z v₁ v₂]
|
2024-06-03 12:56:30 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
theorem partialDeriv_commOn
|
|
|
|
|
{E : Type*} [NormedAddCommGroup E] [NormedSpace ℝ E]
|
|
|
|
|
{F : Type*} [NormedAddCommGroup F] [NormedSpace ℝ F]
|
|
|
|
|
{s : Set E}
|
|
|
|
|
{f : E → F}
|
|
|
|
|
(hs : IsOpen s)
|
|
|
|
|
(h : ContDiffOn ℝ 2 f s) :
|
|
|
|
|
∀ v₁ v₂ : E, ∀ z ∈ s, partialDeriv ℝ v₁ (partialDeriv ℝ v₂ f) z = partialDeriv ℝ v₂ (partialDeriv ℝ v₁ f) z := by
|
|
|
|
|
|
|
|
|
|
intro v₁ v₂ z hz
|
|
|
|
|
|
|
|
|
|
have derivSymm :
|
|
|
|
|
(fderiv ℝ (fun w => fderiv ℝ f w) z) v₁ v₂ = (fderiv ℝ (fun w => fderiv ℝ f w) z) v₂ v₁ := by
|
|
|
|
|
|
|
|
|
|
let f' := fderiv ℝ f
|
2024-06-06 09:52:42 +02:00
|
|
|
|
have h₀1 : ∀ y ∈ s, HasFDerivAt f (f' y) y := by
|
2024-06-03 12:56:30 +02:00
|
|
|
|
intro y hy
|
|
|
|
|
apply DifferentiableAt.hasFDerivAt
|
|
|
|
|
apply DifferentiableOn.differentiableAt _ (IsOpen.mem_nhds hs hy)
|
|
|
|
|
apply h.differentiableOn one_le_two
|
|
|
|
|
|
|
|
|
|
let f'' := (fderiv ℝ f' z)
|
|
|
|
|
have h₁ : HasFDerivAt f' f'' z := by
|
|
|
|
|
apply DifferentiableAt.hasFDerivAt
|
|
|
|
|
apply DifferentiableOn.differentiableAt _ (IsOpen.mem_nhds hs hz)
|
2024-09-09 06:50:28 +02:00
|
|
|
|
apply ContDiffOn.differentiableOn _ (Preorder.le_refl 1)
|
2024-12-02 17:46:48 +01:00
|
|
|
|
rw [← one_add_one_eq_two] at h
|
|
|
|
|
exact ((contDiffOn_succ_iff_fderiv_of_isOpen hs).1 h).2.2
|
2024-06-03 12:56:30 +02:00
|
|
|
|
|
|
|
|
|
have h₀' : ∀ᶠ (y : E) in nhds z, HasFDerivAt f (f' y) y := by
|
|
|
|
|
apply eventually_nhds_iff.mpr
|
|
|
|
|
use s
|
|
|
|
|
|
|
|
|
|
exact second_derivative_symmetric_of_eventually h₀' h₁ v₁ v₂
|
|
|
|
|
|
|
|
|
|
rw [← partialDeriv_fderivOn ℝ hs h v₂ v₁ z hz]
|
|
|
|
|
rw [derivSymm]
|
|
|
|
|
rw [← partialDeriv_fderivOn ℝ hs h v₁ v₂ z hz]
|
2024-06-05 16:31:55 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
theorem partialDeriv_commAt
|
|
|
|
|
{E : Type*} [NormedAddCommGroup E] [NormedSpace ℝ E]
|
|
|
|
|
{F : Type*} [NormedAddCommGroup F] [NormedSpace ℝ F]
|
|
|
|
|
{z : E}
|
|
|
|
|
{f : E → F}
|
|
|
|
|
(h : ContDiffAt ℝ 2 f z) :
|
|
|
|
|
∀ v₁ v₂ : E, partialDeriv ℝ v₁ (partialDeriv ℝ v₂ f) z = partialDeriv ℝ v₂ (partialDeriv ℝ v₁ f) z := by
|
|
|
|
|
|
2024-12-02 17:46:48 +01:00
|
|
|
|
let A := h.contDiffOn le_rfl
|
|
|
|
|
simp at A
|
|
|
|
|
obtain ⟨u, hu₁, hu₂⟩ := A
|
2024-06-06 09:52:42 +02:00
|
|
|
|
obtain ⟨v, hv₁, hv₂, hv₃⟩ := mem_nhds_iff.1 hu₁
|
2024-06-05 16:31:55 +02:00
|
|
|
|
|
2024-06-06 09:52:42 +02:00
|
|
|
|
intro v₁ v₂
|
|
|
|
|
exact partialDeriv_commOn hv₂ (hu₂.mono hv₁) v₁ v₂ z hv₃
|