Users' Mathboxes Mathbox for Steven Nguyen < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >   Mathboxes  >  frlmvscadiccat Structured version   Visualization version   GIF version

Theorem frlmvscadiccat 43003
Description: Scalar multiplication distributes over concatenation. (Contributed by SN, 6-Sep-2023.)
Hypotheses
Ref Expression
frlmfzoccat.w 𝑊 = (𝐾 freeLMod (0..^𝐿))
frlmfzoccat.x 𝑋 = (𝐾 freeLMod (0..^𝑀))
frlmfzoccat.y 𝑌 = (𝐾 freeLMod (0..^𝑁))
frlmfzoccat.b 𝐵 = (Base‘𝑊)
frlmfzoccat.c 𝐶 = (Base‘𝑋)
frlmfzoccat.d 𝐷 = (Base‘𝑌)
frlmfzoccat.k (𝜑𝐾𝑍)
frlmfzoccat.l (𝜑 → (𝑀 + 𝑁) = 𝐿)
frlmfzoccat.m (𝜑𝑀 ∈ ℕ0)
frlmfzoccat.n (𝜑𝑁 ∈ ℕ0)
frlmfzoccat.u (𝜑𝑈𝐶)
frlmfzoccat.v (𝜑𝑉𝐷)
frlmvscadiccat.o 𝑂 = ( ·𝑠𝑊)
frlmvscadiccat.p = ( ·𝑠𝑋)
frlmvscadiccat.q · = ( ·𝑠𝑌)
frlmvscadiccat.s 𝑆 = (Base‘𝐾)
frlmvscadiccat.a (𝜑𝐴𝑆)
Assertion
Ref Expression
frlmvscadiccat (𝜑 → (𝐴𝑂(𝑈 ++ 𝑉)) = ((𝐴 𝑈) ++ (𝐴 · 𝑉)))

Proof of Theorem frlmvscadiccat
Dummy variable 𝑥 is distinct from all other variables.
StepHypRef Expression
1 frlmvscadiccat.a . . . . . . 7 (𝜑𝐴𝑆)
2 fconstg 6721 . . . . . . 7 (𝐴𝑆 → ((0..^𝐿) × {𝐴}):(0..^𝐿)⟶{𝐴})
31, 2syl 17 . . . . . 6 (𝜑 → ((0..^𝐿) × {𝐴}):(0..^𝐿)⟶{𝐴})
43ffnd 6663 . . . . 5 (𝜑 → ((0..^𝐿) × {𝐴}) Fn (0..^𝐿))
5 fconstg 6721 . . . . . . . 8 (𝐴𝑆 → ((0..^𝑀) × {𝐴}):(0..^𝑀)⟶{𝐴})
6 iswrdi 14477 . . . . . . . 8 (((0..^𝑀) × {𝐴}):(0..^𝑀)⟶{𝐴} → ((0..^𝑀) × {𝐴}) ∈ Word {𝐴})
71, 5, 63syl 18 . . . . . . 7 (𝜑 → ((0..^𝑀) × {𝐴}) ∈ Word {𝐴})
8 fconstg 6721 . . . . . . . 8 (𝐴𝑆 → ((0..^𝑁) × {𝐴}):(0..^𝑁)⟶{𝐴})
9 iswrdi 14477 . . . . . . . 8 (((0..^𝑁) × {𝐴}):(0..^𝑁)⟶{𝐴} → ((0..^𝑁) × {𝐴}) ∈ Word {𝐴})
101, 8, 93syl 18 . . . . . . 7 (𝜑 → ((0..^𝑁) × {𝐴}) ∈ Word {𝐴})
11 ccatvalfn 14541 . . . . . . 7 ((((0..^𝑀) × {𝐴}) ∈ Word {𝐴} ∧ ((0..^𝑁) × {𝐴}) ∈ Word {𝐴}) → (((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴})) Fn (0..^((♯‘((0..^𝑀) × {𝐴})) + (♯‘((0..^𝑁) × {𝐴})))))
127, 10, 11syl2anc 590 . . . . . 6 (𝜑 → (((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴})) Fn (0..^((♯‘((0..^𝑀) × {𝐴})) + (♯‘((0..^𝑁) × {𝐴})))))
13 fzofi 13934 . . . . . . . . . . . 12 (0..^𝑀) ∈ Fin
14 snfi 8987 . . . . . . . . . . . 12 {𝐴} ∈ Fin
15 hashxp 14394 . . . . . . . . . . . 12 (((0..^𝑀) ∈ Fin ∧ {𝐴} ∈ Fin) → (♯‘((0..^𝑀) × {𝐴})) = ((♯‘(0..^𝑀)) · (♯‘{𝐴})))
1613, 14, 15mp2an 698 . . . . . . . . . . 11 (♯‘((0..^𝑀) × {𝐴})) = ((♯‘(0..^𝑀)) · (♯‘{𝐴}))
17 hashsng 14329 . . . . . . . . . . . . . 14 (𝐴𝑆 → (♯‘{𝐴}) = 1)
181, 17syl 17 . . . . . . . . . . . . 13 (𝜑 → (♯‘{𝐴}) = 1)
1918oveq2d 7379 . . . . . . . . . . . 12 (𝜑 → ((♯‘(0..^𝑀)) · (♯‘{𝐴})) = ((♯‘(0..^𝑀)) · 1))
20 hashcl 14316 . . . . . . . . . . . . . . 15 ((0..^𝑀) ∈ Fin → (♯‘(0..^𝑀)) ∈ ℕ0)
2113, 20mp1i 13 . . . . . . . . . . . . . 14 (𝜑 → (♯‘(0..^𝑀)) ∈ ℕ0)
2221nn0cnd 12498 . . . . . . . . . . . . 13 (𝜑 → (♯‘(0..^𝑀)) ∈ ℂ)
2322mulridd 11160 . . . . . . . . . . . 12 (𝜑 → ((♯‘(0..^𝑀)) · 1) = (♯‘(0..^𝑀)))
24 frlmfzoccat.m . . . . . . . . . . . . 13 (𝜑𝑀 ∈ ℕ0)
25 hashfzo0 14390 . . . . . . . . . . . . 13 (𝑀 ∈ ℕ0 → (♯‘(0..^𝑀)) = 𝑀)
2624, 25syl 17 . . . . . . . . . . . 12 (𝜑 → (♯‘(0..^𝑀)) = 𝑀)
2719, 23, 263eqtrd 2779 . . . . . . . . . . 11 (𝜑 → ((♯‘(0..^𝑀)) · (♯‘{𝐴})) = 𝑀)
2816, 27eqtrid 2787 . . . . . . . . . 10 (𝜑 → (♯‘((0..^𝑀) × {𝐴})) = 𝑀)
29 fzofi 13934 . . . . . . . . . . . 12 (0..^𝑁) ∈ Fin
30 hashxp 14394 . . . . . . . . . . . 12 (((0..^𝑁) ∈ Fin ∧ {𝐴} ∈ Fin) → (♯‘((0..^𝑁) × {𝐴})) = ((♯‘(0..^𝑁)) · (♯‘{𝐴})))
3129, 14, 30mp2an 698 . . . . . . . . . . 11 (♯‘((0..^𝑁) × {𝐴})) = ((♯‘(0..^𝑁)) · (♯‘{𝐴}))
3218oveq2d 7379 . . . . . . . . . . . 12 (𝜑 → ((♯‘(0..^𝑁)) · (♯‘{𝐴})) = ((♯‘(0..^𝑁)) · 1))
33 hashcl 14316 . . . . . . . . . . . . . . 15 ((0..^𝑁) ∈ Fin → (♯‘(0..^𝑁)) ∈ ℕ0)
3429, 33mp1i 13 . . . . . . . . . . . . . 14 (𝜑 → (♯‘(0..^𝑁)) ∈ ℕ0)
3534nn0cnd 12498 . . . . . . . . . . . . 13 (𝜑 → (♯‘(0..^𝑁)) ∈ ℂ)
3635mulridd 11160 . . . . . . . . . . . 12 (𝜑 → ((♯‘(0..^𝑁)) · 1) = (♯‘(0..^𝑁)))
37 frlmfzoccat.n . . . . . . . . . . . . 13 (𝜑𝑁 ∈ ℕ0)
38 hashfzo0 14390 . . . . . . . . . . . . 13 (𝑁 ∈ ℕ0 → (♯‘(0..^𝑁)) = 𝑁)
3937, 38syl 17 . . . . . . . . . . . 12 (𝜑 → (♯‘(0..^𝑁)) = 𝑁)
4032, 36, 393eqtrd 2779 . . . . . . . . . . 11 (𝜑 → ((♯‘(0..^𝑁)) · (♯‘{𝐴})) = 𝑁)
4131, 40eqtrid 2787 . . . . . . . . . 10 (𝜑 → (♯‘((0..^𝑁) × {𝐴})) = 𝑁)
4228, 41oveq12d 7381 . . . . . . . . 9 (𝜑 → ((♯‘((0..^𝑀) × {𝐴})) + (♯‘((0..^𝑁) × {𝐴}))) = (𝑀 + 𝑁))
43 frlmfzoccat.l . . . . . . . . 9 (𝜑 → (𝑀 + 𝑁) = 𝐿)
4442, 43eqtrd 2775 . . . . . . . 8 (𝜑 → ((♯‘((0..^𝑀) × {𝐴})) + (♯‘((0..^𝑁) × {𝐴}))) = 𝐿)
4544oveq2d 7379 . . . . . . 7 (𝜑 → (0..^((♯‘((0..^𝑀) × {𝐴})) + (♯‘((0..^𝑁) × {𝐴})))) = (0..^𝐿))
4645fneq2d 6586 . . . . . 6 (𝜑 → ((((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴})) Fn (0..^((♯‘((0..^𝑀) × {𝐴})) + (♯‘((0..^𝑁) × {𝐴})))) ↔ (((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴})) Fn (0..^𝐿)))
4712, 46mpbid 233 . . . . 5 (𝜑 → (((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴})) Fn (0..^𝐿))
4828adantr 481 . . . . . . . . 9 ((𝜑𝑥 ∈ (0..^𝐿)) → (♯‘((0..^𝑀) × {𝐴})) = 𝑀)
4948breq2d 5091 . . . . . . . 8 ((𝜑𝑥 ∈ (0..^𝐿)) → (𝑥 < (♯‘((0..^𝑀) × {𝐴})) ↔ 𝑥 < 𝑀))
5049ifbid 4485 . . . . . . 7 ((𝜑𝑥 ∈ (0..^𝐿)) → if(𝑥 < (♯‘((0..^𝑀) × {𝐴})), (((0..^𝑀) × {𝐴})‘𝑥), (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴}))))) = if(𝑥 < 𝑀, (((0..^𝑀) × {𝐴})‘𝑥), (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴}))))))
511adantr 481 . . . . . . . . 9 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝐴𝑆)
52 elfzouz 13616 . . . . . . . . . . 11 (𝑥 ∈ (0..^𝐿) → 𝑥 ∈ (ℤ‘0))
5352ad2antlr 733 . . . . . . . . . 10 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ 𝑥 < 𝑀) → 𝑥 ∈ (ℤ‘0))
5424ad2antrr 732 . . . . . . . . . . 11 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ 𝑥 < 𝑀) → 𝑀 ∈ ℕ0)
5554nn0zd 12547 . . . . . . . . . 10 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ 𝑥 < 𝑀) → 𝑀 ∈ ℤ)
56 simpr 485 . . . . . . . . . 10 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ 𝑥 < 𝑀) → 𝑥 < 𝑀)
57 elfzo2 13614 . . . . . . . . . 10 (𝑥 ∈ (0..^𝑀) ↔ (𝑥 ∈ (ℤ‘0) ∧ 𝑀 ∈ ℤ ∧ 𝑥 < 𝑀))
5853, 55, 56, 57syl3anbrc 1350 . . . . . . . . 9 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ 𝑥 < 𝑀) → 𝑥 ∈ (0..^𝑀))
59 fvconst2g 7153 . . . . . . . . 9 ((𝐴𝑆𝑥 ∈ (0..^𝑀)) → (((0..^𝑀) × {𝐴})‘𝑥) = 𝐴)
6051, 58, 59syl2an2r 691 . . . . . . . 8 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ 𝑥 < 𝑀) → (((0..^𝑀) × {𝐴})‘𝑥) = 𝐴)
6128ad2antrr 732 . . . . . . . . . . 11 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (♯‘((0..^𝑀) × {𝐴})) = 𝑀)
6261oveq2d 7379 . . . . . . . . . 10 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (𝑥 − (♯‘((0..^𝑀) × {𝐴}))) = (𝑥𝑀))
6324ad2antrr 732 . . . . . . . . . . . . 13 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → 𝑀 ∈ ℕ0)
64 elfzonn0 13660 . . . . . . . . . . . . . 14 (𝑥 ∈ (0..^𝐿) → 𝑥 ∈ ℕ0)
6564ad2antlr 733 . . . . . . . . . . . . 13 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → 𝑥 ∈ ℕ0)
6624adantr 481 . . . . . . . . . . . . . . . 16 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑀 ∈ ℕ0)
6766nn0red 12497 . . . . . . . . . . . . . . 15 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑀 ∈ ℝ)
68 elfzoelz 13611 . . . . . . . . . . . . . . . . 17 (𝑥 ∈ (0..^𝐿) → 𝑥 ∈ ℤ)
6968adantl 482 . . . . . . . . . . . . . . . 16 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑥 ∈ ℤ)
7069zred 12631 . . . . . . . . . . . . . . 15 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑥 ∈ ℝ)
7167, 70lenltd 11290 . . . . . . . . . . . . . 14 ((𝜑𝑥 ∈ (0..^𝐿)) → (𝑀𝑥 ↔ ¬ 𝑥 < 𝑀))
7271biimpar 478 . . . . . . . . . . . . 13 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → 𝑀𝑥)
73 nn0sub2 12588 . . . . . . . . . . . . 13 ((𝑀 ∈ ℕ0𝑥 ∈ ℕ0𝑀𝑥) → (𝑥𝑀) ∈ ℕ0)
7463, 65, 72, 73syl3anc 1379 . . . . . . . . . . . 12 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (𝑥𝑀) ∈ ℕ0)
75 elnn0uz 12827 . . . . . . . . . . . 12 ((𝑥𝑀) ∈ ℕ0 ↔ (𝑥𝑀) ∈ (ℤ‘0))
7674, 75sylib 219 . . . . . . . . . . 11 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (𝑥𝑀) ∈ (ℤ‘0))
7737ad2antrr 732 . . . . . . . . . . . 12 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → 𝑁 ∈ ℕ0)
7877nn0zd 12547 . . . . . . . . . . 11 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → 𝑁 ∈ ℤ)
79 elfzolt2 13621 . . . . . . . . . . . . . . 15 (𝑥 ∈ (0..^𝐿) → 𝑥 < 𝐿)
8079adantl 482 . . . . . . . . . . . . . 14 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑥 < 𝐿)
8167recnd 11171 . . . . . . . . . . . . . . 15 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑀 ∈ ℂ)
8270recnd 11171 . . . . . . . . . . . . . . 15 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑥 ∈ ℂ)
8381, 82pncan3d 11506 . . . . . . . . . . . . . 14 ((𝜑𝑥 ∈ (0..^𝐿)) → (𝑀 + (𝑥𝑀)) = 𝑥)
8443adantr 481 . . . . . . . . . . . . . 14 ((𝜑𝑥 ∈ (0..^𝐿)) → (𝑀 + 𝑁) = 𝐿)
8580, 83, 843brtr4d 5111 . . . . . . . . . . . . 13 ((𝜑𝑥 ∈ (0..^𝐿)) → (𝑀 + (𝑥𝑀)) < (𝑀 + 𝑁))
8670, 67resubcld 11576 . . . . . . . . . . . . . 14 ((𝜑𝑥 ∈ (0..^𝐿)) → (𝑥𝑀) ∈ ℝ)
8737adantr 481 . . . . . . . . . . . . . . 15 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑁 ∈ ℕ0)
8887nn0red 12497 . . . . . . . . . . . . . 14 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑁 ∈ ℝ)
8986, 88, 67ltadd2d 11300 . . . . . . . . . . . . 13 ((𝜑𝑥 ∈ (0..^𝐿)) → ((𝑥𝑀) < 𝑁 ↔ (𝑀 + (𝑥𝑀)) < (𝑀 + 𝑁)))
9085, 89mpbird 258 . . . . . . . . . . . 12 ((𝜑𝑥 ∈ (0..^𝐿)) → (𝑥𝑀) < 𝑁)
9190adantr 481 . . . . . . . . . . 11 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (𝑥𝑀) < 𝑁)
92 elfzo2 13614 . . . . . . . . . . 11 ((𝑥𝑀) ∈ (0..^𝑁) ↔ ((𝑥𝑀) ∈ (ℤ‘0) ∧ 𝑁 ∈ ℤ ∧ (𝑥𝑀) < 𝑁))
9376, 78, 91, 92syl3anbrc 1350 . . . . . . . . . 10 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (𝑥𝑀) ∈ (0..^𝑁))
9462, 93eqeltrd 2840 . . . . . . . . 9 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (𝑥 − (♯‘((0..^𝑀) × {𝐴}))) ∈ (0..^𝑁))
95 fvconst2g 7153 . . . . . . . . 9 ((𝐴𝑆 ∧ (𝑥 − (♯‘((0..^𝑀) × {𝐴}))) ∈ (0..^𝑁)) → (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴})))) = 𝐴)
9651, 94, 95syl2an2r 691 . . . . . . . 8 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴})))) = 𝐴)
9760, 96ifeqda 4498 . . . . . . 7 ((𝜑𝑥 ∈ (0..^𝐿)) → if(𝑥 < 𝑀, (((0..^𝑀) × {𝐴})‘𝑥), (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴}))))) = 𝐴)
9850, 97eqtr2d 2776 . . . . . 6 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝐴 = if(𝑥 < (♯‘((0..^𝑀) × {𝐴})), (((0..^𝑀) × {𝐴})‘𝑥), (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴}))))))
99 fvconst2g 7153 . . . . . . 7 ((𝐴𝑆𝑥 ∈ (0..^𝐿)) → (((0..^𝐿) × {𝐴})‘𝑥) = 𝐴)
1001, 99sylan 586 . . . . . 6 ((𝜑𝑥 ∈ (0..^𝐿)) → (((0..^𝐿) × {𝐴})‘𝑥) = 𝐴)
10151, 5, 63syl 18 . . . . . . 7 ((𝜑𝑥 ∈ (0..^𝐿)) → ((0..^𝑀) × {𝐴}) ∈ Word {𝐴})
10251, 8, 93syl 18 . . . . . . 7 ((𝜑𝑥 ∈ (0..^𝐿)) → ((0..^𝑁) × {𝐴}) ∈ Word {𝐴})
103 ccatsymb 14543 . . . . . . 7 ((((0..^𝑀) × {𝐴}) ∈ Word {𝐴} ∧ ((0..^𝑁) × {𝐴}) ∈ Word {𝐴} ∧ 𝑥 ∈ ℤ) → ((((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴}))‘𝑥) = if(𝑥 < (♯‘((0..^𝑀) × {𝐴})), (((0..^𝑀) × {𝐴})‘𝑥), (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴}))))))
104101, 102, 69, 103syl3anc 1379 . . . . . 6 ((𝜑𝑥 ∈ (0..^𝐿)) → ((((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴}))‘𝑥) = if(𝑥 < (♯‘((0..^𝑀) × {𝐴})), (((0..^𝑀) × {𝐴})‘𝑥), (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴}))))))
10598, 100, 1043eqtr4d 2785 . . . . 5 ((𝜑𝑥 ∈ (0..^𝐿)) → (((0..^𝐿) × {𝐴})‘𝑥) = ((((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴}))‘𝑥))
1064, 47, 105eqfnfvd 6981 . . . 4 (𝜑 → ((0..^𝐿) × {𝐴}) = (((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴})))
107106oveq1d 7378 . . 3 (𝜑 → (((0..^𝐿) × {𝐴}) ∘f (.r𝐾)(𝑈 ++ 𝑉)) = ((((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴})) ∘f (.r𝐾)(𝑈 ++ 𝑉)))
108 frlmfzoccat.u . . . . 5 (𝜑𝑈𝐶)
109 frlmfzoccat.x . . . . . 6 𝑋 = (𝐾 freeLMod (0..^𝑀))
110 frlmfzoccat.c . . . . . 6 𝐶 = (Base‘𝑋)
111 frlmvscadiccat.s . . . . . 6 𝑆 = (Base‘𝐾)
112109, 110, 111frlmfzowrd 42999 . . . . 5 (𝑈𝐶𝑈 ∈ Word 𝑆)
113108, 112syl 17 . . . 4 (𝜑𝑈 ∈ Word 𝑆)
114 frlmfzoccat.v . . . . 5 (𝜑𝑉𝐷)
115 frlmfzoccat.y . . . . . 6 𝑌 = (𝐾 freeLMod (0..^𝑁))
116 frlmfzoccat.d . . . . . 6 𝐷 = (Base‘𝑌)
117115, 116, 111frlmfzowrd 42999 . . . . 5 (𝑉𝐷𝑉 ∈ Word 𝑆)
118114, 117syl 17 . . . 4 (𝜑𝑉 ∈ Word 𝑆)
11916, 19eqtrid 2787 . . . . 5 (𝜑 → (♯‘((0..^𝑀) × {𝐴})) = ((♯‘(0..^𝑀)) · 1))
120 ovexd 7398 . . . . . . . 8 (𝜑 → (0..^𝑀) ∈ V)
121109, 111, 110frlmbasf 21742 . . . . . . . 8 (((0..^𝑀) ∈ V ∧ 𝑈𝐶) → 𝑈:(0..^𝑀)⟶𝑆)
122120, 108, 121syl2anc 590 . . . . . . 7 (𝜑𝑈:(0..^𝑀)⟶𝑆)
123122ffnd 6663 . . . . . 6 (𝜑𝑈 Fn (0..^𝑀))
124 hashfn 14335 . . . . . 6 (𝑈 Fn (0..^𝑀) → (♯‘𝑈) = (♯‘(0..^𝑀)))
125123, 124syl 17 . . . . 5 (𝜑 → (♯‘𝑈) = (♯‘(0..^𝑀)))
12623, 119, 1253eqtr4d 2785 . . . 4 (𝜑 → (♯‘((0..^𝑀) × {𝐴})) = (♯‘𝑈))
12732, 36eqtrd 2775 . . . . . 6 (𝜑 → ((♯‘(0..^𝑁)) · (♯‘{𝐴})) = (♯‘(0..^𝑁)))
12831, 127eqtrid 2787 . . . . 5 (𝜑 → (♯‘((0..^𝑁) × {𝐴})) = (♯‘(0..^𝑁)))
129 ovexd 7398 . . . . . . . 8 (𝜑 → (0..^𝑁) ∈ V)
130115, 111, 116frlmbasf 21742 . . . . . . . 8 (((0..^𝑁) ∈ V ∧ 𝑉𝐷) → 𝑉:(0..^𝑁)⟶𝑆)
131129, 114, 130syl2anc 590 . . . . . . 7 (𝜑𝑉:(0..^𝑁)⟶𝑆)
132131ffnd 6663 . . . . . 6 (𝜑𝑉 Fn (0..^𝑁))
133 hashfn 14335 . . . . . 6 (𝑉 Fn (0..^𝑁) → (♯‘𝑉) = (♯‘(0..^𝑁)))
134132, 133syl 17 . . . . 5 (𝜑 → (♯‘𝑉) = (♯‘(0..^𝑁)))
135128, 134eqtr4d 2778 . . . 4 (𝜑 → (♯‘((0..^𝑁) × {𝐴})) = (♯‘𝑉))
1367, 10, 113, 118, 126, 135ofccat 14929 . . 3 (𝜑 → ((((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴})) ∘f (.r𝐾)(𝑈 ++ 𝑉)) = ((((0..^𝑀) × {𝐴}) ∘f (.r𝐾)𝑈) ++ (((0..^𝑁) × {𝐴}) ∘f (.r𝐾)𝑉)))
137107, 136eqtrd 2775 . 2 (𝜑 → (((0..^𝐿) × {𝐴}) ∘f (.r𝐾)(𝑈 ++ 𝑉)) = ((((0..^𝑀) × {𝐴}) ∘f (.r𝐾)𝑈) ++ (((0..^𝑁) × {𝐴}) ∘f (.r𝐾)𝑉)))
138 frlmfzoccat.w . . 3 𝑊 = (𝐾 freeLMod (0..^𝐿))
139 frlmfzoccat.b . . 3 𝐵 = (Base‘𝑊)
140 ovexd 7398 . . 3 (𝜑 → (0..^𝐿) ∈ V)
141 frlmfzoccat.k . . . 4 (𝜑𝐾𝑍)
142138, 109, 115, 139, 110, 116, 141, 43, 24, 37, 108, 114frlmfzoccat 43002 . . 3 (𝜑 → (𝑈 ++ 𝑉) ∈ 𝐵)
143 frlmvscadiccat.o . . 3 𝑂 = ( ·𝑠𝑊)
144 eqid 2740 . . 3 (.r𝐾) = (.r𝐾)
145138, 139, 111, 140, 1, 142, 143, 144frlmvscafval 21748 . 2 (𝜑 → (𝐴𝑂(𝑈 ++ 𝑉)) = (((0..^𝐿) × {𝐴}) ∘f (.r𝐾)(𝑈 ++ 𝑉)))
146 frlmvscadiccat.p . . . 4 = ( ·𝑠𝑋)
147109, 110, 111, 120, 1, 108, 146, 144frlmvscafval 21748 . . 3 (𝜑 → (𝐴 𝑈) = (((0..^𝑀) × {𝐴}) ∘f (.r𝐾)𝑈))
148 frlmvscadiccat.q . . . 4 · = ( ·𝑠𝑌)
149115, 116, 111, 129, 1, 114, 148, 144frlmvscafval 21748 . . 3 (𝜑 → (𝐴 · 𝑉) = (((0..^𝑁) × {𝐴}) ∘f (.r𝐾)𝑉))
150147, 149oveq12d 7381 . 2 (𝜑 → ((𝐴 𝑈) ++ (𝐴 · 𝑉)) = ((((0..^𝑀) × {𝐴}) ∘f (.r𝐾)𝑈) ++ (((0..^𝑁) × {𝐴}) ∘f (.r𝐾)𝑉)))
151137, 145, 1503eqtr4d 2785 1 (𝜑 → (𝐴𝑂(𝑈 ++ 𝑉)) = ((𝐴 𝑈) ++ (𝐴 · 𝑉)))
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wa 396   = wceq 1547  wcel 2119  Vcvv 3432  ifcif 4461  {csn 4562   class class class wbr 5079   × cxp 5623   Fn wfn 6487  wf 6488  cfv 6492  (class class class)co 7363  f cof 7625  Fincfn 8890  0cc0 11036  1c1 11037   + caddc 11039   · cmul 11041   < clt 11177  cle 11178  cmin 11375  0cn0 12435  cz 12522  cuz 12786  ..^cfzo 13606  chash 14290  Word cword 14473   ++ cconcat 14530  Basecbs 17177  .rcmulr 17219   ·𝑠 cvsca 17222   freeLMod cfrlm 21728
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1802  ax-4 1816  ax-5 1917  ax-6 1974  ax-7 2015  ax-8 2121  ax-9 2129  ax-10 2152  ax-11 2168  ax-12 2189  ax-ext 2712  ax-rep 5206  ax-sep 5225  ax-nul 5235  ax-pow 5301  ax-pr 5369  ax-un 7685  ax-cnex 11092  ax-resscn 11093  ax-1cn 11094  ax-icn 11095  ax-addcl 11096  ax-addrcl 11097  ax-mulcl 11098  ax-mulrcl 11099  ax-mulcom 11100  ax-addass 11101  ax-mulass 11102  ax-distr 11103  ax-i2m1 11104  ax-1ne0 11105  ax-1rid 11106  ax-rnegex 11107  ax-rrecex 11108  ax-cnre 11109  ax-pre-lttri 11110  ax-pre-lttrn 11111  ax-pre-ltadd 11112  ax-pre-mulgt0 11113
This theorem depends on definitions:  df-bi 208  df-an 397  df-or 854  df-3or 1093  df-3an 1094  df-tru 1550  df-fal 1560  df-ex 1787  df-nf 1791  df-sb 2074  df-mo 2543  df-eu 2573  df-clab 2719  df-cleq 2732  df-clel 2815  df-nfc 2889  df-ne 2936  df-nel 3040  df-ral 3055  df-rex 3065  df-reu 3346  df-rab 3393  df-v 3434  df-sbc 3731  df-csb 3839  df-dif 3893  df-un 3895  df-in 3897  df-ss 3907  df-pss 3910  df-nul 4269  df-if 4462  df-pw 4538  df-sn 4563  df-pr 4565  df-tp 4567  df-op 4569  df-uni 4846  df-int 4885  df-iun 4930  df-br 5080  df-opab 5142  df-mpt 5161  df-tr 5187  df-id 5520  df-eprel 5525  df-po 5533  df-so 5534  df-fr 5578  df-we 5580  df-xp 5631  df-rel 5632  df-cnv 5633  df-co 5634  df-dm 5635  df-rn 5636  df-res 5637  df-ima 5638  df-pred 6259  df-ord 6320  df-on 6321  df-lim 6322  df-suc 6323  df-iota 6448  df-fun 6494  df-fn 6495  df-f 6496  df-f1 6497  df-fo 6498  df-f1o 6499  df-fv 6500  df-riota 7320  df-ov 7366  df-oprab 7367  df-mpo 7368  df-of 7627  df-om 7814  df-1st 7938  df-2nd 7939  df-supp 8108  df-frecs 8228  df-wrecs 8259  df-recs 8308  df-rdg 8346  df-1o 8402  df-oadd 8406  df-er 8640  df-map 8772  df-ixp 8843  df-en 8891  df-dom 8892  df-sdom 8893  df-fin 8894  df-fsupp 9272  df-sup 9352  df-dju 9823  df-card 9861  df-pnf 11179  df-mnf 11180  df-xr 11181  df-ltxr 11182  df-le 11183  df-sub 11377  df-neg 11378  df-nn 12173  df-2 12242  df-3 12243  df-4 12244  df-5 12245  df-6 12246  df-7 12247  df-8 12248  df-9 12249  df-n0 12436  df-z 12523  df-dec 12643  df-uz 12787  df-fz 13460  df-fzo 13607  df-hash 14291  df-word 14474  df-concat 14531  df-struct 17115  df-sets 17132  df-slot 17150  df-ndx 17162  df-base 17178  df-ress 17199  df-plusg 17231  df-mulr 17232  df-sca 17234  df-vsca 17235  df-ip 17236  df-tset 17237  df-ple 17238  df-ds 17240  df-hom 17242  df-cco 17243  df-0g 17402  df-prds 17408  df-pws 17410  df-sra 21170  df-rgmod 21171  df-dsmm 21714  df-frlm 21729
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator