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

Theorem swrdrevpfx 32363
Description: A subword expressed in terms of reverses and prefixes. (Contributed by BTernaryTau, 3-Dec-2023.)
Assertion
Ref Expression
swrdrevpfx ((𝑊 ∈ Word 𝑉𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑊))) → (𝑊 substr ⟨𝐹, 𝐿⟩) = (reverse‘((reverse‘(𝑊 prefix 𝐿)) prefix (𝐿𝐹))))

Proof of Theorem swrdrevpfx
StepHypRef Expression
1 fznn0sub2 13015 . . . . . 6 (𝐹 ∈ (0...𝐿) → (𝐿𝐹) ∈ (0...𝐿))
2 pfxcl 14039 . . . . . . . . 9 (𝑊 ∈ Word 𝑉 → (𝑊 prefix 𝐿) ∈ Word 𝑉)
3 revcl 14123 . . . . . . . . 9 ((𝑊 prefix 𝐿) ∈ Word 𝑉 → (reverse‘(𝑊 prefix 𝐿)) ∈ Word 𝑉)
42, 3syl 17 . . . . . . . 8 (𝑊 ∈ Word 𝑉 → (reverse‘(𝑊 prefix 𝐿)) ∈ Word 𝑉)
543ad2ant1 1129 . . . . . . 7 ((𝑊 ∈ Word 𝑉𝐿 ∈ (0...(♯‘𝑊)) ∧ (𝐿𝐹) ∈ (0...𝐿)) → (reverse‘(𝑊 prefix 𝐿)) ∈ Word 𝑉)
6 simp3 1134 . . . . . . . 8 ((𝑊 ∈ Word 𝑉𝐿 ∈ (0...(♯‘𝑊)) ∧ (𝐿𝐹) ∈ (0...𝐿)) → (𝐿𝐹) ∈ (0...𝐿))
7 revlen 14124 . . . . . . . . . . . . 13 ((𝑊 prefix 𝐿) ∈ Word 𝑉 → (♯‘(reverse‘(𝑊 prefix 𝐿))) = (♯‘(𝑊 prefix 𝐿)))
82, 7syl 17 . . . . . . . . . . . 12 (𝑊 ∈ Word 𝑉 → (♯‘(reverse‘(𝑊 prefix 𝐿))) = (♯‘(𝑊 prefix 𝐿)))
98adantr 483 . . . . . . . . . . 11 ((𝑊 ∈ Word 𝑉𝐿 ∈ (0...(♯‘𝑊))) → (♯‘(reverse‘(𝑊 prefix 𝐿))) = (♯‘(𝑊 prefix 𝐿)))
10 pfxlen 14045 . . . . . . . . . . 11 ((𝑊 ∈ Word 𝑉𝐿 ∈ (0...(♯‘𝑊))) → (♯‘(𝑊 prefix 𝐿)) = 𝐿)
119, 10eqtrd 2856 . . . . . . . . . 10 ((𝑊 ∈ Word 𝑉𝐿 ∈ (0...(♯‘𝑊))) → (♯‘(reverse‘(𝑊 prefix 𝐿))) = 𝐿)
12113adant3 1128 . . . . . . . . 9 ((𝑊 ∈ Word 𝑉𝐿 ∈ (0...(♯‘𝑊)) ∧ (𝐿𝐹) ∈ (0...𝐿)) → (♯‘(reverse‘(𝑊 prefix 𝐿))) = 𝐿)
1312oveq2d 7172 . . . . . . . 8 ((𝑊 ∈ Word 𝑉𝐿 ∈ (0...(♯‘𝑊)) ∧ (𝐿𝐹) ∈ (0...𝐿)) → (0...(♯‘(reverse‘(𝑊 prefix 𝐿)))) = (0...𝐿))
146, 13eleqtrrd 2916 . . . . . . 7 ((𝑊 ∈ Word 𝑉𝐿 ∈ (0...(♯‘𝑊)) ∧ (𝐿𝐹) ∈ (0...𝐿)) → (𝐿𝐹) ∈ (0...(♯‘(reverse‘(𝑊 prefix 𝐿)))))
155, 14jca 514 . . . . . 6 ((𝑊 ∈ Word 𝑉𝐿 ∈ (0...(♯‘𝑊)) ∧ (𝐿𝐹) ∈ (0...𝐿)) → ((reverse‘(𝑊 prefix 𝐿)) ∈ Word 𝑉 ∧ (𝐿𝐹) ∈ (0...(♯‘(reverse‘(𝑊 prefix 𝐿))))))
161, 15syl3an3 1161 . . . . 5 ((𝑊 ∈ Word 𝑉𝐿 ∈ (0...(♯‘𝑊)) ∧ 𝐹 ∈ (0...𝐿)) → ((reverse‘(𝑊 prefix 𝐿)) ∈ Word 𝑉 ∧ (𝐿𝐹) ∈ (0...(♯‘(reverse‘(𝑊 prefix 𝐿))))))
17163com23 1122 . . . 4 ((𝑊 ∈ Word 𝑉𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑊))) → ((reverse‘(𝑊 prefix 𝐿)) ∈ Word 𝑉 ∧ (𝐿𝐹) ∈ (0...(♯‘(reverse‘(𝑊 prefix 𝐿))))))
18 revpfxsfxrev 32362 . . . 4 (((reverse‘(𝑊 prefix 𝐿)) ∈ Word 𝑉 ∧ (𝐿𝐹) ∈ (0...(♯‘(reverse‘(𝑊 prefix 𝐿))))) → (reverse‘((reverse‘(𝑊 prefix 𝐿)) prefix (𝐿𝐹))) = ((reverse‘(reverse‘(𝑊 prefix 𝐿))) substr ⟨((♯‘(reverse‘(𝑊 prefix 𝐿))) − (𝐿𝐹)), (♯‘(reverse‘(𝑊 prefix 𝐿)))⟩))
1917, 18syl 17 . . 3 ((𝑊 ∈ Word 𝑉𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑊))) → (reverse‘((reverse‘(𝑊 prefix 𝐿)) prefix (𝐿𝐹))) = ((reverse‘(reverse‘(𝑊 prefix 𝐿))) substr ⟨((♯‘(reverse‘(𝑊 prefix 𝐿))) − (𝐿𝐹)), (♯‘(reverse‘(𝑊 prefix 𝐿)))⟩))
20 revrev 14129 . . . . . 6 ((𝑊 prefix 𝐿) ∈ Word 𝑉 → (reverse‘(reverse‘(𝑊 prefix 𝐿))) = (𝑊 prefix 𝐿))
212, 20syl 17 . . . . 5 (𝑊 ∈ Word 𝑉 → (reverse‘(reverse‘(𝑊 prefix 𝐿))) = (𝑊 prefix 𝐿))
2221oveq1d 7171 . . . 4 (𝑊 ∈ Word 𝑉 → ((reverse‘(reverse‘(𝑊 prefix 𝐿))) substr ⟨((♯‘(reverse‘(𝑊 prefix 𝐿))) − (𝐿𝐹)), (♯‘(reverse‘(𝑊 prefix 𝐿)))⟩) = ((𝑊 prefix 𝐿) substr ⟨((♯‘(reverse‘(𝑊 prefix 𝐿))) − (𝐿𝐹)), (♯‘(reverse‘(𝑊 prefix 𝐿)))⟩))
23223ad2ant1 1129 . . 3 ((𝑊 ∈ Word 𝑉𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑊))) → ((reverse‘(reverse‘(𝑊 prefix 𝐿))) substr ⟨((♯‘(reverse‘(𝑊 prefix 𝐿))) − (𝐿𝐹)), (♯‘(reverse‘(𝑊 prefix 𝐿)))⟩) = ((𝑊 prefix 𝐿) substr ⟨((♯‘(reverse‘(𝑊 prefix 𝐿))) − (𝐿𝐹)), (♯‘(reverse‘(𝑊 prefix 𝐿)))⟩))
2411oveq1d 7171 . . . . . . 7 ((𝑊 ∈ Word 𝑉𝐿 ∈ (0...(♯‘𝑊))) → ((♯‘(reverse‘(𝑊 prefix 𝐿))) − (𝐿𝐹)) = (𝐿 − (𝐿𝐹)))
25243adant2 1127 . . . . . 6 ((𝑊 ∈ Word 𝑉𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑊))) → ((♯‘(reverse‘(𝑊 prefix 𝐿))) − (𝐿𝐹)) = (𝐿 − (𝐿𝐹)))
26 elfzel2 12907 . . . . . . . . 9 (𝐹 ∈ (0...𝐿) → 𝐿 ∈ ℤ)
2726zcnd 12089 . . . . . . . 8 (𝐹 ∈ (0...𝐿) → 𝐿 ∈ ℂ)
28 elfzelz 12909 . . . . . . . . 9 (𝐹 ∈ (0...𝐿) → 𝐹 ∈ ℤ)
2928zcnd 12089 . . . . . . . 8 (𝐹 ∈ (0...𝐿) → 𝐹 ∈ ℂ)
3027, 29nncand 11002 . . . . . . 7 (𝐹 ∈ (0...𝐿) → (𝐿 − (𝐿𝐹)) = 𝐹)
31303ad2ant2 1130 . . . . . 6 ((𝑊 ∈ Word 𝑉𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑊))) → (𝐿 − (𝐿𝐹)) = 𝐹)
3225, 31eqtrd 2856 . . . . 5 ((𝑊 ∈ Word 𝑉𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑊))) → ((♯‘(reverse‘(𝑊 prefix 𝐿))) − (𝐿𝐹)) = 𝐹)
33113adant2 1127 . . . . 5 ((𝑊 ∈ Word 𝑉𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑊))) → (♯‘(reverse‘(𝑊 prefix 𝐿))) = 𝐿)
3432, 33opeq12d 4811 . . . 4 ((𝑊 ∈ Word 𝑉𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑊))) → ⟨((♯‘(reverse‘(𝑊 prefix 𝐿))) − (𝐿𝐹)), (♯‘(reverse‘(𝑊 prefix 𝐿)))⟩ = ⟨𝐹, 𝐿⟩)
3534oveq2d 7172 . . 3 ((𝑊 ∈ Word 𝑉𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑊))) → ((𝑊 prefix 𝐿) substr ⟨((♯‘(reverse‘(𝑊 prefix 𝐿))) − (𝐿𝐹)), (♯‘(reverse‘(𝑊 prefix 𝐿)))⟩) = ((𝑊 prefix 𝐿) substr ⟨𝐹, 𝐿⟩))
3619, 23, 353eqtrd 2860 . 2 ((𝑊 ∈ Word 𝑉𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑊))) → (reverse‘((reverse‘(𝑊 prefix 𝐿)) prefix (𝐿𝐹))) = ((𝑊 prefix 𝐿) substr ⟨𝐹, 𝐿⟩))
37 elfzuz3 12906 . . . . . . . 8 (𝐹 ∈ (0...𝐿) → 𝐿 ∈ (ℤ𝐹))
38 eluzfz2 12916 . . . . . . . 8 (𝐿 ∈ (ℤ𝐹) → 𝐿 ∈ (𝐹...𝐿))
3937, 38syl 17 . . . . . . 7 (𝐹 ∈ (0...𝐿) → 𝐿 ∈ (𝐹...𝐿))
4039ancli 551 . . . . . 6 (𝐹 ∈ (0...𝐿) → (𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (𝐹...𝐿)))
41403ad2ant2 1130 . . . . 5 ((𝑊 ∈ Word 𝑉𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑊))) → (𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (𝐹...𝐿)))
42 swrdpfx 14069 . . . . 5 ((𝑊 ∈ Word 𝑉𝐿 ∈ (0...(♯‘𝑊))) → ((𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (𝐹...𝐿)) → ((𝑊 prefix 𝐿) substr ⟨𝐹, 𝐿⟩) = (𝑊 substr ⟨𝐹, 𝐿⟩)))
4341, 42syl5 34 . . . 4 ((𝑊 ∈ Word 𝑉𝐿 ∈ (0...(♯‘𝑊))) → ((𝑊 ∈ Word 𝑉𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑊))) → ((𝑊 prefix 𝐿) substr ⟨𝐹, 𝐿⟩) = (𝑊 substr ⟨𝐹, 𝐿⟩)))
44433adant2 1127 . . 3 ((𝑊 ∈ Word 𝑉𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑊))) → ((𝑊 ∈ Word 𝑉𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑊))) → ((𝑊 prefix 𝐿) substr ⟨𝐹, 𝐿⟩) = (𝑊 substr ⟨𝐹, 𝐿⟩)))
4544pm2.43i 52 . 2 ((𝑊 ∈ Word 𝑉𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑊))) → ((𝑊 prefix 𝐿) substr ⟨𝐹, 𝐿⟩) = (𝑊 substr ⟨𝐹, 𝐿⟩))
4636, 45eqtr2d 2857 1 ((𝑊 ∈ Word 𝑉𝐹 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝑊))) → (𝑊 substr ⟨𝐹, 𝐿⟩) = (reverse‘((reverse‘(𝑊 prefix 𝐿)) prefix (𝐿𝐹))))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wa 398  w3a 1083   = wceq 1537  wcel 2114  cop 4573  cfv 6355  (class class class)co 7156  0cc0 10537  cmin 10870  cuz 12244  ...cfz 12893  chash 13691  Word cword 13862   substr csubstr 14002   prefix cpfx 14032  reversecreverse 14120
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1796  ax-4 1810  ax-5 1911  ax-6 1970  ax-7 2015  ax-8 2116  ax-9 2124  ax-10 2145  ax-11 2161  ax-12 2177  ax-ext 2793  ax-rep 5190  ax-sep 5203  ax-nul 5210  ax-pow 5266  ax-pr 5330  ax-un 7461  ax-cnex 10593  ax-resscn 10594  ax-1cn 10595  ax-icn 10596  ax-addcl 10597  ax-addrcl 10598  ax-mulcl 10599  ax-mulrcl 10600  ax-mulcom 10601  ax-addass 10602  ax-mulass 10603  ax-distr 10604  ax-i2m1 10605  ax-1ne0 10606  ax-1rid 10607  ax-rnegex 10608  ax-rrecex 10609  ax-cnre 10610  ax-pre-lttri 10611  ax-pre-lttrn 10612  ax-pre-ltadd 10613  ax-pre-mulgt0 10614
This theorem depends on definitions:  df-bi 209  df-an 399  df-or 844  df-3or 1084  df-3an 1085  df-tru 1540  df-ex 1781  df-nf 1785  df-sb 2070  df-mo 2622  df-eu 2654  df-clab 2800  df-cleq 2814  df-clel 2893  df-nfc 2963  df-ne 3017  df-nel 3124  df-ral 3143  df-rex 3144  df-reu 3145  df-rab 3147  df-v 3496  df-sbc 3773  df-csb 3884  df-dif 3939  df-un 3941  df-in 3943  df-ss 3952  df-pss 3954  df-nul 4292  df-if 4468  df-pw 4541  df-sn 4568  df-pr 4570  df-tp 4572  df-op 4574  df-uni 4839  df-int 4877  df-iun 4921  df-br 5067  df-opab 5129  df-mpt 5147  df-tr 5173  df-id 5460  df-eprel 5465  df-po 5474  df-so 5475  df-fr 5514  df-we 5516  df-xp 5561  df-rel 5562  df-cnv 5563  df-co 5564  df-dm 5565  df-rn 5566  df-res 5567  df-ima 5568  df-pred 6148  df-ord 6194  df-on 6195  df-lim 6196  df-suc 6197  df-iota 6314  df-fun 6357  df-fn 6358  df-f 6359  df-f1 6360  df-fo 6361  df-f1o 6362  df-fv 6363  df-riota 7114  df-ov 7159  df-oprab 7160  df-mpo 7161  df-om 7581  df-1st 7689  df-2nd 7690  df-wrecs 7947  df-recs 8008  df-rdg 8046  df-1o 8102  df-oadd 8106  df-er 8289  df-en 8510  df-dom 8511  df-sdom 8512  df-fin 8513  df-card 9368  df-pnf 10677  df-mnf 10678  df-xr 10679  df-ltxr 10680  df-le 10681  df-sub 10872  df-neg 10873  df-nn 11639  df-n0 11899  df-z 11983  df-uz 12245  df-fz 12894  df-fzo 13035  df-hash 13692  df-word 13863  df-substr 14003  df-pfx 14033  df-reverse 14121
This theorem is referenced by:  swrdwlk  32373
  Copyright terms: Public domain W3C validator