2024-04-17 14:25:17 -04:00
|
|
|
|
/-
|
|
|
|
|
Copyright (c) 2024 Joseph Tooby-Smith. All rights reserved.
|
2024-07-12 16:39:44 -04:00
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
2024-04-17 14:25:17 -04:00
|
|
|
|
Authors: Joseph Tooby-Smith
|
|
|
|
|
-/
|
|
|
|
|
import HepLean.AnomalyCancellation.SM.Basic
|
|
|
|
|
import HepLean.AnomalyCancellation.SM.NoGrav.Basic
|
|
|
|
|
import Mathlib.Tactic.FieldSimp
|
|
|
|
|
import Mathlib.Tactic.Linarith
|
|
|
|
|
import Mathlib.NumberTheory.FLT.Basic
|
|
|
|
|
import Mathlib.Algebra.QuadraticDiscriminant
|
2024-11-11 05:54:31 +00:00
|
|
|
|
import Mathlib.NumberTheory.FLT.Three
|
2024-04-17 14:25:17 -04:00
|
|
|
|
/-!
|
|
|
|
|
# Parameterizations for solutions to the linear ACCs for 1 family
|
|
|
|
|
|
|
|
|
|
In this file we give two parameterizations
|
|
|
|
|
- `linearParameters` of solutions to the linear ACCs for 1 family
|
|
|
|
|
- `linearParametersQENeqZero` of solutions to the linear ACCs for 1 family with Q and E non-zero
|
|
|
|
|
|
|
|
|
|
These parameterizations are based on:
|
|
|
|
|
https://arxiv.org/abs/1907.00514
|
|
|
|
|
-/
|
|
|
|
|
|
2024-04-17 14:49:59 -04:00
|
|
|
|
universe v u
|
2024-04-17 14:25:17 -04:00
|
|
|
|
namespace SM
|
|
|
|
|
namespace SMNoGrav
|
|
|
|
|
namespace One
|
|
|
|
|
|
|
|
|
|
open SMCharges
|
|
|
|
|
open SMACCs
|
|
|
|
|
open BigOperators
|
|
|
|
|
|
|
|
|
|
/-- The parameters for a linear parameterization to the solution of the linear ACCs. -/
|
|
|
|
|
structure linearParameters where
|
|
|
|
|
/-- The parameter `Q'`. -/
|
|
|
|
|
Q' : ℚ
|
|
|
|
|
/-- The parameter `Y`. -/
|
|
|
|
|
Y : ℚ
|
|
|
|
|
/-- The parameter `E'`. -/
|
|
|
|
|
E' : ℚ
|
|
|
|
|
|
|
|
|
|
namespace linearParameters
|
|
|
|
|
|
|
|
|
|
@[ext]
|
2024-04-17 14:49:59 -04:00
|
|
|
|
lemma ext {S T : linearParameters} (hQ : S.Q' = T.Q') (hY : S.Y = T.Y) (hE : S.E' = T.E') :
|
|
|
|
|
S = T := by
|
2024-04-17 14:25:17 -04:00
|
|
|
|
cases' S
|
|
|
|
|
simp_all only
|
|
|
|
|
|
2024-05-21 14:12:53 +02:00
|
|
|
|
/-- The map from the linear parameters to elements of `(SMNoGrav 1).charges`. -/
|
2024-04-17 14:25:17 -04:00
|
|
|
|
@[simp]
|
2024-06-26 11:54:02 -04:00
|
|
|
|
def asCharges (S : linearParameters) : (SMNoGrav 1).Charges := fun i =>
|
2024-04-17 14:25:17 -04:00
|
|
|
|
match i with
|
|
|
|
|
| (0 : Fin 5) => S.Q'
|
|
|
|
|
| (1 : Fin 5) => S.Y - S.Q'
|
|
|
|
|
| (2 : Fin 5) => - (S.Y + S.Q')
|
|
|
|
|
| (3: Fin 5) => - 3 * S.Q'
|
|
|
|
|
| (4 : Fin 5) => S.E'
|
|
|
|
|
|
2024-04-17 14:49:59 -04:00
|
|
|
|
lemma speciesVal (S : linearParameters) :
|
|
|
|
|
(toSpecies i) S.asCharges (0 : Fin 1) = S.asCharges i := by
|
2024-04-17 14:25:17 -04:00
|
|
|
|
match i with
|
|
|
|
|
| 0 => rfl
|
|
|
|
|
| 1 => rfl
|
|
|
|
|
| 2 => rfl
|
|
|
|
|
| 3 => rfl
|
|
|
|
|
| 4 => rfl
|
|
|
|
|
|
|
|
|
|
/-- The map from the linear paramaters to elements of `(SMNoGrav 1).LinSols`. -/
|
|
|
|
|
def asLinear (S : linearParameters) : (SMNoGrav 1).LinSols :=
|
|
|
|
|
chargeToLinear S.asCharges (by
|
|
|
|
|
simp only [accSU2, SMSpecies_numberCharges, Finset.univ_unique, Fin.default_eq_zero,
|
|
|
|
|
Fin.isValue, Finset.sum_singleton, LinearMap.coe_mk, AddHom.coe_mk]
|
|
|
|
|
erw [speciesVal, speciesVal]
|
|
|
|
|
simp)
|
|
|
|
|
(by
|
|
|
|
|
simp only [accSU3, SMSpecies_numberCharges, Finset.univ_unique, Fin.default_eq_zero,
|
|
|
|
|
Fin.isValue, Finset.sum_singleton, LinearMap.coe_mk, AddHom.coe_mk]
|
|
|
|
|
repeat erw [speciesVal]
|
2024-04-17 14:49:59 -04:00
|
|
|
|
simp only [asCharges, neg_add_rev]
|
2024-04-17 14:25:17 -04:00
|
|
|
|
ring)
|
|
|
|
|
|
|
|
|
|
lemma asLinear_val (S : linearParameters) : S.asLinear.val = S.asCharges := by
|
|
|
|
|
rfl
|
|
|
|
|
|
|
|
|
|
lemma cubic (S : linearParameters) :
|
|
|
|
|
accCube (S.asCharges) = - 54 * S.Q'^3 - 18 * S.Q' * S.Y ^ 2 + S.E'^3 := by
|
2024-04-22 09:48:44 -04:00
|
|
|
|
simp only [HomogeneousCubic, accCube, cubeTriLin, TriLinearSymm.toCubic_apply,
|
|
|
|
|
TriLinearSymm.mk₃_toFun_apply_apply]
|
2024-04-17 14:25:17 -04:00
|
|
|
|
simp only [SMSpecies_numberCharges, Finset.univ_unique, Fin.default_eq_zero, Fin.isValue,
|
|
|
|
|
Finset.sum_singleton]
|
|
|
|
|
repeat erw [speciesVal]
|
2024-04-17 14:49:59 -04:00
|
|
|
|
simp only [asCharges, neg_add_rev, neg_mul, mul_neg, neg_neg]
|
2024-04-17 14:25:17 -04:00
|
|
|
|
ring
|
|
|
|
|
|
|
|
|
|
lemma cubic_zero_Q'_zero (S : linearParameters) (hc : accCube (S.asCharges) = 0)
|
|
|
|
|
(h : S.Q' = 0) : S.E' = 0 := by
|
|
|
|
|
rw [cubic, h] at hc
|
2024-09-09 06:01:25 -04:00
|
|
|
|
simpa using hc
|
2024-04-17 14:25:17 -04:00
|
|
|
|
|
|
|
|
|
lemma cubic_zero_E'_zero (S : linearParameters) (hc : accCube (S.asCharges) = 0)
|
|
|
|
|
(h : S.E' = 0) : S.Q' = 0 := by
|
|
|
|
|
rw [cubic, h] at hc
|
2024-09-09 06:01:25 -04:00
|
|
|
|
simp only [neg_mul, ne_eq, OfNat.ofNat_ne_zero, not_false_eq_true, zero_pow, add_zero] at hc
|
2024-04-17 14:25:17 -04:00
|
|
|
|
have h1 : -(54 * S.Q' ^ 3) - 18 * S.Q' * S.Y ^ 2 = - 18 * (3 * S.Q' ^ 2 + S.Y ^ 2) * S.Q' := by
|
|
|
|
|
ring
|
|
|
|
|
rw [h1] at hc
|
2024-09-09 06:01:25 -04:00
|
|
|
|
simp only [neg_mul, neg_eq_zero, mul_eq_zero, OfNat.ofNat_ne_zero, false_or] at hc
|
2024-04-17 14:25:17 -04:00
|
|
|
|
cases' hc with hc hc
|
2024-09-04 06:28:46 -04:00
|
|
|
|
· have h2 := (add_eq_zero_iff_of_nonneg (by nlinarith) (sq_nonneg S.Y)).mp hc
|
2024-09-09 06:01:25 -04:00
|
|
|
|
simp only [mul_eq_zero, OfNat.ofNat_ne_zero, ne_eq, not_false_eq_true, pow_eq_zero_iff,
|
|
|
|
|
false_or] at h2
|
2024-08-20 15:27:45 -04:00
|
|
|
|
exact h2.1
|
|
|
|
|
· exact hc
|
2024-04-17 14:25:17 -04:00
|
|
|
|
|
|
|
|
|
/-- The bijection between the type of linear parameters and `(SMNoGrav 1).LinSols`. -/
|
|
|
|
|
def bijection : linearParameters ≃ (SMNoGrav 1).LinSols where
|
|
|
|
|
toFun S := S.asLinear
|
|
|
|
|
invFun S := ⟨SMCharges.Q S.val (0 : Fin 1), (SMCharges.U S.val (0 : Fin 1) -
|
2024-07-19 17:00:32 -04:00
|
|
|
|
SMCharges.D S.val (0 : Fin 1))/2,
|
|
|
|
|
SMCharges.E S.val (0 : Fin 1)⟩
|
2024-04-17 14:25:17 -04:00
|
|
|
|
left_inv S := by
|
|
|
|
|
apply linearParameters.ext
|
2024-08-20 15:27:45 -04:00
|
|
|
|
· rfl
|
|
|
|
|
· simp only [Fin.isValue]
|
|
|
|
|
repeat erw [speciesVal]
|
|
|
|
|
simp only [asCharges, neg_add_rev]
|
|
|
|
|
ring
|
2024-08-30 10:11:55 -04:00
|
|
|
|
· rfl
|
2024-04-17 14:25:17 -04:00
|
|
|
|
right_inv S := by
|
2024-04-17 14:49:59 -04:00
|
|
|
|
simp only [Fin.isValue, toSpecies_apply]
|
2024-04-17 14:25:17 -04:00
|
|
|
|
apply ACCSystemLinear.LinSols.ext
|
|
|
|
|
rw [charges_eq_toSpecies_eq]
|
|
|
|
|
intro i
|
|
|
|
|
rw [asLinear_val]
|
|
|
|
|
funext j
|
2024-07-19 17:00:32 -04:00
|
|
|
|
have hj : j = (0 : Fin 1) := by
|
2024-11-02 07:56:45 +00:00
|
|
|
|
simp only [SMSpecies_numberCharges, Fin.isValue]
|
2024-04-17 14:25:17 -04:00
|
|
|
|
ext
|
|
|
|
|
simp
|
|
|
|
|
subst hj
|
|
|
|
|
erw [speciesVal]
|
|
|
|
|
have h1 := SU3Sol S
|
2024-09-09 06:01:25 -04:00
|
|
|
|
simp only [accSU3, SMSpecies_numberCharges, Finset.univ_unique, Fin.default_eq_zero,
|
|
|
|
|
Fin.isValue, toSpecies_apply, Nat.reduceMul, Finset.sum_singleton, Prod.mk_zero_zero,
|
|
|
|
|
LinearMap.coe_mk, AddHom.coe_mk] at h1
|
2024-04-17 14:25:17 -04:00
|
|
|
|
have h2 := SU2Sol S
|
2024-09-09 06:01:25 -04:00
|
|
|
|
simp only [accSU2, SMSpecies_numberCharges, Finset.univ_unique, Fin.default_eq_zero,
|
|
|
|
|
Fin.isValue, toSpecies_apply, Nat.reduceMul, Finset.sum_singleton, Prod.mk_zero_zero,
|
|
|
|
|
LinearMap.coe_mk, AddHom.coe_mk] at h2
|
2024-04-17 14:25:17 -04:00
|
|
|
|
match i with
|
|
|
|
|
| 0 => rfl
|
|
|
|
|
| 1 =>
|
|
|
|
|
field_simp
|
|
|
|
|
linear_combination -(1 * h1)
|
|
|
|
|
| 2 =>
|
|
|
|
|
field_simp
|
|
|
|
|
linear_combination -(1 * h1)
|
|
|
|
|
| 3 =>
|
|
|
|
|
field_simp
|
|
|
|
|
linear_combination -(1 * h2)
|
|
|
|
|
| 4 => rfl
|
|
|
|
|
|
|
|
|
|
/-- The bijection between the linear parameters and `(SMNoGrav 1).LinSols` in the special
|
|
|
|
|
case when Q and E are both not zero. -/
|
|
|
|
|
def bijectionQEZero : {S : linearParameters // S.Q' ≠ 0 ∧ S.E' ≠ 0} ≃
|
2024-04-17 14:49:59 -04:00
|
|
|
|
{S : (SMNoGrav 1).LinSols // Q S.val (0 : Fin 1) ≠ 0 ∧ E S.val (0 : Fin 1) ≠ 0} where
|
2024-04-17 14:25:17 -04:00
|
|
|
|
toFun S := ⟨bijection S, S.2⟩
|
|
|
|
|
invFun S := ⟨bijection.symm S, S.2⟩
|
2024-08-31 18:08:46 +02:00
|
|
|
|
left_inv S := Subtype.ext (bijection.left_inv S.1)
|
|
|
|
|
right_inv S := Subtype.ext (bijection.right_inv S.1)
|
2024-04-17 14:25:17 -04:00
|
|
|
|
|
|
|
|
|
lemma grav (S : linearParameters) :
|
|
|
|
|
accGrav S.asCharges = 0 ↔ S.E' = 6 * S.Q' := by
|
|
|
|
|
rw [accGrav]
|
|
|
|
|
simp only [SMSpecies_numberCharges, Finset.univ_unique, Fin.default_eq_zero, Fin.isValue,
|
|
|
|
|
Finset.sum_singleton, LinearMap.coe_mk, AddHom.coe_mk]
|
|
|
|
|
repeat erw [speciesVal]
|
2024-04-17 14:49:59 -04:00
|
|
|
|
simp only [asCharges, neg_add_rev, neg_mul, mul_neg]
|
2024-04-17 14:25:17 -04:00
|
|
|
|
ring_nf
|
|
|
|
|
rw [add_comm, add_eq_zero_iff_eq_neg]
|
|
|
|
|
simp
|
|
|
|
|
|
|
|
|
|
end linearParameters
|
|
|
|
|
|
2024-07-12 16:22:06 -04:00
|
|
|
|
/-- The parameters for solutions to the linear ACCs with the condition that Q and E are
|
|
|
|
|
non-zero. -/
|
2024-04-17 14:25:17 -04:00
|
|
|
|
structure linearParametersQENeqZero where
|
|
|
|
|
/-- The parameter `x`. -/
|
|
|
|
|
x : ℚ
|
|
|
|
|
/-- The parameter `v`. -/
|
|
|
|
|
v : ℚ
|
|
|
|
|
/-- The parameter `w`. -/
|
|
|
|
|
w : ℚ
|
|
|
|
|
hx : x ≠ 0
|
|
|
|
|
hvw : v + w ≠ 0
|
|
|
|
|
|
|
|
|
|
namespace linearParametersQENeqZero
|
|
|
|
|
|
|
|
|
|
@[ext]
|
|
|
|
|
lemma ext {S T : linearParametersQENeqZero} (hx : S.x = T.x) (hv : S.v = T.v)
|
2024-07-12 11:23:02 -04:00
|
|
|
|
(hw : S.w = T.w) : S = T := by
|
2024-04-17 14:25:17 -04:00
|
|
|
|
cases' S
|
|
|
|
|
simp_all only
|
|
|
|
|
|
|
|
|
|
/-- A map from `linearParametersQENeqZero` to `linearParameters`. -/
|
|
|
|
|
@[simps!]
|
|
|
|
|
def toLinearParameters (S : linearParametersQENeqZero) :
|
2024-07-12 11:23:02 -04:00
|
|
|
|
{S : linearParameters // S.Q' ≠ 0 ∧ S.E' ≠ 0} :=
|
|
|
|
|
⟨⟨S.x, 3 * S.x * (S.v - S.w) / (S.v + S.w), - 6 * S.x / (S.v + S.w)⟩,
|
2024-04-17 14:25:17 -04:00
|
|
|
|
by
|
|
|
|
|
apply And.intro S.hx
|
2024-04-17 14:49:59 -04:00
|
|
|
|
simp only [neg_mul, ne_eq, div_eq_zero_iff, neg_eq_zero, mul_eq_zero, OfNat.ofNat_ne_zero,
|
|
|
|
|
false_or]
|
2024-04-17 14:25:17 -04:00
|
|
|
|
rw [not_or]
|
|
|
|
|
exact And.intro S.hx S.hvw⟩
|
|
|
|
|
|
|
|
|
|
/-- A map from `linearParameters` to `linearParametersQENeqZero` in the special case when
|
|
|
|
|
`Q'` and `E'` of the linear parameters are non-zero. -/
|
|
|
|
|
@[simps!]
|
2024-07-12 11:23:02 -04:00
|
|
|
|
def tolinearParametersQNeqZero (S : {S : linearParameters // S.Q' ≠ 0 ∧ S.E' ≠ 0}) :
|
2024-04-17 14:25:17 -04:00
|
|
|
|
linearParametersQENeqZero :=
|
2024-07-12 11:23:02 -04:00
|
|
|
|
⟨S.1.Q', - (3 * S.1.Q' + S.1.Y) / S.1.E', - (3 * S.1.Q' - S.1.Y)/ S.1.E', S.2.1,
|
2024-04-17 14:25:17 -04:00
|
|
|
|
by
|
2024-04-17 14:49:59 -04:00
|
|
|
|
simp only [ne_eq, neg_add_rev, neg_sub]
|
2024-04-17 14:25:17 -04:00
|
|
|
|
field_simp
|
|
|
|
|
ring_nf
|
2024-04-17 14:49:59 -04:00
|
|
|
|
simp only [neg_eq_zero, mul_eq_zero, OfNat.ofNat_ne_zero, or_false]
|
2024-04-17 14:25:17 -04:00
|
|
|
|
exact S.2⟩
|
|
|
|
|
|
|
|
|
|
/-- A bijection between the type `linearParametersQENeqZero` and linear parameters
|
|
|
|
|
with `Q'` and `E'` non-zero. -/
|
|
|
|
|
@[simps!]
|
|
|
|
|
def bijectionLinearParameters :
|
2024-07-12 11:23:02 -04:00
|
|
|
|
linearParametersQENeqZero ≃ {S : linearParameters // S.Q' ≠ 0 ∧ S.E' ≠ 0} where
|
2024-04-17 14:25:17 -04:00
|
|
|
|
toFun := toLinearParameters
|
|
|
|
|
invFun := tolinearParametersQNeqZero
|
|
|
|
|
left_inv S := by
|
|
|
|
|
have hvw := S.hvw
|
|
|
|
|
have hQ := S.hx
|
|
|
|
|
apply linearParametersQENeqZero.ext
|
2024-08-20 15:27:45 -04:00
|
|
|
|
· rfl
|
|
|
|
|
· field_simp
|
|
|
|
|
ring
|
|
|
|
|
· simp only [tolinearParametersQNeqZero_w, toLinearParameters_coe_Y, toLinearParameters_coe_Q',
|
|
|
|
|
toLinearParameters_coe_E']
|
|
|
|
|
field_simp
|
|
|
|
|
ring
|
2024-04-17 14:25:17 -04:00
|
|
|
|
right_inv S := by
|
|
|
|
|
apply Subtype.ext
|
|
|
|
|
have hQ := S.2.1
|
|
|
|
|
have hE := S.2.2
|
|
|
|
|
apply linearParameters.ext
|
2024-08-20 15:27:45 -04:00
|
|
|
|
· rfl
|
|
|
|
|
· field_simp
|
|
|
|
|
ring_nf
|
|
|
|
|
field_simp [hQ, hE]
|
|
|
|
|
· field_simp
|
|
|
|
|
ring_nf
|
|
|
|
|
field_simp [hQ, hE]
|
2024-04-17 14:25:17 -04:00
|
|
|
|
|
|
|
|
|
/-- The bijection between `linearParametersQENeqZero` and `LinSols` with `Q` and `E` non-zero. -/
|
|
|
|
|
def bijection : linearParametersQENeqZero ≃
|
2024-07-12 11:23:02 -04:00
|
|
|
|
{S : (SMNoGrav 1).LinSols // Q S.val (0 : Fin 1) ≠ 0 ∧ E S.val (0 : Fin 1) ≠ 0} :=
|
2024-04-17 14:25:17 -04:00
|
|
|
|
bijectionLinearParameters.trans (linearParameters.bijectionQEZero)
|
|
|
|
|
|
|
|
|
|
lemma cubic (S : linearParametersQENeqZero) :
|
|
|
|
|
accCube (bijection S).1.val = 0 ↔ S.v ^ 3 + S.w ^ 3 = -1 := by
|
|
|
|
|
erw [linearParameters.cubic]
|
2024-04-17 14:49:59 -04:00
|
|
|
|
simp only [ne_eq, bijectionLinearParameters_apply_coe_Q', neg_mul,
|
|
|
|
|
bijectionLinearParameters_apply_coe_Y, div_pow, bijectionLinearParameters_apply_coe_E']
|
2024-04-17 14:25:17 -04:00
|
|
|
|
have hvw := S.hvw
|
|
|
|
|
have hQ := S.hx
|
|
|
|
|
field_simp
|
|
|
|
|
have h1 : (-(54 * S.x ^ 3 * (S.v + S.w) ^ 2) - 18 * S.x * (3 * S.x * (S.v - S.w)) ^ 2) *
|
|
|
|
|
(S.v + S.w) ^ 3 + (-(6 * S.x)) ^ 3 * (S.v + S.w) ^ 2 =
|
|
|
|
|
- 216 * S.x ^3 * (S.v ^3 + S.w ^3 +1) * (S.v + S.w) ^ 2 := by
|
|
|
|
|
ring
|
|
|
|
|
rw [h1]
|
|
|
|
|
simp_all
|
2024-06-13 08:10:08 -04:00
|
|
|
|
exact add_eq_zero_iff_eq_neg
|
2024-04-17 14:25:17 -04:00
|
|
|
|
|
2024-11-11 05:54:31 +00:00
|
|
|
|
lemma cubic_v_or_w_zero (S : linearParametersQENeqZero) (h : accCube (bijection S).1.val = 0) :
|
2024-04-17 14:25:17 -04:00
|
|
|
|
S.v = 0 ∨ S.w = 0 := by
|
|
|
|
|
rw [S.cubic] at h
|
2024-07-19 17:00:32 -04:00
|
|
|
|
have h1 : (-1)^3 = (-1 : ℚ) := by rfl
|
2024-04-17 14:25:17 -04:00
|
|
|
|
rw [← h1] at h
|
|
|
|
|
by_contra hn
|
2024-09-09 06:01:25 -04:00
|
|
|
|
rw [not_or] at hn
|
2024-11-11 05:54:31 +00:00
|
|
|
|
have FLTThree := fermatLastTheoremFor_iff_rat.mp fermatLastTheoremThree
|
2024-06-13 08:10:08 -04:00
|
|
|
|
have h2 := FLTThree S.v S.w (-1) hn.1 hn.2 (Ne.symm (ne_of_beq_false (by rfl)))
|
|
|
|
|
exact h2 h
|
2024-04-17 14:25:17 -04:00
|
|
|
|
|
|
|
|
|
lemma cubic_v_zero (S : linearParametersQENeqZero) (h : accCube (bijection S).1.val = 0)
|
2024-07-12 16:22:06 -04:00
|
|
|
|
(hv : S.v = 0) : S.w = -1 := by
|
2024-04-17 14:25:17 -04:00
|
|
|
|
rw [S.cubic, hv] at h
|
2024-09-09 06:01:25 -04:00
|
|
|
|
simp only [ne_eq, OfNat.ofNat_ne_zero, not_false_eq_true, zero_pow, zero_add] at h
|
2024-04-17 14:25:17 -04:00
|
|
|
|
have h' : (S.w + 1) * (1 * S.w * S.w + (-1) * S.w + 1) = 0 := by
|
|
|
|
|
ring_nf
|
2024-06-13 08:10:08 -04:00
|
|
|
|
exact add_eq_zero_iff_neg_eq.mpr (id (Eq.symm h))
|
2024-11-02 07:56:45 +00:00
|
|
|
|
have h'' : (1 * (S.w * S.w) + (-1) * S.w + 1) ≠ 0 := by
|
2024-11-04 05:55:37 +00:00
|
|
|
|
refine quadratic_ne_zero_of_discrim_ne_sq ?_ S.w
|
2024-04-17 14:25:17 -04:00
|
|
|
|
intro s
|
|
|
|
|
by_contra hn
|
|
|
|
|
have h : s ^ 2 < 0 := by
|
|
|
|
|
rw [← hn]
|
2024-11-02 07:56:45 +00:00
|
|
|
|
with_unfolding_all rfl
|
2024-04-17 14:25:17 -04:00
|
|
|
|
nlinarith
|
|
|
|
|
simp_all
|
2024-06-13 08:10:08 -04:00
|
|
|
|
exact eq_neg_of_add_eq_zero_left h'
|
2024-04-17 14:25:17 -04:00
|
|
|
|
|
|
|
|
|
lemma cube_w_zero (S : linearParametersQENeqZero) (h : accCube (bijection S).1.val = 0)
|
2024-07-12 16:22:06 -04:00
|
|
|
|
(hw : S.w = 0) : S.v = -1 := by
|
2024-04-17 14:25:17 -04:00
|
|
|
|
rw [S.cubic, hw] at h
|
2024-09-09 06:01:25 -04:00
|
|
|
|
simp only [ne_eq, OfNat.ofNat_ne_zero, not_false_eq_true, zero_pow, add_zero] at h
|
2024-04-17 14:25:17 -04:00
|
|
|
|
have h' : (S.v + 1) * (1 * S.v * S.v + (-1) * S.v + 1) = 0 := by
|
|
|
|
|
ring_nf
|
2024-06-13 08:10:08 -04:00
|
|
|
|
exact add_eq_zero_iff_neg_eq.mpr (id (Eq.symm h))
|
2024-11-02 07:56:45 +00:00
|
|
|
|
have h'' : (1 * (S.v * S.v) + (-1) * S.v + 1) ≠ 0 := by
|
2024-04-17 14:25:17 -04:00
|
|
|
|
refine quadratic_ne_zero_of_discrim_ne_sq ?_ S.v
|
|
|
|
|
intro s
|
|
|
|
|
by_contra hn
|
|
|
|
|
have h : s ^ 2 < 0 := by
|
|
|
|
|
rw [← hn]
|
2024-11-02 07:56:45 +00:00
|
|
|
|
with_unfolding_all rfl
|
2024-04-17 14:25:17 -04:00
|
|
|
|
nlinarith
|
|
|
|
|
simp_all
|
2024-06-13 08:10:08 -04:00
|
|
|
|
exact eq_neg_of_add_eq_zero_left h'
|
2024-04-17 14:25:17 -04:00
|
|
|
|
|
2024-11-11 05:54:31 +00:00
|
|
|
|
lemma cube_w_v (S : linearParametersQENeqZero) (h : accCube (bijection S).1.val = 0) :
|
2024-04-17 14:25:17 -04:00
|
|
|
|
(S.v = -1 ∧ S.w = 0) ∨ (S.v = 0 ∧ S.w = -1) := by
|
2024-11-11 05:54:31 +00:00
|
|
|
|
have h' := cubic_v_or_w_zero S h
|
2024-04-17 14:25:17 -04:00
|
|
|
|
cases' h' with hx hx
|
2024-09-09 06:01:25 -04:00
|
|
|
|
· simpa [hx] using cubic_v_zero S h hx
|
|
|
|
|
· simpa [hx] using cube_w_zero S h hx
|
2024-04-17 14:25:17 -04:00
|
|
|
|
|
|
|
|
|
lemma grav (S : linearParametersQENeqZero) : accGrav (bijection S).1.val = 0 ↔ S.v + S.w = -1 := by
|
|
|
|
|
erw [linearParameters.grav]
|
|
|
|
|
have hvw := S.hvw
|
|
|
|
|
have hQ := S.hx
|
|
|
|
|
field_simp
|
2024-08-20 15:27:45 -04:00
|
|
|
|
refine Iff.intro (fun h => ?_) (fun h => ?_)
|
|
|
|
|
· apply (mul_right_inj' hQ).mp
|
|
|
|
|
linear_combination -1 * h / 6
|
|
|
|
|
· rw [h]
|
|
|
|
|
exact Eq.symm (mul_neg_one (6 * S.x))
|
2024-04-17 14:25:17 -04:00
|
|
|
|
|
2024-11-11 05:54:31 +00:00
|
|
|
|
lemma grav_of_cubic (S : linearParametersQENeqZero) (h : accCube (bijection S).1.val = 0) :
|
2024-04-17 14:25:17 -04:00
|
|
|
|
accGrav (bijection S).1.val = 0 := by
|
|
|
|
|
rw [grav]
|
2024-11-11 05:54:31 +00:00
|
|
|
|
have h' := cube_w_v S h
|
2024-04-17 14:25:17 -04:00
|
|
|
|
cases' h' with h h
|
2024-08-20 15:27:45 -04:00
|
|
|
|
· rw [h.1, h.2]
|
|
|
|
|
exact Rat.add_zero (-1)
|
|
|
|
|
· rw [h.1, h.2]
|
|
|
|
|
exact Rat.zero_add (-1)
|
2024-04-17 14:25:17 -04:00
|
|
|
|
|
|
|
|
|
end linearParametersQENeqZero
|
|
|
|
|
|
|
|
|
|
end One
|
|
|
|
|
end SMNoGrav
|
|
|
|
|
end SM
|