MPE Home Metamath Proof Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >  swrdwrdsymb Structured version   Visualization version   GIF version

Theorem swrdwrdsymb 14616
Description: A subword is a word over the symbols it consists of. (Contributed by AV, 2-Dec-2022.)
Assertion
Ref Expression
swrdwrdsymb (𝑆 ∈ Word 𝐴 → (𝑆 substr ⟨𝑀, 𝑁⟩) ∈ Word (𝑆 “ (𝑀..^𝑁)))

Proof of Theorem swrdwrdsymb
Dummy variable 𝑥 is distinct from all other variables.
StepHypRef Expression
1 swrdval2 14600 . . . . 5 ((𝑆 ∈ Word 𝐴𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆))) → (𝑆 substr ⟨𝑀, 𝑁⟩) = (𝑥 ∈ (0..^(𝑁𝑀)) ↦ (𝑆‘(𝑥 + 𝑀))))
213expb 1118 . . . 4 ((𝑆 ∈ Word 𝐴 ∧ (𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆)))) → (𝑆 substr ⟨𝑀, 𝑁⟩) = (𝑥 ∈ (0..^(𝑁𝑀)) ↦ (𝑆‘(𝑥 + 𝑀))))
3 wrdf 14473 . . . . . . . . . . 11 (𝑆 ∈ Word 𝐴𝑆:(0..^(♯‘𝑆))⟶𝐴)
43ffund 6720 . . . . . . . . . 10 (𝑆 ∈ Word 𝐴 → Fun 𝑆)
54adantr 479 . . . . . . . . 9 ((𝑆 ∈ Word 𝐴 ∧ (𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆)))) → Fun 𝑆)
65adantr 479 . . . . . . . 8 (((𝑆 ∈ Word 𝐴 ∧ (𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆)))) ∧ 𝑥 ∈ (0..^(𝑁𝑀))) → Fun 𝑆)
7 wrddm 14475 . . . . . . . . . 10 (𝑆 ∈ Word 𝐴 → dom 𝑆 = (0..^(♯‘𝑆)))
8 elfzodifsumelfzo 13702 . . . . . . . . . . . . . 14 ((𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆))) → (𝑥 ∈ (0..^(𝑁𝑀)) → (𝑥 + 𝑀) ∈ (0..^(♯‘𝑆))))
98imp 405 . . . . . . . . . . . . 13 (((𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆))) ∧ 𝑥 ∈ (0..^(𝑁𝑀))) → (𝑥 + 𝑀) ∈ (0..^(♯‘𝑆)))
109adantl 480 . . . . . . . . . . . 12 ((dom 𝑆 = (0..^(♯‘𝑆)) ∧ ((𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆))) ∧ 𝑥 ∈ (0..^(𝑁𝑀)))) → (𝑥 + 𝑀) ∈ (0..^(♯‘𝑆)))
11 eleq2 2820 . . . . . . . . . . . . 13 (dom 𝑆 = (0..^(♯‘𝑆)) → ((𝑥 + 𝑀) ∈ dom 𝑆 ↔ (𝑥 + 𝑀) ∈ (0..^(♯‘𝑆))))
1211adantr 479 . . . . . . . . . . . 12 ((dom 𝑆 = (0..^(♯‘𝑆)) ∧ ((𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆))) ∧ 𝑥 ∈ (0..^(𝑁𝑀)))) → ((𝑥 + 𝑀) ∈ dom 𝑆 ↔ (𝑥 + 𝑀) ∈ (0..^(♯‘𝑆))))
1310, 12mpbird 256 . . . . . . . . . . 11 ((dom 𝑆 = (0..^(♯‘𝑆)) ∧ ((𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆))) ∧ 𝑥 ∈ (0..^(𝑁𝑀)))) → (𝑥 + 𝑀) ∈ dom 𝑆)
1413exp32 419 . . . . . . . . . 10 (dom 𝑆 = (0..^(♯‘𝑆)) → ((𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆))) → (𝑥 ∈ (0..^(𝑁𝑀)) → (𝑥 + 𝑀) ∈ dom 𝑆)))
157, 14syl 17 . . . . . . . . 9 (𝑆 ∈ Word 𝐴 → ((𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆))) → (𝑥 ∈ (0..^(𝑁𝑀)) → (𝑥 + 𝑀) ∈ dom 𝑆)))
1615imp31 416 . . . . . . . 8 (((𝑆 ∈ Word 𝐴 ∧ (𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆)))) ∧ 𝑥 ∈ (0..^(𝑁𝑀))) → (𝑥 + 𝑀) ∈ dom 𝑆)
17 simpr 483 . . . . . . . . 9 (((𝑆 ∈ Word 𝐴 ∧ (𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆)))) ∧ 𝑥 ∈ (0..^(𝑁𝑀))) → 𝑥 ∈ (0..^(𝑁𝑀)))
18 elfzelz 13505 . . . . . . . . . . . 12 (𝑁 ∈ (0...(♯‘𝑆)) → 𝑁 ∈ ℤ)
1918adantl 480 . . . . . . . . . . 11 ((𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆))) → 𝑁 ∈ ℤ)
2019adantl 480 . . . . . . . . . 10 ((𝑆 ∈ Word 𝐴 ∧ (𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆)))) → 𝑁 ∈ ℤ)
2120adantr 479 . . . . . . . . 9 (((𝑆 ∈ Word 𝐴 ∧ (𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆)))) ∧ 𝑥 ∈ (0..^(𝑁𝑀))) → 𝑁 ∈ ℤ)
22 elfzelz 13505 . . . . . . . . . . 11 (𝑀 ∈ (0...𝑁) → 𝑀 ∈ ℤ)
2322ad2antrl 724 . . . . . . . . . 10 ((𝑆 ∈ Word 𝐴 ∧ (𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆)))) → 𝑀 ∈ ℤ)
2423adantr 479 . . . . . . . . 9 (((𝑆 ∈ Word 𝐴 ∧ (𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆)))) ∧ 𝑥 ∈ (0..^(𝑁𝑀))) → 𝑀 ∈ ℤ)
25 fzoaddel2 13692 . . . . . . . . 9 ((𝑥 ∈ (0..^(𝑁𝑀)) ∧ 𝑁 ∈ ℤ ∧ 𝑀 ∈ ℤ) → (𝑥 + 𝑀) ∈ (𝑀..^𝑁))
2617, 21, 24, 25syl3anc 1369 . . . . . . . 8 (((𝑆 ∈ Word 𝐴 ∧ (𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆)))) ∧ 𝑥 ∈ (0..^(𝑁𝑀))) → (𝑥 + 𝑀) ∈ (𝑀..^𝑁))
27 funfvima 7233 . . . . . . . . 9 ((Fun 𝑆 ∧ (𝑥 + 𝑀) ∈ dom 𝑆) → ((𝑥 + 𝑀) ∈ (𝑀..^𝑁) → (𝑆‘(𝑥 + 𝑀)) ∈ (𝑆 “ (𝑀..^𝑁))))
2827imp 405 . . . . . . . 8 (((Fun 𝑆 ∧ (𝑥 + 𝑀) ∈ dom 𝑆) ∧ (𝑥 + 𝑀) ∈ (𝑀..^𝑁)) → (𝑆‘(𝑥 + 𝑀)) ∈ (𝑆 “ (𝑀..^𝑁)))
296, 16, 26, 28syl21anc 834 . . . . . . 7 (((𝑆 ∈ Word 𝐴 ∧ (𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆)))) ∧ 𝑥 ∈ (0..^(𝑁𝑀))) → (𝑆‘(𝑥 + 𝑀)) ∈ (𝑆 “ (𝑀..^𝑁)))
3029fmpttd 7115 . . . . . 6 ((𝑆 ∈ Word 𝐴 ∧ (𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆)))) → (𝑥 ∈ (0..^(𝑁𝑀)) ↦ (𝑆‘(𝑥 + 𝑀))):(0..^(𝑁𝑀))⟶(𝑆 “ (𝑀..^𝑁)))
31 fvex 6903 . . . . . . . . . . . 12 (𝑆‘(𝑥 + 𝑀)) ∈ V
32 eqid 2730 . . . . . . . . . . . 12 (𝑥 ∈ (0..^(𝑁𝑀)) ↦ (𝑆‘(𝑥 + 𝑀))) = (𝑥 ∈ (0..^(𝑁𝑀)) ↦ (𝑆‘(𝑥 + 𝑀)))
3331, 32fnmpti 6692 . . . . . . . . . . 11 (𝑥 ∈ (0..^(𝑁𝑀)) ↦ (𝑆‘(𝑥 + 𝑀))) Fn (0..^(𝑁𝑀))
34 hashfn 14339 . . . . . . . . . . 11 ((𝑥 ∈ (0..^(𝑁𝑀)) ↦ (𝑆‘(𝑥 + 𝑀))) Fn (0..^(𝑁𝑀)) → (♯‘(𝑥 ∈ (0..^(𝑁𝑀)) ↦ (𝑆‘(𝑥 + 𝑀)))) = (♯‘(0..^(𝑁𝑀))))
3533, 34mp1i 13 . . . . . . . . . 10 (𝑀 ∈ (0...𝑁) → (♯‘(𝑥 ∈ (0..^(𝑁𝑀)) ↦ (𝑆‘(𝑥 + 𝑀)))) = (♯‘(0..^(𝑁𝑀))))
36 fznn0sub 13537 . . . . . . . . . . 11 (𝑀 ∈ (0...𝑁) → (𝑁𝑀) ∈ ℕ0)
37 hashfzo0 14394 . . . . . . . . . . 11 ((𝑁𝑀) ∈ ℕ0 → (♯‘(0..^(𝑁𝑀))) = (𝑁𝑀))
3836, 37syl 17 . . . . . . . . . 10 (𝑀 ∈ (0...𝑁) → (♯‘(0..^(𝑁𝑀))) = (𝑁𝑀))
3935, 38eqtrd 2770 . . . . . . . . 9 (𝑀 ∈ (0...𝑁) → (♯‘(𝑥 ∈ (0..^(𝑁𝑀)) ↦ (𝑆‘(𝑥 + 𝑀)))) = (𝑁𝑀))
4039oveq2d 7427 . . . . . . . 8 (𝑀 ∈ (0...𝑁) → (0..^(♯‘(𝑥 ∈ (0..^(𝑁𝑀)) ↦ (𝑆‘(𝑥 + 𝑀))))) = (0..^(𝑁𝑀)))
4140feq2d 6702 . . . . . . 7 (𝑀 ∈ (0...𝑁) → ((𝑥 ∈ (0..^(𝑁𝑀)) ↦ (𝑆‘(𝑥 + 𝑀))):(0..^(♯‘(𝑥 ∈ (0..^(𝑁𝑀)) ↦ (𝑆‘(𝑥 + 𝑀)))))⟶(𝑆 “ (𝑀..^𝑁)) ↔ (𝑥 ∈ (0..^(𝑁𝑀)) ↦ (𝑆‘(𝑥 + 𝑀))):(0..^(𝑁𝑀))⟶(𝑆 “ (𝑀..^𝑁))))
4241ad2antrl 724 . . . . . 6 ((𝑆 ∈ Word 𝐴 ∧ (𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆)))) → ((𝑥 ∈ (0..^(𝑁𝑀)) ↦ (𝑆‘(𝑥 + 𝑀))):(0..^(♯‘(𝑥 ∈ (0..^(𝑁𝑀)) ↦ (𝑆‘(𝑥 + 𝑀)))))⟶(𝑆 “ (𝑀..^𝑁)) ↔ (𝑥 ∈ (0..^(𝑁𝑀)) ↦ (𝑆‘(𝑥 + 𝑀))):(0..^(𝑁𝑀))⟶(𝑆 “ (𝑀..^𝑁))))
4330, 42mpbird 256 . . . . 5 ((𝑆 ∈ Word 𝐴 ∧ (𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆)))) → (𝑥 ∈ (0..^(𝑁𝑀)) ↦ (𝑆‘(𝑥 + 𝑀))):(0..^(♯‘(𝑥 ∈ (0..^(𝑁𝑀)) ↦ (𝑆‘(𝑥 + 𝑀)))))⟶(𝑆 “ (𝑀..^𝑁)))
44 iswrdb 14474 . . . . 5 ((𝑥 ∈ (0..^(𝑁𝑀)) ↦ (𝑆‘(𝑥 + 𝑀))) ∈ Word (𝑆 “ (𝑀..^𝑁)) ↔ (𝑥 ∈ (0..^(𝑁𝑀)) ↦ (𝑆‘(𝑥 + 𝑀))):(0..^(♯‘(𝑥 ∈ (0..^(𝑁𝑀)) ↦ (𝑆‘(𝑥 + 𝑀)))))⟶(𝑆 “ (𝑀..^𝑁)))
4543, 44sylibr 233 . . . 4 ((𝑆 ∈ Word 𝐴 ∧ (𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆)))) → (𝑥 ∈ (0..^(𝑁𝑀)) ↦ (𝑆‘(𝑥 + 𝑀))) ∈ Word (𝑆 “ (𝑀..^𝑁)))
462, 45eqeltrd 2831 . . 3 ((𝑆 ∈ Word 𝐴 ∧ (𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆)))) → (𝑆 substr ⟨𝑀, 𝑁⟩) ∈ Word (𝑆 “ (𝑀..^𝑁)))
4746expcom 412 . 2 ((𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆))) → (𝑆 ∈ Word 𝐴 → (𝑆 substr ⟨𝑀, 𝑁⟩) ∈ Word (𝑆 “ (𝑀..^𝑁))))
48 swrdnd0 14611 . . 3 (𝑆 ∈ Word 𝐴 → (¬ (𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆))) → (𝑆 substr ⟨𝑀, 𝑁⟩) = ∅))
49 wrd0 14493 . . . 4 ∅ ∈ Word (𝑆 “ (𝑀..^𝑁))
50 eleq1 2819 . . . 4 ((𝑆 substr ⟨𝑀, 𝑁⟩) = ∅ → ((𝑆 substr ⟨𝑀, 𝑁⟩) ∈ Word (𝑆 “ (𝑀..^𝑁)) ↔ ∅ ∈ Word (𝑆 “ (𝑀..^𝑁))))
5149, 50mpbiri 257 . . 3 ((𝑆 substr ⟨𝑀, 𝑁⟩) = ∅ → (𝑆 substr ⟨𝑀, 𝑁⟩) ∈ Word (𝑆 “ (𝑀..^𝑁)))
5248, 51syl6com 37 . 2 (¬ (𝑀 ∈ (0...𝑁) ∧ 𝑁 ∈ (0...(♯‘𝑆))) → (𝑆 ∈ Word 𝐴 → (𝑆 substr ⟨𝑀, 𝑁⟩) ∈ Word (𝑆 “ (𝑀..^𝑁))))
5347, 52pm2.61i 182 1 (𝑆 ∈ Word 𝐴 → (𝑆 substr ⟨𝑀, 𝑁⟩) ∈ Word (𝑆 “ (𝑀..^𝑁)))
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wb 205  wa 394   = wceq 1539  wcel 2104  c0 4321  cop 4633  cmpt 5230  dom cdm 5675  cima 5678  Fun wfun 6536   Fn wfn 6537  wf 6538  cfv 6542  (class class class)co 7411  0cc0 11112   + caddc 11115  cmin 11448  0cn0 12476  cz 12562  ...cfz 13488  ..^cfzo 13631  chash 14294  Word cword 14468   substr csubstr 14594
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 1911  ax-6 1969  ax-7 2009  ax-8 2106  ax-9 2114  ax-10 2135  ax-11 2152  ax-12 2169  ax-ext 2701  ax-rep 5284  ax-sep 5298  ax-nul 5305  ax-pow 5362  ax-pr 5426  ax-un 7727  ax-cnex 11168  ax-resscn 11169  ax-1cn 11170  ax-icn 11171  ax-addcl 11172  ax-addrcl 11173  ax-mulcl 11174  ax-mulrcl 11175  ax-mulcom 11176  ax-addass 11177  ax-mulass 11178  ax-distr 11179  ax-i2m1 11180  ax-1ne0 11181  ax-1rid 11182  ax-rnegex 11183  ax-rrecex 11184  ax-cnre 11185  ax-pre-lttri 11186  ax-pre-lttrn 11187  ax-pre-ltadd 11188  ax-pre-mulgt0 11189
This theorem depends on definitions:  df-bi 206  df-an 395  df-or 844  df-3or 1086  df-3an 1087  df-tru 1542  df-fal 1552  df-ex 1780  df-nf 1784  df-sb 2066  df-mo 2532  df-eu 2561  df-clab 2708  df-cleq 2722  df-clel 2808  df-nfc 2883  df-ne 2939  df-nel 3045  df-ral 3060  df-rex 3069  df-reu 3375  df-rab 3431  df-v 3474  df-sbc 3777  df-csb 3893  df-dif 3950  df-un 3952  df-in 3954  df-ss 3964  df-pss 3966  df-nul 4322  df-if 4528  df-pw 4603  df-sn 4628  df-pr 4630  df-op 4634  df-uni 4908  df-int 4950  df-iun 4998  df-br 5148  df-opab 5210  df-mpt 5231  df-tr 5265  df-id 5573  df-eprel 5579  df-po 5587  df-so 5588  df-fr 5630  df-we 5632  df-xp 5681  df-rel 5682  df-cnv 5683  df-co 5684  df-dm 5685  df-rn 5686  df-res 5687  df-ima 5688  df-pred 6299  df-ord 6366  df-on 6367  df-lim 6368  df-suc 6369  df-iota 6494  df-fun 6544  df-fn 6545  df-f 6546  df-f1 6547  df-fo 6548  df-f1o 6549  df-fv 6550  df-riota 7367  df-ov 7414  df-oprab 7415  df-mpo 7416  df-om 7858  df-1st 7977  df-2nd 7978  df-frecs 8268  df-wrecs 8299  df-recs 8373  df-rdg 8412  df-1o 8468  df-er 8705  df-en 8942  df-dom 8943  df-sdom 8944  df-fin 8945  df-card 9936  df-pnf 11254  df-mnf 11255  df-xr 11256  df-ltxr 11257  df-le 11258  df-sub 11450  df-neg 11451  df-nn 12217  df-n0 12477  df-z 12563  df-uz 12827  df-fz 13489  df-fzo 13632  df-hash 14295  df-word 14469  df-substr 14595
This theorem is referenced by:  pfxwrdsymb  14643
  Copyright terms: Public domain W3C validator