Users' Mathboxes Mathbox for Thierry Arnoux < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >   Mathboxes  >  gsumwrd2dccat Structured version   Visualization version   GIF version

Theorem gsumwrd2dccat 32979
Description: Rewrite a sum ranging over pairs of words as a sum of sums over concatenated subwords. (Contributed by Thierry Arnoux, 5-Oct-2025.)
Hypotheses
Ref Expression
gsumwrd2dccat.1 𝐵 = (Base‘𝑀)
gsumwrd2dccat.2 𝑍 = (0g𝑀)
gsumwrd2dccat.3 (𝜑𝐹:(Word 𝐴 × Word 𝐴)⟶𝐵)
gsumwrd2dccat.4 (𝜑𝐹 finSupp 𝑍)
gsumwrd2dccat.5 (𝜑𝑀 ∈ CMnd)
gsumwrd2dccat.6 (𝜑𝐴𝐵)
Assertion
Ref Expression
gsumwrd2dccat (𝜑 → (𝑀 Σg 𝐹) = (𝑀 Σg (𝑤 ∈ Word 𝐴 ↦ (𝑀 Σg (𝑗 ∈ (0...(♯‘𝑤)) ↦ (𝐹‘⟨(𝑤 prefix 𝑗), (𝑤 substr ⟨𝑗, (♯‘𝑤)⟩)⟩))))))
Distinct variable groups:   𝑤,𝐴,𝑗   𝐵,𝑗,𝑤   𝑗,𝐹,𝑤   𝑗,𝑀,𝑤   𝑗,𝑍,𝑤   𝜑,𝑗,𝑤

Proof of Theorem gsumwrd2dccat
Dummy variables 𝑎 𝑏 𝑥 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 gsumwrd2dccat.1 . . . 4 𝐵 = (Base‘𝑀)
2 gsumwrd2dccat.2 . . . 4 𝑍 = (0g𝑀)
3 gsumwrd2dccat.5 . . . 4 (𝜑𝑀 ∈ CMnd)
41fvexi 6886 . . . . . . . 8 𝐵 ∈ V
54a1i 11 . . . . . . 7 (𝜑𝐵 ∈ V)
6 gsumwrd2dccat.6 . . . . . . 7 (𝜑𝐴𝐵)
75, 6ssexd 5291 . . . . . 6 (𝜑𝐴 ∈ V)
8 wrdexg 14529 . . . . . 6 (𝐴 ∈ V → Word 𝐴 ∈ V)
97, 8syl 17 . . . . 5 (𝜑 → Word 𝐴 ∈ V)
109, 9xpexd 7739 . . . 4 (𝜑 → (Word 𝐴 × Word 𝐴) ∈ V)
11 gsumwrd2dccat.3 . . . 4 (𝜑𝐹:(Word 𝐴 × Word 𝐴)⟶𝐵)
12 gsumwrd2dccat.4 . . . 4 (𝜑𝐹 finSupp 𝑍)
13 eqid 2734 . . . . . . . 8 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤))) = 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤)))
14 eqid 2734 . . . . . . . 8 (𝑎 ∈ (Word 𝐴 × Word 𝐴) ↦ ⟨((1st𝑎) ++ (2nd𝑎)), (♯‘(1st𝑎))⟩) = (𝑎 ∈ (Word 𝐴 × Word 𝐴) ↦ ⟨((1st𝑎) ++ (2nd𝑎)), (♯‘(1st𝑎))⟩)
15 eqid 2734 . . . . . . . 8 (𝑏 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤))) ↦ ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩) = (𝑏 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤))) ↦ ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩)
1613, 14, 15, 7gsumwrd2dccatlem 32978 . . . . . . 7 (𝜑 → ((𝑎 ∈ (Word 𝐴 × Word 𝐴) ↦ ⟨((1st𝑎) ++ (2nd𝑎)), (♯‘(1st𝑎))⟩):(Word 𝐴 × Word 𝐴)–1-1-onto 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤))) ∧ (𝑎 ∈ (Word 𝐴 × Word 𝐴) ↦ ⟨((1st𝑎) ++ (2nd𝑎)), (♯‘(1st𝑎))⟩) = (𝑏 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤))) ↦ ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩)))
1716simpld 494 . . . . . 6 (𝜑 → (𝑎 ∈ (Word 𝐴 × Word 𝐴) ↦ ⟨((1st𝑎) ++ (2nd𝑎)), (♯‘(1st𝑎))⟩):(Word 𝐴 × Word 𝐴)–1-1-onto 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤))))
18 f1ocnv 6826 . . . . . 6 ((𝑎 ∈ (Word 𝐴 × Word 𝐴) ↦ ⟨((1st𝑎) ++ (2nd𝑎)), (♯‘(1st𝑎))⟩):(Word 𝐴 × Word 𝐴)–1-1-onto 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤))) → (𝑎 ∈ (Word 𝐴 × Word 𝐴) ↦ ⟨((1st𝑎) ++ (2nd𝑎)), (♯‘(1st𝑎))⟩): 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤)))–1-1-onto→(Word 𝐴 × Word 𝐴))
1917, 18syl 17 . . . . 5 (𝜑(𝑎 ∈ (Word 𝐴 × Word 𝐴) ↦ ⟨((1st𝑎) ++ (2nd𝑎)), (♯‘(1st𝑎))⟩): 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤)))–1-1-onto→(Word 𝐴 × Word 𝐴))
2016simprd 495 . . . . . 6 (𝜑(𝑎 ∈ (Word 𝐴 × Word 𝐴) ↦ ⟨((1st𝑎) ++ (2nd𝑎)), (♯‘(1st𝑎))⟩) = (𝑏 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤))) ↦ ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩))
2120f1oeq1d 6809 . . . . 5 (𝜑 → ((𝑎 ∈ (Word 𝐴 × Word 𝐴) ↦ ⟨((1st𝑎) ++ (2nd𝑎)), (♯‘(1st𝑎))⟩): 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤)))–1-1-onto→(Word 𝐴 × Word 𝐴) ↔ (𝑏 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤))) ↦ ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩): 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤)))–1-1-onto→(Word 𝐴 × Word 𝐴)))
2219, 21mpbid 232 . . . 4 (𝜑 → (𝑏 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤))) ↦ ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩): 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤)))–1-1-onto→(Word 𝐴 × Word 𝐴))
231, 2, 3, 10, 11, 12, 22gsumf1o 19882 . . 3 (𝜑 → (𝑀 Σg 𝐹) = (𝑀 Σg (𝐹 ∘ (𝑏 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤))) ↦ ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩))))
24 relxp 5669 . . . . . . . . . . . 12 Rel ({𝑥} × (0...(♯‘𝑥)))
2524a1i 11 . . . . . . . . . . 11 ((𝜑𝑥 ∈ Word 𝐴) → Rel ({𝑥} × (0...(♯‘𝑥))))
2625ralrimiva 3130 . . . . . . . . . 10 (𝜑 → ∀𝑥 ∈ Word 𝐴Rel ({𝑥} × (0...(♯‘𝑥))))
27 reliun 5792 . . . . . . . . . 10 (Rel 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↔ ∀𝑥 ∈ Word 𝐴Rel ({𝑥} × (0...(♯‘𝑥))))
2826, 27sylibr 234 . . . . . . . . 9 (𝜑 → Rel 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))))
29 1stdm 8033 . . . . . . . . 9 ((Rel 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ∧ 𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))) → (1st𝑏) ∈ dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))))
3028, 29sylan 580 . . . . . . . 8 ((𝜑𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))) → (1st𝑏) ∈ dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))))
31 lencl 14538 . . . . . . . . . . . . 13 (𝑥 ∈ Word 𝐴 → (♯‘𝑥) ∈ ℕ0)
3231adantl 481 . . . . . . . . . . . 12 ((𝜑𝑥 ∈ Word 𝐴) → (♯‘𝑥) ∈ ℕ0)
33 nn0uz 12886 . . . . . . . . . . . 12 0 = (ℤ‘0)
3432, 33eleqtrdi 2843 . . . . . . . . . . 11 ((𝜑𝑥 ∈ Word 𝐴) → (♯‘𝑥) ∈ (ℤ‘0))
35 fzn0 13544 . . . . . . . . . . 11 ((0...(♯‘𝑥)) ≠ ∅ ↔ (♯‘𝑥) ∈ (ℤ‘0))
3634, 35sylibr 234 . . . . . . . . . 10 ((𝜑𝑥 ∈ Word 𝐴) → (0...(♯‘𝑥)) ≠ ∅)
3736dmdju 32558 . . . . . . . . 9 (𝜑 → dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) = Word 𝐴)
3837adantr 480 . . . . . . . 8 ((𝜑𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))) → dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) = Word 𝐴)
3930, 38eleqtrd 2835 . . . . . . 7 ((𝜑𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))) → (1st𝑏) ∈ Word 𝐴)
40 pfxcl 14682 . . . . . . 7 ((1st𝑏) ∈ Word 𝐴 → ((1st𝑏) prefix (2nd𝑏)) ∈ Word 𝐴)
4139, 40syl 17 . . . . . 6 ((𝜑𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))) → ((1st𝑏) prefix (2nd𝑏)) ∈ Word 𝐴)
42 swrdcl 14650 . . . . . . 7 ((1st𝑏) ∈ Word 𝐴 → ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩) ∈ Word 𝐴)
4339, 42syl 17 . . . . . 6 ((𝜑𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))) → ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩) ∈ Word 𝐴)
4441, 43opelxpd 5690 . . . . 5 ((𝜑𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))) → ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩ ∈ (Word 𝐴 × Word 𝐴))
45 sneq 4609 . . . . . . . . 9 (𝑤 = 𝑥 → {𝑤} = {𝑥})
46 fveq2 6872 . . . . . . . . . 10 (𝑤 = 𝑥 → (♯‘𝑤) = (♯‘𝑥))
4746oveq2d 7415 . . . . . . . . 9 (𝑤 = 𝑥 → (0...(♯‘𝑤)) = (0...(♯‘𝑥)))
4845, 47xpeq12d 5682 . . . . . . . 8 (𝑤 = 𝑥 → ({𝑤} × (0...(♯‘𝑤))) = ({𝑥} × (0...(♯‘𝑥))))
4948cbviunv 5013 . . . . . . 7 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤))) = 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))
5049mpteq1i 5208 . . . . . 6 (𝑏 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤))) ↦ ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩) = (𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩)
5150a1i 11 . . . . 5 (𝜑 → (𝑏 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤))) ↦ ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩) = (𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩))
5211feqmptd 6943 . . . . 5 (𝜑𝐹 = (𝑎 ∈ (Word 𝐴 × Word 𝐴) ↦ (𝐹𝑎)))
53 fveq2 6872 . . . . 5 (𝑎 = ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩ → (𝐹𝑎) = (𝐹‘⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩))
5444, 51, 52, 53fmptco 7115 . . . 4 (𝜑 → (𝐹 ∘ (𝑏 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤))) ↦ ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩)) = (𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ (𝐹‘⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩)))
5554oveq2d 7415 . . 3 (𝜑 → (𝑀 Σg (𝐹 ∘ (𝑏 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤))) ↦ ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩))) = (𝑀 Σg (𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ (𝐹‘⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩))))
56 nfv 1913 . . . 4 𝑤𝜑
5711, 44cofmpt 7118 . . . . 5 (𝜑 → (𝐹 ∘ (𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩)) = (𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ (𝐹‘⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩)))
5820, 51eqtr2d 2770 . . . . . . . . 9 (𝜑 → (𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩) = (𝑎 ∈ (Word 𝐴 × Word 𝐴) ↦ ⟨((1st𝑎) ++ (2nd𝑎)), (♯‘(1st𝑎))⟩))
5949eqcomi 2743 . . . . . . . . . 10 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) = 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤)))
6059a1i 11 . . . . . . . . 9 (𝜑 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) = 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤))))
61 eqidd 2735 . . . . . . . . 9 (𝜑 → (Word 𝐴 × Word 𝐴) = (Word 𝐴 × Word 𝐴))
6258, 60, 61f1oeq123d 6808 . . . . . . . 8 (𝜑 → ((𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩): 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))–1-1-onto→(Word 𝐴 × Word 𝐴) ↔ (𝑎 ∈ (Word 𝐴 × Word 𝐴) ↦ ⟨((1st𝑎) ++ (2nd𝑎)), (♯‘(1st𝑎))⟩): 𝑤 ∈ Word 𝐴({𝑤} × (0...(♯‘𝑤)))–1-1-onto→(Word 𝐴 × Word 𝐴)))
6319, 62mpbird 257 . . . . . . 7 (𝜑 → (𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩): 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))–1-1-onto→(Word 𝐴 × Word 𝐴))
64 f1of1 6813 . . . . . . 7 ((𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩): 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))–1-1-onto→(Word 𝐴 × Word 𝐴) → (𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩): 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))–1-1→(Word 𝐴 × Word 𝐴))
6563, 64syl 17 . . . . . 6 (𝜑 → (𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩): 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))–1-1→(Word 𝐴 × Word 𝐴))
662fvexi 6886 . . . . . . 7 𝑍 ∈ V
6766a1i 11 . . . . . 6 (𝜑𝑍 ∈ V)
6811, 10fexd 7215 . . . . . 6 (𝜑𝐹 ∈ V)
6912, 65, 67, 68fsuppco 9408 . . . . 5 (𝜑 → (𝐹 ∘ (𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩)) finSupp 𝑍)
7057, 69eqbrtrrd 5140 . . . 4 (𝜑 → (𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ (𝐹‘⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩)) finSupp 𝑍)
7111adantr 480 . . . . . 6 ((𝜑𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))) → 𝐹:(Word 𝐴 × Word 𝐴)⟶𝐵)
7271, 44ffvelcdmd 7071 . . . . 5 ((𝜑𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))) → (𝐹‘⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩) ∈ 𝐵)
7372fmpttd 7101 . . . 4 (𝜑 → (𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ (𝐹‘⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩)): 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))⟶𝐵)
74 vsnex 5401 . . . . . . . 8 {𝑥} ∈ V
75 ovex 7432 . . . . . . . 8 (0...(♯‘𝑥)) ∈ V
7674, 75xpex 7741 . . . . . . 7 ({𝑥} × (0...(♯‘𝑥))) ∈ V
7776a1i 11 . . . . . 6 ((𝜑𝑥 ∈ Word 𝐴) → ({𝑥} × (0...(♯‘𝑥))) ∈ V)
7877ralrimiva 3130 . . . . 5 (𝜑 → ∀𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ∈ V)
79 iunexg 7956 . . . . 5 ((Word 𝐴 ∈ V ∧ ∀𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ∈ V) → 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ∈ V)
809, 78, 79syl2anc 584 . . . 4 (𝜑 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ∈ V)
8156, 1, 2, 28, 70, 3, 73, 80gsumfs2d 32967 . . 3 (𝜑 → (𝑀 Σg (𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ (𝐹‘⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩))) = (𝑀 Σg (𝑤 ∈ dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ (𝑀 Σg (𝑗 ∈ ( 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) “ {𝑤}) ↦ ((𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ (𝐹‘⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩))‘⟨𝑤, 𝑗⟩))))))
8223, 55, 813eqtrd 2773 . 2 (𝜑 → (𝑀 Σg 𝐹) = (𝑀 Σg (𝑤 ∈ dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ (𝑀 Σg (𝑗 ∈ ( 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) “ {𝑤}) ↦ ((𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ (𝐹‘⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩))‘⟨𝑤, 𝑗⟩))))))
83 eqid 2734 . . . . . . 7 (𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ (𝐹‘⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩)) = (𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ (𝐹‘⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩))
84 vex 3461 . . . . . . . . . . 11 𝑤 ∈ V
85 vex 3461 . . . . . . . . . . 11 𝑗 ∈ V
8684, 85op1std 7992 . . . . . . . . . 10 (𝑏 = ⟨𝑤, 𝑗⟩ → (1st𝑏) = 𝑤)
8784, 85op2ndd 7993 . . . . . . . . . 10 (𝑏 = ⟨𝑤, 𝑗⟩ → (2nd𝑏) = 𝑗)
8886, 87oveq12d 7417 . . . . . . . . 9 (𝑏 = ⟨𝑤, 𝑗⟩ → ((1st𝑏) prefix (2nd𝑏)) = (𝑤 prefix 𝑗))
8986fveq2d 6876 . . . . . . . . . . 11 (𝑏 = ⟨𝑤, 𝑗⟩ → (♯‘(1st𝑏)) = (♯‘𝑤))
9087, 89opeq12d 4854 . . . . . . . . . 10 (𝑏 = ⟨𝑤, 𝑗⟩ → ⟨(2nd𝑏), (♯‘(1st𝑏))⟩ = ⟨𝑗, (♯‘𝑤)⟩)
9186, 90oveq12d 7417 . . . . . . . . 9 (𝑏 = ⟨𝑤, 𝑗⟩ → ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩) = (𝑤 substr ⟨𝑗, (♯‘𝑤)⟩))
9288, 91opeq12d 4854 . . . . . . . 8 (𝑏 = ⟨𝑤, 𝑗⟩ → ⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩ = ⟨(𝑤 prefix 𝑗), (𝑤 substr ⟨𝑗, (♯‘𝑤)⟩)⟩)
9392fveq2d 6876 . . . . . . 7 (𝑏 = ⟨𝑤, 𝑗⟩ → (𝐹‘⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩) = (𝐹‘⟨(𝑤 prefix 𝑗), (𝑤 substr ⟨𝑗, (♯‘𝑤)⟩)⟩))
9437eleq2d 2819 . . . . . . . . . 10 (𝜑 → (𝑤 ∈ dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↔ 𝑤 ∈ Word 𝐴))
9594biimpa 476 . . . . . . . . 9 ((𝜑𝑤 ∈ dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))) → 𝑤 ∈ Word 𝐴)
9695adantr 480 . . . . . . . 8 (((𝜑𝑤 ∈ dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))) ∧ 𝑗 ∈ ( 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) “ {𝑤})) → 𝑤 ∈ Word 𝐴)
97 ovexd 7434 . . . . . . . . . . . 12 ((𝜑𝑥 ∈ Word 𝐴) → (0...(♯‘𝑥)) ∈ V)
98 nfcv 2897 . . . . . . . . . . . 12 𝑥(0...(♯‘𝑤))
99 fveq2 6872 . . . . . . . . . . . . 13 (𝑥 = 𝑤 → (♯‘𝑥) = (♯‘𝑤))
10099oveq2d 7415 . . . . . . . . . . . 12 (𝑥 = 𝑤 → (0...(♯‘𝑥)) = (0...(♯‘𝑤)))
1019, 97, 98, 100iunsnima2 32532 . . . . . . . . . . 11 ((𝜑𝑤 ∈ Word 𝐴) → ( 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) “ {𝑤}) = (0...(♯‘𝑤)))
10295, 101syldan 591 . . . . . . . . . 10 ((𝜑𝑤 ∈ dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))) → ( 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) “ {𝑤}) = (0...(♯‘𝑤)))
103102eleq2d 2819 . . . . . . . . 9 ((𝜑𝑤 ∈ dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))) → (𝑗 ∈ ( 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) “ {𝑤}) ↔ 𝑗 ∈ (0...(♯‘𝑤))))
104103biimpa 476 . . . . . . . 8 (((𝜑𝑤 ∈ dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))) ∧ 𝑗 ∈ ( 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) “ {𝑤})) → 𝑗 ∈ (0...(♯‘𝑤)))
105100opeliunxp2 5815 . . . . . . . 8 (⟨𝑤, 𝑗⟩ ∈ 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↔ (𝑤 ∈ Word 𝐴𝑗 ∈ (0...(♯‘𝑤))))
10696, 104, 105sylanbrc 583 . . . . . . 7 (((𝜑𝑤 ∈ dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))) ∧ 𝑗 ∈ ( 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) “ {𝑤})) → ⟨𝑤, 𝑗⟩ ∈ 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))))
107 fvexd 6887 . . . . . . 7 (((𝜑𝑤 ∈ dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))) ∧ 𝑗 ∈ ( 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) “ {𝑤})) → (𝐹‘⟨(𝑤 prefix 𝑗), (𝑤 substr ⟨𝑗, (♯‘𝑤)⟩)⟩) ∈ V)
10883, 93, 106, 107fvmptd3 7005 . . . . . 6 (((𝜑𝑤 ∈ dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))) ∧ 𝑗 ∈ ( 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) “ {𝑤})) → ((𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ (𝐹‘⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩))‘⟨𝑤, 𝑗⟩) = (𝐹‘⟨(𝑤 prefix 𝑗), (𝑤 substr ⟨𝑗, (♯‘𝑤)⟩)⟩))
109108mpteq2dva 5211 . . . . 5 ((𝜑𝑤 ∈ dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))) → (𝑗 ∈ ( 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) “ {𝑤}) ↦ ((𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ (𝐹‘⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩))‘⟨𝑤, 𝑗⟩)) = (𝑗 ∈ ( 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) “ {𝑤}) ↦ (𝐹‘⟨(𝑤 prefix 𝑗), (𝑤 substr ⟨𝑗, (♯‘𝑤)⟩)⟩)))
110109oveq2d 7415 . . . 4 ((𝜑𝑤 ∈ dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))) → (𝑀 Σg (𝑗 ∈ ( 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) “ {𝑤}) ↦ ((𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ (𝐹‘⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩))‘⟨𝑤, 𝑗⟩))) = (𝑀 Σg (𝑗 ∈ ( 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) “ {𝑤}) ↦ (𝐹‘⟨(𝑤 prefix 𝑗), (𝑤 substr ⟨𝑗, (♯‘𝑤)⟩)⟩))))
111110mpteq2dva 5211 . . 3 (𝜑 → (𝑤 ∈ dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ (𝑀 Σg (𝑗 ∈ ( 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) “ {𝑤}) ↦ ((𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ (𝐹‘⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩))‘⟨𝑤, 𝑗⟩)))) = (𝑤 ∈ dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ (𝑀 Σg (𝑗 ∈ ( 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) “ {𝑤}) ↦ (𝐹‘⟨(𝑤 prefix 𝑗), (𝑤 substr ⟨𝑗, (♯‘𝑤)⟩)⟩)))))
112111oveq2d 7415 . 2 (𝜑 → (𝑀 Σg (𝑤 ∈ dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ (𝑀 Σg (𝑗 ∈ ( 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) “ {𝑤}) ↦ ((𝑏 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ (𝐹‘⟨((1st𝑏) prefix (2nd𝑏)), ((1st𝑏) substr ⟨(2nd𝑏), (♯‘(1st𝑏))⟩)⟩))‘⟨𝑤, 𝑗⟩))))) = (𝑀 Σg (𝑤 ∈ dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ (𝑀 Σg (𝑗 ∈ ( 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) “ {𝑤}) ↦ (𝐹‘⟨(𝑤 prefix 𝑗), (𝑤 substr ⟨𝑗, (♯‘𝑤)⟩)⟩))))))
113102mpteq1d 5207 . . . . 5 ((𝜑𝑤 ∈ dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))) → (𝑗 ∈ ( 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) “ {𝑤}) ↦ (𝐹‘⟨(𝑤 prefix 𝑗), (𝑤 substr ⟨𝑗, (♯‘𝑤)⟩)⟩)) = (𝑗 ∈ (0...(♯‘𝑤)) ↦ (𝐹‘⟨(𝑤 prefix 𝑗), (𝑤 substr ⟨𝑗, (♯‘𝑤)⟩)⟩)))
114113oveq2d 7415 . . . 4 ((𝜑𝑤 ∈ dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥)))) → (𝑀 Σg (𝑗 ∈ ( 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) “ {𝑤}) ↦ (𝐹‘⟨(𝑤 prefix 𝑗), (𝑤 substr ⟨𝑗, (♯‘𝑤)⟩)⟩))) = (𝑀 Σg (𝑗 ∈ (0...(♯‘𝑤)) ↦ (𝐹‘⟨(𝑤 prefix 𝑗), (𝑤 substr ⟨𝑗, (♯‘𝑤)⟩)⟩))))
11537, 114mpteq12dva 5203 . . 3 (𝜑 → (𝑤 ∈ dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ (𝑀 Σg (𝑗 ∈ ( 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) “ {𝑤}) ↦ (𝐹‘⟨(𝑤 prefix 𝑗), (𝑤 substr ⟨𝑗, (♯‘𝑤)⟩)⟩)))) = (𝑤 ∈ Word 𝐴 ↦ (𝑀 Σg (𝑗 ∈ (0...(♯‘𝑤)) ↦ (𝐹‘⟨(𝑤 prefix 𝑗), (𝑤 substr ⟨𝑗, (♯‘𝑤)⟩)⟩)))))
116115oveq2d 7415 . 2 (𝜑 → (𝑀 Σg (𝑤 ∈ dom 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) ↦ (𝑀 Σg (𝑗 ∈ ( 𝑥 ∈ Word 𝐴({𝑥} × (0...(♯‘𝑥))) “ {𝑤}) ↦ (𝐹‘⟨(𝑤 prefix 𝑗), (𝑤 substr ⟨𝑗, (♯‘𝑤)⟩)⟩))))) = (𝑀 Σg (𝑤 ∈ Word 𝐴 ↦ (𝑀 Σg (𝑗 ∈ (0...(♯‘𝑤)) ↦ (𝐹‘⟨(𝑤 prefix 𝑗), (𝑤 substr ⟨𝑗, (♯‘𝑤)⟩)⟩))))))
11782, 112, 1163eqtrd 2773 1 (𝜑 → (𝑀 Σg 𝐹) = (𝑀 Σg (𝑤 ∈ Word 𝐴 ↦ (𝑀 Σg (𝑗 ∈ (0...(♯‘𝑤)) ↦ (𝐹‘⟨(𝑤 prefix 𝑗), (𝑤 substr ⟨𝑗, (♯‘𝑤)⟩)⟩))))))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wa 395   = wceq 1539  wcel 2107  wne 2931  wral 3050  Vcvv 3457  wss 3924  c0 4306  {csn 4599  cop 4605   ciun 4964   class class class wbr 5116  cmpt 5198   × cxp 5649  ccnv 5650  dom cdm 5651  cima 5654  ccom 5655  Rel wrel 5656  wf 6523  1-1wf1 6524  1-1-ontowf1o 6526  cfv 6527  (class class class)co 7399  1st c1st 7980  2nd c2nd 7981   finSupp cfsupp 9367  0cc0 11121  0cn0 12493  cuz 12844  ...cfz 13513  chash 14336  Word cword 14519   ++ cconcat 14575   substr csubstr 14645   prefix cpfx 14675  Basecbs 17213  0gc0g 17438   Σg cgsu 17439  CMndccmn 19746
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1794  ax-4 1808  ax-5 1909  ax-6 1966  ax-7 2006  ax-8 2109  ax-9 2117  ax-10 2140  ax-11 2156  ax-12 2176  ax-ext 2706  ax-rep 5246  ax-sep 5263  ax-nul 5273  ax-pow 5332  ax-pr 5399  ax-un 7723  ax-cnex 11177  ax-resscn 11178  ax-1cn 11179  ax-icn 11180  ax-addcl 11181  ax-addrcl 11182  ax-mulcl 11183  ax-mulrcl 11184  ax-mulcom 11185  ax-addass 11186  ax-mulass 11187  ax-distr 11188  ax-i2m1 11189  ax-1ne0 11190  ax-1rid 11191  ax-rnegex 11192  ax-rrecex 11193  ax-cnre 11194  ax-pre-lttri 11195  ax-pre-lttrn 11196  ax-pre-ltadd 11197  ax-pre-mulgt0 11198
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 848  df-3or 1087  df-3an 1088  df-tru 1542  df-fal 1552  df-ex 1779  df-nf 1783  df-sb 2064  df-mo 2538  df-eu 2567  df-clab 2713  df-cleq 2726  df-clel 2808  df-nfc 2884  df-ne 2932  df-nel 3036  df-ral 3051  df-rex 3060  df-rmo 3357  df-reu 3358  df-rab 3414  df-v 3459  df-sbc 3764  df-csb 3873  df-dif 3927  df-un 3929  df-in 3931  df-ss 3941  df-pss 3944  df-nul 4307  df-if 4499  df-pw 4575  df-sn 4600  df-pr 4602  df-op 4606  df-uni 4881  df-int 4920  df-iun 4966  df-iin 4967  df-br 5117  df-opab 5179  df-mpt 5199  df-tr 5227  df-id 5545  df-eprel 5550  df-po 5558  df-so 5559  df-fr 5603  df-se 5604  df-we 5605  df-xp 5657  df-rel 5658  df-cnv 5659  df-co 5660  df-dm 5661  df-rn 5662  df-res 5663  df-ima 5664  df-pred 6287  df-ord 6352  df-on 6353  df-lim 6354  df-suc 6355  df-iota 6480  df-fun 6529  df-fn 6530  df-f 6531  df-f1 6532  df-fo 6533  df-f1o 6534  df-fv 6535  df-isom 6536  df-riota 7356  df-ov 7402  df-oprab 7403  df-mpo 7404  df-of 7665  df-om 7856  df-1st 7982  df-2nd 7983  df-supp 8154  df-frecs 8274  df-wrecs 8305  df-recs 8379  df-rdg 8418  df-1o 8474  df-2o 8475  df-er 8713  df-map 8836  df-en 8954  df-dom 8955  df-sdom 8956  df-fin 8957  df-fsupp 9368  df-oi 9516  df-card 9945  df-pnf 11263  df-mnf 11264  df-xr 11265  df-ltxr 11266  df-le 11267  df-sub 11460  df-neg 11461  df-nn 12233  df-2 12295  df-n0 12494  df-z 12581  df-uz 12845  df-fz 13514  df-fzo 13661  df-seq 14009  df-hash 14337  df-word 14520  df-concat 14576  df-substr 14646  df-pfx 14676  df-sets 17168  df-slot 17186  df-ndx 17198  df-base 17214  df-ress 17237  df-plusg 17269  df-0g 17440  df-gsum 17441  df-mre 17583  df-mrc 17584  df-acs 17586  df-mgm 18603  df-sgrp 18682  df-mnd 18698  df-submnd 18747  df-mulg 19036  df-cntz 19285  df-cmn 19748
This theorem is referenced by:  elrgspnlem2  33156
  Copyright terms: Public domain W3C validator