PhysLean/HepLean/PerturbationTheory/FieldSpecification/NormalOrder.lean

424 lines
19 KiB
Text
Raw Normal View History

/-
Copyright (c) 2025 Joseph Tooby-Smith. All rights reserved.
Released under Apache 2.0 license as described in the file LICENSE.
Authors: Joseph Tooby-Smith
-/
import HepLean.PerturbationTheory.FieldSpecification.Filters
2025-01-30 11:00:25 +00:00
import HepLean.PerturbationTheory.Koszul.KoszulSign
/-!
# Normal Ordering of states
-/
namespace FieldSpecification
variable {𝓕 : FieldSpecification}
2025-02-06 14:10:45 +00:00
/-- For a field specification `𝓕`, `𝓕.normalOrderRel` is a relation on `𝓕.CrAnFieldOp`
representing normal ordering. It is defined such that `𝓕.normalOrderRel φ₀ φ₁`
is true if one of the following is true
2025-02-10 10:21:57 +00:00
- `φ₀` is a field creation operator
- `φ₁` is a field annihilation operator.
2025-02-06 14:10:45 +00:00
Thus, colloquially `𝓕.normalOrderRel φ₀ φ₁` says the creation operators are 'less then'
annihilation operators. -/
2025-02-03 11:28:14 +00:00
def normalOrderRel : 𝓕.CrAnFieldOp → 𝓕.CrAnFieldOp → Prop :=
fun a b => CreateAnnihilate.normalOrder (𝓕 |>ᶜ a) (𝓕 |>ᶜ b)
/-- Normal ordering is total. -/
2025-02-03 11:28:14 +00:00
instance : IsTotal 𝓕.CrAnFieldOp 𝓕.normalOrderRel where
total _ _ := total_of CreateAnnihilate.normalOrder _ _
/-- Normal ordering is transitive. -/
2025-02-03 11:28:14 +00:00
instance : IsTrans 𝓕.CrAnFieldOp 𝓕.normalOrderRel where
trans _ _ _ := fun h h' => IsTrans.trans (α := CreateAnnihilate) _ _ _ h h'
/-- A decidable instance on the normal ordering relation. -/
2025-02-03 11:28:14 +00:00
instance (φ φ' : 𝓕.CrAnFieldOp) : Decidable (normalOrderRel φ φ') :=
CreateAnnihilate.instDecidableNormalOrder (𝓕 |>ᶜ φ) (𝓕 |>ᶜ φ')
/-!
## Normal order sign.
-/
2025-02-07 15:43:59 +00:00
/-- For a field specification `𝓕`, and a list `φs` of `𝓕.CrAnFieldOp`, `𝓕.normalOrderSign φs` is the
2025-02-06 14:10:45 +00:00
sign corresponding to the number of `fermionic`-`fermionic` exchanges undertaken to normal-order
`φs` using the insertion sort algorithm. -/
2025-02-03 11:28:14 +00:00
def normalOrderSign (φs : List 𝓕.CrAnFieldOp) : :=
Wick.koszulSign 𝓕.crAnStatistics 𝓕.normalOrderRel φs
@[simp]
2025-02-03 11:28:14 +00:00
lemma normalOrderSign_mul_self (φs : List 𝓕.CrAnFieldOp) :
normalOrderSign φs * normalOrderSign φs = 1 := by
simp [normalOrderSign, Wick.koszulSign, Wick.koszulSign_mul_self]
2025-02-03 11:28:14 +00:00
lemma koszulSignInsert_create (φ : 𝓕.CrAnFieldOp)
(hφ : 𝓕 |>ᶜ φ = CreateAnnihilate.create) : (φs : List 𝓕.CrAnFieldOp) →
Wick.koszulSignInsert 𝓕.crAnStatistics normalOrderRel φ φs = 1
| [] => rfl
| φ' :: φs => by
dsimp only [Wick.koszulSignInsert]
rw [if_pos]
· exact koszulSignInsert_create φ hφ φs
· dsimp only [normalOrderRel]
rw [hφ]
dsimp [CreateAnnihilate.normalOrder]
2025-02-03 11:28:14 +00:00
lemma normalOrderSign_cons_create (φ : 𝓕.CrAnFieldOp)
(hφ : 𝓕 |>ᶜ φ = CreateAnnihilate.create) (φs : List 𝓕.CrAnFieldOp) :
normalOrderSign (φ :: φs) = normalOrderSign φs := by
2025-01-23 01:16:12 +01:00
simp [normalOrderSign, Wick.koszulSign, koszulSignInsert_create φ hφ φs]
@[simp]
2025-02-03 11:28:14 +00:00
lemma normalOrderSign_singleton (φ : 𝓕.CrAnFieldOp) : normalOrderSign [φ] = 1 := by
simp [normalOrderSign]
@[simp]
2025-01-23 01:16:12 +01:00
lemma normalOrderSign_nil : normalOrderSign (𝓕 := 𝓕) [] = 1 := rfl
2025-02-03 11:28:14 +00:00
lemma koszulSignInsert_append_annihilate (φ' φ : 𝓕.CrAnFieldOp)
(hφ : 𝓕 |>ᶜ φ = CreateAnnihilate.annihilate) :
2025-02-03 11:28:14 +00:00
(φs : List 𝓕.CrAnFieldOp) →
Wick.koszulSignInsert 𝓕.crAnStatistics normalOrderRel φ' (φs ++ [φ]) =
Wick.koszulSignInsert 𝓕.crAnStatistics normalOrderRel φ' φs
| [] => by
simp only [Wick.koszulSignInsert, normalOrderRel, hφ, ite_eq_left_iff,
CreateAnnihilate.not_normalOrder_annihilate_iff_false, ite_eq_right_iff, and_imp,
IsEmpty.forall_iff]
| φ'' :: φs => by
dsimp only [List.cons_append, Wick.koszulSignInsert]
rw [koszulSignInsert_append_annihilate φ' φ hφ φs]
2025-02-07 15:43:59 +00:00
lemma normalOrderSign_append_annihilate (φ : 𝓕.CrAnFieldOp)
(hφ : 𝓕 |>ᶜ φ = CreateAnnihilate.annihilate) :
2025-02-03 11:28:14 +00:00
(φs : List 𝓕.CrAnFieldOp) →
normalOrderSign (φs ++ [φ]) = normalOrderSign φs
| [] => by simp
| φ' :: φs => by
dsimp only [List.cons_append, normalOrderSign, Wick.koszulSign]
2025-02-07 15:43:59 +00:00
have hi := normalOrderSign_append_annihilate φ hφ φs
dsimp only [normalOrderSign] at hi
rw [hi, koszulSignInsert_append_annihilate φ' φ hφ φs]
2025-02-03 11:28:14 +00:00
lemma koszulSignInsert_annihilate_cons_create (φc φa : 𝓕.CrAnFieldOp)
(hφc : 𝓕 |>ᶜ φc = CreateAnnihilate.create)
(hφa : 𝓕 |>ᶜ φa = CreateAnnihilate.annihilate)
2025-02-03 11:28:14 +00:00
(φs : List 𝓕.CrAnFieldOp) :
Wick.koszulSignInsert 𝓕.crAnStatistics normalOrderRel φa (φc :: φs)
= FieldStatistic.exchangeSign (𝓕.crAnStatistics φc) (𝓕.crAnStatistics φa) *
Wick.koszulSignInsert 𝓕.crAnStatistics normalOrderRel φa φs := by
rw [Wick.koszulSignInsert_cons]
simp only [FieldStatistic.instCommGroup.eq_1, mul_eq_mul_right_iff]
apply Or.inl
rw [Wick.koszulSignCons, if_neg, FieldStatistic.exchangeSign_symm,
FieldStatistic.exchangeSign_eq_if]
rw [normalOrderRel, hφa, hφc]
simp [CreateAnnihilate.normalOrder]
2025-02-07 15:43:59 +00:00
lemma normalOrderSign_swap_create_annihilate_fst (φc φa : 𝓕.CrAnFieldOp)
(hφc : 𝓕 |>ᶜ φc = CreateAnnihilate.create)
(hφa : 𝓕 |>ᶜ φa = CreateAnnihilate.annihilate)
2025-02-03 11:28:14 +00:00
(φs : List 𝓕.CrAnFieldOp) :
normalOrderSign (φc :: φa :: φs) =
FieldStatistic.exchangeSign (𝓕.crAnStatistics φc) (𝓕.crAnStatistics φa) *
normalOrderSign (φa :: φc :: φs) := by
rw [normalOrderSign_cons_create φc hφc (φa :: φs)]
conv_rhs =>
rw [normalOrderSign, Wick.koszulSign, ← normalOrderSign]
rw [koszulSignInsert_annihilate_cons_create φc φa hφc hφa φs]
rw [← mul_assoc, ← mul_assoc, FieldStatistic.exchangeSign_mul_self]
rw [one_mul, normalOrderSign_cons_create φc hφc φs]
rfl
2025-02-03 11:28:14 +00:00
lemma koszulSignInsert_swap (φ φc φa : 𝓕.CrAnFieldOp) (φs φs' : List 𝓕.CrAnFieldOp) :
Wick.koszulSignInsert 𝓕.crAnStatistics normalOrderRel φ (φs ++ φa :: φc :: φs')
2025-01-23 01:16:12 +01:00
= Wick.koszulSignInsert 𝓕.crAnStatistics normalOrderRel φ (φs ++ φc :: φa :: φs') :=
Wick.koszulSignInsert_eq_perm _ _ _ _ _ (List.Perm.append_left φs (List.Perm.swap φc φa φs'))
2025-02-07 15:43:59 +00:00
lemma normalOrderSign_swap_create_annihilate (φc φa : 𝓕.CrAnFieldOp)
(hφc : 𝓕 |>ᶜ φc = CreateAnnihilate.create) (hφa : 𝓕 |>ᶜ φa = CreateAnnihilate.annihilate) :
2025-02-03 11:28:14 +00:00
(φs φs' : List 𝓕.CrAnFieldOp) → normalOrderSign (φs ++ φc :: φa :: φs') =
FieldStatistic.exchangeSign (𝓕.crAnStatistics φc) (𝓕.crAnStatistics φa) *
normalOrderSign (φs ++ φa :: φc :: φs')
2025-02-07 15:43:59 +00:00
| [], φs' => normalOrderSign_swap_create_annihilate_fst φc φa hφc hφa φs'
| φ :: φs, φs' => by
rw [normalOrderSign]
dsimp only [List.cons_append, Wick.koszulSign, FieldStatistic.instCommGroup.eq_1]
2025-02-07 15:43:59 +00:00
rw [← normalOrderSign, normalOrderSign_swap_create_annihilate φc φa hφc hφa φs φs']
rw [← mul_assoc, mul_comm _ (FieldStatistic.exchangeSign _ _), mul_assoc]
simp only [FieldStatistic.instCommGroup.eq_1, mul_eq_mul_left_iff]
2025-01-23 01:43:55 +01:00
apply Or.inl
2025-01-23 01:16:12 +01:00
conv_rhs => rw [normalOrderSign, Wick.koszulSign, ← normalOrderSign]
simp only [mul_eq_mul_right_iff]
2025-01-23 01:16:12 +01:00
left
rw [koszulSignInsert_swap]
2025-02-03 11:28:14 +00:00
lemma normalOrderSign_swap_create_create_fst (φc φc' : 𝓕.CrAnFieldOp)
(hφc : 𝓕 |>ᶜ φc = CreateAnnihilate.create) (hφc' : 𝓕 |>ᶜ φc' = CreateAnnihilate.create)
2025-02-03 11:28:14 +00:00
(φs : List 𝓕.CrAnFieldOp) :
normalOrderSign (φc :: φc' :: φs) = normalOrderSign (φc' :: φc :: φs) := by
rw [normalOrderSign_cons_create φc hφc, normalOrderSign_cons_create φc' hφc']
rw [normalOrderSign_cons_create φc' hφc', normalOrderSign_cons_create φc hφc]
2025-02-03 11:28:14 +00:00
lemma normalOrderSign_swap_create_create (φc φc' : 𝓕.CrAnFieldOp)
(hφc : 𝓕 |>ᶜ φc = CreateAnnihilate.create) (hφc' : 𝓕 |>ᶜ φc' = CreateAnnihilate.create) :
2025-02-03 11:28:14 +00:00
(φs φs' : List 𝓕.CrAnFieldOp) →
normalOrderSign (φs ++ φc :: φc' :: φs') = normalOrderSign (φs ++ φc' :: φc :: φs')
| [], φs' => by
exact normalOrderSign_swap_create_create_fst φc φc' hφc hφc' φs'
| φ :: φs, φs' => by
rw [normalOrderSign]
dsimp only [List.cons_append, Wick.koszulSign]
rw [← normalOrderSign, normalOrderSign_swap_create_create φc φc' hφc hφc']
dsimp only [normalOrderSign, Wick.koszulSign]
rw [← normalOrderSign]
simp only [mul_eq_mul_right_iff]
apply Or.inl (Wick.koszulSignInsert_eq_perm _ _ _ _ _ _)
exact List.Perm.append_left φs (List.Perm.swap φc' φc φs')
2025-02-03 11:28:14 +00:00
lemma normalOrderSign_swap_annihilate_annihilate_fst (φa φa' : 𝓕.CrAnFieldOp)
(hφa : 𝓕 |>ᶜ φa = CreateAnnihilate.annihilate)
(hφa' : 𝓕 |>ᶜ φa' = CreateAnnihilate.annihilate)
2025-02-03 11:28:14 +00:00
(φs : List 𝓕.CrAnFieldOp) :
normalOrderSign (φa :: φa' :: φs) =
normalOrderSign (φa' :: φa :: φs) := by
rw [normalOrderSign, normalOrderSign]
dsimp only [Wick.koszulSign]
rw [← mul_assoc, ← mul_assoc]
congr 1
rw [Wick.koszulSignInsert_cons, Wick.koszulSignInsert_cons, mul_assoc, mul_assoc]
congr 1
· dsimp only [Wick.koszulSignCons]
rw [if_pos, if_pos]
· simp [normalOrderRel, hφa, hφa', CreateAnnihilate.normalOrder]
· simp [normalOrderRel, hφa, hφa', CreateAnnihilate.normalOrder]
· rw [NonUnitalNormedCommRing.mul_comm]
2025-02-03 11:28:14 +00:00
lemma normalOrderSign_swap_annihilate_annihilate (φa φa' : 𝓕.CrAnFieldOp)
(hφa : 𝓕 |>ᶜ φa = CreateAnnihilate.annihilate)
2025-02-03 11:28:14 +00:00
(hφa' : 𝓕 |>ᶜ φa' = CreateAnnihilate.annihilate) : (φs φs' : List 𝓕.CrAnFieldOp) →
normalOrderSign (φs ++ φa :: φa' :: φs') = normalOrderSign (φs ++ φa' :: φa :: φs')
| [], φs' => by
exact normalOrderSign_swap_annihilate_annihilate_fst φa φa' hφa hφa' φs'
| φ :: φs, φs' => by
rw [normalOrderSign]
dsimp only [List.cons_append, Wick.koszulSign]
rw [← normalOrderSign]
rw [normalOrderSign_swap_annihilate_annihilate φa φa' hφa hφa']
dsimp only [normalOrderSign, Wick.koszulSign]
rw [← normalOrderSign]
simp only [mul_eq_mul_right_iff]
apply Or.inl
apply Wick.koszulSignInsert_eq_perm
refine List.Perm.append_left φs ?h.h.a
exact List.Perm.swap φa' φa φs'
open FieldStatistic
/-!
## Normal order of lists
-/
2025-02-06 14:10:45 +00:00
/-- For a field specification `𝓕`, and a list `φs` of `𝓕.CrAnFieldOp`,
`𝓕.normalOrderList φs` is the list `φs` normal-ordered using ther
insertion sort algorithm. It puts creation operators on the left and annihilation operators on
the right. For example:
`𝓕.normalOrderList [φ1c, φ1a, φ2c, φ2a] = [φ1c, φ2c, φ1a, φ2a]`
-/
2025-02-03 11:28:14 +00:00
def normalOrderList (φs : List 𝓕.CrAnFieldOp) : List 𝓕.CrAnFieldOp :=
List.insertionSort 𝓕.normalOrderRel φs
@[simp]
lemma normalOrderList_nil : normalOrderList (𝓕 := 𝓕) [] = [] := by
simp [normalOrderList]
@[simp]
2025-02-03 11:28:14 +00:00
lemma normalOrderList_statistics (φs : List 𝓕.CrAnFieldOp) :
(𝓕 |>ₛ (normalOrderList φs)) = 𝓕 |>ₛ φs := by
simp [normalOrderList, List.insertionSort]
2025-02-03 11:28:14 +00:00
lemma orderedInsert_create (φ : 𝓕.CrAnFieldOp)
(hφ : 𝓕 |>ᶜ φ = CreateAnnihilate.create) :
2025-02-03 11:28:14 +00:00
(φs : List 𝓕.CrAnFieldOp) → List.orderedInsert normalOrderRel φ φs = φ :: φs
| [] => rfl
| φ' :: φs => by
dsimp only [List.orderedInsert.eq_2]
rw [if_pos]
dsimp only [normalOrderRel]
rw [hφ]
dsimp [CreateAnnihilate.normalOrder]
2025-02-03 11:28:14 +00:00
lemma normalOrderList_cons_create (φ : 𝓕.CrAnFieldOp)
(hφ : 𝓕 |>ᶜ φ = CreateAnnihilate.create) (φs : List 𝓕.CrAnFieldOp) :
normalOrderList (φ :: φs) = φ :: normalOrderList φs := by
simp only [normalOrderList, List.insertionSort]
rw [orderedInsert_create φ hφ]
2025-02-03 11:28:14 +00:00
lemma orderedInsert_append_annihilate (φ' φ : 𝓕.CrAnFieldOp)
(hφ : 𝓕 |>ᶜ φ = CreateAnnihilate.annihilate) :
2025-02-03 11:28:14 +00:00
(φs : List 𝓕.CrAnFieldOp) → List.orderedInsert normalOrderRel φ' (φs ++ [φ]) =
List.orderedInsert normalOrderRel φ' φs ++ [φ]
| [] => by
simp [Wick.koszulSignInsert, normalOrderRel, hφ]
| φ'' :: φs => by
dsimp only [List.cons_append, List.orderedInsert.eq_2]
have hi := orderedInsert_append_annihilate φ' φ hφ φs
rw [hi]
split
next h => simp_all only [List.cons_append]
next h => simp_all only [List.cons_append]
2025-02-03 11:28:14 +00:00
lemma normalOrderList_append_annihilate (φ : 𝓕.CrAnFieldOp)
(hφ : 𝓕 |>ᶜ φ = CreateAnnihilate.annihilate) :
2025-02-03 11:28:14 +00:00
(φs : List 𝓕.CrAnFieldOp) →
normalOrderList (φs ++ [φ]) = normalOrderList φs ++ [φ]
| [] => by simp [normalOrderList]
| φ' :: φs => by
simp only [normalOrderList, List.insertionSort, List.append_eq]
have hi := normalOrderList_append_annihilate φ hφ φs
dsimp only [normalOrderList] at hi
rw [hi, orderedInsert_append_annihilate φ' φ hφ]
2025-02-07 15:43:59 +00:00
lemma normalOrder_swap_create_annihilate_fst (φc φa : 𝓕.CrAnFieldOp)
(hφc : 𝓕 |>ᶜ φc = CreateAnnihilate.create)
(hφa : 𝓕 |>ᶜ φa = CreateAnnihilate.annihilate)
2025-02-03 11:28:14 +00:00
(φs : List 𝓕.CrAnFieldOp) :
normalOrderList (φc :: φa :: φs) = normalOrderList (φa :: φc :: φs) := by
rw [normalOrderList_cons_create φc hφc (φa :: φs)]
conv_rhs =>
rw [normalOrderList, List.insertionSort]
have hi := normalOrderList_cons_create φc hφc φs
rw [normalOrderList] at hi
rw [hi]
dsimp only [List.orderedInsert.eq_2]
split
· rename_i h
rw [normalOrderRel, hφa, hφc] at h
dsimp [CreateAnnihilate.normalOrder] at h
· rfl
2025-02-07 15:43:59 +00:00
lemma normalOrderList_swap_create_annihilate (φc φa : 𝓕.CrAnFieldOp)
(hφc : 𝓕 |>ᶜ φc = CreateAnnihilate.create)
(hφa : 𝓕 |>ᶜ φa = CreateAnnihilate.annihilate) :
2025-02-03 11:28:14 +00:00
(φs φs' : List 𝓕.CrAnFieldOp) →
normalOrderList (φs ++ φc :: φa :: φs') = normalOrderList (φs ++ φa :: φc :: φs')
2025-02-07 15:43:59 +00:00
| [], φs' => normalOrder_swap_create_annihilate_fst φc φa hφc hφa φs'
| φ :: φs, φs' => by
dsimp only [List.cons_append, normalOrderList, List.insertionSort]
2025-02-07 15:43:59 +00:00
have hi := normalOrderList_swap_create_annihilate φc φa hφc hφa φs φs'
dsimp only [normalOrderList] at hi
rw [hi]
2025-02-07 15:43:59 +00:00
/-- For a list of creation and annihilation states, the equivalence between
`Fin φs.length` and `Fin (normalOrderList φs).length` taking each position in `φs`
to it's corresponding position in the normal ordered list. This assumes that
we are using the insertion sort method.
For example:
- For `[φ1c, φ1a, φ2c, φ2a]` this equivalence sends `0 ↦ 0`, `1 ↦ 2`, `2 ↦ 1`, `3 ↦ 3`.
-/
2025-02-03 11:28:14 +00:00
def normalOrderEquiv {φs : List 𝓕.CrAnFieldOp} : Fin φs.length ≃ Fin (normalOrderList φs).length :=
HepLean.List.insertionSortEquiv 𝓕.normalOrderRel φs
lemma sum_normalOrderList_length {M : Type} [AddCommMonoid M]
2025-02-03 11:28:14 +00:00
(φs : List 𝓕.CrAnFieldOp) (f : Fin (normalOrderList φs).length → M) :
∑ (n : Fin (normalOrderList φs).length), f n = ∑ (n : Fin φs.length), f (normalOrderEquiv n) :=
Eq.symm (Equiv.sum_comp normalOrderEquiv f)
@[simp]
2025-02-03 11:28:14 +00:00
lemma normalOrderList_get_normalOrderEquiv {φs : List 𝓕.CrAnFieldOp} (n : Fin φs.length) :
(normalOrderList φs)[(normalOrderEquiv n).val] = φs[n.val] := by
change (normalOrderList φs).get (normalOrderEquiv n) = _
simp only [normalOrderList, normalOrderEquiv]
erw [← HepLean.List.insertionSortEquiv_get]
simp
@[simp]
2025-02-03 11:28:14 +00:00
lemma normalOrderList_eraseIdx_normalOrderEquiv {φs : List 𝓕.CrAnFieldOp} (n : Fin φs.length) :
(normalOrderList φs).eraseIdx (normalOrderEquiv n).val =
normalOrderList (φs.eraseIdx n.val) := by
simp only [normalOrderList, normalOrderEquiv]
rw [HepLean.List.eraseIdx_insertionSort_fin]
2025-02-06 14:10:45 +00:00
/-- For a field specification `𝓕`, a list `φs = φ₀…φₙ` of `𝓕.CrAnFieldOp` and an `i < φs.length`,
2025-02-10 10:21:57 +00:00
then
2025-02-06 14:10:45 +00:00
`normalOrderSign (φ₀…φᵢ₋₁φᵢ₊₁…φₙ)` is equal to the product of
- `normalOrderSign φ₀…φₙ`,
2025-02-07 10:34:48 +00:00
- `𝓢(φᵢ, φ₀…φᵢ₋₁)` i.e. the sign needed to remove `φᵢ` from `φ₀…φₙ`,
2025-02-10 10:21:57 +00:00
- `𝓢(φᵢ, _)` where `_` is the list of elements appearing before `φᵢ` after normal ordering,
i.e.
2025-02-06 14:10:45 +00:00
the sign needed to insert `φᵢ` back into the normal-ordered list at the correct place. -/
lemma normalOrderSign_eraseIdx (φs : List 𝓕.CrAnFieldOp) (i : Fin φs.length) :
normalOrderSign (φs.eraseIdx i) = normalOrderSign φs *
𝓢(𝓕 |>ₛ (φs.get i), 𝓕 |>ₛ (φs.take i)) *
𝓢(𝓕 |>ₛ (φs.get i), 𝓕 |>ₛ ((normalOrderList φs).take (normalOrderEquiv i))) := by
rw [normalOrderSign, Wick.koszulSign_eraseIdx, ← normalOrderSign]
rfl
2025-02-03 11:28:14 +00:00
lemma orderedInsert_createFilter_append_annihilate (φ : 𝓕.CrAnFieldOp)
(hφ : 𝓕 |>ᶜ φ = CreateAnnihilate.annihilate) : (φs φs' : List 𝓕.CrAnFieldOp) →
List.orderedInsert normalOrderRel φ (createFilter φs ++ φs') =
createFilter φs ++ List.orderedInsert normalOrderRel φ φs'
| [], φs' => by simp [createFilter]
| φ' :: φs, φs' => by
rcases CreateAnnihilate.eq_create_or_annihilate (𝓕 |>ᶜ φ') with hφ' | hφ'
· rw [createFilter_cons_create hφ']
dsimp only [List.cons_append, List.orderedInsert.eq_2]
rw [if_neg, orderedInsert_createFilter_append_annihilate φ hφ φs φs']
simp [normalOrderRel, hφ, hφ', CreateAnnihilate.normalOrder]
· rw [createFilter_cons_annihilate hφ', orderedInsert_createFilter_append_annihilate φ hφ φs]
2025-02-03 11:28:14 +00:00
lemma orderedInsert_annihilateFilter (φ : 𝓕.CrAnFieldOp) : (φs : List 𝓕.CrAnFieldOp) →
List.orderedInsert normalOrderRel φ (annihilateFilter φs) =
φ :: annihilateFilter φs
| [] => by simp [annihilateFilter]
| φ' :: φs => by
rcases CreateAnnihilate.eq_create_or_annihilate (𝓕 |>ᶜ φ') with hφ' | hφ'
· rw [annihilateFilter_cons_create hφ', orderedInsert_annihilateFilter φ φs]
· rw [annihilateFilter_cons_annihilate hφ']
dsimp only [List.orderedInsert.eq_2]
rw [if_pos]
dsimp only [normalOrderRel]
rw [hφ']
rcases CreateAnnihilate.eq_create_or_annihilate (𝓕 |>ᶜ φ) with hφ | hφ
· rw [hφ]
simp only [CreateAnnihilate.normalOrder]
· rw [hφ]
simp [CreateAnnihilate.normalOrder]
2025-02-03 11:28:14 +00:00
lemma orderedInsert_createFilter_append_annihilateFilter_annihilate (φ : 𝓕.CrAnFieldOp)
(hφ : 𝓕 |>ᶜ φ = CreateAnnihilate.annihilate) (φs : List 𝓕.CrAnFieldOp) :
List.orderedInsert normalOrderRel φ (createFilter φs ++ annihilateFilter φs) =
createFilter φs ++ φ :: annihilateFilter φs := by
rw [orderedInsert_createFilter_append_annihilate φ hφ, orderedInsert_annihilateFilter]
2025-02-03 11:28:14 +00:00
lemma normalOrderList_eq_createFilter_append_annihilateFilter : (φs : List 𝓕.CrAnFieldOp) →
normalOrderList φs = createFilter φs ++ annihilateFilter φs
| [] => by simp [normalOrderList, createFilter, annihilateFilter]
| φ :: φs => by
by_cases hφ : 𝓕 |>ᶜ φ = CreateAnnihilate.create
· rw [normalOrderList_cons_create φ hφ φs]
dsimp only [createFilter]
rw [List.filter_cons_of_pos]
swap
simp only [hφ, decide_true]
dsimp only [annihilateFilter, List.cons_append]
rw [List.filter_cons_of_neg]
swap
simp only [hφ, reduceCtorEq, decide_false, Bool.false_eq_true, not_false_eq_true]
rw [normalOrderList_eq_createFilter_append_annihilateFilter φs]
rfl
· dsimp only [normalOrderList, List.insertionSort]
rw [← normalOrderList]
have hφ' : 𝓕 |>ᶜ φ = CreateAnnihilate.annihilate := by
have hx := CreateAnnihilate.eq_create_or_annihilate (𝓕 |>ᶜ φ)
simp_all
rw [normalOrderList_eq_createFilter_append_annihilateFilter φs]
rw [orderedInsert_createFilter_append_annihilateFilter_annihilate φ hφ']
rw [createFilter_cons_annihilate hφ', annihilateFilter_cons_annihilate hφ']
end FieldSpecification