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

Theorem isspthonpth 29736
Description: A pair of functions is a simple path between two given vertices iff it is a simple path starting and ending at the two vertices. (Contributed by Alexander van der Vekens, 9-Mar-2018.) (Revised by AV, 17-Jan-2021.)
Hypothesis
Ref Expression
isspthonpth.v 𝑉 = (Vtx‘𝐺)
Assertion
Ref Expression
isspthonpth (((𝐴𝑉𝐵𝑉) ∧ (𝐹𝑊𝑃𝑍)) → (𝐹(𝐴(SPathsOn‘𝐺)𝐵)𝑃 ↔ (𝐹(SPaths‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)))

Proof of Theorem isspthonpth
StepHypRef Expression
1 isspthonpth.v . . 3 𝑉 = (Vtx‘𝐺)
21isspthson 29730 . 2 (((𝐴𝑉𝐵𝑉) ∧ (𝐹𝑊𝑃𝑍)) → (𝐹(𝐴(SPathsOn‘𝐺)𝐵)𝑃 ↔ (𝐹(𝐴(TrailsOn‘𝐺)𝐵)𝑃𝐹(SPaths‘𝐺)𝑃)))
31istrlson 29692 . . . . . . 7 (((𝐴𝑉𝐵𝑉) ∧ (𝐹𝑊𝑃𝑍)) → (𝐹(𝐴(TrailsOn‘𝐺)𝐵)𝑃 ↔ (𝐹(𝐴(WalksOn‘𝐺)𝐵)𝑃𝐹(Trails‘𝐺)𝑃)))
43adantr 480 . . . . . 6 ((((𝐴𝑉𝐵𝑉) ∧ (𝐹𝑊𝑃𝑍)) ∧ 𝐹(SPaths‘𝐺)𝑃) → (𝐹(𝐴(TrailsOn‘𝐺)𝐵)𝑃 ↔ (𝐹(𝐴(WalksOn‘𝐺)𝐵)𝑃𝐹(Trails‘𝐺)𝑃)))
5 spthispth 29711 . . . . . . . . 9 (𝐹(SPaths‘𝐺)𝑃𝐹(Paths‘𝐺)𝑃)
6 pthistrl 29710 . . . . . . . . 9 (𝐹(Paths‘𝐺)𝑃𝐹(Trails‘𝐺)𝑃)
75, 6syl 17 . . . . . . . 8 (𝐹(SPaths‘𝐺)𝑃𝐹(Trails‘𝐺)𝑃)
87adantl 481 . . . . . . 7 ((((𝐴𝑉𝐵𝑉) ∧ (𝐹𝑊𝑃𝑍)) ∧ 𝐹(SPaths‘𝐺)𝑃) → 𝐹(Trails‘𝐺)𝑃)
98biantrud 531 . . . . . 6 ((((𝐴𝑉𝐵𝑉) ∧ (𝐹𝑊𝑃𝑍)) ∧ 𝐹(SPaths‘𝐺)𝑃) → (𝐹(𝐴(WalksOn‘𝐺)𝐵)𝑃 ↔ (𝐹(𝐴(WalksOn‘𝐺)𝐵)𝑃𝐹(Trails‘𝐺)𝑃)))
10 spthiswlk 29713 . . . . . . . 8 (𝐹(SPaths‘𝐺)𝑃𝐹(Walks‘𝐺)𝑃)
1110adantl 481 . . . . . . 7 ((((𝐴𝑉𝐵𝑉) ∧ (𝐹𝑊𝑃𝑍)) ∧ 𝐹(SPaths‘𝐺)𝑃) → 𝐹(Walks‘𝐺)𝑃)
121iswlkon 29642 . . . . . . . . 9 (((𝐴𝑉𝐵𝑉) ∧ (𝐹𝑊𝑃𝑍)) → (𝐹(𝐴(WalksOn‘𝐺)𝐵)𝑃 ↔ (𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)))
13 3anass 1094 . . . . . . . . 9 ((𝐹(Walks‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵) ↔ (𝐹(Walks‘𝐺)𝑃 ∧ ((𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)))
1412, 13bitrdi 287 . . . . . . . 8 (((𝐴𝑉𝐵𝑉) ∧ (𝐹𝑊𝑃𝑍)) → (𝐹(𝐴(WalksOn‘𝐺)𝐵)𝑃 ↔ (𝐹(Walks‘𝐺)𝑃 ∧ ((𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵))))
1514adantr 480 . . . . . . 7 ((((𝐴𝑉𝐵𝑉) ∧ (𝐹𝑊𝑃𝑍)) ∧ 𝐹(SPaths‘𝐺)𝑃) → (𝐹(𝐴(WalksOn‘𝐺)𝐵)𝑃 ↔ (𝐹(Walks‘𝐺)𝑃 ∧ ((𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵))))
1611, 15mpbirand 707 . . . . . 6 ((((𝐴𝑉𝐵𝑉) ∧ (𝐹𝑊𝑃𝑍)) ∧ 𝐹(SPaths‘𝐺)𝑃) → (𝐹(𝐴(WalksOn‘𝐺)𝐵)𝑃 ↔ ((𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)))
174, 9, 163bitr2d 307 . . . . 5 ((((𝐴𝑉𝐵𝑉) ∧ (𝐹𝑊𝑃𝑍)) ∧ 𝐹(SPaths‘𝐺)𝑃) → (𝐹(𝐴(TrailsOn‘𝐺)𝐵)𝑃 ↔ ((𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)))
1817ex 412 . . . 4 (((𝐴𝑉𝐵𝑉) ∧ (𝐹𝑊𝑃𝑍)) → (𝐹(SPaths‘𝐺)𝑃 → (𝐹(𝐴(TrailsOn‘𝐺)𝐵)𝑃 ↔ ((𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵))))
1918pm5.32rd 578 . . 3 (((𝐴𝑉𝐵𝑉) ∧ (𝐹𝑊𝑃𝑍)) → ((𝐹(𝐴(TrailsOn‘𝐺)𝐵)𝑃𝐹(SPaths‘𝐺)𝑃) ↔ (((𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵) ∧ 𝐹(SPaths‘𝐺)𝑃)))
20 3anass 1094 . . . 4 ((𝐹(SPaths‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵) ↔ (𝐹(SPaths‘𝐺)𝑃 ∧ ((𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)))
21 ancom 460 . . . 4 ((𝐹(SPaths‘𝐺)𝑃 ∧ ((𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)) ↔ (((𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵) ∧ 𝐹(SPaths‘𝐺)𝑃))
2220, 21bitr2i 276 . . 3 ((((𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵) ∧ 𝐹(SPaths‘𝐺)𝑃) ↔ (𝐹(SPaths‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵))
2319, 22bitrdi 287 . 2 (((𝐴𝑉𝐵𝑉) ∧ (𝐹𝑊𝑃𝑍)) → ((𝐹(𝐴(TrailsOn‘𝐺)𝐵)𝑃𝐹(SPaths‘𝐺)𝑃) ↔ (𝐹(SPaths‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)))
242, 23bitrd 279 1 (((𝐴𝑉𝐵𝑉) ∧ (𝐹𝑊𝑃𝑍)) → (𝐹(𝐴(SPathsOn‘𝐺)𝐵)𝑃 ↔ (𝐹(SPaths‘𝐺)𝑃 ∧ (𝑃‘0) = 𝐴 ∧ (𝑃‘(♯‘𝐹)) = 𝐵)))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 206  wa 395  w3a 1086   = wceq 1540  wcel 2109   class class class wbr 5124  cfv 6536  (class class class)co 7410  0cc0 11134  chash 14353  Vtxcvtx 28980  Walkscwlks 29581  WalksOncwlkson 29582  Trailsctrls 29675  TrailsOnctrlson 29676  Pathscpths 29697  SPathscspths 29698  SPathsOncspthson 29700
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 1910  ax-6 1967  ax-7 2008  ax-8 2111  ax-9 2119  ax-10 2142  ax-11 2158  ax-12 2178  ax-ext 2708  ax-sep 5271  ax-nul 5281  ax-pow 5340  ax-pr 5407  ax-un 7734  ax-cnex 11190  ax-resscn 11191  ax-1cn 11192  ax-icn 11193  ax-addcl 11194  ax-addrcl 11195  ax-mulcl 11196  ax-mulrcl 11197  ax-mulcom 11198  ax-addass 11199  ax-mulass 11200  ax-distr 11201  ax-i2m1 11202  ax-1ne0 11203  ax-1rid 11204  ax-rnegex 11205  ax-rrecex 11206  ax-cnre 11207  ax-pre-lttri 11208  ax-pre-lttrn 11209  ax-pre-ltadd 11210  ax-pre-mulgt0 11211
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 848  df-3or 1087  df-3an 1088  df-tru 1543  df-fal 1553  df-ex 1780  df-nf 1784  df-sb 2066  df-mo 2540  df-eu 2569  df-clab 2715  df-cleq 2728  df-clel 2810  df-nfc 2886  df-ne 2934  df-nel 3038  df-ral 3053  df-rex 3062  df-reu 3365  df-rab 3421  df-v 3466  df-sbc 3771  df-csb 3880  df-dif 3934  df-un 3936  df-in 3938  df-ss 3948  df-pss 3951  df-nul 4314  df-if 4506  df-pw 4582  df-sn 4607  df-pr 4609  df-op 4613  df-uni 4889  df-iun 4974  df-br 5125  df-opab 5187  df-mpt 5207  df-tr 5235  df-id 5553  df-eprel 5558  df-po 5566  df-so 5567  df-fr 5611  df-we 5613  df-xp 5665  df-rel 5666  df-cnv 5667  df-co 5668  df-dm 5669  df-rn 5670  df-res 5671  df-ima 5672  df-pred 6295  df-ord 6360  df-on 6361  df-lim 6362  df-suc 6363  df-iota 6489  df-fun 6538  df-fn 6539  df-f 6540  df-f1 6541  df-fo 6542  df-f1o 6543  df-fv 6544  df-riota 7367  df-ov 7413  df-oprab 7414  df-mpo 7415  df-om 7867  df-1st 7993  df-2nd 7994  df-frecs 8285  df-wrecs 8316  df-recs 8390  df-rdg 8429  df-er 8724  df-en 8965  df-dom 8966  df-sdom 8967  df-pnf 11276  df-mnf 11277  df-xr 11278  df-ltxr 11279  df-le 11280  df-sub 11473  df-neg 11474  df-nn 12246  df-n0 12507  df-z 12594  df-uz 12858  df-fz 13530  df-fzo 13677  df-wlks 29584  df-wlkson 29585  df-trls 29677  df-trlson 29678  df-pths 29701  df-spths 29702  df-spthson 29704
This theorem is referenced by:  uhgrwkspth  29742  usgr2wlkspth  29746  wspthsnwspthsnon  29903  elwspths2spth  29954
  Copyright terms: Public domain W3C validator