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

Theorem wwlksnextbij 27674
Description: There is a bijection between the extensions of a walk (as word) by an edge and the set of vertices being connected to the trailing vertex of the walk. (Contributed by Alexander van der Vekens, 21-Aug-2018.) (Revised by AV, 18-Apr-2021.) (Revised by AV, 27-Oct-2022.)
Hypotheses
Ref Expression
wwlksnextbij.v 𝑉 = (Vtx‘𝐺)
wwlksnextbij.e 𝐸 = (Edg‘𝐺)
Assertion
Ref Expression
wwlksnextbij (𝑊 ∈ (𝑁 WWalksN 𝐺) → ∃𝑓 𝑓:{𝑤 ∈ ((𝑁 + 1) WWalksN 𝐺) ∣ ((𝑤 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑤)} ∈ 𝐸)}–1-1-onto→{𝑛𝑉 ∣ {(lastS‘𝑊), 𝑛} ∈ 𝐸})
Distinct variable groups:   𝑓,𝐸,𝑛,𝑤   𝑓,𝐺,𝑤   𝑓,𝑁,𝑤   𝑓,𝑉,𝑛,𝑤   𝑓,𝑊,𝑛,𝑤
Allowed substitution hints:   𝐺(𝑛)   𝑁(𝑛)

Proof of Theorem wwlksnextbij
Dummy variables 𝑝 𝑡 𝑥 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 ovexd 7185 . . 3 (𝑊 ∈ (𝑁 WWalksN 𝐺) → ((𝑁 + 1) WWalksN 𝐺) ∈ V)
2 rabexg 5226 . . 3 (((𝑁 + 1) WWalksN 𝐺) ∈ V → {𝑡 ∈ ((𝑁 + 1) WWalksN 𝐺) ∣ ((𝑡 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑡)} ∈ 𝐸)} ∈ V)
3 mptexg 6978 . . 3 ({𝑡 ∈ ((𝑁 + 1) WWalksN 𝐺) ∣ ((𝑡 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑡)} ∈ 𝐸)} ∈ V → (𝑥 ∈ {𝑡 ∈ ((𝑁 + 1) WWalksN 𝐺) ∣ ((𝑡 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑡)} ∈ 𝐸)} ↦ (lastS‘𝑥)) ∈ V)
41, 2, 33syl 18 . 2 (𝑊 ∈ (𝑁 WWalksN 𝐺) → (𝑥 ∈ {𝑡 ∈ ((𝑁 + 1) WWalksN 𝐺) ∣ ((𝑡 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑡)} ∈ 𝐸)} ↦ (lastS‘𝑥)) ∈ V)
5 wwlksnextbij.v . . . 4 𝑉 = (Vtx‘𝐺)
6 wwlksnextbij.e . . . 4 𝐸 = (Edg‘𝐺)
7 eqid 2821 . . . 4 {𝑤 ∈ Word 𝑉 ∣ ((♯‘𝑤) = (𝑁 + 2) ∧ (𝑤 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑤)} ∈ 𝐸)} = {𝑤 ∈ Word 𝑉 ∣ ((♯‘𝑤) = (𝑁 + 2) ∧ (𝑤 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑤)} ∈ 𝐸)}
8 preq2 4663 . . . . . 6 (𝑛 = 𝑝 → {(lastS‘𝑊), 𝑛} = {(lastS‘𝑊), 𝑝})
98eleq1d 2897 . . . . 5 (𝑛 = 𝑝 → ({(lastS‘𝑊), 𝑛} ∈ 𝐸 ↔ {(lastS‘𝑊), 𝑝} ∈ 𝐸))
109cbvrabv 3491 . . . 4 {𝑛𝑉 ∣ {(lastS‘𝑊), 𝑛} ∈ 𝐸} = {𝑝𝑉 ∣ {(lastS‘𝑊), 𝑝} ∈ 𝐸}
11 fveqeq2 6673 . . . . . . 7 (𝑡 = 𝑤 → ((♯‘𝑡) = (𝑁 + 2) ↔ (♯‘𝑤) = (𝑁 + 2)))
12 oveq1 7157 . . . . . . . 8 (𝑡 = 𝑤 → (𝑡 prefix (𝑁 + 1)) = (𝑤 prefix (𝑁 + 1)))
1312eqeq1d 2823 . . . . . . 7 (𝑡 = 𝑤 → ((𝑡 prefix (𝑁 + 1)) = 𝑊 ↔ (𝑤 prefix (𝑁 + 1)) = 𝑊))
14 fveq2 6664 . . . . . . . . 9 (𝑡 = 𝑤 → (lastS‘𝑡) = (lastS‘𝑤))
1514preq2d 4669 . . . . . . . 8 (𝑡 = 𝑤 → {(lastS‘𝑊), (lastS‘𝑡)} = {(lastS‘𝑊), (lastS‘𝑤)})
1615eleq1d 2897 . . . . . . 7 (𝑡 = 𝑤 → ({(lastS‘𝑊), (lastS‘𝑡)} ∈ 𝐸 ↔ {(lastS‘𝑊), (lastS‘𝑤)} ∈ 𝐸))
1711, 13, 163anbi123d 1432 . . . . . 6 (𝑡 = 𝑤 → (((♯‘𝑡) = (𝑁 + 2) ∧ (𝑡 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑡)} ∈ 𝐸) ↔ ((♯‘𝑤) = (𝑁 + 2) ∧ (𝑤 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑤)} ∈ 𝐸)))
1817cbvrabv 3491 . . . . 5 {𝑡 ∈ Word 𝑉 ∣ ((♯‘𝑡) = (𝑁 + 2) ∧ (𝑡 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑡)} ∈ 𝐸)} = {𝑤 ∈ Word 𝑉 ∣ ((♯‘𝑤) = (𝑁 + 2) ∧ (𝑤 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑤)} ∈ 𝐸)}
1918mpteq1i 5148 . . . 4 (𝑥 ∈ {𝑡 ∈ Word 𝑉 ∣ ((♯‘𝑡) = (𝑁 + 2) ∧ (𝑡 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑡)} ∈ 𝐸)} ↦ (lastS‘𝑥)) = (𝑥 ∈ {𝑤 ∈ Word 𝑉 ∣ ((♯‘𝑤) = (𝑁 + 2) ∧ (𝑤 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑤)} ∈ 𝐸)} ↦ (lastS‘𝑥))
205, 6, 7, 10, 19wwlksnextbij0 27673 . . 3 (𝑊 ∈ (𝑁 WWalksN 𝐺) → (𝑥 ∈ {𝑡 ∈ Word 𝑉 ∣ ((♯‘𝑡) = (𝑁 + 2) ∧ (𝑡 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑡)} ∈ 𝐸)} ↦ (lastS‘𝑥)):{𝑤 ∈ Word 𝑉 ∣ ((♯‘𝑤) = (𝑁 + 2) ∧ (𝑤 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑤)} ∈ 𝐸)}–1-1-onto→{𝑛𝑉 ∣ {(lastS‘𝑊), 𝑛} ∈ 𝐸})
21 eqid 2821 . . . . . . 7 {𝑡 ∈ Word 𝑉 ∣ ((♯‘𝑡) = (𝑁 + 2) ∧ (𝑡 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑡)} ∈ 𝐸)} = {𝑡 ∈ Word 𝑉 ∣ ((♯‘𝑡) = (𝑁 + 2) ∧ (𝑡 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑡)} ∈ 𝐸)}
225, 6, 21wwlksnextwrd 27669 . . . . . 6 (𝑊 ∈ (𝑁 WWalksN 𝐺) → {𝑡 ∈ Word 𝑉 ∣ ((♯‘𝑡) = (𝑁 + 2) ∧ (𝑡 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑡)} ∈ 𝐸)} = {𝑡 ∈ ((𝑁 + 1) WWalksN 𝐺) ∣ ((𝑡 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑡)} ∈ 𝐸)})
2322eqcomd 2827 . . . . 5 (𝑊 ∈ (𝑁 WWalksN 𝐺) → {𝑡 ∈ ((𝑁 + 1) WWalksN 𝐺) ∣ ((𝑡 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑡)} ∈ 𝐸)} = {𝑡 ∈ Word 𝑉 ∣ ((♯‘𝑡) = (𝑁 + 2) ∧ (𝑡 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑡)} ∈ 𝐸)})
2423mpteq1d 5147 . . . 4 (𝑊 ∈ (𝑁 WWalksN 𝐺) → (𝑥 ∈ {𝑡 ∈ ((𝑁 + 1) WWalksN 𝐺) ∣ ((𝑡 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑡)} ∈ 𝐸)} ↦ (lastS‘𝑥)) = (𝑥 ∈ {𝑡 ∈ Word 𝑉 ∣ ((♯‘𝑡) = (𝑁 + 2) ∧ (𝑡 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑡)} ∈ 𝐸)} ↦ (lastS‘𝑥)))
255, 6, 7wwlksnextwrd 27669 . . . . 5 (𝑊 ∈ (𝑁 WWalksN 𝐺) → {𝑤 ∈ Word 𝑉 ∣ ((♯‘𝑤) = (𝑁 + 2) ∧ (𝑤 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑤)} ∈ 𝐸)} = {𝑤 ∈ ((𝑁 + 1) WWalksN 𝐺) ∣ ((𝑤 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑤)} ∈ 𝐸)})
2625eqcomd 2827 . . . 4 (𝑊 ∈ (𝑁 WWalksN 𝐺) → {𝑤 ∈ ((𝑁 + 1) WWalksN 𝐺) ∣ ((𝑤 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑤)} ∈ 𝐸)} = {𝑤 ∈ Word 𝑉 ∣ ((♯‘𝑤) = (𝑁 + 2) ∧ (𝑤 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑤)} ∈ 𝐸)})
27 eqidd 2822 . . . 4 (𝑊 ∈ (𝑁 WWalksN 𝐺) → {𝑛𝑉 ∣ {(lastS‘𝑊), 𝑛} ∈ 𝐸} = {𝑛𝑉 ∣ {(lastS‘𝑊), 𝑛} ∈ 𝐸})
2824, 26, 27f1oeq123d 6604 . . 3 (𝑊 ∈ (𝑁 WWalksN 𝐺) → ((𝑥 ∈ {𝑡 ∈ ((𝑁 + 1) WWalksN 𝐺) ∣ ((𝑡 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑡)} ∈ 𝐸)} ↦ (lastS‘𝑥)):{𝑤 ∈ ((𝑁 + 1) WWalksN 𝐺) ∣ ((𝑤 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑤)} ∈ 𝐸)}–1-1-onto→{𝑛𝑉 ∣ {(lastS‘𝑊), 𝑛} ∈ 𝐸} ↔ (𝑥 ∈ {𝑡 ∈ Word 𝑉 ∣ ((♯‘𝑡) = (𝑁 + 2) ∧ (𝑡 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑡)} ∈ 𝐸)} ↦ (lastS‘𝑥)):{𝑤 ∈ Word 𝑉 ∣ ((♯‘𝑤) = (𝑁 + 2) ∧ (𝑤 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑤)} ∈ 𝐸)}–1-1-onto→{𝑛𝑉 ∣ {(lastS‘𝑊), 𝑛} ∈ 𝐸}))
2920, 28mpbird 259 . 2 (𝑊 ∈ (𝑁 WWalksN 𝐺) → (𝑥 ∈ {𝑡 ∈ ((𝑁 + 1) WWalksN 𝐺) ∣ ((𝑡 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑡)} ∈ 𝐸)} ↦ (lastS‘𝑥)):{𝑤 ∈ ((𝑁 + 1) WWalksN 𝐺) ∣ ((𝑤 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑤)} ∈ 𝐸)}–1-1-onto→{𝑛𝑉 ∣ {(lastS‘𝑊), 𝑛} ∈ 𝐸})
30 f1oeq1 6598 . 2 (𝑓 = (𝑥 ∈ {𝑡 ∈ ((𝑁 + 1) WWalksN 𝐺) ∣ ((𝑡 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑡)} ∈ 𝐸)} ↦ (lastS‘𝑥)) → (𝑓:{𝑤 ∈ ((𝑁 + 1) WWalksN 𝐺) ∣ ((𝑤 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑤)} ∈ 𝐸)}–1-1-onto→{𝑛𝑉 ∣ {(lastS‘𝑊), 𝑛} ∈ 𝐸} ↔ (𝑥 ∈ {𝑡 ∈ ((𝑁 + 1) WWalksN 𝐺) ∣ ((𝑡 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑡)} ∈ 𝐸)} ↦ (lastS‘𝑥)):{𝑤 ∈ ((𝑁 + 1) WWalksN 𝐺) ∣ ((𝑤 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑤)} ∈ 𝐸)}–1-1-onto→{𝑛𝑉 ∣ {(lastS‘𝑊), 𝑛} ∈ 𝐸}))
314, 29, 30spcedv 3598 1 (𝑊 ∈ (𝑁 WWalksN 𝐺) → ∃𝑓 𝑓:{𝑤 ∈ ((𝑁 + 1) WWalksN 𝐺) ∣ ((𝑤 prefix (𝑁 + 1)) = 𝑊 ∧ {(lastS‘𝑊), (lastS‘𝑤)} ∈ 𝐸)}–1-1-onto→{𝑛𝑉 ∣ {(lastS‘𝑊), 𝑛} ∈ 𝐸})
Colors of variables: wff setvar class
Syntax hints:  wi 4  wa 398  w3a 1083   = wceq 1533  wex 1776  wcel 2110  {crab 3142  Vcvv 3494  {cpr 4562  cmpt 5138  1-1-ontowf1o 6348  cfv 6349  (class class class)co 7150  1c1 10532   + caddc 10534  2c2 11686  chash 13684  Word cword 13855  lastSclsw 13908   prefix cpfx 14026  Vtxcvtx 26775  Edgcedg 26826   WWalksN cwwlksn 27598
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1792  ax-4 1806  ax-5 1907  ax-6 1966  ax-7 2011  ax-8 2112  ax-9 2120  ax-10 2141  ax-11 2157  ax-12 2173  ax-ext 2793  ax-rep 5182  ax-sep 5195  ax-nul 5202  ax-pow 5258  ax-pr 5321  ax-un 7455  ax-cnex 10587  ax-resscn 10588  ax-1cn 10589  ax-icn 10590  ax-addcl 10591  ax-addrcl 10592  ax-mulcl 10593  ax-mulrcl 10594  ax-mulcom 10595  ax-addass 10596  ax-mulass 10597  ax-distr 10598  ax-i2m1 10599  ax-1ne0 10600  ax-1rid 10601  ax-rnegex 10602  ax-rrecex 10603  ax-cnre 10604  ax-pre-lttri 10605  ax-pre-lttrn 10606  ax-pre-ltadd 10607  ax-pre-mulgt0 10608
This theorem depends on definitions:  df-bi 209  df-an 399  df-or 844  df-3or 1084  df-3an 1085  df-tru 1536  df-fal 1546  df-ex 1777  df-nf 1781  df-sb 2066  df-mo 2618  df-eu 2650  df-clab 2800  df-cleq 2814  df-clel 2893  df-nfc 2963  df-ne 3017  df-nel 3124  df-ral 3143  df-rex 3144  df-reu 3145  df-rab 3147  df-v 3496  df-sbc 3772  df-csb 3883  df-dif 3938  df-un 3940  df-in 3942  df-ss 3951  df-pss 3953  df-nul 4291  df-if 4467  df-pw 4540  df-sn 4561  df-pr 4563  df-tp 4565  df-op 4567  df-uni 4832  df-int 4869  df-iun 4913  df-br 5059  df-opab 5121  df-mpt 5139  df-tr 5165  df-id 5454  df-eprel 5459  df-po 5468  df-so 5469  df-fr 5508  df-we 5510  df-xp 5555  df-rel 5556  df-cnv 5557  df-co 5558  df-dm 5559  df-rn 5560  df-res 5561  df-ima 5562  df-pred 6142  df-ord 6188  df-on 6189  df-lim 6190  df-suc 6191  df-iota 6308  df-fun 6351  df-fn 6352  df-f 6353  df-f1 6354  df-fo 6355  df-f1o 6356  df-fv 6357  df-riota 7108  df-ov 7153  df-oprab 7154  df-mpo 7155  df-om 7575  df-1st 7683  df-2nd 7684  df-wrecs 7941  df-recs 8002  df-rdg 8040  df-1o 8096  df-oadd 8100  df-er 8283  df-map 8402  df-en 8504  df-dom 8505  df-sdom 8506  df-fin 8507  df-card 9362  df-pnf 10671  df-mnf 10672  df-xr 10673  df-ltxr 10674  df-le 10675  df-sub 10866  df-neg 10867  df-nn 11633  df-2 11694  df-n0 11892  df-xnn0 11962  df-z 11976  df-uz 12238  df-rp 12384  df-fz 12887  df-fzo 13028  df-hash 13685  df-word 13856  df-lsw 13909  df-concat 13917  df-s1 13944  df-substr 13997  df-pfx 14027  df-wwlks 27602  df-wwlksn 27603
This theorem is referenced by:  wwlksnexthasheq  27675
  Copyright terms: Public domain W3C validator