From b81147354d8393cf167a1477284a39ddfd6536e1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ya=C3=ABl=20Dillies?= Date: Tue, 12 Nov 2024 15:39:09 +0000 Subject: [PATCH] Bump mathlib --- LeanAPAP.lean | 5 +- .../Complex/CircleAddChar.lean | 39 --- LeanAPAP/Physics/AlmostPeriodicity.lean | 2 +- LeanAPAP/Prereqs/AddChar/Basic.lean | 79 ------ .../Prereqs/AddChar/PontryaginDuality.lean | 232 ------------------ LeanAPAP/Prereqs/Bohr/Arc.lean | 1 - LeanAPAP/Prereqs/Bohr/Basic.lean | 2 +- LeanAPAP/Prereqs/Convolution/Compact.lean | 2 +- .../Prereqs/Convolution/Discrete/Basic.lean | 2 +- .../Prereqs/Convolution/Discrete/Defs.lean | 4 +- LeanAPAP/Prereqs/Convolution/Norm.lean | 2 +- LeanAPAP/Prereqs/Energy.lean | 1 - .../Prereqs/FourierTransform/Convolution.lean | 2 +- .../Prereqs/FourierTransform/Discrete.lean | 5 +- LeanAPAP/Prereqs/Function/Dilate.lean | 16 ++ .../Prereqs/Function/Indicator/Basic.lean | 4 +- LeanAPAP/Prereqs/Function/Translate.lean | 83 ------- LeanAPAP/Prereqs/LpNorm/Compact.lean | 4 +- LeanAPAP/Prereqs/LpNorm/Discrete/Basic.lean | 4 +- LeanAPAP/Prereqs/LpNorm/Weighted.lean | 4 +- LeanAPAP/Prereqs/Randomisation.lean | 2 +- lake-manifest.json | 8 +- 22 files changed, 41 insertions(+), 462 deletions(-) delete mode 100644 LeanAPAP/Mathlib/Analysis/SpecialFunctions/Complex/CircleAddChar.lean delete mode 100644 LeanAPAP/Prereqs/AddChar/Basic.lean delete mode 100644 LeanAPAP/Prereqs/AddChar/PontryaginDuality.lean create mode 100644 LeanAPAP/Prereqs/Function/Dilate.lean delete mode 100644 LeanAPAP/Prereqs/Function/Translate.lean diff --git a/LeanAPAP.lean b/LeanAPAP.lean index 3bd7563418..9fe86fb1f7 100644 --- a/LeanAPAP.lean +++ b/LeanAPAP.lean @@ -1,7 +1,6 @@ import LeanAPAP.Extras.BSG import LeanAPAP.FiniteField import LeanAPAP.Integer -import LeanAPAP.Mathlib.Analysis.SpecialFunctions.Complex.CircleAddChar import LeanAPAP.Mathlib.MeasureTheory.Function.LpSeminorm.Basic import LeanAPAP.Mathlib.Probability.ConditionalProbability import LeanAPAP.Mathlib.Probability.UniformOn @@ -9,8 +8,6 @@ import LeanAPAP.Mathlib.Tactic.Positivity import LeanAPAP.Physics.AlmostPeriodicity import LeanAPAP.Physics.DRC import LeanAPAP.Physics.Unbalancing -import LeanAPAP.Prereqs.AddChar.Basic -import LeanAPAP.Prereqs.AddChar.PontryaginDuality import LeanAPAP.Prereqs.Bohr.Arc import LeanAPAP.Prereqs.Bohr.Basic import LeanAPAP.Prereqs.Bohr.Regular @@ -25,10 +22,10 @@ import LeanAPAP.Prereqs.Energy import LeanAPAP.Prereqs.FourierTransform.Compact import LeanAPAP.Prereqs.FourierTransform.Convolution import LeanAPAP.Prereqs.FourierTransform.Discrete +import LeanAPAP.Prereqs.Function.Dilate import LeanAPAP.Prereqs.Function.Indicator.Basic import LeanAPAP.Prereqs.Function.Indicator.Complex import LeanAPAP.Prereqs.Function.Indicator.Defs -import LeanAPAP.Prereqs.Function.Translate import LeanAPAP.Prereqs.Inner.Function import LeanAPAP.Prereqs.Inner.Hoelder.Compact import LeanAPAP.Prereqs.Inner.Hoelder.Discrete diff --git a/LeanAPAP/Mathlib/Analysis/SpecialFunctions/Complex/CircleAddChar.lean b/LeanAPAP/Mathlib/Analysis/SpecialFunctions/Complex/CircleAddChar.lean deleted file mode 100644 index c7d8182a2c..0000000000 --- a/LeanAPAP/Mathlib/Analysis/SpecialFunctions/Complex/CircleAddChar.lean +++ /dev/null @@ -1,39 +0,0 @@ -import Mathlib.Algebra.EuclideanDomain.Basic -import Mathlib.Algebra.EuclideanDomain.Field -import Mathlib.Analysis.SpecialFunctions.Complex.Circle - -open AddChar Multiplicative Real -open scoped ComplexConjugate Real - -namespace Circle -variable {r s : ℝ} - -noncomputable def e : AddChar ℝ Circle where - toFun r := exp (2 * π * r) - map_zero_eq_one' := by simp - map_add_eq_mul' := by simp [mul_add, Complex.exp_add] - -lemma e_apply (r : ℝ) : e r = exp (2 * π * r) := rfl - -@[simp, norm_cast] lemma coe_e (r : ℝ) : ↑(e r) = Complex.exp ((2 * π * r : ℝ) * Complex.I) := rfl - -@[simp] lemma e_int (z : ℤ) : e z = 1 := exp_two_pi_mul_int _ -@[simp] lemma e_one : e 1 = 1 := by simpa using e_int 1 -@[simp] lemma e_add_int {z : ℤ} : e (r + z) = e r := by rw [map_add_eq_mul, e_int, mul_one] -@[simp] lemma e_sub_int {z : ℤ} : e (r - z) = e r := by rw [map_sub_eq_div, e_int, div_one] -@[simp] lemma e_fract (r : ℝ) : e (Int.fract r) = e r := by rw [Int.fract, e_sub_int] - -@[simp] lemma e_mod_div {m : ℤ} {n : ℕ} : e ((m % n : ℤ) / n) = e (m / n) := by - obtain hn | hn := eq_or_ne (n : ℝ) 0 - · rw [hn, div_zero, div_zero] - · rw [Int.emod_def, Int.cast_sub, sub_div, Int.cast_mul, Int.cast_natCast, - mul_div_cancel_left₀ _ hn, e_sub_int] - -lemma e_eq_one : e r = 1 ↔ ∃ n : ℤ, r = n := by - simp [e_apply, exp_eq_one, mul_comm (2 * π), pi_ne_zero] - -lemma e_inj : e r = e s ↔ r ≡ s [PMOD 1] := by - simp [AddCommGroup.ModEq, ← e_eq_one, div_eq_one, map_sub_eq_div, eq_comm (b := 1), - eq_comm (a := e r)] - -end Circle diff --git a/LeanAPAP/Physics/AlmostPeriodicity.lean b/LeanAPAP/Physics/AlmostPeriodicity.lean index 8f8fdc9d79..54e7ff4d95 100644 --- a/LeanAPAP/Physics/AlmostPeriodicity.lean +++ b/LeanAPAP/Physics/AlmostPeriodicity.lean @@ -11,7 +11,7 @@ import LeanAPAP.Prereqs.MarcinkiewiczZygmund -/ open MeasureTheory -open scoped Pointwise Combinatorics.Additive +open scoped Pointwise Combinatorics.Additive translate namespace Finset variable {α : Type*} [DecidableEq α] {s : Finset α} {k : ℕ} diff --git a/LeanAPAP/Prereqs/AddChar/Basic.lean b/LeanAPAP/Prereqs/AddChar/Basic.lean deleted file mode 100644 index 1d4ae361a9..0000000000 --- a/LeanAPAP/Prereqs/AddChar/Basic.lean +++ /dev/null @@ -1,79 +0,0 @@ -import Mathlib.Algebra.BigOperators.Expect -import Mathlib.Algebra.Group.AddChar -import Mathlib.Analysis.RCLike.Inner - -open Finset hiding card -open Fintype (card) -open Function RCLike -open scoped BigOperators ComplexConjugate DirectSum - -variable {G H R : Type*} - -namespace AddChar -section AddGroup -variable [AddGroup G] - -section Semifield -variable [Fintype G] [Semifield R] [IsDomain R] [CharZero R] {ψ : AddChar G R} - -lemma expect_eq_ite (ψ : AddChar G R) : 𝔼 a, ψ a = if ψ = 0 then 1 else 0 := by - split_ifs with h - · simp [h, card_univ] - obtain ⟨x, hx⟩ := ne_one_iff.1 h - refine eq_zero_of_mul_eq_self_left hx ?_ - rw [Finset.mul_expect] - exact Fintype.expect_equiv (Equiv.addLeft x) _ _ fun y ↦ (map_add_eq_mul _ _ _).symm - -lemma expect_eq_zero_iff_ne_zero : 𝔼 x, ψ x = 0 ↔ ψ ≠ 0 := by - rw [expect_eq_ite, one_ne_zero.ite_eq_right_iff] - -lemma expect_ne_zero_iff_eq_zero : 𝔼 x, ψ x ≠ 0 ↔ ψ = 0 := expect_eq_zero_iff_ne_zero.not_left - -end Semifield - -section RCLike -variable [RCLike R] [Fintype G] - -lemma wInner_cWeight_self (ψ : AddChar G R) : ⟪(ψ : G → R), ψ⟫ₙ_[R] = 1 := by - simp [wInner_cWeight_eq_expect, ψ.norm_apply, RCLike.conj_mul] - -end RCLike -end AddGroup - -section AddCommGroup -variable [AddCommGroup G] - -section RCLike -variable [RCLike R] {ψ₁ ψ₂ : AddChar G R} - -lemma wInner_cWeight_eq_boole [Fintype G] (ψ₁ ψ₂ : AddChar G R) : - ⟪(ψ₁ : G → R), ψ₂⟫ₙ_[R] = if ψ₁ = ψ₂ then 1 else 0 := by - split_ifs with h - · rw [h, wInner_cWeight_self] - have : ψ₁⁻¹ * ψ₂ ≠ 1 := by rwa [Ne, inv_mul_eq_one] - simp_rw [wInner_cWeight_eq_expect, RCLike.inner_apply, ← inv_apply_eq_conj] - simpa [map_neg_eq_inv] using expect_eq_zero_iff_ne_zero.2 this - -lemma wInner_cWeight_eq_zero_iff_ne [Fintype G] : ⟪(ψ₁ : G → R), ψ₂⟫ₙ_[R] = 0 ↔ ψ₁ ≠ ψ₂ := by - rw [wInner_cWeight_eq_boole, one_ne_zero.ite_eq_right_iff] - -lemma wInner_cWeight_eq_one_iff_eq [Fintype G] : ⟪(ψ₁ : G → R), ψ₂⟫ₙ_[R] = 1 ↔ ψ₁ = ψ₂ := by - rw [wInner_cWeight_eq_boole, one_ne_zero.ite_eq_left_iff] - -variable (G R) - -protected lemma linearIndependent [Finite G] : LinearIndependent R ((⇑) : AddChar G R → G → R) := by - cases nonempty_fintype G - exact linearIndependent_of_ne_zero_of_wInner_cWeight_eq_zero AddChar.coe_ne_zero fun ψ₁ ψ₂ ↦ - wInner_cWeight_eq_zero_iff_ne.2 - -noncomputable instance instFintype [Finite G] : Fintype (AddChar G R) := - @Fintype.ofFinite _ (AddChar.linearIndependent G R).finite - -@[simp] lemma card_addChar_le [Fintype G] : card (AddChar G R) ≤ card G := by - simpa only [Module.finrank_fintype_fun_eq_card] using - (AddChar.linearIndependent G R).fintype_card_le_finrank - -end RCLike -end AddCommGroup -end AddChar diff --git a/LeanAPAP/Prereqs/AddChar/PontryaginDuality.lean b/LeanAPAP/Prereqs/AddChar/PontryaginDuality.lean deleted file mode 100644 index 2faf766cec..0000000000 --- a/LeanAPAP/Prereqs/AddChar/PontryaginDuality.lean +++ /dev/null @@ -1,232 +0,0 @@ -import Mathlib.Algebra.DirectSum.AddChar -import Mathlib.GroupTheory.FiniteAbelian.Basic -import LeanAPAP.Mathlib.Analysis.SpecialFunctions.Complex.CircleAddChar -import LeanAPAP.Prereqs.AddChar.Basic - -/-! -# Pontryagin duality for finite abelian groups - -This file proves the Pontryagin duality in case of finite abelian groups. This states that any -finite abelian group is canonically isomorphic to its double dual (the space of complex-valued -characters of its space of complex-valued characters). - -We first prove it for `ZMod n` and then extend to all finite abelian groups using the -Structure Theorem. --/ - -noncomputable section - -open Circle Finset Function Multiplicative -open Fintype (card) -open scoped BigOperators DirectSum - -variable {α : Type*} [AddCommGroup α] {n : ℕ} {a b : α} - -namespace AddChar - -private def zmodAuxAux (n : ℕ) : ℤ →+ Additive Circle where - toFun x := Additive.ofMul (e $ x / n) - map_zero' := by dsimp; rw [Int.cast_zero, zero_div, ofMul_eq_zero, map_zero_eq_one] - map_add' x y := by rw [← ofMul_mul, Equiv.apply_eq_iff_eq, Int.cast_add, add_div, map_add_eq_mul] - -@[simp] -lemma zmodAuxAux_apply (n : ℕ) (z : ℤ) : zmodAuxAux n z = Additive.ofMul (e $ z / n) := rfl - -/-- The character sending `k : ZMod n` to `e ^ (2 * π * i * k / n)`. -/ -private def zmodAux (n : ℕ) : AddChar (ZMod n) Circle := - AddChar.toAddMonoidHomEquiv.symm $ ZMod.lift n ⟨zmodAuxAux n, by - obtain hn | hn := eq_or_ne (n : ℝ) 0 <;> simp [hn, zmodAuxAux]⟩ - ---TODO: Heavily generalise. Yaël's attempts at generalising failed :( -@[simp] lemma aux (n : ℕ) (h) : - (⟨zmodAuxAux n, h⟩ : {f : ℤ →+ Additive Circle // f n = 0}) = zmodAuxAux n := rfl - -@[simp] lemma zmodAux_apply (n : ℕ) (z : ℤ) : zmodAux n z = e (z / n) := by simp [zmodAux] - --- probably an evil lemma --- @[simp] lemma zmodAux_apply (n : ℕ) (x : ZMod n) : zmodAux n x = e (x / n) := --- by simp [zmodAux] - -lemma zmodAux_injective (hn : n ≠ 0) : Injective (zmodAux n) := by - replace hn : (n : ℝ) ≠ 0 := Nat.cast_ne_zero.2 hn - simp [zmodAux, ZMod.lift_injective, CharP.intCast_eq_zero_iff _ n, e_eq_one, div_eq_iff hn, - mul_comm _ (n : ℝ), -forall_exists_index] - norm_cast - exact fun _ ↦ id - -/-- Indexing of the complex characters of `ZMod n`. `AddChar.zmod n x` is the character sending `y` -to `e ^ (2 * π * i * x * y / n)`. -/ -def zmod (n : ℕ) (x : ZMod n) : AddChar (ZMod n) Circle := - (zmodAux n).compAddMonoidHom $ AddMonoidHom.mulLeft x - -@[simp] lemma zmod_apply (n : ℕ) (x y : ℤ) : - (zmod n x) (y : ZMod n) = e (x * y / n) := by - simp [zmod, ← Int.cast_mul x y, -Int.cast_mul] - -@[simp] lemma zmod_zero (n : ℕ) : zmod n 0 = 1 := by - refine DFunLike.ext _ _ ?_ - rw [ZMod.intCast_surjective.forall] - rintro y - simpa using zmod_apply n 0 y - -@[simp] lemma zmod_add (n : ℕ) : ∀ x y : ZMod n, zmod n (x + y) = zmod n x * zmod n y := by - simp only [DFunLike.ext_iff, ZMod.intCast_surjective.forall, ← Int.cast_add, AddChar.mul_apply, - zmod_apply] - simp [add_mul, add_div, map_add_eq_mul] - --- probably an evil lemma --- @[simp] lemma zmod_apply (n : ℕ) (x y : ZMod n) : zmod n x y = e (x * y / n) := --- by simp [addChar.zmod, ZMod.coe_mul] - -lemma zmod_injective (hn : n ≠ 0) : Injective (zmod n) := by - simp_rw [Injective, ZMod.intCast_surjective.forall] - rintro x y h - replace hn : (n : ℝ) ≠ 0 := by positivity - simpa only [Int.cast_one, mul_one, one_mul, e_inj, AddCommGroup.div_modEq_div hn, - AddCommGroup.intCast_modEq_intCast', AddCommGroup.modEq_iff_int_modEq, - CharP.intCast_eq_intCast (ZMod n) n] using (zmod_apply _ _ _).symm.trans $ - (DFunLike.congr_fun h ((1 : ℤ) : ZMod n)).trans $ zmod_apply _ _ _ - -@[simp] lemma zmod_inj (hn : n ≠ 0) {x y : ZMod n} : zmod n x = zmod n y ↔ x = y := - (zmod_injective hn).eq_iff - -def zmodHom (n : ℕ) : AddChar (ZMod n) (AddChar (ZMod n) Circle) where - toFun := zmod n - map_zero_eq_one' := by simp - map_add_eq_mul' := by simp - -def mkZModAux {ι : Type} [DecidableEq ι] (n : ι → ℕ) (u : ∀ i, ZMod (n i)) : - AddChar (⨁ i, ZMod (n i)) Circle := - AddChar.directSum fun i ↦ zmod (n i) (u i) - -lemma mkZModAux_injective {ι : Type} [DecidableEq ι] {n : ι → ℕ} (hn : ∀ i, n i ≠ 0) : - Injective (mkZModAux n) := - AddChar.directSum_injective.comp fun f g h ↦ by simpa [funext_iff, hn] using h - -/-- The circle-valued characters of a finite abelian group are the same as its complex-valued -characters. -/ -def circleEquivComplex [Finite α] : AddChar α Circle ≃+ AddChar α ℂ where - toFun ψ := toMonoidHomEquiv.symm $ coeHom.comp ψ.toMonoidHom - invFun ψ := - { toFun := fun a ↦ (⟨ψ a, mem_sphere_zero_iff_norm.2 $ ψ.norm_apply _⟩ : Circle) - map_zero_eq_one' := by simp [Circle] - map_add_eq_mul' := fun a b ↦ by ext : 1; simp [map_add_eq_mul] } - left_inv ψ := by ext : 1; simp - right_inv ψ := by ext : 1; simp - map_add' ψ χ := rfl - -@[simp] lemma card_eq [Fintype α] : card (AddChar α ℂ) = card α := by - obtain ⟨ι, _, n, hn, ⟨e⟩⟩ := AddCommGroup.equiv_directSum_zmod_of_finite' α - classical - have hn' : ∀ i, n i ≠ 0 := fun i ↦ by have := hn i; positivity - let f : α → AddChar α ℂ := fun a ↦ coeHom.compAddChar ((mkZModAux n $ e a).compAddMonoidHom e) - have hf : Injective f := circleEquivComplex.injective.comp - ((compAddMonoidHom_injective_left _ e.surjective).comp $ (mkZModAux_injective hn').comp $ - DFunLike.coe_injective.comp $ e.injective.comp Additive.ofMul.injective) - exact (card_addChar_le _ _).antisymm (Fintype.card_le_of_injective _ hf) - -/-- `ZMod n` is (noncanonically) isomorphic to its group of characters. -/ -def zmodAddEquiv (hn : n ≠ 0) : ZMod n ≃+ AddChar (ZMod n) ℂ := by - haveI : NeZero n := ⟨hn⟩ - refine AddEquiv.ofBijective - (circleEquivComplex.toAddMonoidHom.comp $ AddChar.toAddMonoidHom $ zmodHom n) ?_ - rw [Fintype.bijective_iff_injective_and_card, card_eq] - exact ⟨circleEquivComplex.injective.comp $ zmod_injective hn, rfl⟩ - -@[simp] lemma zmodAddEquiv_apply [NeZero n] (x : ZMod n) : - zmodAddEquiv (NeZero.ne _) x = circleEquivComplex (zmod n x) := rfl - -section Finite -variable (α) [Finite α] - -/-- Complex-valued characters of a finite abelian group `α` form a basis of `α → ℂ`. -/ -def complexBasis : Basis (AddChar α ℂ) ℂ (α → ℂ) := - basisOfLinearIndependentOfCardEqFinrank (AddChar.linearIndependent _ _) $ by - cases nonempty_fintype α; rw [card_eq, Module.finrank_fintype_fun_eq_card] - -@[simp, norm_cast] -lemma coe_complexBasis : ⇑(complexBasis α) = ((⇑) : AddChar α ℂ → α → ℂ) := by - rw [complexBasis, coe_basisOfLinearIndependentOfCardEqFinrank] - -variable {α} - -@[simp] -lemma complexBasis_apply (ψ : AddChar α ℂ) : complexBasis α ψ = ψ := by rw [coe_complexBasis] - -lemma exists_apply_ne_zero : (∃ ψ : AddChar α ℂ, ψ a ≠ 1) ↔ a ≠ 0 := by - refine ⟨?_, fun ha ↦ ?_⟩ - · rintro ⟨ψ, hψ⟩ rfl - exact hψ ψ.map_zero_eq_one - classical - by_contra! h - let f : α → ℂ := fun b ↦ if a = b then 1 else 0 - have h₀ := congr_fun ((complexBasis α).sum_repr f) 0 - have h₁ := congr_fun ((complexBasis α).sum_repr f) a - simp only [complexBasis_apply, Fintype.sum_apply, Pi.smul_apply, h, smul_eq_mul, mul_one, - map_zero_eq_one, if_pos rfl, if_neg ha, f] at h₀ h₁ - exact one_ne_zero (h₁.symm.trans h₀) - -lemma forall_apply_eq_zero : (∀ ψ : AddChar α ℂ, ψ a = 1) ↔ a = 0 := by - simpa using exists_apply_ne_zero.not - -lemma doubleDualEmb_injective : Injective (doubleDualEmb : α → AddChar (AddChar α ℂ) ℂ) := - doubleDualEmb.ker_eq_bot_iff.1 $ eq_bot_iff.2 fun a ha ↦ - forall_apply_eq_zero.1 fun ψ ↦ by simpa using DFunLike.congr_fun ha (Additive.ofMul ψ) - -lemma doubleDualEmb_bijective : Bijective (doubleDualEmb : α → AddChar (AddChar α ℂ) ℂ) := by - cases nonempty_fintype α - exact (Fintype.bijective_iff_injective_and_card _).2 - ⟨doubleDualEmb_injective, card_eq.symm.trans card_eq.symm⟩ - -@[simp] -lemma doubleDualEmb_inj : (doubleDualEmb a : AddChar (AddChar α ℂ) ℂ) = doubleDualEmb b ↔ a = b := - doubleDualEmb_injective.eq_iff - -@[simp] lemma doubleDualEmb_eq_zero : (doubleDualEmb a : AddChar (AddChar α ℂ) ℂ) = 0 ↔ a = 0 := by - rw [← map_zero doubleDualEmb, doubleDualEmb_inj] - -lemma doubleDualEmb_ne_zero : (doubleDualEmb a : AddChar (AddChar α ℂ) ℂ) ≠ 0 ↔ a ≠ 0 := - doubleDualEmb_eq_zero.not - -/-- The double dual isomorphism. -/ -def doubleDualEquiv : α ≃+ AddChar (AddChar α ℂ) ℂ := - AddEquiv.ofBijective _ doubleDualEmb_bijective - -@[simp] -lemma coe_doubleDualEquiv : ⇑(doubleDualEquiv : α ≃+ AddChar (AddChar α ℂ) ℂ) = doubleDualEmb := rfl - -@[simp] lemma doubleDualEmb_doubleDualEquiv_symm_apply (a : AddChar (AddChar α ℂ) ℂ) : - doubleDualEmb (doubleDualEquiv.symm a) = a := - doubleDualEquiv.apply_symm_apply _ - -@[simp] lemma doubleDualEquiv_symm_doubleDualEmb_apply (a : AddChar (AddChar α ℂ) ℂ) : - doubleDualEquiv.symm (doubleDualEmb a) = a := doubleDualEquiv.symm_apply_apply _ - -end Finite - -lemma sum_apply_eq_ite [Fintype α] [DecidableEq α] (a : α) : - ∑ ψ : AddChar α ℂ, ψ a = if a = 0 then (Fintype.card α : ℂ) else 0 := by - simpa using sum_eq_ite (doubleDualEmb a : AddChar (AddChar α ℂ) ℂ) - -lemma expect_apply_eq_ite [Fintype α] [DecidableEq α] (a : α) : - 𝔼 ψ : AddChar α ℂ, ψ a = if a = 0 then 1 else 0 := by - simpa using expect_eq_ite (doubleDualEmb a : AddChar (AddChar α ℂ) ℂ) - -lemma sum_apply_eq_zero_iff_ne_zero [Finite α] : ∑ ψ : AddChar α ℂ, ψ a = 0 ↔ a ≠ 0 := by - classical - cases nonempty_fintype α - rw [sum_apply_eq_ite, Ne.ite_eq_right_iff] - exact Nat.cast_ne_zero.2 Fintype.card_ne_zero - -lemma sum_apply_ne_zero_iff_eq_zero [Finite α] : ∑ ψ : AddChar α ℂ, ψ a ≠ 0 ↔ a = 0 := - sum_apply_eq_zero_iff_ne_zero.not_left - -lemma expect_apply_eq_zero_iff_ne_zero [Finite α] : 𝔼 ψ : AddChar α ℂ, ψ a = 0 ↔ a ≠ 0 := by - classical - cases nonempty_fintype α - rw [expect_apply_eq_ite, one_ne_zero.ite_eq_right_iff] - -lemma expect_apply_ne_zero_iff_eq_zero [Finite α] : 𝔼 ψ : AddChar α ℂ, ψ a ≠ 0 ↔ a = 0 := - expect_apply_eq_zero_iff_ne_zero.not_left - -end AddChar diff --git a/LeanAPAP/Prereqs/Bohr/Arc.lean b/LeanAPAP/Prereqs/Bohr/Arc.lean index 411f70f308..f34f95884b 100644 --- a/LeanAPAP/Prereqs/Bohr/Arc.lean +++ b/LeanAPAP/Prereqs/Bohr/Arc.lean @@ -1,5 +1,4 @@ import Mathlib.Analysis.Complex.Angle -import LeanAPAP.Prereqs.AddChar.PontryaginDuality import LeanAPAP.Prereqs.Bohr.Basic /- ### Arc Bohr sets -/ diff --git a/LeanAPAP/Prereqs/Bohr/Basic.lean b/LeanAPAP/Prereqs/Bohr/Basic.lean index 9ee0f08479..7ca3a9adcb 100644 --- a/LeanAPAP/Prereqs/Bohr/Basic.lean +++ b/LeanAPAP/Prereqs/Bohr/Basic.lean @@ -1,5 +1,5 @@ import Mathlib.Analysis.Complex.Basic -import LeanAPAP.Prereqs.AddChar.PontryaginDuality +import Mathlib.Analysis.Fourier.FiniteAbelian.PontryaginDuality open AddChar Function open scoped NNReal ENNReal Finset diff --git a/LeanAPAP/Prereqs/Convolution/Compact.lean b/LeanAPAP/Prereqs/Convolution/Compact.lean index 025cf85d6c..d933e9645e 100644 --- a/LeanAPAP/Prereqs/Convolution/Compact.lean +++ b/LeanAPAP/Prereqs/Convolution/Compact.lean @@ -30,7 +30,7 @@ point in time. -/ open Finset Fintype Function -open scoped BigOperators ComplexConjugate NNReal Pointwise +open scoped BigOperators ComplexConjugate NNReal Pointwise translate local notation a " /ℚ " q => (q : ℚ≥0)⁻¹ • a diff --git a/LeanAPAP/Prereqs/Convolution/Discrete/Basic.lean b/LeanAPAP/Prereqs/Convolution/Discrete/Basic.lean index 1a343be73b..1f7c5e70ef 100644 --- a/LeanAPAP/Prereqs/Convolution/Discrete/Basic.lean +++ b/LeanAPAP/Prereqs/Convolution/Discrete/Basic.lean @@ -37,7 +37,7 @@ Multiplicativise? Probably ugly and not very useful. local notation:70 s:70 " ^^ " n:71 => Fintype.piFinset fun _ : Fin n ↦ s open Finset Fintype Function -open scoped BigOperators ComplexConjugate NNReal Pointwise +open scoped BigOperators ComplexConjugate NNReal Pointwise translate variable {G R γ : Type*} [Fintype G] [DecidableEq G] [AddCommGroup G] diff --git a/LeanAPAP/Prereqs/Convolution/Discrete/Defs.lean b/LeanAPAP/Prereqs/Convolution/Discrete/Defs.lean index 58c9e2baaa..e6b1e8cc8f 100644 --- a/LeanAPAP/Prereqs/Convolution/Discrete/Defs.lean +++ b/LeanAPAP/Prereqs/Convolution/Discrete/Defs.lean @@ -1,6 +1,6 @@ +import Mathlib.Algebra.Group.Translate import Mathlib.Algebra.Star.Conjneg import Mathlib.Analysis.Complex.Basic -import LeanAPAP.Prereqs.Function.Translate /-! # Convolution @@ -33,7 +33,7 @@ Multiplicativise? Probably ugly and not very useful. -/ open Finset Fintype Function -open scoped ComplexConjugate NNReal Pointwise NNRat +open scoped ComplexConjugate NNReal Pointwise translate variable {G H R S : Type*} [DecidableEq G] [AddCommGroup G] diff --git a/LeanAPAP/Prereqs/Convolution/Norm.lean b/LeanAPAP/Prereqs/Convolution/Norm.lean index fb96931636..b31507e7ef 100644 --- a/LeanAPAP/Prereqs/Convolution/Norm.lean +++ b/LeanAPAP/Prereqs/Convolution/Norm.lean @@ -12,7 +12,7 @@ convolution inequality. -/ open Finset Function MeasureTheory RCLike Real -open scoped ComplexConjugate ENNReal NNReal Pointwise +open scoped ComplexConjugate ENNReal NNReal Pointwise translate variable {ι 𝕜 : Type*} [Fintype ι] [DecidableEq ι] [AddCommGroup ι] diff --git a/LeanAPAP/Prereqs/Energy.lean b/LeanAPAP/Prereqs/Energy.lean index 4cab0bffed..5d4d108705 100644 --- a/LeanAPAP/Prereqs/Energy.lean +++ b/LeanAPAP/Prereqs/Energy.lean @@ -1,4 +1,3 @@ -import LeanAPAP.Prereqs.AddChar.Basic import LeanAPAP.Prereqs.Convolution.Discrete.Basic import LeanAPAP.Prereqs.FourierTransform.Discrete import LeanAPAP.Prereqs.Function.Indicator.Complex diff --git a/LeanAPAP/Prereqs/FourierTransform/Convolution.lean b/LeanAPAP/Prereqs/FourierTransform/Convolution.lean index e43e869a2a..6a8e05a191 100644 --- a/LeanAPAP/Prereqs/FourierTransform/Convolution.lean +++ b/LeanAPAP/Prereqs/FourierTransform/Convolution.lean @@ -1,4 +1,4 @@ -import LeanAPAP.Prereqs.AddChar.PontryaginDuality +import Mathlib.Analysis.Fourier.FiniteAbelian.PontryaginDuality import LeanAPAP.Prereqs.Convolution.Compact import LeanAPAP.Prereqs.Function.Indicator.Defs import LeanAPAP.Prereqs.Inner.Hoelder.Compact diff --git a/LeanAPAP/Prereqs/FourierTransform/Discrete.lean b/LeanAPAP/Prereqs/FourierTransform/Discrete.lean index 0a677f1897..e946e4dd6a 100644 --- a/LeanAPAP/Prereqs/FourierTransform/Discrete.lean +++ b/LeanAPAP/Prereqs/FourierTransform/Discrete.lean @@ -1,7 +1,8 @@ import Mathlib.Algebra.BigOperators.Balance +import Mathlib.Analysis.Fourier.FiniteAbelian.PontryaginDuality import Mathlib.MeasureTheory.Constructions.AddChar -import LeanAPAP.Prereqs.AddChar.PontryaginDuality import LeanAPAP.Prereqs.Convolution.Discrete.Defs +import LeanAPAP.Prereqs.Function.Dilate import LeanAPAP.Prereqs.Function.Indicator.Defs import LeanAPAP.Prereqs.Inner.Hoelder.Compact @@ -13,7 +14,7 @@ Fourier inversion formula for it. -/ open AddChar Finset Fintype Function MeasureTheory RCLike -open scoped BigOperators ComplexConjugate ComplexOrder +open scoped BigOperators ComplexConjugate ComplexOrder translate variable {α γ : Type*} [AddCommGroup α] [Fintype α] {f : α → ℂ} {ψ : AddChar α ℂ} {n : ℕ} diff --git a/LeanAPAP/Prereqs/Function/Dilate.lean b/LeanAPAP/Prereqs/Function/Dilate.lean new file mode 100644 index 0000000000..945fdd0dab --- /dev/null +++ b/LeanAPAP/Prereqs/Function/Dilate.lean @@ -0,0 +1,16 @@ +import Mathlib.Algebra.Star.SelfAdjoint +import Mathlib.Data.ZMod.Basic + +/-! +# Dilation operator +-/ + +variable {G 𝕜 : Type*} [AddCommGroup G] + +noncomputable def dilate (f : G → 𝕜) (n : ℕ) : G → 𝕜 := + fun a ↦ f ((n⁻¹ : ZMod (Nat.card G)).val • a) + +variable [Star 𝕜] {f : G → 𝕜} + +protected lemma IsSelfAdjoint.dilate (hf : IsSelfAdjoint f) (n : ℕ) : IsSelfAdjoint (dilate f n) := + Pi.isSelfAdjoint.2 fun _g ↦ hf.apply _ diff --git a/LeanAPAP/Prereqs/Function/Indicator/Basic.lean b/LeanAPAP/Prereqs/Function/Indicator/Basic.lean index 2807a8554e..0bb463372b 100644 --- a/LeanAPAP/Prereqs/Function/Indicator/Basic.lean +++ b/LeanAPAP/Prereqs/Function/Indicator/Basic.lean @@ -1,14 +1,14 @@ import Mathlib.Algebra.AddTorsor import Mathlib.Algebra.BigOperators.Expect +import Mathlib.Algebra.Group.Translate import Mathlib.Algebra.Star.Conjneg import Mathlib.Data.Fintype.Lattice import Mathlib.Data.NNRat.Order -import LeanAPAP.Prereqs.Function.Translate import LeanAPAP.Prereqs.Function.Indicator.Defs open Finset Function open Fintype (card) -open scoped BigOperators ComplexConjugate Pointwise +open scoped BigOperators ComplexConjugate Pointwise translate local notation a " /ℚ " q => (q : ℚ≥0)⁻¹ • a diff --git a/LeanAPAP/Prereqs/Function/Translate.lean b/LeanAPAP/Prereqs/Function/Translate.lean deleted file mode 100644 index d7f939aa0f..0000000000 --- a/LeanAPAP/Prereqs/Function/Translate.lean +++ /dev/null @@ -1,83 +0,0 @@ -import Mathlib.Algebra.BigOperators.Pi -import Mathlib.Algebra.Star.SelfAdjoint -import Mathlib.Data.ZMod.Basic - -/-! -# Precomposition operators --/ - -open Function Set -open scoped ComplexConjugate Pointwise - -/-! ### Translation operator -/ - -section translate -variable {ι α β γ : Type*} [AddCommGroup α] - -def translate (a : α) (f : α → β) : α → β := fun x ↦ f (x - a) - -notation "τ " => translate - -@[simp] lemma translate_apply (a : α) (f : α → β) (x : α) : τ a f x = f (x - a) := rfl -@[simp] lemma translate_zero (f : α → β) : τ 0 f = f := by ext; simp - -lemma translate_translate (a b : α) (f : α → β) : τ a (τ b f) = τ (a + b) f := by - ext; simp [sub_sub] - -lemma translate_add (a b : α) (f : α → β) : τ (a + b) f = τ a (τ b f) := by ext; simp [sub_sub] - -lemma translate_add' (a b : α) (f : α → β) : τ (a + b) f = τ b (τ a f) := by - rw [add_comm, translate_add] - -lemma translate_comm (a b : α) (f : α → β) : τ a (τ b f) = τ b (τ a f) := by - rw [← translate_add, translate_add'] - -@[simp] lemma comp_translate (a : α) (f : α → β) (g : β → γ) : g ∘ τ a f = τ a (g ∘ f) := rfl - -@[simp] -lemma translate_smul_right [SMul γ β] (a : α) (f : α → β) (c : γ) : τ a (c • f) = c • τ a f := rfl - -section AddCommMonoid -variable [AddCommMonoid β] - -@[simp] lemma translate_zero_right (a : α) : τ a (0 : α → β) = 0 := rfl - -lemma translate_add_right (a : α) (f g : α → β) : τ a (f + g) = τ a f + τ a g := rfl - -lemma translate_sum_right (a : α) (f : ι → α → β) (s : Finset ι) : - τ a (∑ i in s, f i) = ∑ i in s, τ a (f i) := by ext; simp - -lemma sum_translate [Fintype α] (a : α) (f : α → β) : ∑ b, τ a f b = ∑ b, f b := - Fintype.sum_equiv (Equiv.subRight _) _ _ fun _ ↦ rfl - -end AddCommMonoid - -section AddCommGroup -variable [AddCommGroup β] - -lemma translate_sub_right (a : α) (f g : α → β) : τ a (f - g) = τ a f - τ a g := rfl -lemma translate_neg_right (a : α) (f : α → β) : τ a (-f) = -τ a f := rfl - -@[simp] lemma support_translate (a : α) (f : α → β) : support (τ a f) = a +ᵥ support f := by - ext; simp [mem_vadd_set_iff_neg_vadd_mem, sub_eq_neg_add] - -end AddCommGroup - -variable [CommRing β] - -lemma translate_prod_right (a : α) (f : ι → α → β) (s : Finset ι) : - τ a (∏ i in s, f i) = ∏ i in s, τ a (f i) := by ext; simp - -end translate - -open Fintype - -variable {α β G 𝕜 : Type*} [AddCommGroup G] - -noncomputable def dilate (f : G → 𝕜) (n : ℕ) : G → 𝕜 := - fun a ↦ f ((n⁻¹ : ZMod (Nat.card G)).val • a) - -variable [Star 𝕜] {f : G → 𝕜} - -protected lemma IsSelfAdjoint.dilate (hf : IsSelfAdjoint f) (n : ℕ) : IsSelfAdjoint (dilate f n) := - Pi.isSelfAdjoint.2 fun _g ↦ hf.apply _ diff --git a/LeanAPAP/Prereqs/LpNorm/Compact.lean b/LeanAPAP/Prereqs/LpNorm/Compact.lean index 84641d613b..72f3f79f60 100644 --- a/LeanAPAP/Prereqs/LpNorm/Compact.lean +++ b/LeanAPAP/Prereqs/LpNorm/Compact.lean @@ -1,7 +1,7 @@ +import Mathlib.Algebra.Group.Translate import Mathlib.Algebra.Star.Conjneg import Mathlib.Data.Fintype.Order import LeanAPAP.Prereqs.Function.Indicator.Defs -import LeanAPAP.Prereqs.Function.Translate import LeanAPAP.Prereqs.NNLpNorm /-! @@ -11,7 +11,7 @@ import LeanAPAP.Prereqs.NNLpNorm open Finset hiding card open Function ProbabilityTheory Real open Fintype (card) -open scoped BigOperators ComplexConjugate ENNReal NNReal +open scoped BigOperators ComplexConjugate ENNReal NNReal translate local notation:70 s:70 " ^^ " n:71 => Fintype.piFinset fun _ : Fin n ↦ s diff --git a/LeanAPAP/Prereqs/LpNorm/Discrete/Basic.lean b/LeanAPAP/Prereqs/LpNorm/Discrete/Basic.lean index 610ebb43c4..4537d151f2 100644 --- a/LeanAPAP/Prereqs/LpNorm/Discrete/Basic.lean +++ b/LeanAPAP/Prereqs/LpNorm/Discrete/Basic.lean @@ -1,6 +1,6 @@ +import Mathlib.Algebra.Group.Translate import Mathlib.Algebra.Star.Conjneg import LeanAPAP.Prereqs.Function.Indicator.Defs -import LeanAPAP.Prereqs.Function.Translate import LeanAPAP.Prereqs.LpNorm.Discrete.Defs /-! @@ -8,7 +8,7 @@ import LeanAPAP.Prereqs.LpNorm.Discrete.Defs -/ open Finset Function Real -open scoped BigOperators ComplexConjugate ENNReal NNReal +open scoped BigOperators ComplexConjugate ENNReal NNReal translate namespace MeasureTheory variable {ι G 𝕜 E R : Type*} [Fintype ι] {mι : MeasurableSpace ι} [DiscreteMeasurableSpace ι] diff --git a/LeanAPAP/Prereqs/LpNorm/Weighted.lean b/LeanAPAP/Prereqs/LpNorm/Weighted.lean index ab6de63804..6a039f90df 100644 --- a/LeanAPAP/Prereqs/LpNorm/Weighted.lean +++ b/LeanAPAP/Prereqs/LpNorm/Weighted.lean @@ -1,5 +1,5 @@ +import Mathlib.Algebra.Group.Translate import Mathlib.Algebra.Star.Conjneg -import LeanAPAP.Prereqs.Function.Translate import LeanAPAP.Prereqs.LpNorm.Discrete.Defs /-! @@ -7,7 +7,7 @@ import LeanAPAP.Prereqs.LpNorm.Discrete.Defs -/ open Finset Function Real MeasureTheory -open scoped ComplexConjugate ENNReal NNReal +open scoped ComplexConjugate ENNReal NNReal translate variable {α 𝕜 E : Type*} [MeasurableSpace α] diff --git a/LeanAPAP/Prereqs/Randomisation.lean b/LeanAPAP/Prereqs/Randomisation.lean index a5a24e469d..2677f2e9a6 100644 --- a/LeanAPAP/Prereqs/Randomisation.lean +++ b/LeanAPAP/Prereqs/Randomisation.lean @@ -1,5 +1,5 @@ +import Mathlib.Analysis.Fourier.FiniteAbelian.Orthogonality import Mathlib.Combinatorics.Additive.Dissociation -import LeanAPAP.Prereqs.AddChar.Basic /-! # Randomisation diff --git a/lake-manifest.json b/lake-manifest.json index 633613a339..5a339de0ac 100644 --- a/lake-manifest.json +++ b/lake-manifest.json @@ -5,7 +5,7 @@ "type": "git", "subDir": null, "scope": "leanprover-community", - "rev": "af731107d531b39cd7278c73f91c573f40340612", + "rev": "1bfaec42a7481a81e7e12565442bd1f8dc202ae2", "name": "batteries", "manifestFile": "lake-manifest.json", "inputRev": "main", @@ -55,7 +55,7 @@ "type": "git", "subDir": null, "scope": "leanprover-community", - "rev": "ac7b989cbf99169509433124ae484318e953d201", + "rev": "b0b73e5bc33f1bc4d3c0f254630dd0e262cecc08", "name": "importGraph", "manifestFile": "lake-manifest.json", "inputRev": "main", @@ -85,7 +85,7 @@ "type": "git", "subDir": null, "scope": "", - "rev": "62a2cc31bac6416736c17a57383a622c208f21cb", + "rev": "b00c9dba4d70ab0ba583936391d41c5d5df86681", "name": "mathlib", "manifestFile": "lake-manifest.json", "inputRev": null, @@ -125,7 +125,7 @@ "type": "git", "subDir": null, "scope": "", - "rev": "e18c6c23dd7cb1f12d79d6304262351df943aa37", + "rev": "6e6a825641f66cbb5ed12bc0e8513e9768e1ff0a", "name": "«doc-gen4»", "manifestFile": "lake-manifest.json", "inputRev": "main",