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 42482
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 6715 . . . . . . 7 (𝐴𝑆 → ((0..^𝐿) × {𝐴}):(0..^𝐿)⟶{𝐴})
31, 2syl 17 . . . . . 6 (𝜑 → ((0..^𝐿) × {𝐴}):(0..^𝐿)⟶{𝐴})
43ffnd 6657 . . . . 5 (𝜑 → ((0..^𝐿) × {𝐴}) Fn (0..^𝐿))
5 fconstg 6715 . . . . . . . 8 (𝐴𝑆 → ((0..^𝑀) × {𝐴}):(0..^𝑀)⟶{𝐴})
6 iswrdi 14442 . . . . . . . 8 (((0..^𝑀) × {𝐴}):(0..^𝑀)⟶{𝐴} → ((0..^𝑀) × {𝐴}) ∈ Word {𝐴})
71, 5, 63syl 18 . . . . . . 7 (𝜑 → ((0..^𝑀) × {𝐴}) ∈ Word {𝐴})
8 fconstg 6715 . . . . . . . 8 (𝐴𝑆 → ((0..^𝑁) × {𝐴}):(0..^𝑁)⟶{𝐴})
9 iswrdi 14442 . . . . . . . 8 (((0..^𝑁) × {𝐴}):(0..^𝑁)⟶{𝐴} → ((0..^𝑁) × {𝐴}) ∈ Word {𝐴})
101, 8, 93syl 18 . . . . . . 7 (𝜑 → ((0..^𝑁) × {𝐴}) ∈ Word {𝐴})
11 ccatvalfn 14506 . . . . . . 7 ((((0..^𝑀) × {𝐴}) ∈ Word {𝐴} ∧ ((0..^𝑁) × {𝐴}) ∈ Word {𝐴}) → (((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴})) Fn (0..^((♯‘((0..^𝑀) × {𝐴})) + (♯‘((0..^𝑁) × {𝐴})))))
127, 10, 11syl2anc 584 . . . . . 6 (𝜑 → (((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴})) Fn (0..^((♯‘((0..^𝑀) × {𝐴})) + (♯‘((0..^𝑁) × {𝐴})))))
13 fzofi 13899 . . . . . . . . . . . 12 (0..^𝑀) ∈ Fin
14 snfi 8975 . . . . . . . . . . . 12 {𝐴} ∈ Fin
15 hashxp 14359 . . . . . . . . . . . 12 (((0..^𝑀) ∈ Fin ∧ {𝐴} ∈ Fin) → (♯‘((0..^𝑀) × {𝐴})) = ((♯‘(0..^𝑀)) · (♯‘{𝐴})))
1613, 14, 15mp2an 692 . . . . . . . . . . 11 (♯‘((0..^𝑀) × {𝐴})) = ((♯‘(0..^𝑀)) · (♯‘{𝐴}))
17 hashsng 14294 . . . . . . . . . . . . . 14 (𝐴𝑆 → (♯‘{𝐴}) = 1)
181, 17syl 17 . . . . . . . . . . . . 13 (𝜑 → (♯‘{𝐴}) = 1)
1918oveq2d 7369 . . . . . . . . . . . 12 (𝜑 → ((♯‘(0..^𝑀)) · (♯‘{𝐴})) = ((♯‘(0..^𝑀)) · 1))
20 hashcl 14281 . . . . . . . . . . . . . . 15 ((0..^𝑀) ∈ Fin → (♯‘(0..^𝑀)) ∈ ℕ0)
2113, 20mp1i 13 . . . . . . . . . . . . . 14 (𝜑 → (♯‘(0..^𝑀)) ∈ ℕ0)
2221nn0cnd 12465 . . . . . . . . . . . . 13 (𝜑 → (♯‘(0..^𝑀)) ∈ ℂ)
2322mulridd 11151 . . . . . . . . . . . 12 (𝜑 → ((♯‘(0..^𝑀)) · 1) = (♯‘(0..^𝑀)))
24 frlmfzoccat.m . . . . . . . . . . . . 13 (𝜑𝑀 ∈ ℕ0)
25 hashfzo0 14355 . . . . . . . . . . . . 13 (𝑀 ∈ ℕ0 → (♯‘(0..^𝑀)) = 𝑀)
2624, 25syl 17 . . . . . . . . . . . 12 (𝜑 → (♯‘(0..^𝑀)) = 𝑀)
2719, 23, 263eqtrd 2768 . . . . . . . . . . 11 (𝜑 → ((♯‘(0..^𝑀)) · (♯‘{𝐴})) = 𝑀)
2816, 27eqtrid 2776 . . . . . . . . . 10 (𝜑 → (♯‘((0..^𝑀) × {𝐴})) = 𝑀)
29 fzofi 13899 . . . . . . . . . . . 12 (0..^𝑁) ∈ Fin
30 hashxp 14359 . . . . . . . . . . . 12 (((0..^𝑁) ∈ Fin ∧ {𝐴} ∈ Fin) → (♯‘((0..^𝑁) × {𝐴})) = ((♯‘(0..^𝑁)) · (♯‘{𝐴})))
3129, 14, 30mp2an 692 . . . . . . . . . . 11 (♯‘((0..^𝑁) × {𝐴})) = ((♯‘(0..^𝑁)) · (♯‘{𝐴}))
3218oveq2d 7369 . . . . . . . . . . . 12 (𝜑 → ((♯‘(0..^𝑁)) · (♯‘{𝐴})) = ((♯‘(0..^𝑁)) · 1))
33 hashcl 14281 . . . . . . . . . . . . . . 15 ((0..^𝑁) ∈ Fin → (♯‘(0..^𝑁)) ∈ ℕ0)
3429, 33mp1i 13 . . . . . . . . . . . . . 14 (𝜑 → (♯‘(0..^𝑁)) ∈ ℕ0)
3534nn0cnd 12465 . . . . . . . . . . . . 13 (𝜑 → (♯‘(0..^𝑁)) ∈ ℂ)
3635mulridd 11151 . . . . . . . . . . . 12 (𝜑 → ((♯‘(0..^𝑁)) · 1) = (♯‘(0..^𝑁)))
37 frlmfzoccat.n . . . . . . . . . . . . 13 (𝜑𝑁 ∈ ℕ0)
38 hashfzo0 14355 . . . . . . . . . . . . 13 (𝑁 ∈ ℕ0 → (♯‘(0..^𝑁)) = 𝑁)
3937, 38syl 17 . . . . . . . . . . . 12 (𝜑 → (♯‘(0..^𝑁)) = 𝑁)
4032, 36, 393eqtrd 2768 . . . . . . . . . . 11 (𝜑 → ((♯‘(0..^𝑁)) · (♯‘{𝐴})) = 𝑁)
4131, 40eqtrid 2776 . . . . . . . . . 10 (𝜑 → (♯‘((0..^𝑁) × {𝐴})) = 𝑁)
4228, 41oveq12d 7371 . . . . . . . . 9 (𝜑 → ((♯‘((0..^𝑀) × {𝐴})) + (♯‘((0..^𝑁) × {𝐴}))) = (𝑀 + 𝑁))
43 frlmfzoccat.l . . . . . . . . 9 (𝜑 → (𝑀 + 𝑁) = 𝐿)
4442, 43eqtrd 2764 . . . . . . . 8 (𝜑 → ((♯‘((0..^𝑀) × {𝐴})) + (♯‘((0..^𝑁) × {𝐴}))) = 𝐿)
4544oveq2d 7369 . . . . . . 7 (𝜑 → (0..^((♯‘((0..^𝑀) × {𝐴})) + (♯‘((0..^𝑁) × {𝐴})))) = (0..^𝐿))
4645fneq2d 6580 . . . . . 6 (𝜑 → ((((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴})) Fn (0..^((♯‘((0..^𝑀) × {𝐴})) + (♯‘((0..^𝑁) × {𝐴})))) ↔ (((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴})) Fn (0..^𝐿)))
4712, 46mpbid 232 . . . . 5 (𝜑 → (((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴})) Fn (0..^𝐿))
4828adantr 480 . . . . . . . . 9 ((𝜑𝑥 ∈ (0..^𝐿)) → (♯‘((0..^𝑀) × {𝐴})) = 𝑀)
4948breq2d 5107 . . . . . . . 8 ((𝜑𝑥 ∈ (0..^𝐿)) → (𝑥 < (♯‘((0..^𝑀) × {𝐴})) ↔ 𝑥 < 𝑀))
5049ifbid 4502 . . . . . . 7 ((𝜑𝑥 ∈ (0..^𝐿)) → if(𝑥 < (♯‘((0..^𝑀) × {𝐴})), (((0..^𝑀) × {𝐴})‘𝑥), (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴}))))) = if(𝑥 < 𝑀, (((0..^𝑀) × {𝐴})‘𝑥), (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴}))))))
511adantr 480 . . . . . . . . 9 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝐴𝑆)
52 elfzouz 13584 . . . . . . . . . . 11 (𝑥 ∈ (0..^𝐿) → 𝑥 ∈ (ℤ‘0))
5352ad2antlr 727 . . . . . . . . . 10 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ 𝑥 < 𝑀) → 𝑥 ∈ (ℤ‘0))
5424ad2antrr 726 . . . . . . . . . . 11 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ 𝑥 < 𝑀) → 𝑀 ∈ ℕ0)
5554nn0zd 12515 . . . . . . . . . 10 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ 𝑥 < 𝑀) → 𝑀 ∈ ℤ)
56 simpr 484 . . . . . . . . . 10 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ 𝑥 < 𝑀) → 𝑥 < 𝑀)
57 elfzo2 13583 . . . . . . . . . 10 (𝑥 ∈ (0..^𝑀) ↔ (𝑥 ∈ (ℤ‘0) ∧ 𝑀 ∈ ℤ ∧ 𝑥 < 𝑀))
5853, 55, 56, 57syl3anbrc 1344 . . . . . . . . 9 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ 𝑥 < 𝑀) → 𝑥 ∈ (0..^𝑀))
59 fvconst2g 7142 . . . . . . . . 9 ((𝐴𝑆𝑥 ∈ (0..^𝑀)) → (((0..^𝑀) × {𝐴})‘𝑥) = 𝐴)
6051, 58, 59syl2an2r 685 . . . . . . . 8 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ 𝑥 < 𝑀) → (((0..^𝑀) × {𝐴})‘𝑥) = 𝐴)
6128ad2antrr 726 . . . . . . . . . . 11 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (♯‘((0..^𝑀) × {𝐴})) = 𝑀)
6261oveq2d 7369 . . . . . . . . . 10 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (𝑥 − (♯‘((0..^𝑀) × {𝐴}))) = (𝑥𝑀))
6324ad2antrr 726 . . . . . . . . . . . . 13 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → 𝑀 ∈ ℕ0)
64 elfzonn0 13628 . . . . . . . . . . . . . 14 (𝑥 ∈ (0..^𝐿) → 𝑥 ∈ ℕ0)
6564ad2antlr 727 . . . . . . . . . . . . 13 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → 𝑥 ∈ ℕ0)
6624adantr 480 . . . . . . . . . . . . . . . 16 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑀 ∈ ℕ0)
6766nn0red 12464 . . . . . . . . . . . . . . 15 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑀 ∈ ℝ)
68 elfzoelz 13580 . . . . . . . . . . . . . . . . 17 (𝑥 ∈ (0..^𝐿) → 𝑥 ∈ ℤ)
6968adantl 481 . . . . . . . . . . . . . . . 16 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑥 ∈ ℤ)
7069zred 12598 . . . . . . . . . . . . . . 15 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑥 ∈ ℝ)
7167, 70lenltd 11280 . . . . . . . . . . . . . 14 ((𝜑𝑥 ∈ (0..^𝐿)) → (𝑀𝑥 ↔ ¬ 𝑥 < 𝑀))
7271biimpar 477 . . . . . . . . . . . . 13 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → 𝑀𝑥)
73 nn0sub2 12555 . . . . . . . . . . . . 13 ((𝑀 ∈ ℕ0𝑥 ∈ ℕ0𝑀𝑥) → (𝑥𝑀) ∈ ℕ0)
7463, 65, 72, 73syl3anc 1373 . . . . . . . . . . . 12 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (𝑥𝑀) ∈ ℕ0)
75 elnn0uz 12798 . . . . . . . . . . . 12 ((𝑥𝑀) ∈ ℕ0 ↔ (𝑥𝑀) ∈ (ℤ‘0))
7674, 75sylib 218 . . . . . . . . . . 11 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (𝑥𝑀) ∈ (ℤ‘0))
7737ad2antrr 726 . . . . . . . . . . . 12 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → 𝑁 ∈ ℕ0)
7877nn0zd 12515 . . . . . . . . . . 11 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → 𝑁 ∈ ℤ)
79 elfzolt2 13589 . . . . . . . . . . . . . . 15 (𝑥 ∈ (0..^𝐿) → 𝑥 < 𝐿)
8079adantl 481 . . . . . . . . . . . . . 14 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑥 < 𝐿)
8167recnd 11162 . . . . . . . . . . . . . . 15 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑀 ∈ ℂ)
8270recnd 11162 . . . . . . . . . . . . . . 15 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑥 ∈ ℂ)
8381, 82pncan3d 11496 . . . . . . . . . . . . . 14 ((𝜑𝑥 ∈ (0..^𝐿)) → (𝑀 + (𝑥𝑀)) = 𝑥)
8443adantr 480 . . . . . . . . . . . . . 14 ((𝜑𝑥 ∈ (0..^𝐿)) → (𝑀 + 𝑁) = 𝐿)
8580, 83, 843brtr4d 5127 . . . . . . . . . . . . 13 ((𝜑𝑥 ∈ (0..^𝐿)) → (𝑀 + (𝑥𝑀)) < (𝑀 + 𝑁))
8670, 67resubcld 11566 . . . . . . . . . . . . . 14 ((𝜑𝑥 ∈ (0..^𝐿)) → (𝑥𝑀) ∈ ℝ)
8737adantr 480 . . . . . . . . . . . . . . 15 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑁 ∈ ℕ0)
8887nn0red 12464 . . . . . . . . . . . . . 14 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑁 ∈ ℝ)
8986, 88, 67ltadd2d 11290 . . . . . . . . . . . . 13 ((𝜑𝑥 ∈ (0..^𝐿)) → ((𝑥𝑀) < 𝑁 ↔ (𝑀 + (𝑥𝑀)) < (𝑀 + 𝑁)))
9085, 89mpbird 257 . . . . . . . . . . . 12 ((𝜑𝑥 ∈ (0..^𝐿)) → (𝑥𝑀) < 𝑁)
9190adantr 480 . . . . . . . . . . 11 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (𝑥𝑀) < 𝑁)
92 elfzo2 13583 . . . . . . . . . . 11 ((𝑥𝑀) ∈ (0..^𝑁) ↔ ((𝑥𝑀) ∈ (ℤ‘0) ∧ 𝑁 ∈ ℤ ∧ (𝑥𝑀) < 𝑁))
9376, 78, 91, 92syl3anbrc 1344 . . . . . . . . . 10 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (𝑥𝑀) ∈ (0..^𝑁))
9462, 93eqeltrd 2828 . . . . . . . . 9 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (𝑥 − (♯‘((0..^𝑀) × {𝐴}))) ∈ (0..^𝑁))
95 fvconst2g 7142 . . . . . . . . 9 ((𝐴𝑆 ∧ (𝑥 − (♯‘((0..^𝑀) × {𝐴}))) ∈ (0..^𝑁)) → (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴})))) = 𝐴)
9651, 94, 95syl2an2r 685 . . . . . . . 8 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴})))) = 𝐴)
9760, 96ifeqda 4515 . . . . . . 7 ((𝜑𝑥 ∈ (0..^𝐿)) → if(𝑥 < 𝑀, (((0..^𝑀) × {𝐴})‘𝑥), (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴}))))) = 𝐴)
9850, 97eqtr2d 2765 . . . . . 6 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝐴 = if(𝑥 < (♯‘((0..^𝑀) × {𝐴})), (((0..^𝑀) × {𝐴})‘𝑥), (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴}))))))
99 fvconst2g 7142 . . . . . . 7 ((𝐴𝑆𝑥 ∈ (0..^𝐿)) → (((0..^𝐿) × {𝐴})‘𝑥) = 𝐴)
1001, 99sylan 580 . . . . . 6 ((𝜑𝑥 ∈ (0..^𝐿)) → (((0..^𝐿) × {𝐴})‘𝑥) = 𝐴)
10151, 5, 63syl 18 . . . . . . 7 ((𝜑𝑥 ∈ (0..^𝐿)) → ((0..^𝑀) × {𝐴}) ∈ Word {𝐴})
10251, 8, 93syl 18 . . . . . . 7 ((𝜑𝑥 ∈ (0..^𝐿)) → ((0..^𝑁) × {𝐴}) ∈ Word {𝐴})
103 ccatsymb 14507 . . . . . . 7 ((((0..^𝑀) × {𝐴}) ∈ Word {𝐴} ∧ ((0..^𝑁) × {𝐴}) ∈ Word {𝐴} ∧ 𝑥 ∈ ℤ) → ((((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴}))‘𝑥) = if(𝑥 < (♯‘((0..^𝑀) × {𝐴})), (((0..^𝑀) × {𝐴})‘𝑥), (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴}))))))
104101, 102, 69, 103syl3anc 1373 . . . . . 6 ((𝜑𝑥 ∈ (0..^𝐿)) → ((((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴}))‘𝑥) = if(𝑥 < (♯‘((0..^𝑀) × {𝐴})), (((0..^𝑀) × {𝐴})‘𝑥), (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴}))))))
10598, 100, 1043eqtr4d 2774 . . . . 5 ((𝜑𝑥 ∈ (0..^𝐿)) → (((0..^𝐿) × {𝐴})‘𝑥) = ((((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴}))‘𝑥))
1064, 47, 105eqfnfvd 6972 . . . 4 (𝜑 → ((0..^𝐿) × {𝐴}) = (((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴})))
107106oveq1d 7368 . . 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 42478 . . . . 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 42478 . . . . 5 (𝑉𝐷𝑉 ∈ Word 𝑆)
118114, 117syl 17 . . . 4 (𝜑𝑉 ∈ Word 𝑆)
11916, 19eqtrid 2776 . . . . 5 (𝜑 → (♯‘((0..^𝑀) × {𝐴})) = ((♯‘(0..^𝑀)) · 1))
120 ovexd 7388 . . . . . . . 8 (𝜑 → (0..^𝑀) ∈ V)
121109, 111, 110frlmbasf 21685 . . . . . . . 8 (((0..^𝑀) ∈ V ∧ 𝑈𝐶) → 𝑈:(0..^𝑀)⟶𝑆)
122120, 108, 121syl2anc 584 . . . . . . 7 (𝜑𝑈:(0..^𝑀)⟶𝑆)
123122ffnd 6657 . . . . . 6 (𝜑𝑈 Fn (0..^𝑀))
124 hashfn 14300 . . . . . 6 (𝑈 Fn (0..^𝑀) → (♯‘𝑈) = (♯‘(0..^𝑀)))
125123, 124syl 17 . . . . 5 (𝜑 → (♯‘𝑈) = (♯‘(0..^𝑀)))
12623, 119, 1253eqtr4d 2774 . . . 4 (𝜑 → (♯‘((0..^𝑀) × {𝐴})) = (♯‘𝑈))
12732, 36eqtrd 2764 . . . . . 6 (𝜑 → ((♯‘(0..^𝑁)) · (♯‘{𝐴})) = (♯‘(0..^𝑁)))
12831, 127eqtrid 2776 . . . . 5 (𝜑 → (♯‘((0..^𝑁) × {𝐴})) = (♯‘(0..^𝑁)))
129 ovexd 7388 . . . . . . . 8 (𝜑 → (0..^𝑁) ∈ V)
130115, 111, 116frlmbasf 21685 . . . . . . . 8 (((0..^𝑁) ∈ V ∧ 𝑉𝐷) → 𝑉:(0..^𝑁)⟶𝑆)
131129, 114, 130syl2anc 584 . . . . . . 7 (𝜑𝑉:(0..^𝑁)⟶𝑆)
132131ffnd 6657 . . . . . 6 (𝜑𝑉 Fn (0..^𝑁))
133 hashfn 14300 . . . . . 6 (𝑉 Fn (0..^𝑁) → (♯‘𝑉) = (♯‘(0..^𝑁)))
134132, 133syl 17 . . . . 5 (𝜑 → (♯‘𝑉) = (♯‘(0..^𝑁)))
135128, 134eqtr4d 2767 . . . 4 (𝜑 → (♯‘((0..^𝑁) × {𝐴})) = (♯‘𝑉))
1367, 10, 113, 118, 126, 135ofccat 14894 . . 3 (𝜑 → ((((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴})) ∘f (.r𝐾)(𝑈 ++ 𝑉)) = ((((0..^𝑀) × {𝐴}) ∘f (.r𝐾)𝑈) ++ (((0..^𝑁) × {𝐴}) ∘f (.r𝐾)𝑉)))
137107, 136eqtrd 2764 . 2 (𝜑 → (((0..^𝐿) × {𝐴}) ∘f (.r𝐾)(𝑈 ++ 𝑉)) = ((((0..^𝑀) × {𝐴}) ∘f (.r𝐾)𝑈) ++ (((0..^𝑁) × {𝐴}) ∘f (.r𝐾)𝑉)))
138 frlmfzoccat.w . . 3 𝑊 = (𝐾 freeLMod (0..^𝐿))
139 frlmfzoccat.b . . 3 𝐵 = (Base‘𝑊)
140 ovexd 7388 . . 3 (𝜑 → (0..^𝐿) ∈ V)
141 frlmfzoccat.k . . . 4 (𝜑𝐾𝑍)
142138, 109, 115, 139, 110, 116, 141, 43, 24, 37, 108, 114frlmfzoccat 42481 . . 3 (𝜑 → (𝑈 ++ 𝑉) ∈ 𝐵)
143 frlmvscadiccat.o . . 3 𝑂 = ( ·𝑠𝑊)
144 eqid 2729 . . 3 (.r𝐾) = (.r𝐾)
145138, 139, 111, 140, 1, 142, 143, 144frlmvscafval 21691 . 2 (𝜑 → (𝐴𝑂(𝑈 ++ 𝑉)) = (((0..^𝐿) × {𝐴}) ∘f (.r𝐾)(𝑈 ++ 𝑉)))
146 frlmvscadiccat.p . . . 4 = ( ·𝑠𝑋)
147109, 110, 111, 120, 1, 108, 146, 144frlmvscafval 21691 . . 3 (𝜑 → (𝐴 𝑈) = (((0..^𝑀) × {𝐴}) ∘f (.r𝐾)𝑈))
148 frlmvscadiccat.q . . . 4 · = ( ·𝑠𝑌)
149115, 116, 111, 129, 1, 114, 148, 144frlmvscafval 21691 . . 3 (𝜑 → (𝐴 · 𝑉) = (((0..^𝑁) × {𝐴}) ∘f (.r𝐾)𝑉))
150147, 149oveq12d 7371 . 2 (𝜑 → ((𝐴 𝑈) ++ (𝐴 · 𝑉)) = ((((0..^𝑀) × {𝐴}) ∘f (.r𝐾)𝑈) ++ (((0..^𝑁) × {𝐴}) ∘f (.r𝐾)𝑉)))
151137, 145, 1503eqtr4d 2774 1 (𝜑 → (𝐴𝑂(𝑈 ++ 𝑉)) = ((𝐴 𝑈) ++ (𝐴 · 𝑉)))
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wa 395   = wceq 1540  wcel 2109  Vcvv 3438  ifcif 4478  {csn 4579   class class class wbr 5095   × cxp 5621   Fn wfn 6481  wf 6482  cfv 6486  (class class class)co 7353  f cof 7615  Fincfn 8879  0cc0 11028  1c1 11029   + caddc 11031   · cmul 11033   < clt 11168  cle 11169  cmin 11365  0cn0 12402  cz 12489  cuz 12753  ..^cfzo 13575  chash 14255  Word cword 14438   ++ cconcat 14495  Basecbs 17138  .rcmulr 17180   ·𝑠 cvsca 17183   freeLMod cfrlm 21671
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1795  ax-4 1809  ax-5 1910  ax-6 1967  ax-7 2008  ax-8 2111  ax-9 2119  ax-10 2142  ax-11 2158  ax-12 2178  ax-ext 2701  ax-rep 5221  ax-sep 5238  ax-nul 5248  ax-pow 5307  ax-pr 5374  ax-un 7675  ax-cnex 11084  ax-resscn 11085  ax-1cn 11086  ax-icn 11087  ax-addcl 11088  ax-addrcl 11089  ax-mulcl 11090  ax-mulrcl 11091  ax-mulcom 11092  ax-addass 11093  ax-mulass 11094  ax-distr 11095  ax-i2m1 11096  ax-1ne0 11097  ax-1rid 11098  ax-rnegex 11099  ax-rrecex 11100  ax-cnre 11101  ax-pre-lttri 11102  ax-pre-lttrn 11103  ax-pre-ltadd 11104  ax-pre-mulgt0 11105
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 848  df-3or 1087  df-3an 1088  df-tru 1543  df-fal 1553  df-ex 1780  df-nf 1784  df-sb 2066  df-mo 2533  df-eu 2562  df-clab 2708  df-cleq 2721  df-clel 2803  df-nfc 2878  df-ne 2926  df-nel 3030  df-ral 3045  df-rex 3054  df-reu 3346  df-rab 3397  df-v 3440  df-sbc 3745  df-csb 3854  df-dif 3908  df-un 3910  df-in 3912  df-ss 3922  df-pss 3925  df-nul 4287  df-if 4479  df-pw 4555  df-sn 4580  df-pr 4582  df-tp 4584  df-op 4586  df-uni 4862  df-int 4900  df-iun 4946  df-br 5096  df-opab 5158  df-mpt 5177  df-tr 5203  df-id 5518  df-eprel 5523  df-po 5531  df-so 5532  df-fr 5576  df-we 5578  df-xp 5629  df-rel 5630  df-cnv 5631  df-co 5632  df-dm 5633  df-rn 5634  df-res 5635  df-ima 5636  df-pred 6253  df-ord 6314  df-on 6315  df-lim 6316  df-suc 6317  df-iota 6442  df-fun 6488  df-fn 6489  df-f 6490  df-f1 6491  df-fo 6492  df-f1o 6493  df-fv 6494  df-riota 7310  df-ov 7356  df-oprab 7357  df-mpo 7358  df-of 7617  df-om 7807  df-1st 7931  df-2nd 7932  df-supp 8101  df-frecs 8221  df-wrecs 8252  df-recs 8301  df-rdg 8339  df-1o 8395  df-oadd 8399  df-er 8632  df-map 8762  df-ixp 8832  df-en 8880  df-dom 8881  df-sdom 8882  df-fin 8883  df-fsupp 9271  df-sup 9351  df-dju 9816  df-card 9854  df-pnf 11170  df-mnf 11171  df-xr 11172  df-ltxr 11173  df-le 11174  df-sub 11367  df-neg 11368  df-nn 12147  df-2 12209  df-3 12210  df-4 12211  df-5 12212  df-6 12213  df-7 12214  df-8 12215  df-9 12216  df-n0 12403  df-z 12490  df-dec 12610  df-uz 12754  df-fz 13429  df-fzo 13576  df-hash 14256  df-word 14439  df-concat 14496  df-struct 17076  df-sets 17093  df-slot 17111  df-ndx 17123  df-base 17139  df-ress 17160  df-plusg 17192  df-mulr 17193  df-sca 17195  df-vsca 17196  df-ip 17197  df-tset 17198  df-ple 17199  df-ds 17201  df-hom 17203  df-cco 17204  df-0g 17363  df-prds 17369  df-pws 17371  df-sra 21095  df-rgmod 21096  df-dsmm 21657  df-frlm 21672
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator