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 35321
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 35318 . . . . . . 7 ((𝐹(Walks‘𝐺)𝑃𝐿 ∈ (0...(♯‘𝐹))) → (𝐹 prefix 𝐿)(Walks‘𝐺)(𝑃 prefix (𝐿 + 1)))
213adant2 1131 . . . . . 6 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (𝐹 prefix 𝐿)(Walks‘𝐺)(𝑃 prefix (𝐿 + 1)))
3 revwlk 35319 . . . . . 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 13551 . . . . . . 7 (𝐵 ∈ (0...𝐿) → (𝐿𝐵) ∈ (0...𝐿))
653ad2ant2 1134 . . . . . 6 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (𝐿𝐵) ∈ (0...𝐿))
7 eqid 2736 . . . . . . . . . . 11 (iEdg‘𝐺) = (iEdg‘𝐺)
87wlkf 29688 . . . . . . . . . 10 (𝐹(Walks‘𝐺)𝑃𝐹 ∈ Word dom (iEdg‘𝐺))
983ad2ant1 1133 . . . . . . . . 9 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → 𝐹 ∈ Word dom (iEdg‘𝐺))
10 pfxcl 14601 . . . . . . . . 9 (𝐹 ∈ Word dom (iEdg‘𝐺) → (𝐹 prefix 𝐿) ∈ Word dom (iEdg‘𝐺))
11 revlen 14685 . . . . . . . . 9 ((𝐹 prefix 𝐿) ∈ Word dom (iEdg‘𝐺) → (♯‘(reverse‘(𝐹 prefix 𝐿))) = (♯‘(𝐹 prefix 𝐿)))
129, 10, 113syl 18 . . . . . . . 8 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (♯‘(reverse‘(𝐹 prefix 𝐿))) = (♯‘(𝐹 prefix 𝐿)))
13 pfxlen 14607 . . . . . . . . . 10 ((𝐹 ∈ Word dom (iEdg‘𝐺) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (♯‘(𝐹 prefix 𝐿)) = 𝐿)
148, 13sylan 580 . . . . . . . . 9 ((𝐹(Walks‘𝐺)𝑃𝐿 ∈ (0...(♯‘𝐹))) → (♯‘(𝐹 prefix 𝐿)) = 𝐿)
15143adant2 1131 . . . . . . . 8 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (♯‘(𝐹 prefix 𝐿)) = 𝐿)
1612, 15eqtrd 2771 . . . . . . 7 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (♯‘(reverse‘(𝐹 prefix 𝐿))) = 𝐿)
1716oveq2d 7374 . . . . . 6 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (0...(♯‘(reverse‘(𝐹 prefix 𝐿)))) = (0...𝐿))
186, 17eleqtrrd 2839 . . . . 5 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (𝐿𝐵) ∈ (0...(♯‘(reverse‘(𝐹 prefix 𝐿)))))
19 pfxwlk 35318 . . . . 5 (((reverse‘(𝐹 prefix 𝐿))(Walks‘𝐺)(reverse‘(𝑃 prefix (𝐿 + 1))) ∧ (𝐿𝐵) ∈ (0...(♯‘(reverse‘(𝐹 prefix 𝐿))))) → ((reverse‘(𝐹 prefix 𝐿)) prefix (𝐿𝐵))(Walks‘𝐺)((reverse‘(𝑃 prefix (𝐿 + 1))) prefix ((𝐿𝐵) + 1)))
204, 18, 19syl2anc 584 . . . 4 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → ((reverse‘(𝐹 prefix 𝐿)) prefix (𝐿𝐵))(Walks‘𝐺)((reverse‘(𝑃 prefix (𝐿 + 1))) prefix ((𝐿𝐵) + 1)))
21 elfzel2 13438 . . . . . . . 8 (𝐵 ∈ (0...𝐿) → 𝐿 ∈ ℤ)
22213ad2ant2 1134 . . . . . . 7 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → 𝐿 ∈ ℤ)
2322zcnd 12597 . . . . . 6 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → 𝐿 ∈ ℂ)
24 1cnd 11127 . . . . . 6 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → 1 ∈ ℂ)
25 elfzelz 13440 . . . . . . . 8 (𝐵 ∈ (0...𝐿) → 𝐵 ∈ ℤ)
26253ad2ant2 1134 . . . . . . 7 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → 𝐵 ∈ ℤ)
2726zcnd 12597 . . . . . 6 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → 𝐵 ∈ ℂ)
2823, 24, 27addsubd 11513 . . . . 5 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → ((𝐿 + 1) − 𝐵) = ((𝐿𝐵) + 1))
2928oveq2d 7374 . . . 4 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → ((reverse‘(𝑃 prefix (𝐿 + 1))) prefix ((𝐿 + 1) − 𝐵)) = ((reverse‘(𝑃 prefix (𝐿 + 1))) prefix ((𝐿𝐵) + 1)))
3020, 29breqtrrd 5126 . . 3 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → ((reverse‘(𝐹 prefix 𝐿)) prefix (𝐿𝐵))(Walks‘𝐺)((reverse‘(𝑃 prefix (𝐿 + 1))) prefix ((𝐿 + 1) − 𝐵)))
31 revwlk 35319 . . 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 35311 . . 3 ((𝐹 ∈ Word dom (iEdg‘𝐺) ∧ 𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (𝐹 substr ⟨𝐵, 𝐿⟩) = (reverse‘((reverse‘(𝐹 prefix 𝐿)) prefix (𝐿𝐵))))
348, 33syl3an1 1163 . 2 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (𝐹 substr ⟨𝐵, 𝐿⟩) = (reverse‘((reverse‘(𝐹 prefix 𝐿)) prefix (𝐿𝐵))))
35 eqid 2736 . . . . 5 (Vtx‘𝐺) = (Vtx‘𝐺)
3635wlkpwrd 29691 . . . 4 (𝐹(Walks‘𝐺)𝑃𝑃 ∈ Word (Vtx‘𝐺))
37363ad2ant1 1133 . . 3 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → 𝑃 ∈ Word (Vtx‘𝐺))
38 fzelp1 13492 . . . 4 (𝐵 ∈ (0...𝐿) → 𝐵 ∈ (0...(𝐿 + 1)))
39383ad2ant2 1134 . . 3 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → 𝐵 ∈ (0...(𝐿 + 1)))
40 fzp1elp1 13493 . . . . 5 (𝐿 ∈ (0...(♯‘𝐹)) → (𝐿 + 1) ∈ (0...((♯‘𝐹) + 1)))
41403ad2ant3 1135 . . . 4 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (𝐿 + 1) ∈ (0...((♯‘𝐹) + 1)))
42 wlklenvp1 29692 . . . . . 6 (𝐹(Walks‘𝐺)𝑃 → (♯‘𝑃) = ((♯‘𝐹) + 1))
43423ad2ant1 1133 . . . . 5 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (♯‘𝑃) = ((♯‘𝐹) + 1))
4443oveq2d 7374 . . . 4 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (0...(♯‘𝑃)) = (0...((♯‘𝐹) + 1)))
4541, 44eleqtrrd 2839 . . 3 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (𝐿 + 1) ∈ (0...(♯‘𝑃)))
46 swrdrevpfx 35311 . . 3 ((𝑃 ∈ Word (Vtx‘𝐺) ∧ 𝐵 ∈ (0...(𝐿 + 1)) ∧ (𝐿 + 1) ∈ (0...(♯‘𝑃))) → (𝑃 substr ⟨𝐵, (𝐿 + 1)⟩) = (reverse‘((reverse‘(𝑃 prefix (𝐿 + 1))) prefix ((𝐿 + 1) − 𝐵))))
4737, 39, 45, 46syl3anc 1373 . 2 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (𝑃 substr ⟨𝐵, (𝐿 + 1)⟩) = (reverse‘((reverse‘(𝑃 prefix (𝐿 + 1))) prefix ((𝐿 + 1) − 𝐵))))
4832, 34, 473brtr4d 5130 1 ((𝐹(Walks‘𝐺)𝑃𝐵 ∈ (0...𝐿) ∧ 𝐿 ∈ (0...(♯‘𝐹))) → (𝐹 substr ⟨𝐵, 𝐿⟩)(Walks‘𝐺)(𝑃 substr ⟨𝐵, (𝐿 + 1)⟩))
Colors of variables: wff setvar class
Syntax hints:  wi 4  w3a 1086   = wceq 1541  wcel 2113  cop 4586   class class class wbr 5098  dom cdm 5624  cfv 6492  (class class class)co 7358  0cc0 11026  1c1 11027   + caddc 11029  cmin 11364  cz 12488  ...cfz 13423  chash 14253  Word cword 14436   substr csubstr 14564   prefix cpfx 14594  reversecreverse 14681  Vtxcvtx 29069  iEdgciedg 29070  Walkscwlks 29670
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 1968  ax-7 2009  ax-8 2115  ax-9 2123  ax-10 2146  ax-11 2162  ax-12 2184  ax-ext 2708  ax-rep 5224  ax-sep 5241  ax-nul 5251  ax-pow 5310  ax-pr 5377  ax-un 7680  ax-cnex 11082  ax-resscn 11083  ax-1cn 11084  ax-icn 11085  ax-addcl 11086  ax-addrcl 11087  ax-mulcl 11088  ax-mulrcl 11089  ax-mulcom 11090  ax-addass 11091  ax-mulass 11092  ax-distr 11093  ax-i2m1 11094  ax-1ne0 11095  ax-1rid 11096  ax-rnegex 11097  ax-rrecex 11098  ax-cnre 11099  ax-pre-lttri 11100  ax-pre-lttrn 11101  ax-pre-ltadd 11102  ax-pre-mulgt0 11103
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 848  df-ifp 1063  df-3or 1087  df-3an 1088  df-tru 1544  df-fal 1554  df-ex 1781  df-nf 1785  df-sb 2068  df-mo 2539  df-eu 2569  df-clab 2715  df-cleq 2728  df-clel 2811  df-nfc 2885  df-ne 2933  df-nel 3037  df-ral 3052  df-rex 3061  df-reu 3351  df-rab 3400  df-v 3442  df-sbc 3741  df-csb 3850  df-dif 3904  df-un 3906  df-in 3908  df-ss 3918  df-pss 3921  df-nul 4286  df-if 4480  df-pw 4556  df-sn 4581  df-pr 4583  df-op 4587  df-uni 4864  df-int 4903  df-iun 4948  df-br 5099  df-opab 5161  df-mpt 5180  df-tr 5206  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 7315  df-ov 7361  df-oprab 7362  df-mpo 7363  df-om 7809  df-1st 7933  df-2nd 7934  df-frecs 8223  df-wrecs 8254  df-recs 8303  df-rdg 8341  df-1o 8397  df-er 8635  df-map 8765  df-pm 8766  df-en 8884  df-dom 8885  df-sdom 8886  df-fin 8887  df-card 9851  df-pnf 11168  df-mnf 11169  df-xr 11170  df-ltxr 11171  df-le 11172  df-sub 11366  df-neg 11367  df-nn 12146  df-2 12208  df-n0 12402  df-z 12489  df-uz 12752  df-fz 13424  df-fzo 13571  df-hash 14254  df-word 14437  df-substr 14565  df-pfx 14595  df-reverse 14682  df-wlks 29673
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator