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

Theorem swrdwlk 35325
Description: Two matching subwords of a walk also represent a walk. (Contributed by BTernaryTau, 7-Dec-2023.)
Assertion
Ref Expression
swrdwlk ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (𝐹 substr ⟨𝐵, 𝐿⟩)(Walks‘𝐺)(𝑃 substr ⟨𝐵, (𝐿 + 1)⟩))

Proof of Theorem swrdwlk
StepHypRef Expression
1 pfxwlk 35322 . . . . . . 7 ((𝐹(Walks‘𝐺)𝑃𝐿 ∈ (0...(♯‘𝐹))) → (𝐹 prefix 𝐿)(Walks‘𝐺)(𝑃 prefix (𝐿 + 1)))
213adant2 1132 . . . . . 6 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (𝐹 prefix 𝐿)(Walks‘𝐺)(𝑃 prefix (𝐿 + 1)))
3 revwlk 35323 . . . . . 6 ((𝐹 prefix 𝐿)(Walks‘𝐺)(𝑃 prefix (𝐿 + 1)) → (reverse‘(𝐹 prefix 𝐿))(Walks‘𝐺)(reverse‘(𝑃 prefix (𝐿 + 1))))
42, 3syl 17 . . . . 5 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (reverse‘(𝐹 prefix 𝐿))(Walks‘𝐺)(reverse‘(𝑃 prefix (𝐿 + 1))))
5 fznn0sub2 13580 . . . . . . 7 (𝐵 ∈ (0...𝐿) → (𝐿𝐵) ∈ (0...𝐿))
653ad2ant2 1135 . . . . . 6 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (𝐿𝐵) ∈ (0...𝐿))
7 eqid 2737 . . . . . . . . . . 11 (iEdg‘𝐺) = (iEdg‘𝐺)
87wlkf 29698 . . . . . . . . . 10 (𝐹(Walks‘𝐺)𝑃𝐹 ∈ Word dom (iEdg‘𝐺))
983ad2ant1 1134 . . . . . . . . 9 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → 𝐹 ∈ Word dom (iEdg‘𝐺))
10 pfxcl 14631 . . . . . . . . 9 (𝐹 ∈ Word dom (iEdg‘𝐺) → (𝐹 prefix 𝐿) ∈ Word dom (iEdg‘𝐺))
11 revlen 14715 . . . . . . . . 9 ((𝐹 prefix 𝐿) ∈ Word dom (iEdg‘𝐺) → (♯‘(reverse‘(𝐹 prefix 𝐿))) = (♯‘(𝐹 prefix 𝐿)))
129, 10, 113syl 18 . . . . . . . 8 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (♯‘(reverse‘(𝐹 prefix 𝐿))) = (♯‘(𝐹 prefix 𝐿)))
13 pfxlen 14637 . . . . . . . . . 10 ((𝐹 ∈ Word dom (iEdg‘𝐺) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (♯‘(𝐹 prefix 𝐿)) = 𝐿)
148, 13sylan 581 . . . . . . . . 9 ((𝐹(Walks‘𝐺)𝑃𝐿 ∈ (0...(♯‘𝐹))) → (♯‘(𝐹 prefix 𝐿)) = 𝐿)
15143adant2 1132 . . . . . . . 8 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (♯‘(𝐹 prefix 𝐿)) = 𝐿)
1612, 15eqtrd 2772 . . . . . . 7 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (♯‘(reverse‘(𝐹 prefix 𝐿))) = 𝐿)
1716oveq2d 7376 . . . . . 6 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (0...(♯‘(reverse‘(𝐹 prefix 𝐿)))) = (0...𝐿))
186, 17eleqtrrd 2840 . . . . 5 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (𝐿𝐵) ∈ (0...(♯‘(reverse‘(𝐹 prefix 𝐿)))))
19 pfxwlk 35322 . . . . 5 (((reverse‘(𝐹 prefix 𝐿))(Walks‘𝐺)(reverse‘(𝑃 prefix (𝐿 + 1))) ∧ (𝐿𝐵) ∈ (0...(♯‘(reverse‘(𝐹 prefix 𝐿))))) → ((reverse‘(𝐹 prefix 𝐿)) prefix (𝐿𝐵))(Walks‘𝐺)((reverse‘(𝑃 prefix (𝐿 + 1))) prefix ((𝐿𝐵) + 1)))
204, 18, 19syl2anc 585 . . . 4 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → ((reverse‘(𝐹 prefix 𝐿)) prefix (𝐿𝐵))(Walks‘𝐺)((reverse‘(𝑃 prefix (𝐿 + 1))) prefix ((𝐿𝐵) + 1)))
21 elfzel2 13467 . . . . . . . 8 (𝐵 ∈ (0...𝐿) → 𝐿 ∈ ℤ)
22213ad2ant2 1135 . . . . . . 7 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → 𝐿 ∈ ℤ)
2322zcnd 12625 . . . . . 6 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → 𝐿 ∈ ℂ)
24 1cnd 11130 . . . . . 6 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → 1 ∈ ℂ)
25 elfzelz 13469 . . . . . . . 8 (𝐵 ∈ (0...𝐿) → 𝐵 ∈ ℤ)
26253ad2ant2 1135 . . . . . . 7 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → 𝐵 ∈ ℤ)
2726zcnd 12625 . . . . . 6 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → 𝐵 ∈ ℂ)
2823, 24, 27addsubd 11517 . . . . 5 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → ((𝐿 + 1) − 𝐵) = ((𝐿𝐵) + 1))
2928oveq2d 7376 . . . 4 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → ((reverse‘(𝑃 prefix (𝐿 + 1))) prefix ((𝐿 + 1) − 𝐵)) = ((reverse‘(𝑃 prefix (𝐿 + 1))) prefix ((𝐿𝐵) + 1)))
3020, 29breqtrrd 5114 . . 3 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → ((reverse‘(𝐹 prefix 𝐿)) prefix (𝐿𝐵))(Walks‘𝐺)((reverse‘(𝑃 prefix (𝐿 + 1))) prefix ((𝐿 + 1) − 𝐵)))
31 revwlk 35323 . . 3 (((reverse‘(𝐹 prefix 𝐿)) prefix (𝐿𝐵))(Walks‘𝐺)((reverse‘(𝑃 prefix (𝐿 + 1))) prefix ((𝐿 + 1) − 𝐵)) → (reverse‘((reverse‘(𝐹 prefix 𝐿)) prefix (𝐿𝐵)))(Walks‘𝐺)(reverse‘((reverse‘(𝑃 prefix (𝐿 + 1))) prefix ((𝐿 + 1) − 𝐵))))
3230, 31syl 17 . 2 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (reverse‘((reverse‘(𝐹 prefix 𝐿)) prefix (𝐿𝐵)))(Walks‘𝐺)(reverse‘((reverse‘(𝑃 prefix (𝐿 + 1))) prefix ((𝐿 + 1) − 𝐵))))
33 swrdrevpfx 35315 . . 3 ((𝐹 ∈ Word dom (iEdg‘𝐺) ∧ 𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (𝐹 substr ⟨𝐵, 𝐿⟩) = (reverse‘((reverse‘(𝐹 prefix 𝐿)) prefix (𝐿𝐵))))
348, 33syl3an1 1164 . 2 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (𝐹 substr ⟨𝐵, 𝐿⟩) = (reverse‘((reverse‘(𝐹 prefix 𝐿)) prefix (𝐿𝐵))))
35 eqid 2737 . . . . 5 (Vtx‘𝐺) = (Vtx‘𝐺)
3635wlkpwrd 29701 . . . 4 (𝐹(Walks‘𝐺)𝑃𝑃 ∈ Word (Vtx‘𝐺))
37363ad2ant1 1134 . . 3 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → 𝑃 ∈ Word (Vtx‘𝐺))
38 fzelp1 13521 . . . 4 (𝐵 ∈ (0...𝐿) → 𝐵 ∈ (0...(𝐿 + 1)))
39383ad2ant2 1135 . . 3 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → 𝐵 ∈ (0...(𝐿 + 1)))
40 fzp1elp1 13522 . . . . 5 (𝐿 ∈ (0...(♯‘𝐹)) → (𝐿 + 1) ∈ (0...((♯‘𝐹) + 1)))
41403ad2ant3 1136 . . . 4 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (𝐿 + 1) ∈ (0...((♯‘𝐹) + 1)))
42 wlklenvp1 29702 . . . . . 6 (𝐹(Walks‘𝐺)𝑃 → (♯‘𝑃) = ((♯‘𝐹) + 1))
43423ad2ant1 1134 . . . . 5 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (♯‘𝑃) = ((♯‘𝐹) + 1))
4443oveq2d 7376 . . . 4 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (0...(♯‘𝑃)) = (0...((♯‘𝐹) + 1)))
4541, 44eleqtrrd 2840 . . 3 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (𝐿 + 1) ∈ (0...(♯‘𝑃)))
46 swrdrevpfx 35315 . . 3 ((𝑃 ∈ Word (Vtx‘𝐺) ∧ 𝐵 ∈ (0...(𝐿 + 1)) ∧ (𝐿 + 1) ∈ (0...(♯‘𝑃))) → (𝑃 substr ⟨𝐵, (𝐿 + 1)⟩) = (reverse‘((reverse‘(𝑃 prefix (𝐿 + 1))) prefix ((𝐿 + 1) − 𝐵))))
4737, 39, 45, 46syl3anc 1374 . 2 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (𝑃 substr ⟨𝐵, (𝐿 + 1)⟩) = (reverse‘((reverse‘(𝑃 prefix (𝐿 + 1))) prefix ((𝐿 + 1) − 𝐵))))
4832, 34, 473brtr4d 5118 1 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (𝐹 substr ⟨𝐵, 𝐿⟩)(Walks‘𝐺)(𝑃 substr ⟨𝐵, (𝐿 + 1)⟩))
Colors of variables: wff setvar class
Syntax hints:  wi 4  w3a 1087   = wceq 1542  wcel 2114  cop 4574   class class class wbr 5086  dom cdm 5624  cfv 6492  (class class class)co 7360  0cc0 11029  1c1 11030   + caddc 11032  cmin 11368  cz 12515  ...cfz 13452  chash 14283  Word cword 14466   substr csubstr 14594   prefix cpfx 14624  reversecreverse 14711  Vtxcvtx 29079  iEdgciedg 29080  Walkscwlks 29680
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1797  ax-4 1811  ax-5 1912  ax-6 1969  ax-7 2010  ax-8 2116  ax-9 2124  ax-10 2147  ax-11 2163  ax-12 2185  ax-ext 2709  ax-rep 5212  ax-sep 5231  ax-nul 5241  ax-pow 5302  ax-pr 5370  ax-un 7682  ax-cnex 11085  ax-resscn 11086  ax-1cn 11087  ax-icn 11088  ax-addcl 11089  ax-addrcl 11090  ax-mulcl 11091  ax-mulrcl 11092  ax-mulcom 11093  ax-addass 11094  ax-mulass 11095  ax-distr 11096  ax-i2m1 11097  ax-1ne0 11098  ax-1rid 11099  ax-rnegex 11100  ax-rrecex 11101  ax-cnre 11102  ax-pre-lttri 11103  ax-pre-lttrn 11104  ax-pre-ltadd 11105  ax-pre-mulgt0 11106
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 849  df-ifp 1064  df-3or 1088  df-3an 1089  df-tru 1545  df-fal 1555  df-ex 1782  df-nf 1786  df-sb 2069  df-mo 2540  df-eu 2570  df-clab 2716  df-cleq 2729  df-clel 2812  df-nfc 2886  df-ne 2934  df-nel 3038  df-ral 3053  df-rex 3063  df-reu 3344  df-rab 3391  df-v 3432  df-sbc 3730  df-csb 3839  df-dif 3893  df-un 3895  df-in 3897  df-ss 3907  df-pss 3910  df-nul 4275  df-if 4468  df-pw 4544  df-sn 4569  df-pr 4571  df-op 4575  df-uni 4852  df-int 4891  df-iun 4936  df-br 5087  df-opab 5149  df-mpt 5168  df-tr 5194  df-id 5519  df-eprel 5524  df-po 5532  df-so 5533  df-fr 5577  df-we 5579  df-xp 5630  df-rel 5631  df-cnv 5632  df-co 5633  df-dm 5634  df-rn 5635  df-res 5636  df-ima 5637  df-pred 6259  df-ord 6320  df-on 6321  df-lim 6322  df-suc 6323  df-iota 6448  df-fun 6494  df-fn 6495  df-f 6496  df-f1 6497  df-fo 6498  df-f1o 6499  df-fv 6500  df-riota 7317  df-ov 7363  df-oprab 7364  df-mpo 7365  df-om 7811  df-1st 7935  df-2nd 7936  df-frecs 8224  df-wrecs 8255  df-recs 8304  df-rdg 8342  df-1o 8398  df-er 8636  df-map 8768  df-pm 8769  df-en 8887  df-dom 8888  df-sdom 8889  df-fin 8890  df-card 9854  df-pnf 11172  df-mnf 11173  df-xr 11174  df-ltxr 11175  df-le 11176  df-sub 11370  df-neg 11371  df-nn 12166  df-2 12235  df-n0 12429  df-z 12516  df-uz 12780  df-fz 13453  df-fzo 13600  df-hash 14284  df-word 14467  df-substr 14595  df-pfx 14625  df-reverse 14712  df-wlks 29683
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator