2024-04-17 14:25:17 -04:00
|
|
|
|
/-
|
|
|
|
|
Copyright (c) 2024 Joseph Tooby-Smith. All rights reserved.
|
|
|
|
|
Released under Apache 2.0 license.
|
|
|
|
|
Authors: Joseph Tooby-Smith
|
|
|
|
|
-/
|
|
|
|
|
import HepLean.AnomalyCancellation.SM.Basic
|
|
|
|
|
/-!
|
|
|
|
|
# Family maps for the Standard Model ACCs
|
|
|
|
|
|
2024-05-20 00:19:30 +02:00
|
|
|
|
We define the a series of maps between the charges for different numbers of families.
|
2024-04-17 14:25:17 -04:00
|
|
|
|
|
|
|
|
|
-/
|
|
|
|
|
|
|
|
|
|
universe v u
|
|
|
|
|
|
|
|
|
|
namespace SM
|
|
|
|
|
open SMCharges
|
|
|
|
|
open SMACCs
|
|
|
|
|
open BigOperators
|
|
|
|
|
|
|
|
|
|
/-- Given a map of for a generic species, the corresponding map for charges. -/
|
|
|
|
|
@[simps!]
|
2024-06-26 11:54:02 -04:00
|
|
|
|
def chargesMapOfSpeciesMap {n m : ℕ} (f : (SMSpecies n).Charges →ₗ[ℚ] (SMSpecies m).Charges) :
|
|
|
|
|
(SMCharges n).Charges →ₗ[ℚ] (SMCharges m).Charges where
|
2024-04-17 14:25:17 -04:00
|
|
|
|
toFun S := toSpeciesEquiv.symm (fun i => (LinearMap.comp f (toSpecies i)) S)
|
|
|
|
|
map_add' S T := by
|
|
|
|
|
rw [charges_eq_toSpecies_eq]
|
|
|
|
|
intro i
|
|
|
|
|
rw [map_add]
|
|
|
|
|
rw [toSMSpecies_toSpecies_inv, toSMSpecies_toSpecies_inv, toSMSpecies_toSpecies_inv]
|
|
|
|
|
rw [map_add]
|
|
|
|
|
map_smul' a S := by
|
|
|
|
|
rw [charges_eq_toSpecies_eq]
|
|
|
|
|
intro i
|
|
|
|
|
rw [map_smul]
|
|
|
|
|
rw [toSMSpecies_toSpecies_inv, toSMSpecies_toSpecies_inv]
|
|
|
|
|
rw [map_smul]
|
|
|
|
|
rfl
|
|
|
|
|
|
|
|
|
|
/-- The projection of the `m`-family charges onto the first `n`-family charges for species. -/
|
|
|
|
|
@[simps!]
|
|
|
|
|
def speciesFamilyProj {m n : ℕ} (h : n ≤ m) :
|
2024-06-26 11:54:02 -04:00
|
|
|
|
(SMSpecies m).Charges →ₗ[ℚ] (SMSpecies n).Charges where
|
2024-04-17 14:25:17 -04:00
|
|
|
|
toFun S := S ∘ Fin.castLE h
|
|
|
|
|
map_add' S T := by
|
|
|
|
|
funext i
|
|
|
|
|
simp
|
|
|
|
|
map_smul' a S := by
|
|
|
|
|
funext i
|
|
|
|
|
simp [HSMul.hSMul]
|
|
|
|
|
--rw [show Rat.cast a = a from rfl]
|
|
|
|
|
|
|
|
|
|
/-- The projection of the `m`-family charges onto the first `n`-family charges. -/
|
2024-06-26 11:54:02 -04:00
|
|
|
|
def familyProjection {m n : ℕ} (h : n ≤ m) : (SMCharges m).Charges →ₗ[ℚ] (SMCharges n).Charges :=
|
2024-04-17 14:25:17 -04:00
|
|
|
|
chargesMapOfSpeciesMap (speciesFamilyProj h)
|
|
|
|
|
|
|
|
|
|
/-- For species, the embedding of the `m`-family charges onto the `n`-family charges, with all
|
|
|
|
|
other charges zero. -/
|
|
|
|
|
@[simps!]
|
|
|
|
|
def speciesEmbed (m n : ℕ) :
|
2024-06-26 11:54:02 -04:00
|
|
|
|
(SMSpecies m).Charges →ₗ[ℚ] (SMSpecies n).Charges where
|
2024-04-17 14:25:17 -04:00
|
|
|
|
toFun S := fun i =>
|
|
|
|
|
if hi : i.val < m then
|
|
|
|
|
S ⟨i, hi⟩
|
|
|
|
|
else
|
|
|
|
|
0
|
|
|
|
|
map_add' S T := by
|
|
|
|
|
funext i
|
2024-04-17 14:49:59 -04:00
|
|
|
|
simp only [SMSpecies_numberCharges, ACCSystemCharges.chargesAddCommMonoid_add]
|
2024-04-17 14:25:17 -04:00
|
|
|
|
by_cases hi : i.val < m
|
|
|
|
|
erw [dif_pos hi, dif_pos hi, dif_pos hi]
|
|
|
|
|
erw [dif_neg hi, dif_neg hi, dif_neg hi]
|
|
|
|
|
rfl
|
|
|
|
|
map_smul' a S := by
|
|
|
|
|
funext i
|
|
|
|
|
simp [HSMul.hSMul]
|
|
|
|
|
by_cases hi : i.val < m
|
|
|
|
|
erw [dif_pos hi, dif_pos hi]
|
|
|
|
|
erw [dif_neg hi, dif_neg hi]
|
|
|
|
|
simp
|
|
|
|
|
|
|
|
|
|
/-- The embedding of the `m`-family charges onto the `n`-family charges, with all
|
|
|
|
|
other charges zero. -/
|
2024-06-26 11:54:02 -04:00
|
|
|
|
def familyEmbedding (m n : ℕ) : (SMCharges m).Charges →ₗ[ℚ] (SMCharges n).Charges :=
|
2024-04-17 14:25:17 -04:00
|
|
|
|
chargesMapOfSpeciesMap (speciesEmbed m n)
|
|
|
|
|
|
2024-05-20 00:19:30 +02:00
|
|
|
|
/-- For species, the embedding of the `1`-family charges into the `n`-family charges in
|
2024-04-17 14:25:17 -04:00
|
|
|
|
a universal manor. -/
|
|
|
|
|
@[simps!]
|
|
|
|
|
def speciesFamilyUniversial (n : ℕ) :
|
2024-06-26 11:54:02 -04:00
|
|
|
|
(SMSpecies 1).Charges →ₗ[ℚ] (SMSpecies n).Charges where
|
2024-04-17 14:25:17 -04:00
|
|
|
|
toFun S _ := S ⟨0, by simp⟩
|
|
|
|
|
map_add' S T := by
|
|
|
|
|
funext _
|
|
|
|
|
simp
|
|
|
|
|
map_smul' a S := by
|
|
|
|
|
funext i
|
|
|
|
|
simp [HSMul.hSMul]
|
|
|
|
|
--rw [show Rat.cast a = a from rfl]
|
|
|
|
|
|
2024-05-20 00:19:30 +02:00
|
|
|
|
/-- The embedding of the `1`-family charges into the `n`-family charges in
|
2024-04-17 14:25:17 -04:00
|
|
|
|
a universal manor. -/
|
2024-06-26 11:54:02 -04:00
|
|
|
|
def familyUniversal ( n : ℕ) : (SMCharges 1).Charges →ₗ[ℚ] (SMCharges n).Charges :=
|
2024-04-17 14:25:17 -04:00
|
|
|
|
chargesMapOfSpeciesMap (speciesFamilyUniversial n)
|
|
|
|
|
|
|
|
|
|
end SM
|