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

Theorem spthcycl 35342
Description: A walk is a trivial path if and only if it is both a simple path and a cycle. (Contributed by BTernaryTau, 8-Oct-2023.)
Assertion
Ref Expression
spthcycl ((𝐹(Paths‘𝐺)𝑃𝐹 = ∅) ↔ (𝐹(SPaths‘𝐺)𝑃𝐹(Cycles‘𝐺)𝑃))

Proof of Theorem spthcycl
StepHypRef Expression
1 pthistrl 29808 . . . 4 (𝐹(Paths‘𝐺)𝑃𝐹(Trails‘𝐺)𝑃)
2 pthiswlk 29810 . . . . 5 (𝐹(Paths‘𝐺)𝑃𝐹(Walks‘𝐺)𝑃)
3 eqid 2737 . . . . . . . 8 (Vtx‘𝐺) = (Vtx‘𝐺)
43wlkp 29702 . . . . . . 7 (𝐹(Walks‘𝐺)𝑃𝑃:(0...(♯‘𝐹))⟶(Vtx‘𝐺))
54ffund 6674 . . . . . 6 (𝐹(Walks‘𝐺)𝑃 → Fun 𝑃)
6 wlklenvp1 29704 . . . . . . . . 9 (𝐹(Walks‘𝐺)𝑃 → (♯‘𝑃) = ((♯‘𝐹) + 1))
76adantr 480 . . . . . . . 8 ((𝐹(Walks‘𝐺)𝑃𝐹 = ∅) → (♯‘𝑃) = ((♯‘𝐹) + 1))
8 wlkv 29698 . . . . . . . . . . 11 (𝐹(Walks‘𝐺)𝑃 → (𝐺 ∈ V ∧ 𝐹 ∈ V ∧ 𝑃 ∈ V))
98simp2d 1144 . . . . . . . . . 10 (𝐹(Walks‘𝐺)𝑃𝐹 ∈ V)
10 hasheq0 14298 . . . . . . . . . . 11 (𝐹 ∈ V → ((♯‘𝐹) = 0 ↔ 𝐹 = ∅))
1110biimpar 477 . . . . . . . . . 10 ((𝐹 ∈ V ∧ 𝐹 = ∅) → (♯‘𝐹) = 0)
129, 11sylan 581 . . . . . . . . 9 ((𝐹(Walks‘𝐺)𝑃𝐹 = ∅) → (♯‘𝐹) = 0)
13 oveq1 7375 . . . . . . . . . 10 ((♯‘𝐹) = 0 → ((♯‘𝐹) + 1) = (0 + 1))
14 0p1e1 12274 . . . . . . . . . 10 (0 + 1) = 1
1513, 14eqtrdi 2788 . . . . . . . . 9 ((♯‘𝐹) = 0 → ((♯‘𝐹) + 1) = 1)
1612, 15syl 17 . . . . . . . 8 ((𝐹(Walks‘𝐺)𝑃𝐹 = ∅) → ((♯‘𝐹) + 1) = 1)
177, 16eqtrd 2772 . . . . . . 7 ((𝐹(Walks‘𝐺)𝑃𝐹 = ∅) → (♯‘𝑃) = 1)
188simp3d 1145 . . . . . . . . 9 (𝐹(Walks‘𝐺)𝑃𝑃 ∈ V)
19 hashen1 14305 . . . . . . . . 9 (𝑃 ∈ V → ((♯‘𝑃) = 1 ↔ 𝑃 ≈ 1o))
2018, 19syl 17 . . . . . . . 8 (𝐹(Walks‘𝐺)𝑃 → ((♯‘𝑃) = 1 ↔ 𝑃 ≈ 1o))
2120biimpa 476 . . . . . . 7 ((𝐹(Walks‘𝐺)𝑃 ∧ (♯‘𝑃) = 1) → 𝑃 ≈ 1o)
2217, 21syldan 592 . . . . . 6 ((𝐹(Walks‘𝐺)𝑃𝐹 = ∅) → 𝑃 ≈ 1o)
23 funen1cnv 35263 . . . . . 6 ((Fun 𝑃𝑃 ≈ 1o) → Fun 𝑃)
245, 22, 23syl2an2r 686 . . . . 5 ((𝐹(Walks‘𝐺)𝑃𝐹 = ∅) → Fun 𝑃)
252, 24sylan 581 . . . 4 ((𝐹(Paths‘𝐺)𝑃𝐹 = ∅) → Fun 𝑃)
26 isspth 29807 . . . . 5 (𝐹(SPaths‘𝐺)𝑃 ↔ (𝐹(Trails‘𝐺)𝑃 ∧ Fun 𝑃))
2726biimpri 228 . . . 4 ((𝐹(Trails‘𝐺)𝑃 ∧ Fun 𝑃) → 𝐹(SPaths‘𝐺)𝑃)
281, 25, 27syl2an2r 686 . . 3 ((𝐹(Paths‘𝐺)𝑃𝐹 = ∅) → 𝐹(SPaths‘𝐺)𝑃)
29 fveq2 6842 . . . . . . 7 (0 = (♯‘𝐹) → (𝑃‘0) = (𝑃‘(♯‘𝐹)))
3029eqcoms 2745 . . . . . 6 ((♯‘𝐹) = 0 → (𝑃‘0) = (𝑃‘(♯‘𝐹)))
3112, 30syl 17 . . . . 5 ((𝐹(Walks‘𝐺)𝑃𝐹 = ∅) → (𝑃‘0) = (𝑃‘(♯‘𝐹)))
322, 31sylan 581 . . . 4 ((𝐹(Paths‘𝐺)𝑃𝐹 = ∅) → (𝑃‘0) = (𝑃‘(♯‘𝐹)))
33 iscycl 29876 . . . . 5 (𝐹(Cycles‘𝐺)𝑃 ↔ (𝐹(Paths‘𝐺)𝑃 ∧ (𝑃‘0) = (𝑃‘(♯‘𝐹))))
3433biimpri 228 . . . 4 ((𝐹(Paths‘𝐺)𝑃 ∧ (𝑃‘0) = (𝑃‘(♯‘𝐹))) → 𝐹(Cycles‘𝐺)𝑃)
3532, 34syldan 592 . . 3 ((𝐹(Paths‘𝐺)𝑃𝐹 = ∅) → 𝐹(Cycles‘𝐺)𝑃)
3628, 35jca 511 . 2 ((𝐹(Paths‘𝐺)𝑃𝐹 = ∅) → (𝐹(SPaths‘𝐺)𝑃𝐹(Cycles‘𝐺)𝑃))
37 spthispth 29809 . . . 4 (𝐹(SPaths‘𝐺)𝑃𝐹(Paths‘𝐺)𝑃)
3837adantr 480 . . 3 ((𝐹(SPaths‘𝐺)𝑃𝐹(Cycles‘𝐺)𝑃) → 𝐹(Paths‘𝐺)𝑃)
39 notnot 142 . . . . 5 (𝐹(SPaths‘𝐺)𝑃 → ¬ ¬ 𝐹(SPaths‘𝐺)𝑃)
40 cyclnspth 29886 . . . . . . . 8 (𝐹 ≠ ∅ → (𝐹(Cycles‘𝐺)𝑃 → ¬ 𝐹(SPaths‘𝐺)𝑃))
4140com12 32 . . . . . . 7 (𝐹(Cycles‘𝐺)𝑃 → (𝐹 ≠ ∅ → ¬ 𝐹(SPaths‘𝐺)𝑃))
4241con3dimp 408 . . . . . 6 ((𝐹(Cycles‘𝐺)𝑃 ∧ ¬ ¬ 𝐹(SPaths‘𝐺)𝑃) → ¬ 𝐹 ≠ ∅)
43 nne 2937 . . . . . 6 𝐹 ≠ ∅ ↔ 𝐹 = ∅)
4442, 43sylib 218 . . . . 5 ((𝐹(Cycles‘𝐺)𝑃 ∧ ¬ ¬ 𝐹(SPaths‘𝐺)𝑃) → 𝐹 = ∅)
4539, 44sylan2 594 . . . 4 ((𝐹(Cycles‘𝐺)𝑃𝐹(SPaths‘𝐺)𝑃) → 𝐹 = ∅)
4645ancoms 458 . . 3 ((𝐹(SPaths‘𝐺)𝑃𝐹(Cycles‘𝐺)𝑃) → 𝐹 = ∅)
4738, 46jca 511 . 2 ((𝐹(SPaths‘𝐺)𝑃𝐹(Cycles‘𝐺)𝑃) → (𝐹(Paths‘𝐺)𝑃𝐹 = ∅))
4836, 47impbii 209 1 ((𝐹(Paths‘𝐺)𝑃𝐹 = ∅) ↔ (𝐹(SPaths‘𝐺)𝑃𝐹(Cycles‘𝐺)𝑃))
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wb 206  wa 395   = wceq 1542  wcel 2114  wne 2933  Vcvv 3442  c0 4287   class class class wbr 5100  ccnv 5631  Fun wfun 6494  cfv 6500  (class class class)co 7368  1oc1o 8400  cen 8892  0cc0 11038  1c1 11039   + caddc 11041  ...cfz 13435  chash 14265  Vtxcvtx 29081  Walkscwlks 29682  Trailsctrls 29774  Pathscpths 29795  SPathscspths 29796  Cyclesccycls 29870
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 5243  ax-nul 5253  ax-pow 5312  ax-pr 5379  ax-un 7690  ax-cnex 11094  ax-resscn 11095  ax-1cn 11096  ax-icn 11097  ax-addcl 11098  ax-addrcl 11099  ax-mulcl 11100  ax-mulrcl 11101  ax-mulcom 11102  ax-addass 11103  ax-mulass 11104  ax-distr 11105  ax-i2m1 11106  ax-1ne0 11107  ax-1rid 11108  ax-rnegex 11109  ax-rrecex 11110  ax-cnre 11111  ax-pre-lttri 11112  ax-pre-lttrn 11113  ax-pre-ltadd 11114  ax-pre-mulgt0 11115
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-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 5527  df-eprel 5532  df-po 5540  df-so 5541  df-fr 5585  df-we 5587  df-xp 5638  df-rel 5639  df-cnv 5640  df-co 5641  df-dm 5642  df-rn 5643  df-res 5644  df-ima 5645  df-pred 6267  df-ord 6328  df-on 6329  df-lim 6330  df-suc 6331  df-iota 6456  df-fun 6502  df-fn 6503  df-f 6504  df-f1 6505  df-fo 6506  df-f1o 6507  df-fv 6508  df-riota 7325  df-ov 7371  df-oprab 7372  df-mpo 7373  df-om 7819  df-1st 7943  df-2nd 7944  df-frecs 8233  df-wrecs 8264  df-recs 8313  df-rdg 8351  df-1o 8407  df-er 8645  df-map 8777  df-en 8896  df-dom 8897  df-sdom 8898  df-fin 8899  df-card 9863  df-pnf 11180  df-mnf 11181  df-xr 11182  df-ltxr 11183  df-le 11184  df-sub 11378  df-neg 11379  df-nn 12158  df-n0 12414  df-z 12501  df-uz 12764  df-fz 13436  df-fzo 13583  df-hash 14266  df-word 14449  df-wlks 29685  df-trls 29776  df-pths 29799  df-spths 29800  df-cycls 29872
This theorem is referenced by:  pthacycspth  35370
  Copyright terms: Public domain W3C validator