2024-07-29 08:38:01 -04:00
|
|
|
|
/-
|
|
|
|
|
Copyright (c) 2024 Joseph Tooby-Smith. All rights reserved.
|
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
|
Authors: Joseph Tooby-Smith
|
|
|
|
|
-/
|
2024-07-30 16:07:16 -04:00
|
|
|
|
import HepLean.SpaceTime.LorentzTensor.MulActionTensor
|
2024-07-29 08:38:01 -04:00
|
|
|
|
/-!
|
|
|
|
|
|
|
|
|
|
# Contraction of indices
|
|
|
|
|
|
2024-07-29 16:54:59 -04:00
|
|
|
|
We define a number of ways to contract indices of tensors:
|
|
|
|
|
|
|
|
|
|
- `contrDualLeft`: Contracts vectors on the left as:
|
|
|
|
|
`𝓣.ColorModule ν ⊗[R] 𝓣.ColorModule (𝓣.τ ν) ⊗[R] 𝓣.ColorModule η →ₗ[R] 𝓣.ColorModule η`
|
|
|
|
|
|
|
|
|
|
- `contrDualMid`: Contracts vectors in the middle as:
|
|
|
|
|
`(𝓣.ColorModule μ ⊗[R] 𝓣.ColorModule ν) ⊗[R] (𝓣.ColorModule (𝓣.τ ν) ⊗[R] 𝓣.ColorModule η) →ₗ[R]`
|
|
|
|
|
`𝓣.ColorModule μ ⊗[R] 𝓣.ColorModule η`
|
|
|
|
|
|
|
|
|
|
- `contrAll'`: Contracts all indices of manifestly tensors with manifestly dual colors as:
|
|
|
|
|
`𝓣.Tensor cX ⊗[R] 𝓣.Tensor (𝓣.τ ∘ cX) →ₗ[R] R`
|
|
|
|
|
|
|
|
|
|
- `contrAll`: Contracts all indices of tensors with dual colors as:
|
|
|
|
|
`𝓣.Tensor cX ⊗[R] 𝓣.Tensor cY →ₗ[R] R`
|
|
|
|
|
|
|
|
|
|
- `contrAllLeft`: Contracts all indices of tensors on the left as:
|
|
|
|
|
`𝓣.Tensor cX ⊗[R] 𝓣.Tensor cY ⊗[R] 𝓣.Tensor cZ →ₗ[R] 𝓣.Tensor cZ`
|
|
|
|
|
|
|
|
|
|
- `contrElim`: Contracting indices of tensors indexed by `Sum.elim _ _` as:
|
|
|
|
|
`𝓣.Tensor (Sum.elim cW cX) ⊗[R] 𝓣.Tensor (Sum.elim cY cZ) →ₗ[R] 𝓣.Tensor (Sum.elim cW cZ)`
|
|
|
|
|
|
2024-07-29 08:38:01 -04:00
|
|
|
|
-/
|
2024-07-30 16:07:16 -04:00
|
|
|
|
|
|
|
|
|
/-! TODO: Define contraction based on an equivalence `(C ⊗ C) ⊗ P ≃ X` satisfying ... . -/
|
|
|
|
|
|
2024-07-29 08:38:01 -04:00
|
|
|
|
noncomputable section
|
|
|
|
|
|
|
|
|
|
open TensorProduct
|
2024-07-30 16:07:16 -04:00
|
|
|
|
open MulActionTensor
|
2024-07-29 08:38:01 -04:00
|
|
|
|
|
|
|
|
|
variable {R : Type} [CommSemiring R]
|
|
|
|
|
|
|
|
|
|
namespace TensorStructure
|
|
|
|
|
|
|
|
|
|
variable (𝓣 : TensorStructure R)
|
|
|
|
|
|
2024-07-30 16:07:16 -04:00
|
|
|
|
variable {d : ℕ} {X Y Y' Z W C P : Type} [Fintype X] [DecidableEq X] [Fintype Y] [DecidableEq Y]
|
2024-07-29 08:38:01 -04:00
|
|
|
|
[Fintype Y'] [DecidableEq Y'] [Fintype Z] [DecidableEq Z] [Fintype W] [DecidableEq W]
|
2024-07-30 16:07:16 -04:00
|
|
|
|
[Fintype C] [DecidableEq C] [Fintype P] [DecidableEq P]
|
2024-07-29 08:38:01 -04:00
|
|
|
|
{cX cX2 : X → 𝓣.Color} {cY : Y → 𝓣.Color} {cZ : Z → 𝓣.Color}
|
|
|
|
|
{cW : W → 𝓣.Color} {cY' : Y' → 𝓣.Color} {μ ν: 𝓣.Color}
|
|
|
|
|
|
2024-07-30 16:07:16 -04:00
|
|
|
|
variable {G H : Type} [Group G] [Group H] [MulActionTensor G 𝓣]
|
|
|
|
|
local infixl:101 " • " => 𝓣.rep
|
2024-07-29 16:54:59 -04:00
|
|
|
|
/-!
|
|
|
|
|
|
|
|
|
|
# Contractions of vectors
|
|
|
|
|
|
|
|
|
|
-/
|
|
|
|
|
|
2024-07-29 08:38:01 -04:00
|
|
|
|
/-- The contraction of a vector in `𝓣.ColorModule ν` with a vector in
|
|
|
|
|
`𝓣.ColorModule (𝓣.τ ν) ⊗[R] 𝓣.ColorModule η` to form a vector in `𝓣.ColorModule η`. -/
|
2024-07-29 16:54:59 -04:00
|
|
|
|
def contrDualLeft {ν η : 𝓣.Color} :
|
2024-07-29 08:38:01 -04:00
|
|
|
|
𝓣.ColorModule ν ⊗[R] 𝓣.ColorModule (𝓣.τ ν) ⊗[R] 𝓣.ColorModule η →ₗ[R] 𝓣.ColorModule η :=
|
2024-07-30 16:07:16 -04:00
|
|
|
|
contrLeftAux (𝓣.contrDual ν)
|
2024-07-29 16:54:59 -04:00
|
|
|
|
|
2024-07-29 08:38:01 -04:00
|
|
|
|
/-- The contraction of a vector in `𝓣.ColorModule μ ⊗[R] 𝓣.ColorModule ν` with a vector in
|
|
|
|
|
`𝓣.ColorModule (𝓣.τ ν) ⊗[R] 𝓣.ColorModule η` to form a vector in
|
|
|
|
|
`𝓣.ColorModule μ ⊗[R] 𝓣.ColorModule η`. -/
|
2024-07-29 16:54:59 -04:00
|
|
|
|
def contrDualMid {μ ν η : 𝓣.Color} :
|
2024-07-29 08:38:01 -04:00
|
|
|
|
(𝓣.ColorModule μ ⊗[R] 𝓣.ColorModule ν) ⊗[R] (𝓣.ColorModule (𝓣.τ ν) ⊗[R] 𝓣.ColorModule η) →ₗ[R]
|
|
|
|
|
𝓣.ColorModule μ ⊗[R] 𝓣.ColorModule η :=
|
2024-07-30 16:07:16 -04:00
|
|
|
|
contrMidAux (𝓣.contrDual ν)
|
2024-07-29 08:38:01 -04:00
|
|
|
|
|
|
|
|
|
/-- A linear map taking tensors mapped with the same index set to the product of paired tensors. -/
|
|
|
|
|
def pairProd : 𝓣.Tensor cX ⊗[R] 𝓣.Tensor cX2 →ₗ[R]
|
|
|
|
|
⨂[R] x, 𝓣.ColorModule (cX x) ⊗[R] 𝓣.ColorModule (cX2 x) :=
|
|
|
|
|
TensorProduct.lift (
|
|
|
|
|
PiTensorProduct.map₂ (fun x =>
|
|
|
|
|
TensorProduct.mk R (𝓣.ColorModule (cX x)) (𝓣.ColorModule (cX2 x))))
|
|
|
|
|
|
|
|
|
|
lemma mkPiAlgebra_equiv (e : X ≃ Y) :
|
|
|
|
|
(PiTensorProduct.lift (MultilinearMap.mkPiAlgebra R X R)) =
|
|
|
|
|
(PiTensorProduct.lift (MultilinearMap.mkPiAlgebra R Y R)) ∘ₗ
|
|
|
|
|
(PiTensorProduct.reindex R _ e).toLinearMap := by
|
|
|
|
|
apply PiTensorProduct.ext
|
|
|
|
|
apply MultilinearMap.ext
|
|
|
|
|
intro x
|
|
|
|
|
simp only [LinearMap.compMultilinearMap_apply, PiTensorProduct.lift.tprod,
|
|
|
|
|
MultilinearMap.mkPiAlgebra_apply, LinearMap.coe_comp, LinearEquiv.coe_coe, Function.comp_apply,
|
|
|
|
|
PiTensorProduct.reindex_tprod, Equiv.prod_comp]
|
|
|
|
|
|
|
|
|
|
/-- Given a tensor in `𝓣.Tensor cX` and a tensor in `𝓣.Tensor (𝓣.τ ∘ cX)`, the element of
|
|
|
|
|
`R` formed by contracting all of their indices. -/
|
|
|
|
|
def contrAll' : 𝓣.Tensor cX ⊗[R] 𝓣.Tensor (𝓣.τ ∘ cX) →ₗ[R] R :=
|
|
|
|
|
(PiTensorProduct.lift (MultilinearMap.mkPiAlgebra R X R)) ∘ₗ
|
|
|
|
|
(PiTensorProduct.map (fun x => 𝓣.contrDual (cX x))) ∘ₗ
|
|
|
|
|
(𝓣.pairProd)
|
|
|
|
|
|
|
|
|
|
lemma contrAll'_mapIso_cond {e : X ≃ Y} (h : cX = cY ∘ e) :
|
|
|
|
|
𝓣.τ ∘ cY = (𝓣.τ ∘ cX) ∘ ⇑e.symm := by
|
|
|
|
|
subst h
|
|
|
|
|
exact (Equiv.eq_comp_symm e (𝓣.τ ∘ cY) (𝓣.τ ∘ cY ∘ ⇑e)).mpr rfl
|
|
|
|
|
|
|
|
|
|
@[simp]
|
|
|
|
|
lemma contrAll'_mapIso (e : X ≃ Y) (h : c = cY ∘ e) :
|
|
|
|
|
𝓣.contrAll' ∘ₗ
|
|
|
|
|
(TensorProduct.congr (𝓣.mapIso e h) (LinearEquiv.refl R _)).toLinearMap =
|
|
|
|
|
𝓣.contrAll' ∘ₗ (TensorProduct.congr (LinearEquiv.refl R _)
|
|
|
|
|
(𝓣.mapIso e.symm (𝓣.contrAll'_mapIso_cond h))).toLinearMap := by
|
|
|
|
|
apply TensorProduct.ext'
|
|
|
|
|
refine fun x ↦
|
|
|
|
|
PiTensorProduct.induction_on' x ?_ (by
|
|
|
|
|
intro a b hx hy y
|
|
|
|
|
simp [map_add, add_tmul, hx, hy])
|
|
|
|
|
intro rx fx
|
|
|
|
|
refine fun y ↦
|
|
|
|
|
PiTensorProduct.induction_on' y ?_ (by
|
|
|
|
|
intro a b hx hy
|
|
|
|
|
simp at hx hy
|
|
|
|
|
simp [map_add, tmul_add, hx, hy])
|
|
|
|
|
intro ry fy
|
|
|
|
|
simp [contrAll']
|
|
|
|
|
rw [mkPiAlgebra_equiv e]
|
|
|
|
|
apply congrArg
|
|
|
|
|
simp only [LinearMap.coe_comp, LinearEquiv.coe_coe, Function.comp_apply]
|
|
|
|
|
apply congrArg
|
|
|
|
|
rw [← LinearEquiv.symm_apply_eq]
|
|
|
|
|
rw [PiTensorProduct.reindex_symm]
|
|
|
|
|
rw [← PiTensorProduct.map_reindex]
|
|
|
|
|
subst h
|
|
|
|
|
simp only [Equiv.symm_symm_apply, Function.comp_apply]
|
|
|
|
|
apply congrArg
|
|
|
|
|
rw [pairProd, pairProd]
|
|
|
|
|
simp only [Function.comp_apply, lift.tmul, LinearMapClass.map_smul, LinearMap.smul_apply]
|
|
|
|
|
apply congrArg
|
|
|
|
|
change _ = ((PiTensorProduct.map₂ fun x => TensorProduct.mk R (𝓣.ColorModule (cY (e x)))
|
|
|
|
|
(𝓣.ColorModule (𝓣.τ (cY (e x)))))
|
|
|
|
|
((PiTensorProduct.tprod R) fx))
|
|
|
|
|
((𝓣.mapIso e.symm _) ((PiTensorProduct.tprod R) fy))
|
|
|
|
|
rw [mapIso_tprod]
|
|
|
|
|
simp only [Equiv.symm_symm_apply, Function.comp_apply]
|
|
|
|
|
rw [PiTensorProduct.map₂_tprod_tprod]
|
|
|
|
|
change PiTensorProduct.reindex R _ e.symm
|
|
|
|
|
((PiTensorProduct.map₂ _
|
|
|
|
|
((PiTensorProduct.tprod R) fun i => (𝓣.colorModuleCast _) (fx (e.symm i))))
|
|
|
|
|
((PiTensorProduct.tprod R) fy)) = _
|
|
|
|
|
rw [PiTensorProduct.map₂_tprod_tprod]
|
|
|
|
|
simp only [Equiv.symm_symm_apply, Function.comp_apply, mk_apply]
|
|
|
|
|
erw [PiTensorProduct.reindex_tprod]
|
|
|
|
|
apply congrArg
|
|
|
|
|
funext i
|
|
|
|
|
simp only [Equiv.symm_symm_apply]
|
|
|
|
|
congr
|
|
|
|
|
simp [colorModuleCast]
|
|
|
|
|
apply cast_eq_iff_heq.mpr
|
|
|
|
|
rw [Equiv.symm_apply_apply]
|
|
|
|
|
|
|
|
|
|
@[simp]
|
|
|
|
|
lemma contrAll'_mapIso_tmul (e : X ≃ Y) (h : c = cY ∘ e) (x : 𝓣.Tensor c)
|
|
|
|
|
(y : 𝓣.Tensor (𝓣.τ ∘ cY)) : 𝓣.contrAll' ((𝓣.mapIso e h) x ⊗ₜ[R] y) =
|
|
|
|
|
𝓣.contrAll' (x ⊗ₜ[R] (𝓣.mapIso e.symm (𝓣.contrAll'_mapIso_cond h) y)) := by
|
|
|
|
|
change (𝓣.contrAll' ∘ₗ
|
|
|
|
|
(TensorProduct.congr (𝓣.mapIso e h) (LinearEquiv.refl R _)).toLinearMap) (x ⊗ₜ[R] y) = _
|
|
|
|
|
rw [contrAll'_mapIso]
|
|
|
|
|
rfl
|
|
|
|
|
|
|
|
|
|
/-- The contraction of all the indices of two tensors with dual colors. -/
|
2024-07-29 16:54:59 -04:00
|
|
|
|
def contrAll (e : X ≃ Y) (h : cX = 𝓣.τ ∘ cY ∘ e) : 𝓣.Tensor cX ⊗[R] 𝓣.Tensor cY →ₗ[R] R :=
|
2024-07-29 08:38:01 -04:00
|
|
|
|
𝓣.contrAll' ∘ₗ (TensorProduct.congr (LinearEquiv.refl _ _)
|
|
|
|
|
(𝓣.mapIso e.symm (by funext a; simpa [h] using (𝓣.τ_involutive _).symm))).toLinearMap
|
|
|
|
|
|
|
|
|
|
lemma contrAll_symm_cond {e : X ≃ Y} (h : c = 𝓣.τ ∘ cY ∘ e) :
|
|
|
|
|
cY = 𝓣.τ ∘ c ∘ ⇑e.symm := by
|
|
|
|
|
subst h
|
|
|
|
|
ext1 x
|
|
|
|
|
simp only [Function.comp_apply, Equiv.apply_symm_apply]
|
|
|
|
|
rw [𝓣.τ_involutive]
|
|
|
|
|
|
|
|
|
|
lemma contrAll_mapIso_right_cond {e : X ≃ Y} {e' : Z ≃ Y}
|
|
|
|
|
(h : c = 𝓣.τ ∘ cY ∘ e) (h' : cZ = cY ∘ e') : c = 𝓣.τ ∘ cZ ∘ ⇑(e.trans e'.symm) := by
|
|
|
|
|
subst h h'
|
|
|
|
|
ext1 x
|
|
|
|
|
simp only [Function.comp_apply, Equiv.coe_trans, Equiv.apply_symm_apply]
|
|
|
|
|
|
|
|
|
|
@[simp]
|
|
|
|
|
lemma contrAll_mapIso_right_tmul (e : X ≃ Y) (e' : Z ≃ Y)
|
|
|
|
|
(h : c = 𝓣.τ ∘ cY ∘ e) (h' : cZ = cY ∘ e') (x : 𝓣.Tensor c) (z : 𝓣.Tensor cZ) :
|
|
|
|
|
𝓣.contrAll e h (x ⊗ₜ[R] 𝓣.mapIso e' h' z) =
|
|
|
|
|
𝓣.contrAll (e.trans e'.symm) (𝓣.contrAll_mapIso_right_cond h h') (x ⊗ₜ[R] z) := by
|
|
|
|
|
rw [contrAll, contrAll]
|
|
|
|
|
simp only [LinearMap.coe_comp, LinearEquiv.coe_coe, Function.comp_apply, congr_tmul,
|
|
|
|
|
LinearEquiv.refl_apply, mapIso_mapIso]
|
|
|
|
|
congr
|
|
|
|
|
|
|
|
|
|
@[simp]
|
|
|
|
|
lemma contrAll_comp_mapIso_right (e : X ≃ Y) (e' : Z ≃ Y)
|
|
|
|
|
(h : c = 𝓣.τ ∘ cY ∘ e) (h' : cZ = cY ∘ e') : 𝓣.contrAll e h ∘ₗ
|
|
|
|
|
(TensorProduct.congr (LinearEquiv.refl R (𝓣.Tensor c)) (𝓣.mapIso e' h')).toLinearMap
|
|
|
|
|
= 𝓣.contrAll (e.trans e'.symm) (𝓣.contrAll_mapIso_right_cond h h') := by
|
|
|
|
|
apply TensorProduct.ext'
|
|
|
|
|
intro x y
|
|
|
|
|
exact 𝓣.contrAll_mapIso_right_tmul e e' h h' x y
|
|
|
|
|
|
|
|
|
|
lemma contrAll_mapIso_left_cond {e : X ≃ Y} {e' : Z ≃ X}
|
|
|
|
|
(h : c = 𝓣.τ ∘ cY ∘ e) (h' : cZ = c ∘ e') : cZ = 𝓣.τ ∘ cY ∘ ⇑(e'.trans e) := by
|
|
|
|
|
subst h h'
|
|
|
|
|
ext1 x
|
|
|
|
|
simp only [Function.comp_apply, Equiv.coe_trans, Equiv.apply_symm_apply]
|
|
|
|
|
|
|
|
|
|
@[simp]
|
|
|
|
|
lemma contrAll_mapIso_left_tmul {e : X ≃ Y} {e' : Z ≃ X}
|
|
|
|
|
(h : c = 𝓣.τ ∘ cY ∘ e) (h' : cZ = c ∘ e') (x : 𝓣.Tensor cZ) (y : 𝓣.Tensor cY) :
|
|
|
|
|
𝓣.contrAll e h (𝓣.mapIso e' h' x ⊗ₜ[R] y) =
|
|
|
|
|
𝓣.contrAll (e'.trans e) (𝓣.contrAll_mapIso_left_cond h h') (x ⊗ₜ[R] y) := by
|
|
|
|
|
rw [contrAll, contrAll]
|
|
|
|
|
simp only [LinearMap.coe_comp, LinearEquiv.coe_coe, Function.comp_apply, congr_tmul,
|
|
|
|
|
LinearEquiv.refl_apply, contrAll'_mapIso_tmul, mapIso_mapIso]
|
|
|
|
|
congr
|
|
|
|
|
|
|
|
|
|
@[simp]
|
|
|
|
|
lemma contrAll_mapIso_left {e : X ≃ Y} {e' : Z ≃ X}
|
|
|
|
|
(h : c = 𝓣.τ ∘ cY ∘ e) (h' : cZ = c ∘ e') :
|
|
|
|
|
𝓣.contrAll e h ∘ₗ
|
|
|
|
|
(TensorProduct.congr (𝓣.mapIso e' h') (LinearEquiv.refl R (𝓣.Tensor cY))).toLinearMap
|
|
|
|
|
= 𝓣.contrAll (e'.trans e) (𝓣.contrAll_mapIso_left_cond h h') := by
|
|
|
|
|
apply TensorProduct.ext'
|
|
|
|
|
intro x y
|
|
|
|
|
exact 𝓣.contrAll_mapIso_left_tmul h h' x y
|
|
|
|
|
|
2024-07-29 16:54:59 -04:00
|
|
|
|
/-- The linear map from `𝓣.Tensor cX ⊗[R] 𝓣.Tensor cY ⊗[R] 𝓣.Tensor cZ` to
|
|
|
|
|
`𝓣.Tensor cZ` obtained by contracting all indices in `𝓣.Tensor cX` and `𝓣.Tensor cY`,
|
|
|
|
|
given a proof that this is possible. -/
|
|
|
|
|
def contrAllLeft (e : X ≃ Y) (h : cX = 𝓣.τ ∘ cY ∘ e) :
|
|
|
|
|
𝓣.Tensor cX ⊗[R] 𝓣.Tensor cY ⊗[R] 𝓣.Tensor cZ →ₗ[R] 𝓣.Tensor cZ :=
|
|
|
|
|
(TensorProduct.lid R _).toLinearMap ∘ₗ
|
|
|
|
|
TensorProduct.map (𝓣.contrAll e h) (LinearEquiv.refl R (𝓣.Tensor cZ)).toLinearMap
|
|
|
|
|
∘ₗ (TensorProduct.assoc R _ _ _).symm.toLinearMap
|
|
|
|
|
|
|
|
|
|
/-- The linear map from `(𝓣.Tensor cW ⊗[R] 𝓣.Tensor cX) ⊗[R] (𝓣.Tensor cY ⊗[R] 𝓣.Tensor cZ)`
|
|
|
|
|
to `𝓣.Tensor cW ⊗[R] 𝓣.Tensor cZ` obtained by contracting all indices of the tensors
|
|
|
|
|
in the middle. -/
|
|
|
|
|
def contrAllMid (e : X ≃ Y) (h : cX = 𝓣.τ ∘ cY ∘ e) :
|
|
|
|
|
(𝓣.Tensor cW ⊗[R] 𝓣.Tensor cX) ⊗[R] (𝓣.Tensor cY ⊗[R] 𝓣.Tensor cZ) →ₗ[R]
|
|
|
|
|
𝓣.Tensor cW ⊗[R] 𝓣.Tensor cZ :=
|
|
|
|
|
(TensorProduct.map (LinearEquiv.refl R _).toLinearMap (𝓣.contrAllLeft e h)) ∘ₗ
|
|
|
|
|
(TensorProduct.assoc R _ _ _).toLinearMap
|
|
|
|
|
|
|
|
|
|
/-- The linear map from `𝓣.Tensor (Sum.elim cW cX) ⊗[R] 𝓣.Tensor (Sum.elim cY cZ)`
|
|
|
|
|
to `𝓣.Tensor (Sum.elim cW cZ)` formed by contracting the indices specified by
|
|
|
|
|
`cX` and `cY`, which are assumed to be dual. -/
|
|
|
|
|
def contrElim (e : X ≃ Y) (h : cX = 𝓣.τ ∘ cY ∘ e) :
|
|
|
|
|
𝓣.Tensor (Sum.elim cW cX) ⊗[R] 𝓣.Tensor (Sum.elim cY cZ) →ₗ[R] 𝓣.Tensor (Sum.elim cW cZ) :=
|
|
|
|
|
(𝓣.tensoratorEquiv cW cZ).toLinearMap ∘ₗ 𝓣.contrAllMid e h ∘ₗ
|
|
|
|
|
(TensorProduct.congr (𝓣.tensoratorEquiv cW cX).symm
|
|
|
|
|
(𝓣.tensoratorEquiv cY cZ).symm).toLinearMap
|
|
|
|
|
|
2024-07-30 16:07:16 -04:00
|
|
|
|
/-!
|
|
|
|
|
|
|
|
|
|
## Group acting on contraction
|
|
|
|
|
|
|
|
|
|
-/
|
|
|
|
|
|
|
|
|
|
@[simp]
|
|
|
|
|
lemma contrAll_rep {c : X → 𝓣.Color} {d : Y → 𝓣.Color} (e : X ≃ Y) (h : c = 𝓣.τ ∘ d ∘ e) (g : G) :
|
|
|
|
|
𝓣.contrAll e h ∘ₗ (TensorProduct.map (𝓣.rep g) (𝓣.rep g)) = 𝓣.contrAll e h := by
|
|
|
|
|
apply TensorProduct.ext'
|
|
|
|
|
refine fun x ↦ PiTensorProduct.induction_on' x ?_ (by
|
|
|
|
|
intro a b hx hy y
|
|
|
|
|
simp [map_add, add_tmul, hx, hy])
|
|
|
|
|
intro rx fx
|
|
|
|
|
refine fun y ↦ PiTensorProduct.induction_on' y ?_ (by
|
|
|
|
|
intro a b hx hy
|
|
|
|
|
simp at hx hy
|
|
|
|
|
simp [map_add, tmul_add, hx, hy])
|
|
|
|
|
intro ry fy
|
|
|
|
|
simp [contrAll, TensorProduct.smul_tmul]
|
|
|
|
|
apply congrArg
|
|
|
|
|
apply congrArg
|
|
|
|
|
simp [contrAll']
|
|
|
|
|
apply congrArg
|
|
|
|
|
simp [pairProd]
|
|
|
|
|
change (PiTensorProduct.map _) ((PiTensorProduct.map₂ _ _) _) =
|
|
|
|
|
(PiTensorProduct.map _) ((PiTensorProduct.map₂ _ _) _)
|
|
|
|
|
rw [PiTensorProduct.map₂_tprod_tprod, PiTensorProduct.map₂_tprod_tprod, PiTensorProduct.map_tprod,
|
|
|
|
|
PiTensorProduct.map_tprod]
|
|
|
|
|
simp only [mk_apply]
|
|
|
|
|
apply congrArg
|
|
|
|
|
funext x
|
2024-07-31 07:29:59 -04:00
|
|
|
|
rw [← colorModuleCast_equivariant_apply]
|
2024-07-30 16:07:16 -04:00
|
|
|
|
nth_rewrite 2 [← contrDual_inv (c x) g]
|
2024-07-31 07:29:59 -04:00
|
|
|
|
simp
|
2024-07-30 16:07:16 -04:00
|
|
|
|
|
|
|
|
|
@[simp]
|
|
|
|
|
lemma contrAll_rep_apply {c : X → 𝓣.Color} {d : Y → 𝓣.Color} (e : X ≃ Y) (h : c = 𝓣.τ ∘ d ∘ e)
|
|
|
|
|
(g : G) (x : 𝓣.Tensor c ⊗ 𝓣.Tensor d) :
|
|
|
|
|
𝓣.contrAll e h (TensorProduct.map (𝓣.rep g) (𝓣.rep g) x) = 𝓣.contrAll e h x := by
|
|
|
|
|
change (𝓣.contrAll e h ∘ₗ (TensorProduct.map (𝓣.rep g) (𝓣.rep g))) x = _
|
|
|
|
|
rw [contrAll_rep]
|
|
|
|
|
|
|
|
|
|
@[simp]
|
|
|
|
|
lemma contrAll_rep_tmul {c : X → 𝓣.Color} {d : Y → 𝓣.Color} (e : X ≃ Y) (h : c = 𝓣.τ ∘ d ∘ e)
|
|
|
|
|
(g : G) (x : 𝓣.Tensor c) (y : 𝓣.Tensor d) :
|
|
|
|
|
𝓣.contrAll e h ((g • x) ⊗ₜ[R] (g • y)) = 𝓣.contrAll e h (x ⊗ₜ[R] y) := by
|
|
|
|
|
nth_rewrite 2 [← @contrAll_rep_apply R _ 𝓣 _ _ _ G]
|
|
|
|
|
rfl
|
|
|
|
|
|
|
|
|
|
/-!
|
|
|
|
|
|
|
|
|
|
## Contraction based on specification
|
|
|
|
|
|
|
|
|
|
-/
|
|
|
|
|
|
|
|
|
|
lemma contr_cond (e : (C ⊕ C) ⊕ P ≃ X) :
|
|
|
|
|
cX = Sum.elim (Sum.elim (cX ∘ ⇑e ∘ Sum.inl ∘ Sum.inl) (cX ∘ ⇑e ∘ Sum.inl ∘ Sum.inr)) (
|
|
|
|
|
cX ∘ ⇑e ∘ Sum.inr) ∘ ⇑e.symm := by
|
|
|
|
|
rw [Equiv.eq_comp_symm]
|
|
|
|
|
funext x
|
|
|
|
|
match x with
|
|
|
|
|
| Sum.inl (Sum.inl x) => rfl
|
|
|
|
|
| Sum.inl (Sum.inr x) => rfl
|
|
|
|
|
| Sum.inr x => rfl
|
|
|
|
|
|
|
|
|
|
/-- Contraction of indices based on an equivalence `(C ⊕ C) ⊕ P ≃ X`. The indices
|
|
|
|
|
in `C` are contracted pair-wise, whilst the indices in `P` are preserved. -/
|
|
|
|
|
def contr (e : (C ⊕ C) ⊕ P ≃ X)
|
|
|
|
|
(h : cX ∘ e ∘ Sum.inl ∘ Sum.inl = 𝓣.τ ∘ cX ∘ e ∘ Sum.inl ∘ Sum.inr) :
|
|
|
|
|
𝓣.Tensor cX →ₗ[R] 𝓣.Tensor (cX ∘ e ∘ Sum.inr) :=
|
|
|
|
|
(TensorProduct.lid R _).toLinearMap ∘ₗ
|
|
|
|
|
(TensorProduct.map (𝓣.contrAll (Equiv.refl C) (by simpa using h)) LinearMap.id) ∘ₗ
|
|
|
|
|
(TensorProduct.congr (𝓣.tensoratorEquiv _ _).symm (LinearEquiv.refl R _)).toLinearMap ∘ₗ
|
|
|
|
|
(𝓣.tensoratorEquiv _ _).symm.toLinearMap ∘ₗ
|
|
|
|
|
(𝓣.mapIso e.symm (𝓣.contr_cond e)).toLinearMap
|
|
|
|
|
|
|
|
|
|
/-- The contraction of indices via `contr` is equivariant. -/
|
|
|
|
|
@[simp]
|
|
|
|
|
lemma contr_equivariant (e : (C ⊕ C) ⊕ P ≃ X)
|
|
|
|
|
(h : cX ∘ e ∘ Sum.inl ∘ Sum.inl = 𝓣.τ ∘ cX ∘ e ∘ Sum.inl ∘ Sum.inr)
|
|
|
|
|
(g : G) (x : 𝓣.Tensor cX) : 𝓣.contr e h (g • x) = g • 𝓣.contr e h x := by
|
|
|
|
|
simp only [contr, TensorProduct.congr, LinearEquiv.refl_toLinearMap, LinearEquiv.symm_symm,
|
|
|
|
|
LinearEquiv.refl_symm, LinearEquiv.ofLinear_toLinearMap, LinearEquiv.comp_coe,
|
|
|
|
|
LinearMap.coe_comp, LinearEquiv.coe_coe, Function.comp_apply, LinearEquiv.trans_apply,
|
|
|
|
|
rep_mapIso_apply, rep_tensoratorEquiv_symm_apply]
|
|
|
|
|
rw [← LinearMap.comp_apply (TensorProduct.map _ _), ← TensorProduct.map_comp]
|
|
|
|
|
rw [← LinearMap.comp_apply (TensorProduct.map _ _), ← TensorProduct.map_comp]
|
|
|
|
|
rw [LinearMap.comp_assoc, rep_tensoratorEquiv_symm, ← LinearMap.comp_assoc]
|
|
|
|
|
simp only [contrAll_rep, LinearMap.comp_id, LinearMap.id_comp]
|
|
|
|
|
have h1 {M N A B : Type} [AddCommMonoid M] [AddCommMonoid N]
|
|
|
|
|
[AddCommMonoid A] [AddCommMonoid B] [Module R M] [Module R N] [Module R A] [Module R B]
|
2024-07-30 16:31:38 -04:00
|
|
|
|
(f : M →ₗ[R] N) (g : A →ₗ[R] B) : TensorProduct.map f g
|
2024-07-30 16:07:16 -04:00
|
|
|
|
= TensorProduct.map (LinearMap.id) g ∘ₗ TensorProduct.map f (LinearMap.id) :=
|
|
|
|
|
ext rfl
|
|
|
|
|
rw [h1]
|
|
|
|
|
simp only [LinearMap.coe_comp, Function.comp_apply, rep_lid_apply]
|
|
|
|
|
rw [← LinearMap.comp_apply (TensorProduct.map _ _), ← TensorProduct.map_comp]
|
|
|
|
|
rfl
|
|
|
|
|
|
2024-07-29 08:38:01 -04:00
|
|
|
|
end TensorStructure
|