Mathbox for Alexander van der Vekens < Previous   Next > Nearby theorems Mirrors  >  Home  >  MPE Home  >  Th. List  >   Mathboxes  >  pfxccatpfx2 Structured version   Visualization version   GIF version

Theorem pfxccatpfx2 41956
 Description: A prefix of a concatenation of two words being the first word concatenated with a prefix of the second word. (Contributed by AV, 10-May-2020.)
Hypotheses
Ref Expression
pfxccatin12.l 𝐿 = (♯‘𝐴)
pfxccatpfx2.m 𝑀 = (♯‘𝐵)
Assertion
Ref Expression
pfxccatpfx2 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉𝑁 ∈ ((𝐿 + 1)...(𝐿 + 𝑀))) → ((𝐴 ++ 𝐵) prefix 𝑁) = (𝐴 ++ (𝐵 prefix (𝑁𝐿))))

Proof of Theorem pfxccatpfx2
StepHypRef Expression
1 ccatcl 13556 . . . 4 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → (𝐴 ++ 𝐵) ∈ Word 𝑉)
213adant3 1126 . . 3 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉𝑁 ∈ ((𝐿 + 1)...(𝐿 + 𝑀))) → (𝐴 ++ 𝐵) ∈ Word 𝑉)
3 pfxccatin12.l . . . . . . 7 𝐿 = (♯‘𝐴)
4 lencl 13520 . . . . . . 7 (𝐴 ∈ Word 𝑉 → (♯‘𝐴) ∈ ℕ0)
53, 4syl5eqel 2854 . . . . . 6 (𝐴 ∈ Word 𝑉𝐿 ∈ ℕ0)
6 elfzuz 12545 . . . . . 6 (𝑁 ∈ ((𝐿 + 1)...(𝐿 + 𝑀)) → 𝑁 ∈ (ℤ‘(𝐿 + 1)))
7 peano2nn0 11535 . . . . . . 7 (𝐿 ∈ ℕ0 → (𝐿 + 1) ∈ ℕ0)
87anim1i 602 . . . . . 6 ((𝐿 ∈ ℕ0𝑁 ∈ (ℤ‘(𝐿 + 1))) → ((𝐿 + 1) ∈ ℕ0𝑁 ∈ (ℤ‘(𝐿 + 1))))
95, 6, 8syl2an 583 . . . . 5 ((𝐴 ∈ Word 𝑉𝑁 ∈ ((𝐿 + 1)...(𝐿 + 𝑀))) → ((𝐿 + 1) ∈ ℕ0𝑁 ∈ (ℤ‘(𝐿 + 1))))
1093adant2 1125 . . . 4 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉𝑁 ∈ ((𝐿 + 1)...(𝐿 + 𝑀))) → ((𝐿 + 1) ∈ ℕ0𝑁 ∈ (ℤ‘(𝐿 + 1))))
11 eluznn0 11960 . . . 4 (((𝐿 + 1) ∈ ℕ0𝑁 ∈ (ℤ‘(𝐿 + 1))) → 𝑁 ∈ ℕ0)
1210, 11syl 17 . . 3 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉𝑁 ∈ ((𝐿 + 1)...(𝐿 + 𝑀))) → 𝑁 ∈ ℕ0)
13 pfxval 41911 . . 3 (((𝐴 ++ 𝐵) ∈ Word 𝑉𝑁 ∈ ℕ0) → ((𝐴 ++ 𝐵) prefix 𝑁) = ((𝐴 ++ 𝐵) substr ⟨0, 𝑁⟩))
142, 12, 13syl2anc 573 . 2 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉𝑁 ∈ ((𝐿 + 1)...(𝐿 + 𝑀))) → ((𝐴 ++ 𝐵) prefix 𝑁) = ((𝐴 ++ 𝐵) substr ⟨0, 𝑁⟩))
15 3simpa 1142 . . 3 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉𝑁 ∈ ((𝐿 + 1)...(𝐿 + 𝑀))) → (𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉))
1653ad2ant1 1127 . . . . 5 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉𝑁 ∈ ((𝐿 + 1)...(𝐿 + 𝑀))) → 𝐿 ∈ ℕ0)
17 0elfz 12644 . . . . 5 (𝐿 ∈ ℕ0 → 0 ∈ (0...𝐿))
1816, 17syl 17 . . . 4 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉𝑁 ∈ ((𝐿 + 1)...(𝐿 + 𝑀))) → 0 ∈ (0...𝐿))
194nn0zd 11682 . . . . . . . . . . 11 (𝐴 ∈ Word 𝑉 → (♯‘𝐴) ∈ ℤ)
203, 19syl5eqel 2854 . . . . . . . . . 10 (𝐴 ∈ Word 𝑉𝐿 ∈ ℤ)
2120adantr 466 . . . . . . . . 9 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → 𝐿 ∈ ℤ)
22 uzid 11903 . . . . . . . . 9 (𝐿 ∈ ℤ → 𝐿 ∈ (ℤ𝐿))
2321, 22syl 17 . . . . . . . 8 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → 𝐿 ∈ (ℤ𝐿))
24 peano2uz 11943 . . . . . . . 8 (𝐿 ∈ (ℤ𝐿) → (𝐿 + 1) ∈ (ℤ𝐿))
25 fzss1 12587 . . . . . . . 8 ((𝐿 + 1) ∈ (ℤ𝐿) → ((𝐿 + 1)...(𝐿 + 𝑀)) ⊆ (𝐿...(𝐿 + 𝑀)))
2623, 24, 253syl 18 . . . . . . 7 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → ((𝐿 + 1)...(𝐿 + 𝑀)) ⊆ (𝐿...(𝐿 + 𝑀)))
27 pfxccatpfx2.m . . . . . . . . . 10 𝑀 = (♯‘𝐵)
2827eqcomi 2780 . . . . . . . . 9 (♯‘𝐵) = 𝑀
2928oveq2i 6804 . . . . . . . 8 (𝐿 + (♯‘𝐵)) = (𝐿 + 𝑀)
3029oveq2i 6804 . . . . . . 7 (𝐿...(𝐿 + (♯‘𝐵))) = (𝐿...(𝐿 + 𝑀))
3126, 30syl6sseqr 3801 . . . . . 6 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → ((𝐿 + 1)...(𝐿 + 𝑀)) ⊆ (𝐿...(𝐿 + (♯‘𝐵))))
3231sseld 3751 . . . . 5 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → (𝑁 ∈ ((𝐿 + 1)...(𝐿 + 𝑀)) → 𝑁 ∈ (𝐿...(𝐿 + (♯‘𝐵)))))
33323impia 1109 . . . 4 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉𝑁 ∈ ((𝐿 + 1)...(𝐿 + 𝑀))) → 𝑁 ∈ (𝐿...(𝐿 + (♯‘𝐵))))
3418, 33jca 501 . . 3 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉𝑁 ∈ ((𝐿 + 1)...(𝐿 + 𝑀))) → (0 ∈ (0...𝐿) ∧ 𝑁 ∈ (𝐿...(𝐿 + (♯‘𝐵)))))
353pfxccatin12 41953 . . 3 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉) → ((0 ∈ (0...𝐿) ∧ 𝑁 ∈ (𝐿...(𝐿 + (♯‘𝐵)))) → ((𝐴 ++ 𝐵) substr ⟨0, 𝑁⟩) = ((𝐴 substr ⟨0, 𝐿⟩) ++ (𝐵 prefix (𝑁𝐿)))))
3615, 34, 35sylc 65 . 2 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉𝑁 ∈ ((𝐿 + 1)...(𝐿 + 𝑀))) → ((𝐴 ++ 𝐵) substr ⟨0, 𝑁⟩) = ((𝐴 substr ⟨0, 𝐿⟩) ++ (𝐵 prefix (𝑁𝐿))))
373opeq2i 4543 . . . . . 6 ⟨0, 𝐿⟩ = ⟨0, (♯‘𝐴)⟩
3837oveq2i 6804 . . . . 5 (𝐴 substr ⟨0, 𝐿⟩) = (𝐴 substr ⟨0, (♯‘𝐴)⟩)
39 swrdid 13637 . . . . 5 (𝐴 ∈ Word 𝑉 → (𝐴 substr ⟨0, (♯‘𝐴)⟩) = 𝐴)
4038, 39syl5eq 2817 . . . 4 (𝐴 ∈ Word 𝑉 → (𝐴 substr ⟨0, 𝐿⟩) = 𝐴)
41403ad2ant1 1127 . . 3 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉𝑁 ∈ ((𝐿 + 1)...(𝐿 + 𝑀))) → (𝐴 substr ⟨0, 𝐿⟩) = 𝐴)
4241oveq1d 6808 . 2 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉𝑁 ∈ ((𝐿 + 1)...(𝐿 + 𝑀))) → ((𝐴 substr ⟨0, 𝐿⟩) ++ (𝐵 prefix (𝑁𝐿))) = (𝐴 ++ (𝐵 prefix (𝑁𝐿))))
4314, 36, 423eqtrd 2809 1 ((𝐴 ∈ Word 𝑉𝐵 ∈ Word 𝑉𝑁 ∈ ((𝐿 + 1)...(𝐿 + 𝑀))) → ((𝐴 ++ 𝐵) prefix 𝑁) = (𝐴 ++ (𝐵 prefix (𝑁𝐿))))
 Colors of variables: wff setvar class Syntax hints:   → wi 4   ∧ wa 382   ∧ w3a 1071   = wceq 1631   ∈ wcel 2145   ⊆ wss 3723  ⟨cop 4322  ‘cfv 6031  (class class class)co 6793  0cc0 10138  1c1 10139   + caddc 10141   − cmin 10468  ℕ0cn0 11494  ℤcz 11579  ℤ≥cuz 11888  ...cfz 12533  ♯chash 13321  Word cword 13487   ++ cconcat 13489   substr csubstr 13491   prefix cpfx 41909 This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1870  ax-4 1885  ax-5 1991  ax-6 2057  ax-7 2093  ax-8 2147  ax-9 2154  ax-10 2174  ax-11 2190  ax-12 2203  ax-13 2408  ax-ext 2751  ax-rep 4904  ax-sep 4915  ax-nul 4923  ax-pow 4974  ax-pr 5034  ax-un 7096  ax-cnex 10194  ax-resscn 10195  ax-1cn 10196  ax-icn 10197  ax-addcl 10198  ax-addrcl 10199  ax-mulcl 10200  ax-mulrcl 10201  ax-mulcom 10202  ax-addass 10203  ax-mulass 10204  ax-distr 10205  ax-i2m1 10206  ax-1ne0 10207  ax-1rid 10208  ax-rnegex 10209  ax-rrecex 10210  ax-cnre 10211  ax-pre-lttri 10212  ax-pre-lttrn 10213  ax-pre-ltadd 10214  ax-pre-mulgt0 10215 This theorem depends on definitions:  df-bi 197  df-an 383  df-or 837  df-3or 1072  df-3an 1073  df-tru 1634  df-ex 1853  df-nf 1858  df-sb 2050  df-eu 2622  df-mo 2623  df-clab 2758  df-cleq 2764  df-clel 2767  df-nfc 2902  df-ne 2944  df-nel 3047  df-ral 3066  df-rex 3067  df-reu 3068  df-rab 3070  df-v 3353  df-sbc 3588  df-csb 3683  df-dif 3726  df-un 3728  df-in 3730  df-ss 3737  df-pss 3739  df-nul 4064  df-if 4226  df-pw 4299  df-sn 4317  df-pr 4319  df-tp 4321  df-op 4323  df-uni 4575  df-int 4612  df-iun 4656  df-br 4787  df-opab 4847  df-mpt 4864  df-tr 4887  df-id 5157  df-eprel 5162  df-po 5170  df-so 5171  df-fr 5208  df-we 5210  df-xp 5255  df-rel 5256  df-cnv 5257  df-co 5258  df-dm 5259  df-rn 5260  df-res 5261  df-ima 5262  df-pred 5823  df-ord 5869  df-on 5870  df-lim 5871  df-suc 5872  df-iota 5994  df-fun 6033  df-fn 6034  df-f 6035  df-f1 6036  df-fo 6037  df-f1o 6038  df-fv 6039  df-riota 6754  df-ov 6796  df-oprab 6797  df-mpt2 6798  df-om 7213  df-1st 7315  df-2nd 7316  df-wrecs 7559  df-recs 7621  df-rdg 7659  df-1o 7713  df-oadd 7717  df-er 7896  df-en 8110  df-dom 8111  df-sdom 8112  df-fin 8113  df-card 8965  df-pnf 10278  df-mnf 10279  df-xr 10280  df-ltxr 10281  df-le 10282  df-sub 10470  df-neg 10471  df-nn 11223  df-n0 11495  df-z 11580  df-uz 11889  df-fz 12534  df-fzo 12674  df-hash 13322  df-word 13495  df-concat 13497  df-substr 13499  df-pfx 41910 This theorem is referenced by:  pfxccat3a  41957
 Copyright terms: Public domain W3C validator