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

Theorem usgr2wlkspth 29850
Description: In a simple graph, any walk of length 2 between two different vertices is a simple path. (Contributed by Alexander van der Vekens, 2-Mar-2018.) (Revised by AV, 27-Jan-2021.) (Proof shortened by AV, 31-Oct-2021.)
Assertion
Ref Expression
usgr2wlkspth ((𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ 𝐴𝐵) → (𝐹(𝐴(WalksOn‘𝐺)𝐵)𝑃𝐹(𝐴(SPathsOn‘𝐺)𝐵)𝑃))

Proof of Theorem usgr2wlkspth
StepHypRef Expression
1 simpl31 1256 . . . . . . . 8 ((((𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)) ∧ (𝐹 ∈ V ∧ 𝑃 ∈ V) ∧ (𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)) ∧ (𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ 𝐴𝐵)) → 𝐹(Walks‘𝐺)𝑃)
2 simp2 1138 . . . . . . . . . . . . . 14 ((𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵) → (𝑃‘0) = 𝐴)
3 simp3 1139 . . . . . . . . . . . . . 14 ((𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵) → (𝑃‘(♯‘𝐹)) = 𝐵)
42, 3neeq12d 2994 . . . . . . . . . . . . 13 ((𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵) → ((𝑃‘0) ≠ (𝑃‘(♯‘𝐹)) ↔ 𝐴𝐵))
54bicomd 223 . . . . . . . . . . . 12 ((𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵) → (𝐴𝐵 ↔ (𝑃‘0) ≠ (𝑃‘(♯‘𝐹))))
653anbi3d 1445 . . . . . . . . . . 11 ((𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵) → ((𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ 𝐴𝐵) ↔ (𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ (𝑃‘0) ≠ (𝑃‘(♯‘𝐹)))))
7 usgr2wlkspthlem1 29848 . . . . . . . . . . . . 13 ((𝐹(Walks‘𝐺)𝑃 ∧ (𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ (𝑃‘0) ≠ (𝑃‘(♯‘𝐹)))) → Fun 𝐹)
87ex 412 . . . . . . . . . . . 12 (𝐹(Walks‘𝐺)𝑃 → ((𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ (𝑃‘0) ≠ (𝑃‘(♯‘𝐹))) → Fun 𝐹))
983ad2ant1 1134 . . . . . . . . . . 11 ((𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵) → ((𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ (𝑃‘0) ≠ (𝑃‘(♯‘𝐹))) → Fun 𝐹))
106, 9sylbid 240 . . . . . . . . . 10 ((𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵) → ((𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ 𝐴𝐵) → Fun 𝐹))
11103ad2ant3 1136 . . . . . . . . 9 (((𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)) ∧ (𝐹 ∈ V ∧ 𝑃 ∈ V) ∧ (𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)) → ((𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ 𝐴𝐵) → Fun 𝐹))
1211imp 406 . . . . . . . 8 ((((𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)) ∧ (𝐹 ∈ V ∧ 𝑃 ∈ V) ∧ (𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)) ∧ (𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ 𝐴𝐵)) → Fun 𝐹)
13 istrl 29786 . . . . . . . 8 (𝐹(Trails‘𝐺)𝑃 ↔ (𝐹(Walks‘𝐺)𝑃 ∧ Fun 𝐹))
141, 12, 13sylanbrc 584 . . . . . . 7 ((((𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)) ∧ (𝐹 ∈ V ∧ 𝑃 ∈ V) ∧ (𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)) ∧ (𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ 𝐴𝐵)) → 𝐹(Trails‘𝐺)𝑃)
15 usgr2wlkspthlem2 29849 . . . . . . . . . . . 12 ((𝐹(Walks‘𝐺)𝑃 ∧ (𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ (𝑃‘0) ≠ (𝑃‘(♯‘𝐹)))) → Fun 𝑃)
1615ex 412 . . . . . . . . . . 11 (𝐹(Walks‘𝐺)𝑃 → ((𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ (𝑃‘0) ≠ (𝑃‘(♯‘𝐹))) → Fun 𝑃))
17163ad2ant1 1134 . . . . . . . . . 10 ((𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵) → ((𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ (𝑃‘0) ≠ (𝑃‘(♯‘𝐹))) → Fun 𝑃))
186, 17sylbid 240 . . . . . . . . 9 ((𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵) → ((𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ 𝐴𝐵) → Fun 𝑃))
19183ad2ant3 1136 . . . . . . . 8 (((𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)) ∧ (𝐹 ∈ V ∧ 𝑃 ∈ V) ∧ (𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)) → ((𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ 𝐴𝐵) → Fun 𝑃))
2019imp 406 . . . . . . 7 ((((𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)) ∧ (𝐹 ∈ V ∧ 𝑃 ∈ V) ∧ (𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)) ∧ (𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ 𝐴𝐵)) → Fun 𝑃)
21 isspth 29813 . . . . . . 7 (𝐹(SPaths‘𝐺)𝑃 ↔ (𝐹(Trails‘𝐺)𝑃 ∧ Fun 𝑃))
2214, 20, 21sylanbrc 584 . . . . . 6 ((((𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)) ∧ (𝐹 ∈ V ∧ 𝑃 ∈ V) ∧ (𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)) ∧ (𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ 𝐴𝐵)) → 𝐹(SPaths‘𝐺)𝑃)
23 3simpc 1151 . . . . . . . 8 ((𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵) → ((𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵))
24233ad2ant3 1136 . . . . . . 7 (((𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)) ∧ (𝐹 ∈ V ∧ 𝑃 ∈ V) ∧ (𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)) → ((𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵))
2524adantr 480 . . . . . 6 ((((𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)) ∧ (𝐹 ∈ V ∧ 𝑃 ∈ V) ∧ (𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)) ∧ (𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ 𝐴𝐵)) → ((𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵))
26 3anass 1095 . . . . . 6 ((𝐹(SPaths‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵) ↔ (𝐹(SPaths‘𝐺)𝑃 ∧ ((𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)))
2722, 25, 26sylanbrc 584 . . . . 5 ((((𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)) ∧ (𝐹 ∈ V ∧ 𝑃 ∈ V) ∧ (𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)) ∧ (𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ 𝐴𝐵)) → (𝐹(SPaths‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵))
28 3simpa 1149 . . . . . . 7 (((𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)) ∧ (𝐹 ∈ V ∧ 𝑃 ∈ V) ∧ (𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)) → ((𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)) ∧ (𝐹 ∈ V ∧ 𝑃 ∈ V)))
2928adantr 480 . . . . . 6 ((((𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)) ∧ (𝐹 ∈ V ∧ 𝑃 ∈ V) ∧ (𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)) ∧ (𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ 𝐴𝐵)) → ((𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)) ∧ (𝐹 ∈ V ∧ 𝑃 ∈ V)))
30 eqid 2737 . . . . . . 7 (Vtx‘𝐺) = (Vtx‘𝐺)
3130isspthonpth 29840 . . . . . 6 (((𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)) ∧ (𝐹 ∈ V ∧ 𝑃 ∈ V)) → (𝐹(𝐴(SPathsOn‘𝐺)𝐵)𝑃 ↔ (𝐹(SPaths‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)))
3229, 31syl 17 . . . . 5 ((((𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)) ∧ (𝐹 ∈ V ∧ 𝑃 ∈ V) ∧ (𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)) ∧ (𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ 𝐴𝐵)) → (𝐹(𝐴(SPathsOn‘𝐺)𝐵)𝑃 ↔ (𝐹(SPaths‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)))
3327, 32mpbird 257 . . . 4 ((((𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)) ∧ (𝐹 ∈ V ∧ 𝑃 ∈ V) ∧ (𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)) ∧ (𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ 𝐴𝐵)) → 𝐹(𝐴(SPathsOn‘𝐺)𝐵)𝑃)
3433ex 412 . . 3 (((𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)) ∧ (𝐹 ∈ V ∧ 𝑃 ∈ V) ∧ (𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)) → ((𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ 𝐴𝐵) → 𝐹(𝐴(SPathsOn‘𝐺)𝐵)𝑃))
3530wlkonprop 29748 . . . 4 (𝐹(𝐴(WalksOn‘𝐺)𝐵)𝑃 → ((𝐺 ∈ V ∧ 𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)) ∧ (𝐹 ∈ V ∧ 𝑃 ∈ V) ∧ (𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)))
36 3simpc 1151 . . . . 5 ((𝐺 ∈ V ∧ 𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)) → (𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)))
37363anim1i 1153 . . . 4 (((𝐺 ∈ V ∧ 𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)) ∧ (𝐹 ∈ V ∧ 𝑃 ∈ V) ∧ (𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)) → ((𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)) ∧ (𝐹 ∈ V ∧ 𝑃 ∈ V) ∧ (𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)))
3835, 37syl 17 . . 3 (𝐹(𝐴(WalksOn‘𝐺)𝐵)𝑃 → ((𝐴 ∈ (Vtx‘𝐺) ∧ 𝐵 ∈ (Vtx‘𝐺)) ∧ (𝐹 ∈ V ∧ 𝑃 ∈ V) ∧ (𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)))
3934, 38syl11 33 . 2 ((𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ 𝐴𝐵) → (𝐹(𝐴(WalksOn‘𝐺)𝐵)𝑃𝐹(𝐴(SPathsOn‘𝐺)𝐵)𝑃))
40 spthonpthon 29842 . . 3 (𝐹(𝐴(SPathsOn‘𝐺)𝐵)𝑃𝐹(𝐴(PathsOn‘𝐺)𝐵)𝑃)
41 pthontrlon 29838 . . 3 (𝐹(𝐴(PathsOn‘𝐺)𝐵)𝑃𝐹(𝐴(TrailsOn‘𝐺)𝐵)𝑃)
42 trlsonwlkon 29799 . . 3 (𝐹(𝐴(TrailsOn‘𝐺)𝐵)𝑃𝐹(𝐴(WalksOn‘𝐺)𝐵)𝑃)
4340, 41, 423syl 18 . 2 (𝐹(𝐴(SPathsOn‘𝐺)𝐵)𝑃𝐹(𝐴(WalksOn‘𝐺)𝐵)𝑃)
4439, 43impbid1 225 1 ((𝐺 ∈ USGraph ∧ (♯‘𝐹) = 2 ∧ 𝐴𝐵) → (𝐹(𝐴(WalksOn‘𝐺)𝐵)𝑃𝐹(𝐴(SPathsOn‘𝐺)𝐵)𝑃))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 206  wa 395  w3a 1087   = wceq 1542  wcel 2114  wne 2933  Vcvv 3442   class class class wbr 5100  ccnv 5633  Fun wfun 6496  cfv 6502  (class class class)co 7370  0cc0 11040  2c2 12214  chash 14267  Vtxcvtx 29087  USGraphcusgr 29240  Walkscwlks 29688  WalksOncwlkson 29689  Trailsctrls 29780  TrailsOnctrlson 29781  SPathscspths 29802  PathsOncpthson 29803  SPathsOncspthson 29804
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 5226  ax-sep 5245  ax-nul 5255  ax-pow 5314  ax-pr 5381  ax-un 7692  ax-cnex 11096  ax-resscn 11097  ax-1cn 11098  ax-icn 11099  ax-addcl 11100  ax-addrcl 11101  ax-mulcl 11102  ax-mulrcl 11103  ax-mulcom 11104  ax-addass 11105  ax-mulass 11106  ax-distr 11107  ax-i2m1 11108  ax-1ne0 11109  ax-1rid 11110  ax-rnegex 11111  ax-rrecex 11112  ax-cnre 11113  ax-pre-lttri 11114  ax-pre-lttrn 11115  ax-pre-ltadd 11116  ax-pre-mulgt0 11117
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 3353  df-rab 3402  df-v 3444  df-sbc 3743  df-csb 3852  df-dif 3906  df-un 3908  df-in 3910  df-ss 3920  df-pss 3923  df-nul 4288  df-if 4482  df-pw 4558  df-sn 4583  df-pr 4585  df-tp 4587  df-op 4589  df-uni 4866  df-int 4905  df-iun 4950  df-br 5101  df-opab 5163  df-mpt 5182  df-tr 5208  df-id 5529  df-eprel 5534  df-po 5542  df-so 5543  df-fr 5587  df-we 5589  df-xp 5640  df-rel 5641  df-cnv 5642  df-co 5643  df-dm 5644  df-rn 5645  df-res 5646  df-ima 5647  df-pred 6269  df-ord 6330  df-on 6331  df-lim 6332  df-suc 6333  df-iota 6458  df-fun 6504  df-fn 6505  df-f 6506  df-f1 6507  df-fo 6508  df-f1o 6509  df-fv 6510  df-riota 7327  df-ov 7373  df-oprab 7374  df-mpo 7375  df-om 7821  df-1st 7945  df-2nd 7946  df-frecs 8235  df-wrecs 8266  df-recs 8315  df-rdg 8353  df-1o 8409  df-2o 8410  df-oadd 8413  df-er 8647  df-map 8779  df-pm 8780  df-en 8898  df-dom 8899  df-sdom 8900  df-fin 8901  df-dju 9827  df-card 9865  df-pnf 11182  df-mnf 11183  df-xr 11184  df-ltxr 11185  df-le 11186  df-sub 11380  df-neg 11381  df-nn 12160  df-2 12222  df-3 12223  df-n0 12416  df-xnn0 12489  df-z 12503  df-uz 12766  df-fz 13438  df-fzo 13585  df-hash 14268  df-word 14451  df-concat 14508  df-s1 14534  df-s2 14785  df-s3 14786  df-edg 29139  df-uhgr 29149  df-upgr 29173  df-umgr 29174  df-uspgr 29241  df-usgr 29242  df-wlks 29691  df-wlkson 29692  df-trls 29782  df-trlson 29783  df-pths 29805  df-spths 29806  df-pthson 29807  df-spthson 29808
This theorem is referenced by:  usgr2trlspth  29852  wpthswwlks2on  30055
  Copyright terms: Public domain W3C validator