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 42461
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 6808 . . . . . . 7 (𝐴𝑆 → ((0..^𝐿) × {𝐴}):(0..^𝐿)⟶{𝐴})
31, 2syl 17 . . . . . 6 (𝜑 → ((0..^𝐿) × {𝐴}):(0..^𝐿)⟶{𝐴})
43ffnd 6748 . . . . 5 (𝜑 → ((0..^𝐿) × {𝐴}) Fn (0..^𝐿))
5 fconstg 6808 . . . . . . . 8 (𝐴𝑆 → ((0..^𝑀) × {𝐴}):(0..^𝑀)⟶{𝐴})
6 iswrdi 14566 . . . . . . . 8 (((0..^𝑀) × {𝐴}):(0..^𝑀)⟶{𝐴} → ((0..^𝑀) × {𝐴}) ∈ Word {𝐴})
71, 5, 63syl 18 . . . . . . 7 (𝜑 → ((0..^𝑀) × {𝐴}) ∈ Word {𝐴})
8 fconstg 6808 . . . . . . . 8 (𝐴𝑆 → ((0..^𝑁) × {𝐴}):(0..^𝑁)⟶{𝐴})
9 iswrdi 14566 . . . . . . . 8 (((0..^𝑁) × {𝐴}):(0..^𝑁)⟶{𝐴} → ((0..^𝑁) × {𝐴}) ∈ Word {𝐴})
101, 8, 93syl 18 . . . . . . 7 (𝜑 → ((0..^𝑁) × {𝐴}) ∈ Word {𝐴})
11 ccatvalfn 14629 . . . . . . 7 ((((0..^𝑀) × {𝐴}) ∈ Word {𝐴} ∧ ((0..^𝑁) × {𝐴}) ∈ Word {𝐴}) → (((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴})) Fn (0..^((♯‘((0..^𝑀) × {𝐴})) + (♯‘((0..^𝑁) × {𝐴})))))
127, 10, 11syl2anc 583 . . . . . 6 (𝜑 → (((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴})) Fn (0..^((♯‘((0..^𝑀) × {𝐴})) + (♯‘((0..^𝑁) × {𝐴})))))
13 fzofi 14025 . . . . . . . . . . . 12 (0..^𝑀) ∈ Fin
14 snfi 9109 . . . . . . . . . . . 12 {𝐴} ∈ Fin
15 hashxp 14483 . . . . . . . . . . . 12 (((0..^𝑀) ∈ Fin ∧ {𝐴} ∈ Fin) → (♯‘((0..^𝑀) × {𝐴})) = ((♯‘(0..^𝑀)) · (♯‘{𝐴})))
1613, 14, 15mp2an 691 . . . . . . . . . . 11 (♯‘((0..^𝑀) × {𝐴})) = ((♯‘(0..^𝑀)) · (♯‘{𝐴}))
17 hashsng 14418 . . . . . . . . . . . . . 14 (𝐴𝑆 → (♯‘{𝐴}) = 1)
181, 17syl 17 . . . . . . . . . . . . 13 (𝜑 → (♯‘{𝐴}) = 1)
1918oveq2d 7464 . . . . . . . . . . . 12 (𝜑 → ((♯‘(0..^𝑀)) · (♯‘{𝐴})) = ((♯‘(0..^𝑀)) · 1))
20 hashcl 14405 . . . . . . . . . . . . . . 15 ((0..^𝑀) ∈ Fin → (♯‘(0..^𝑀)) ∈ ℕ0)
2113, 20mp1i 13 . . . . . . . . . . . . . 14 (𝜑 → (♯‘(0..^𝑀)) ∈ ℕ0)
2221nn0cnd 12615 . . . . . . . . . . . . 13 (𝜑 → (♯‘(0..^𝑀)) ∈ ℂ)
2322mulridd 11307 . . . . . . . . . . . 12 (𝜑 → ((♯‘(0..^𝑀)) · 1) = (♯‘(0..^𝑀)))
24 frlmfzoccat.m . . . . . . . . . . . . 13 (𝜑𝑀 ∈ ℕ0)
25 hashfzo0 14479 . . . . . . . . . . . . 13 (𝑀 ∈ ℕ0 → (♯‘(0..^𝑀)) = 𝑀)
2624, 25syl 17 . . . . . . . . . . . 12 (𝜑 → (♯‘(0..^𝑀)) = 𝑀)
2719, 23, 263eqtrd 2784 . . . . . . . . . . 11 (𝜑 → ((♯‘(0..^𝑀)) · (♯‘{𝐴})) = 𝑀)
2816, 27eqtrid 2792 . . . . . . . . . 10 (𝜑 → (♯‘((0..^𝑀) × {𝐴})) = 𝑀)
29 fzofi 14025 . . . . . . . . . . . 12 (0..^𝑁) ∈ Fin
30 hashxp 14483 . . . . . . . . . . . 12 (((0..^𝑁) ∈ Fin ∧ {𝐴} ∈ Fin) → (♯‘((0..^𝑁) × {𝐴})) = ((♯‘(0..^𝑁)) · (♯‘{𝐴})))
3129, 14, 30mp2an 691 . . . . . . . . . . 11 (♯‘((0..^𝑁) × {𝐴})) = ((♯‘(0..^𝑁)) · (♯‘{𝐴}))
3218oveq2d 7464 . . . . . . . . . . . 12 (𝜑 → ((♯‘(0..^𝑁)) · (♯‘{𝐴})) = ((♯‘(0..^𝑁)) · 1))
33 hashcl 14405 . . . . . . . . . . . . . . 15 ((0..^𝑁) ∈ Fin → (♯‘(0..^𝑁)) ∈ ℕ0)
3429, 33mp1i 13 . . . . . . . . . . . . . 14 (𝜑 → (♯‘(0..^𝑁)) ∈ ℕ0)
3534nn0cnd 12615 . . . . . . . . . . . . 13 (𝜑 → (♯‘(0..^𝑁)) ∈ ℂ)
3635mulridd 11307 . . . . . . . . . . . 12 (𝜑 → ((♯‘(0..^𝑁)) · 1) = (♯‘(0..^𝑁)))
37 frlmfzoccat.n . . . . . . . . . . . . 13 (𝜑𝑁 ∈ ℕ0)
38 hashfzo0 14479 . . . . . . . . . . . . 13 (𝑁 ∈ ℕ0 → (♯‘(0..^𝑁)) = 𝑁)
3937, 38syl 17 . . . . . . . . . . . 12 (𝜑 → (♯‘(0..^𝑁)) = 𝑁)
4032, 36, 393eqtrd 2784 . . . . . . . . . . 11 (𝜑 → ((♯‘(0..^𝑁)) · (♯‘{𝐴})) = 𝑁)
4131, 40eqtrid 2792 . . . . . . . . . 10 (𝜑 → (♯‘((0..^𝑁) × {𝐴})) = 𝑁)
4228, 41oveq12d 7466 . . . . . . . . 9 (𝜑 → ((♯‘((0..^𝑀) × {𝐴})) + (♯‘((0..^𝑁) × {𝐴}))) = (𝑀 + 𝑁))
43 frlmfzoccat.l . . . . . . . . 9 (𝜑 → (𝑀 + 𝑁) = 𝐿)
4442, 43eqtrd 2780 . . . . . . . 8 (𝜑 → ((♯‘((0..^𝑀) × {𝐴})) + (♯‘((0..^𝑁) × {𝐴}))) = 𝐿)
4544oveq2d 7464 . . . . . . 7 (𝜑 → (0..^((♯‘((0..^𝑀) × {𝐴})) + (♯‘((0..^𝑁) × {𝐴})))) = (0..^𝐿))
4645fneq2d 6673 . . . . . 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 5178 . . . . . . . 8 ((𝜑𝑥 ∈ (0..^𝐿)) → (𝑥 < (♯‘((0..^𝑀) × {𝐴})) ↔ 𝑥 < 𝑀))
5049ifbid 4571 . . . . . . 7 ((𝜑𝑥 ∈ (0..^𝐿)) → if(𝑥 < (♯‘((0..^𝑀) × {𝐴})), (((0..^𝑀) × {𝐴})‘𝑥), (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴}))))) = if(𝑥 < 𝑀, (((0..^𝑀) × {𝐴})‘𝑥), (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴}))))))
511adantr 480 . . . . . . . . 9 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝐴𝑆)
52 elfzouz 13720 . . . . . . . . . . 11 (𝑥 ∈ (0..^𝐿) → 𝑥 ∈ (ℤ‘0))
5352ad2antlr 726 . . . . . . . . . 10 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ 𝑥 < 𝑀) → 𝑥 ∈ (ℤ‘0))
5424ad2antrr 725 . . . . . . . . . . 11 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ 𝑥 < 𝑀) → 𝑀 ∈ ℕ0)
5554nn0zd 12665 . . . . . . . . . 10 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ 𝑥 < 𝑀) → 𝑀 ∈ ℤ)
56 simpr 484 . . . . . . . . . 10 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ 𝑥 < 𝑀) → 𝑥 < 𝑀)
57 elfzo2 13719 . . . . . . . . . 10 (𝑥 ∈ (0..^𝑀) ↔ (𝑥 ∈ (ℤ‘0) ∧ 𝑀 ∈ ℤ ∧ 𝑥 < 𝑀))
5853, 55, 56, 57syl3anbrc 1343 . . . . . . . . 9 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ 𝑥 < 𝑀) → 𝑥 ∈ (0..^𝑀))
59 fvconst2g 7239 . . . . . . . . 9 ((𝐴𝑆𝑥 ∈ (0..^𝑀)) → (((0..^𝑀) × {𝐴})‘𝑥) = 𝐴)
6051, 58, 59syl2an2r 684 . . . . . . . 8 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ 𝑥 < 𝑀) → (((0..^𝑀) × {𝐴})‘𝑥) = 𝐴)
6128ad2antrr 725 . . . . . . . . . . 11 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (♯‘((0..^𝑀) × {𝐴})) = 𝑀)
6261oveq2d 7464 . . . . . . . . . 10 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (𝑥 − (♯‘((0..^𝑀) × {𝐴}))) = (𝑥𝑀))
6324ad2antrr 725 . . . . . . . . . . . . 13 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → 𝑀 ∈ ℕ0)
64 elfzonn0 13761 . . . . . . . . . . . . . 14 (𝑥 ∈ (0..^𝐿) → 𝑥 ∈ ℕ0)
6564ad2antlr 726 . . . . . . . . . . . . 13 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → 𝑥 ∈ ℕ0)
6624adantr 480 . . . . . . . . . . . . . . . 16 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑀 ∈ ℕ0)
6766nn0red 12614 . . . . . . . . . . . . . . 15 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑀 ∈ ℝ)
68 elfzoelz 13716 . . . . . . . . . . . . . . . . 17 (𝑥 ∈ (0..^𝐿) → 𝑥 ∈ ℤ)
6968adantl 481 . . . . . . . . . . . . . . . 16 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑥 ∈ ℤ)
7069zred 12747 . . . . . . . . . . . . . . 15 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑥 ∈ ℝ)
7167, 70lenltd 11436 . . . . . . . . . . . . . 14 ((𝜑𝑥 ∈ (0..^𝐿)) → (𝑀𝑥 ↔ ¬ 𝑥 < 𝑀))
7271biimpar 477 . . . . . . . . . . . . 13 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → 𝑀𝑥)
73 nn0sub2 12704 . . . . . . . . . . . . 13 ((𝑀 ∈ ℕ0𝑥 ∈ ℕ0𝑀𝑥) → (𝑥𝑀) ∈ ℕ0)
7463, 65, 72, 73syl3anc 1371 . . . . . . . . . . . 12 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (𝑥𝑀) ∈ ℕ0)
75 elnn0uz 12948 . . . . . . . . . . . 12 ((𝑥𝑀) ∈ ℕ0 ↔ (𝑥𝑀) ∈ (ℤ‘0))
7674, 75sylib 218 . . . . . . . . . . 11 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (𝑥𝑀) ∈ (ℤ‘0))
7737ad2antrr 725 . . . . . . . . . . . 12 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → 𝑁 ∈ ℕ0)
7877nn0zd 12665 . . . . . . . . . . 11 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → 𝑁 ∈ ℤ)
79 elfzolt2 13725 . . . . . . . . . . . . . . 15 (𝑥 ∈ (0..^𝐿) → 𝑥 < 𝐿)
8079adantl 481 . . . . . . . . . . . . . 14 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑥 < 𝐿)
8167recnd 11318 . . . . . . . . . . . . . . 15 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑀 ∈ ℂ)
8270recnd 11318 . . . . . . . . . . . . . . 15 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑥 ∈ ℂ)
8381, 82pncan3d 11650 . . . . . . . . . . . . . 14 ((𝜑𝑥 ∈ (0..^𝐿)) → (𝑀 + (𝑥𝑀)) = 𝑥)
8443adantr 480 . . . . . . . . . . . . . 14 ((𝜑𝑥 ∈ (0..^𝐿)) → (𝑀 + 𝑁) = 𝐿)
8580, 83, 843brtr4d 5198 . . . . . . . . . . . . 13 ((𝜑𝑥 ∈ (0..^𝐿)) → (𝑀 + (𝑥𝑀)) < (𝑀 + 𝑁))
8670, 67resubcld 11718 . . . . . . . . . . . . . 14 ((𝜑𝑥 ∈ (0..^𝐿)) → (𝑥𝑀) ∈ ℝ)
8737adantr 480 . . . . . . . . . . . . . . 15 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑁 ∈ ℕ0)
8887nn0red 12614 . . . . . . . . . . . . . 14 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝑁 ∈ ℝ)
8986, 88, 67ltadd2d 11446 . . . . . . . . . . . . 13 ((𝜑𝑥 ∈ (0..^𝐿)) → ((𝑥𝑀) < 𝑁 ↔ (𝑀 + (𝑥𝑀)) < (𝑀 + 𝑁)))
9085, 89mpbird 257 . . . . . . . . . . . 12 ((𝜑𝑥 ∈ (0..^𝐿)) → (𝑥𝑀) < 𝑁)
9190adantr 480 . . . . . . . . . . 11 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (𝑥𝑀) < 𝑁)
92 elfzo2 13719 . . . . . . . . . . 11 ((𝑥𝑀) ∈ (0..^𝑁) ↔ ((𝑥𝑀) ∈ (ℤ‘0) ∧ 𝑁 ∈ ℤ ∧ (𝑥𝑀) < 𝑁))
9376, 78, 91, 92syl3anbrc 1343 . . . . . . . . . 10 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (𝑥𝑀) ∈ (0..^𝑁))
9462, 93eqeltrd 2844 . . . . . . . . 9 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (𝑥 − (♯‘((0..^𝑀) × {𝐴}))) ∈ (0..^𝑁))
95 fvconst2g 7239 . . . . . . . . 9 ((𝐴𝑆 ∧ (𝑥 − (♯‘((0..^𝑀) × {𝐴}))) ∈ (0..^𝑁)) → (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴})))) = 𝐴)
9651, 94, 95syl2an2r 684 . . . . . . . 8 (((𝜑𝑥 ∈ (0..^𝐿)) ∧ ¬ 𝑥 < 𝑀) → (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴})))) = 𝐴)
9760, 96ifeqda 4584 . . . . . . 7 ((𝜑𝑥 ∈ (0..^𝐿)) → if(𝑥 < 𝑀, (((0..^𝑀) × {𝐴})‘𝑥), (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴}))))) = 𝐴)
9850, 97eqtr2d 2781 . . . . . 6 ((𝜑𝑥 ∈ (0..^𝐿)) → 𝐴 = if(𝑥 < (♯‘((0..^𝑀) × {𝐴})), (((0..^𝑀) × {𝐴})‘𝑥), (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴}))))))
99 fvconst2g 7239 . . . . . . 7 ((𝐴𝑆𝑥 ∈ (0..^𝐿)) → (((0..^𝐿) × {𝐴})‘𝑥) = 𝐴)
1001, 99sylan 579 . . . . . 6 ((𝜑𝑥 ∈ (0..^𝐿)) → (((0..^𝐿) × {𝐴})‘𝑥) = 𝐴)
10151, 5, 63syl 18 . . . . . . 7 ((𝜑𝑥 ∈ (0..^𝐿)) → ((0..^𝑀) × {𝐴}) ∈ Word {𝐴})
10251, 8, 93syl 18 . . . . . . 7 ((𝜑𝑥 ∈ (0..^𝐿)) → ((0..^𝑁) × {𝐴}) ∈ Word {𝐴})
103 ccatsymb 14630 . . . . . . 7 ((((0..^𝑀) × {𝐴}) ∈ Word {𝐴} ∧ ((0..^𝑁) × {𝐴}) ∈ Word {𝐴} ∧ 𝑥 ∈ ℤ) → ((((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴}))‘𝑥) = if(𝑥 < (♯‘((0..^𝑀) × {𝐴})), (((0..^𝑀) × {𝐴})‘𝑥), (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴}))))))
104101, 102, 69, 103syl3anc 1371 . . . . . 6 ((𝜑𝑥 ∈ (0..^𝐿)) → ((((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴}))‘𝑥) = if(𝑥 < (♯‘((0..^𝑀) × {𝐴})), (((0..^𝑀) × {𝐴})‘𝑥), (((0..^𝑁) × {𝐴})‘(𝑥 − (♯‘((0..^𝑀) × {𝐴}))))))
10598, 100, 1043eqtr4d 2790 . . . . 5 ((𝜑𝑥 ∈ (0..^𝐿)) → (((0..^𝐿) × {𝐴})‘𝑥) = ((((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴}))‘𝑥))
1064, 47, 105eqfnfvd 7067 . . . 4 (𝜑 → ((0..^𝐿) × {𝐴}) = (((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴})))
107106oveq1d 7463 . . 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 42457 . . . . 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 42457 . . . . 5 (𝑉𝐷𝑉 ∈ Word 𝑆)
118114, 117syl 17 . . . 4 (𝜑𝑉 ∈ Word 𝑆)
11916, 19eqtrid 2792 . . . . 5 (𝜑 → (♯‘((0..^𝑀) × {𝐴})) = ((♯‘(0..^𝑀)) · 1))
120 ovexd 7483 . . . . . . . 8 (𝜑 → (0..^𝑀) ∈ V)
121109, 111, 110frlmbasf 21803 . . . . . . . 8 (((0..^𝑀) ∈ V ∧ 𝑈𝐶) → 𝑈:(0..^𝑀)⟶𝑆)
122120, 108, 121syl2anc 583 . . . . . . 7 (𝜑𝑈:(0..^𝑀)⟶𝑆)
123122ffnd 6748 . . . . . 6 (𝜑𝑈 Fn (0..^𝑀))
124 hashfn 14424 . . . . . 6 (𝑈 Fn (0..^𝑀) → (♯‘𝑈) = (♯‘(0..^𝑀)))
125123, 124syl 17 . . . . 5 (𝜑 → (♯‘𝑈) = (♯‘(0..^𝑀)))
12623, 119, 1253eqtr4d 2790 . . . 4 (𝜑 → (♯‘((0..^𝑀) × {𝐴})) = (♯‘𝑈))
12732, 36eqtrd 2780 . . . . . 6 (𝜑 → ((♯‘(0..^𝑁)) · (♯‘{𝐴})) = (♯‘(0..^𝑁)))
12831, 127eqtrid 2792 . . . . 5 (𝜑 → (♯‘((0..^𝑁) × {𝐴})) = (♯‘(0..^𝑁)))
129 ovexd 7483 . . . . . . . 8 (𝜑 → (0..^𝑁) ∈ V)
130115, 111, 116frlmbasf 21803 . . . . . . . 8 (((0..^𝑁) ∈ V ∧ 𝑉𝐷) → 𝑉:(0..^𝑁)⟶𝑆)
131129, 114, 130syl2anc 583 . . . . . . 7 (𝜑𝑉:(0..^𝑁)⟶𝑆)
132131ffnd 6748 . . . . . 6 (𝜑𝑉 Fn (0..^𝑁))
133 hashfn 14424 . . . . . 6 (𝑉 Fn (0..^𝑁) → (♯‘𝑉) = (♯‘(0..^𝑁)))
134132, 133syl 17 . . . . 5 (𝜑 → (♯‘𝑉) = (♯‘(0..^𝑁)))
135128, 134eqtr4d 2783 . . . 4 (𝜑 → (♯‘((0..^𝑁) × {𝐴})) = (♯‘𝑉))
1367, 10, 113, 118, 126, 135ofccat 15018 . . 3 (𝜑 → ((((0..^𝑀) × {𝐴}) ++ ((0..^𝑁) × {𝐴})) ∘f (.r𝐾)(𝑈 ++ 𝑉)) = ((((0..^𝑀) × {𝐴}) ∘f (.r𝐾)𝑈) ++ (((0..^𝑁) × {𝐴}) ∘f (.r𝐾)𝑉)))
137107, 136eqtrd 2780 . 2 (𝜑 → (((0..^𝐿) × {𝐴}) ∘f (.r𝐾)(𝑈 ++ 𝑉)) = ((((0..^𝑀) × {𝐴}) ∘f (.r𝐾)𝑈) ++ (((0..^𝑁) × {𝐴}) ∘f (.r𝐾)𝑉)))
138 frlmfzoccat.w . . 3 𝑊 = (𝐾 freeLMod (0..^𝐿))
139 frlmfzoccat.b . . 3 𝐵 = (Base‘𝑊)
140 ovexd 7483 . . 3 (𝜑 → (0..^𝐿) ∈ V)
141 frlmfzoccat.k . . . 4 (𝜑𝐾𝑍)
142138, 109, 115, 139, 110, 116, 141, 43, 24, 37, 108, 114frlmfzoccat 42460 . . 3 (𝜑 → (𝑈 ++ 𝑉) ∈ 𝐵)
143 frlmvscadiccat.o . . 3 𝑂 = ( ·𝑠𝑊)
144 eqid 2740 . . 3 (.r𝐾) = (.r𝐾)
145138, 139, 111, 140, 1, 142, 143, 144frlmvscafval 21809 . 2 (𝜑 → (𝐴𝑂(𝑈 ++ 𝑉)) = (((0..^𝐿) × {𝐴}) ∘f (.r𝐾)(𝑈 ++ 𝑉)))
146 frlmvscadiccat.p . . . 4 = ( ·𝑠𝑋)
147109, 110, 111, 120, 1, 108, 146, 144frlmvscafval 21809 . . 3 (𝜑 → (𝐴 𝑈) = (((0..^𝑀) × {𝐴}) ∘f (.r𝐾)𝑈))
148 frlmvscadiccat.q . . . 4 · = ( ·𝑠𝑌)
149115, 116, 111, 129, 1, 114, 148, 144frlmvscafval 21809 . . 3 (𝜑 → (𝐴 · 𝑉) = (((0..^𝑁) × {𝐴}) ∘f (.r𝐾)𝑉))
150147, 149oveq12d 7466 . 2 (𝜑 → ((𝐴 𝑈) ++ (𝐴 · 𝑉)) = ((((0..^𝑀) × {𝐴}) ∘f (.r𝐾)𝑈) ++ (((0..^𝑁) × {𝐴}) ∘f (.r𝐾)𝑉)))
151137, 145, 1503eqtr4d 2790 1 (𝜑 → (𝐴𝑂(𝑈 ++ 𝑉)) = ((𝐴 𝑈) ++ (𝐴 · 𝑉)))
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wa 395   = wceq 1537  wcel 2108  Vcvv 3488  ifcif 4548  {csn 4648   class class class wbr 5166   × cxp 5698   Fn wfn 6568  wf 6569  cfv 6573  (class class class)co 7448  f cof 7712  Fincfn 9003  0cc0 11184  1c1 11185   + caddc 11187   · cmul 11189   < clt 11324  cle 11325  cmin 11520  0cn0 12553  cz 12639  cuz 12903  ..^cfzo 13711  chash 14379  Word cword 14562   ++ cconcat 14618  Basecbs 17258  .rcmulr 17312   ·𝑠 cvsca 17315   freeLMod cfrlm 21789
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1793  ax-4 1807  ax-5 1909  ax-6 1967  ax-7 2007  ax-8 2110  ax-9 2118  ax-10 2141  ax-11 2158  ax-12 2178  ax-ext 2711  ax-rep 5303  ax-sep 5317  ax-nul 5324  ax-pow 5383  ax-pr 5447  ax-un 7770  ax-cnex 11240  ax-resscn 11241  ax-1cn 11242  ax-icn 11243  ax-addcl 11244  ax-addrcl 11245  ax-mulcl 11246  ax-mulrcl 11247  ax-mulcom 11248  ax-addass 11249  ax-mulass 11250  ax-distr 11251  ax-i2m1 11252  ax-1ne0 11253  ax-1rid 11254  ax-rnegex 11255  ax-rrecex 11256  ax-cnre 11257  ax-pre-lttri 11258  ax-pre-lttrn 11259  ax-pre-ltadd 11260  ax-pre-mulgt0 11261
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 847  df-3or 1088  df-3an 1089  df-tru 1540  df-fal 1550  df-ex 1778  df-nf 1782  df-sb 2065  df-mo 2543  df-eu 2572  df-clab 2718  df-cleq 2732  df-clel 2819  df-nfc 2895  df-ne 2947  df-nel 3053  df-ral 3068  df-rex 3077  df-reu 3389  df-rab 3444  df-v 3490  df-sbc 3805  df-csb 3922  df-dif 3979  df-un 3981  df-in 3983  df-ss 3993  df-pss 3996  df-nul 4353  df-if 4549  df-pw 4624  df-sn 4649  df-pr 4651  df-tp 4653  df-op 4655  df-uni 4932  df-int 4971  df-iun 5017  df-br 5167  df-opab 5229  df-mpt 5250  df-tr 5284  df-id 5593  df-eprel 5599  df-po 5607  df-so 5608  df-fr 5652  df-we 5654  df-xp 5706  df-rel 5707  df-cnv 5708  df-co 5709  df-dm 5710  df-rn 5711  df-res 5712  df-ima 5713  df-pred 6332  df-ord 6398  df-on 6399  df-lim 6400  df-suc 6401  df-iota 6525  df-fun 6575  df-fn 6576  df-f 6577  df-f1 6578  df-fo 6579  df-f1o 6580  df-fv 6581  df-riota 7404  df-ov 7451  df-oprab 7452  df-mpo 7453  df-of 7714  df-om 7904  df-1st 8030  df-2nd 8031  df-supp 8202  df-frecs 8322  df-wrecs 8353  df-recs 8427  df-rdg 8466  df-1o 8522  df-oadd 8526  df-er 8763  df-map 8886  df-ixp 8956  df-en 9004  df-dom 9005  df-sdom 9006  df-fin 9007  df-fsupp 9432  df-sup 9511  df-dju 9970  df-card 10008  df-pnf 11326  df-mnf 11327  df-xr 11328  df-ltxr 11329  df-le 11330  df-sub 11522  df-neg 11523  df-nn 12294  df-2 12356  df-3 12357  df-4 12358  df-5 12359  df-6 12360  df-7 12361  df-8 12362  df-9 12363  df-n0 12554  df-z 12640  df-dec 12759  df-uz 12904  df-fz 13568  df-fzo 13712  df-hash 14380  df-word 14563  df-concat 14619  df-struct 17194  df-sets 17211  df-slot 17229  df-ndx 17241  df-base 17259  df-ress 17288  df-plusg 17324  df-mulr 17325  df-sca 17327  df-vsca 17328  df-ip 17329  df-tset 17330  df-ple 17331  df-ds 17333  df-hom 17335  df-cco 17336  df-0g 17501  df-prds 17507  df-pws 17509  df-sra 21195  df-rgmod 21196  df-dsmm 21775  df-frlm 21790
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator