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

Theorem uspgr2wlkeqi 29725
Description: Conditions for two walks within the same simple pseudograph to be identical. It is sufficient that the vertices (in the same order) are identical. (Contributed by AV, 6-May-2021.)
Assertion
Ref Expression
uspgr2wlkeqi ((𝐺 ∈ USPGraph ∧ (𝐴 ∈ (Walks‘𝐺) ∧ 𝐵 ∈ (Walks‘𝐺)) ∧ (2nd𝐴) = (2nd𝐵)) → 𝐴 = 𝐵)

Proof of Theorem uspgr2wlkeqi
StepHypRef Expression
1 wlkcpr 29706 . . . . 5 (𝐴 ∈ (Walks‘𝐺) ↔ (1st𝐴)(Walks‘𝐺)(2nd𝐴))
2 wlkcpr 29706 . . . . . 6 (𝐵 ∈ (Walks‘𝐺) ↔ (1st𝐵)(Walks‘𝐺)(2nd𝐵))
3 wlkcl 29693 . . . . . . 7 ((1st𝐴)(Walks‘𝐺)(2nd𝐴) → (♯‘(1st𝐴)) ∈ ℕ0)
4 fveq2 6835 . . . . . . . . . . . . 13 ((2nd𝐴) = (2nd𝐵) → (♯‘(2nd𝐴)) = (♯‘(2nd𝐵)))
54oveq1d 7375 . . . . . . . . . . . 12 ((2nd𝐴) = (2nd𝐵) → ((♯‘(2nd𝐴)) − 1) = ((♯‘(2nd𝐵)) − 1))
65eqcomd 2743 . . . . . . . . . . 11 ((2nd𝐴) = (2nd𝐵) → ((♯‘(2nd𝐵)) − 1) = ((♯‘(2nd𝐴)) − 1))
76adantl 481 . . . . . . . . . 10 ((((1st𝐴)(Walks‘𝐺)(2nd𝐴) ∧ (1st𝐵)(Walks‘𝐺)(2nd𝐵)) ∧ (2nd𝐴) = (2nd𝐵)) → ((♯‘(2nd𝐵)) − 1) = ((♯‘(2nd𝐴)) − 1))
8 wlklenvm1 29699 . . . . . . . . . . . 12 ((1st𝐵)(Walks‘𝐺)(2nd𝐵) → (♯‘(1st𝐵)) = ((♯‘(2nd𝐵)) − 1))
9 wlklenvm1 29699 . . . . . . . . . . . 12 ((1st𝐴)(Walks‘𝐺)(2nd𝐴) → (♯‘(1st𝐴)) = ((♯‘(2nd𝐴)) − 1))
108, 9eqeqan12rd 2752 . . . . . . . . . . 11 (((1st𝐴)(Walks‘𝐺)(2nd𝐴) ∧ (1st𝐵)(Walks‘𝐺)(2nd𝐵)) → ((♯‘(1st𝐵)) = (♯‘(1st𝐴)) ↔ ((♯‘(2nd𝐵)) − 1) = ((♯‘(2nd𝐴)) − 1)))
1110adantr 480 . . . . . . . . . 10 ((((1st𝐴)(Walks‘𝐺)(2nd𝐴) ∧ (1st𝐵)(Walks‘𝐺)(2nd𝐵)) ∧ (2nd𝐴) = (2nd𝐵)) → ((♯‘(1st𝐵)) = (♯‘(1st𝐴)) ↔ ((♯‘(2nd𝐵)) − 1) = ((♯‘(2nd𝐴)) − 1)))
127, 11mpbird 257 . . . . . . . . 9 ((((1st𝐴)(Walks‘𝐺)(2nd𝐴) ∧ (1st𝐵)(Walks‘𝐺)(2nd𝐵)) ∧ (2nd𝐴) = (2nd𝐵)) → (♯‘(1st𝐵)) = (♯‘(1st𝐴)))
1312anim2i 618 . . . . . . . 8 (((♯‘(1st𝐴)) ∈ ℕ0 ∧ (((1st𝐴)(Walks‘𝐺)(2nd𝐴) ∧ (1st𝐵)(Walks‘𝐺)(2nd𝐵)) ∧ (2nd𝐴) = (2nd𝐵))) → ((♯‘(1st𝐴)) ∈ ℕ0 ∧ (♯‘(1st𝐵)) = (♯‘(1st𝐴))))
1413exp44 437 . . . . . . 7 ((♯‘(1st𝐴)) ∈ ℕ0 → ((1st𝐴)(Walks‘𝐺)(2nd𝐴) → ((1st𝐵)(Walks‘𝐺)(2nd𝐵) → ((2nd𝐴) = (2nd𝐵) → ((♯‘(1st𝐴)) ∈ ℕ0 ∧ (♯‘(1st𝐵)) = (♯‘(1st𝐴)))))))
153, 14mpcom 38 . . . . . 6 ((1st𝐴)(Walks‘𝐺)(2nd𝐴) → ((1st𝐵)(Walks‘𝐺)(2nd𝐵) → ((2nd𝐴) = (2nd𝐵) → ((♯‘(1st𝐴)) ∈ ℕ0 ∧ (♯‘(1st𝐵)) = (♯‘(1st𝐴))))))
162, 15biimtrid 242 . . . . 5 ((1st𝐴)(Walks‘𝐺)(2nd𝐴) → (𝐵 ∈ (Walks‘𝐺) → ((2nd𝐴) = (2nd𝐵) → ((♯‘(1st𝐴)) ∈ ℕ0 ∧ (♯‘(1st𝐵)) = (♯‘(1st𝐴))))))
171, 16sylbi 217 . . . 4 (𝐴 ∈ (Walks‘𝐺) → (𝐵 ∈ (Walks‘𝐺) → ((2nd𝐴) = (2nd𝐵) → ((♯‘(1st𝐴)) ∈ ℕ0 ∧ (♯‘(1st𝐵)) = (♯‘(1st𝐴))))))
1817imp31 417 . . 3 (((𝐴 ∈ (Walks‘𝐺) ∧ 𝐵 ∈ (Walks‘𝐺)) ∧ (2nd𝐴) = (2nd𝐵)) → ((♯‘(1st𝐴)) ∈ ℕ0 ∧ (♯‘(1st𝐵)) = (♯‘(1st𝐴))))
19183adant1 1131 . 2 ((𝐺 ∈ USPGraph ∧ (𝐴 ∈ (Walks‘𝐺) ∧ 𝐵 ∈ (Walks‘𝐺)) ∧ (2nd𝐴) = (2nd𝐵)) → ((♯‘(1st𝐴)) ∈ ℕ0 ∧ (♯‘(1st𝐵)) = (♯‘(1st𝐴))))
20 simpl 482 . . . . . . 7 ((𝐺 ∈ USPGraph ∧ (𝐴 ∈ (Walks‘𝐺) ∧ 𝐵 ∈ (Walks‘𝐺))) → 𝐺 ∈ USPGraph)
21 simpl 482 . . . . . . 7 (((♯‘(1st𝐴)) ∈ ℕ0 ∧ (♯‘(1st𝐵)) = (♯‘(1st𝐴))) → (♯‘(1st𝐴)) ∈ ℕ0)
2220, 21anim12i 614 . . . . . 6 (((𝐺 ∈ USPGraph ∧ (𝐴 ∈ (Walks‘𝐺) ∧ 𝐵 ∈ (Walks‘𝐺))) ∧ ((♯‘(1st𝐴)) ∈ ℕ0 ∧ (♯‘(1st𝐵)) = (♯‘(1st𝐴)))) → (𝐺 ∈ USPGraph ∧ (♯‘(1st𝐴)) ∈ ℕ0))
23 simpl 482 . . . . . . . 8 ((𝐴 ∈ (Walks‘𝐺) ∧ 𝐵 ∈ (Walks‘𝐺)) → 𝐴 ∈ (Walks‘𝐺))
2423adantl 481 . . . . . . 7 ((𝐺 ∈ USPGraph ∧ (𝐴 ∈ (Walks‘𝐺) ∧ 𝐵 ∈ (Walks‘𝐺))) → 𝐴 ∈ (Walks‘𝐺))
25 eqidd 2738 . . . . . . 7 (((♯‘(1st𝐴)) ∈ ℕ0 ∧ (♯‘(1st𝐵)) = (♯‘(1st𝐴))) → (♯‘(1st𝐴)) = (♯‘(1st𝐴)))
2624, 25anim12i 614 . . . . . 6 (((𝐺 ∈ USPGraph ∧ (𝐴 ∈ (Walks‘𝐺) ∧ 𝐵 ∈ (Walks‘𝐺))) ∧ ((♯‘(1st𝐴)) ∈ ℕ0 ∧ (♯‘(1st𝐵)) = (♯‘(1st𝐴)))) → (𝐴 ∈ (Walks‘𝐺) ∧ (♯‘(1st𝐴)) = (♯‘(1st𝐴))))
27 simpr 484 . . . . . . . 8 ((𝐴 ∈ (Walks‘𝐺) ∧ 𝐵 ∈ (Walks‘𝐺)) → 𝐵 ∈ (Walks‘𝐺))
2827adantl 481 . . . . . . 7 ((𝐺 ∈ USPGraph ∧ (𝐴 ∈ (Walks‘𝐺) ∧ 𝐵 ∈ (Walks‘𝐺))) → 𝐵 ∈ (Walks‘𝐺))
29 simpr 484 . . . . . . 7 (((♯‘(1st𝐴)) ∈ ℕ0 ∧ (♯‘(1st𝐵)) = (♯‘(1st𝐴))) → (♯‘(1st𝐵)) = (♯‘(1st𝐴)))
3028, 29anim12i 614 . . . . . 6 (((𝐺 ∈ USPGraph ∧ (𝐴 ∈ (Walks‘𝐺) ∧ 𝐵 ∈ (Walks‘𝐺))) ∧ ((♯‘(1st𝐴)) ∈ ℕ0 ∧ (♯‘(1st𝐵)) = (♯‘(1st𝐴)))) → (𝐵 ∈ (Walks‘𝐺) ∧ (♯‘(1st𝐵)) = (♯‘(1st𝐴))))
31 uspgr2wlkeq2 29724 . . . . . 6 (((𝐺 ∈ USPGraph ∧ (♯‘(1st𝐴)) ∈ ℕ0) ∧ (𝐴 ∈ (Walks‘𝐺) ∧ (♯‘(1st𝐴)) = (♯‘(1st𝐴))) ∧ (𝐵 ∈ (Walks‘𝐺) ∧ (♯‘(1st𝐵)) = (♯‘(1st𝐴)))) → ((2nd𝐴) = (2nd𝐵) → 𝐴 = 𝐵))
3222, 26, 30, 31syl3anc 1374 . . . . 5 (((𝐺 ∈ USPGraph ∧ (𝐴 ∈ (Walks‘𝐺) ∧ 𝐵 ∈ (Walks‘𝐺))) ∧ ((♯‘(1st𝐴)) ∈ ℕ0 ∧ (♯‘(1st𝐵)) = (♯‘(1st𝐴)))) → ((2nd𝐴) = (2nd𝐵) → 𝐴 = 𝐵))
3332ex 412 . . . 4 ((𝐺 ∈ USPGraph ∧ (𝐴 ∈ (Walks‘𝐺) ∧ 𝐵 ∈ (Walks‘𝐺))) → (((♯‘(1st𝐴)) ∈ ℕ0 ∧ (♯‘(1st𝐵)) = (♯‘(1st𝐴))) → ((2nd𝐴) = (2nd𝐵) → 𝐴 = 𝐵)))
3433com23 86 . . 3 ((𝐺 ∈ USPGraph ∧ (𝐴 ∈ (Walks‘𝐺) ∧ 𝐵 ∈ (Walks‘𝐺))) → ((2nd𝐴) = (2nd𝐵) → (((♯‘(1st𝐴)) ∈ ℕ0 ∧ (♯‘(1st𝐵)) = (♯‘(1st𝐴))) → 𝐴 = 𝐵)))
35343impia 1118 . 2 ((𝐺 ∈ USPGraph ∧ (𝐴 ∈ (Walks‘𝐺) ∧ 𝐵 ∈ (Walks‘𝐺)) ∧ (2nd𝐴) = (2nd𝐵)) → (((♯‘(1st𝐴)) ∈ ℕ0 ∧ (♯‘(1st𝐵)) = (♯‘(1st𝐴))) → 𝐴 = 𝐵))
3619, 35mpd 15 1 ((𝐺 ∈ USPGraph ∧ (𝐴 ∈ (Walks‘𝐺) ∧ 𝐵 ∈ (Walks‘𝐺)) ∧ (2nd𝐴) = (2nd𝐵)) → 𝐴 = 𝐵)
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 206  wa 395  w3a 1087   = wceq 1542  wcel 2114   class class class wbr 5099  cfv 6493  (class class class)co 7360  1st c1st 7933  2nd c2nd 7934  1c1 11031  cmin 11368  0cn0 12405  chash 14257  USPGraphcuspgr 29225  Walkscwlks 29674
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 5225  ax-sep 5242  ax-nul 5252  ax-pow 5311  ax-pr 5378  ax-un 7682  ax-cnex 11086  ax-resscn 11087  ax-1cn 11088  ax-icn 11089  ax-addcl 11090  ax-addrcl 11091  ax-mulcl 11092  ax-mulrcl 11093  ax-mulcom 11094  ax-addass 11095  ax-mulass 11096  ax-distr 11097  ax-i2m1 11098  ax-1ne0 11099  ax-1rid 11100  ax-rnegex 11101  ax-rrecex 11102  ax-cnre 11103  ax-pre-lttri 11104  ax-pre-lttrn 11105  ax-pre-ltadd 11106  ax-pre-mulgt0 11107
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 3062  df-reu 3352  df-rab 3401  df-v 3443  df-sbc 3742  df-csb 3851  df-dif 3905  df-un 3907  df-in 3909  df-ss 3919  df-pss 3922  df-nul 4287  df-if 4481  df-pw 4557  df-sn 4582  df-pr 4584  df-op 4588  df-uni 4865  df-int 4904  df-iun 4949  df-br 5100  df-opab 5162  df-mpt 5181  df-tr 5207  df-id 5520  df-eprel 5525  df-po 5533  df-so 5534  df-fr 5578  df-we 5580  df-xp 5631  df-rel 5632  df-cnv 5633  df-co 5634  df-dm 5635  df-rn 5636  df-res 5637  df-ima 5638  df-pred 6260  df-ord 6321  df-on 6322  df-lim 6323  df-suc 6324  df-iota 6449  df-fun 6495  df-fn 6496  df-f 6497  df-f1 6498  df-fo 6499  df-f1o 6500  df-fv 6501  df-riota 7317  df-ov 7363  df-oprab 7364  df-mpo 7365  df-om 7811  df-1st 7935  df-2nd 7936  df-frecs 8225  df-wrecs 8256  df-recs 8305  df-rdg 8343  df-1o 8399  df-2o 8400  df-oadd 8403  df-er 8637  df-map 8769  df-pm 8770  df-en 8888  df-dom 8889  df-sdom 8890  df-fin 8891  df-dju 9817  df-card 9855  df-pnf 11172  df-mnf 11173  df-xr 11174  df-ltxr 11175  df-le 11176  df-sub 11370  df-neg 11371  df-nn 12150  df-2 12212  df-n0 12406  df-xnn0 12479  df-z 12493  df-uz 12756  df-fz 13428  df-fzo 13575  df-hash 14258  df-word 14441  df-edg 29125  df-uhgr 29135  df-upgr 29159  df-uspgr 29227  df-wlks 29677
This theorem is referenced by:  wlkswwlksf1o  29956
  Copyright terms: Public domain W3C validator