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

Theorem wwlks 27873
Description: The set of walks (in an undirected graph) as words over the set of vertices. (Contributed by Alexander van der Vekens, 15-Jul-2018.) (Revised by AV, 8-Apr-2021.)
Hypotheses
Ref Expression
wwlks.v 𝑉 = (Vtx‘𝐺)
wwlks.e 𝐸 = (Edg‘𝐺)
Assertion
Ref Expression
wwlks (WWalks‘𝐺) = {𝑤 ∈ Word 𝑉 ∣ (𝑤 ≠ ∅ ∧ ∀𝑖 ∈ (0..^((♯‘𝑤) − 1)){(𝑤𝑖), (𝑤‘(𝑖 + 1))} ∈ 𝐸)}
Distinct variable groups:   𝑖,𝐺,𝑤   𝑤,𝑉
Allowed substitution hints:   𝐸(𝑤,𝑖)   𝑉(𝑖)

Proof of Theorem wwlks
Dummy variable 𝑔 is distinct from all other variables.
StepHypRef Expression
1 df-wwlks 27868 . . 3 WWalks = (𝑔 ∈ V ↦ {𝑤 ∈ Word (Vtx‘𝑔) ∣ (𝑤 ≠ ∅ ∧ ∀𝑖 ∈ (0..^((♯‘𝑤) − 1)){(𝑤𝑖), (𝑤‘(𝑖 + 1))} ∈ (Edg‘𝑔))})
2 fveq2 6695 . . . . . 6 (𝑔 = 𝐺 → (Vtx‘𝑔) = (Vtx‘𝐺))
3 wwlks.v . . . . . 6 𝑉 = (Vtx‘𝐺)
42, 3eqtr4di 2789 . . . . 5 (𝑔 = 𝐺 → (Vtx‘𝑔) = 𝑉)
5 wrdeq 14056 . . . . 5 ((Vtx‘𝑔) = 𝑉 → Word (Vtx‘𝑔) = Word 𝑉)
64, 5syl 17 . . . 4 (𝑔 = 𝐺 → Word (Vtx‘𝑔) = Word 𝑉)
7 fveq2 6695 . . . . . . . 8 (𝑔 = 𝐺 → (Edg‘𝑔) = (Edg‘𝐺))
8 wwlks.e . . . . . . . 8 𝐸 = (Edg‘𝐺)
97, 8eqtr4di 2789 . . . . . . 7 (𝑔 = 𝐺 → (Edg‘𝑔) = 𝐸)
109eleq2d 2816 . . . . . 6 (𝑔 = 𝐺 → ({(𝑤𝑖), (𝑤‘(𝑖 + 1))} ∈ (Edg‘𝑔) ↔ {(𝑤𝑖), (𝑤‘(𝑖 + 1))} ∈ 𝐸))
1110ralbidv 3108 . . . . 5 (𝑔 = 𝐺 → (∀𝑖 ∈ (0..^((♯‘𝑤) − 1)){(𝑤𝑖), (𝑤‘(𝑖 + 1))} ∈ (Edg‘𝑔) ↔ ∀𝑖 ∈ (0..^((♯‘𝑤) − 1)){(𝑤𝑖), (𝑤‘(𝑖 + 1))} ∈ 𝐸))
1211anbi2d 632 . . . 4 (𝑔 = 𝐺 → ((𝑤 ≠ ∅ ∧ ∀𝑖 ∈ (0..^((♯‘𝑤) − 1)){(𝑤𝑖), (𝑤‘(𝑖 + 1))} ∈ (Edg‘𝑔)) ↔ (𝑤 ≠ ∅ ∧ ∀𝑖 ∈ (0..^((♯‘𝑤) − 1)){(𝑤𝑖), (𝑤‘(𝑖 + 1))} ∈ 𝐸)))
136, 12rabeqbidv 3386 . . 3 (𝑔 = 𝐺 → {𝑤 ∈ Word (Vtx‘𝑔) ∣ (𝑤 ≠ ∅ ∧ ∀𝑖 ∈ (0..^((♯‘𝑤) − 1)){(𝑤𝑖), (𝑤‘(𝑖 + 1))} ∈ (Edg‘𝑔))} = {𝑤 ∈ Word 𝑉 ∣ (𝑤 ≠ ∅ ∧ ∀𝑖 ∈ (0..^((♯‘𝑤) − 1)){(𝑤𝑖), (𝑤‘(𝑖 + 1))} ∈ 𝐸)})
14 id 22 . . 3 (𝐺 ∈ V → 𝐺 ∈ V)
153fvexi 6709 . . . . 5 𝑉 ∈ V
1615a1i 11 . . . 4 (𝐺 ∈ V → 𝑉 ∈ V)
17 wrdexg 14044 . . . 4 (𝑉 ∈ V → Word 𝑉 ∈ V)
18 rabexg 5209 . . . 4 (Word 𝑉 ∈ V → {𝑤 ∈ Word 𝑉 ∣ (𝑤 ≠ ∅ ∧ ∀𝑖 ∈ (0..^((♯‘𝑤) − 1)){(𝑤𝑖), (𝑤‘(𝑖 + 1))} ∈ 𝐸)} ∈ V)
1916, 17, 183syl 18 . . 3 (𝐺 ∈ V → {𝑤 ∈ Word 𝑉 ∣ (𝑤 ≠ ∅ ∧ ∀𝑖 ∈ (0..^((♯‘𝑤) − 1)){(𝑤𝑖), (𝑤‘(𝑖 + 1))} ∈ 𝐸)} ∈ V)
201, 13, 14, 19fvmptd3 6819 . 2 (𝐺 ∈ V → (WWalks‘𝐺) = {𝑤 ∈ Word 𝑉 ∣ (𝑤 ≠ ∅ ∧ ∀𝑖 ∈ (0..^((♯‘𝑤) − 1)){(𝑤𝑖), (𝑤‘(𝑖 + 1))} ∈ 𝐸)})
21 fvprc 6687 . . 3 𝐺 ∈ V → (WWalks‘𝐺) = ∅)
22 fvprc 6687 . . . . . . . . . 10 𝐺 ∈ V → (Vtx‘𝐺) = ∅)
233, 22syl5eq 2783 . . . . . . . . 9 𝐺 ∈ V → 𝑉 = ∅)
24 wrdeq 14056 . . . . . . . . 9 (𝑉 = ∅ → Word 𝑉 = Word ∅)
2523, 24syl 17 . . . . . . . 8 𝐺 ∈ V → Word 𝑉 = Word ∅)
2625eleq2d 2816 . . . . . . 7 𝐺 ∈ V → (𝑤 ∈ Word 𝑉𝑤 ∈ Word ∅))
27 0wrd0 14060 . . . . . . 7 (𝑤 ∈ Word ∅ ↔ 𝑤 = ∅)
2826, 27bitrdi 290 . . . . . 6 𝐺 ∈ V → (𝑤 ∈ Word 𝑉𝑤 = ∅))
29 nne 2936 . . . . . . . 8 𝑤 ≠ ∅ ↔ 𝑤 = ∅)
3029biimpri 231 . . . . . . 7 (𝑤 = ∅ → ¬ 𝑤 ≠ ∅)
3130intnanrd 493 . . . . . 6 (𝑤 = ∅ → ¬ (𝑤 ≠ ∅ ∧ ∀𝑖 ∈ (0..^((♯‘𝑤) − 1)){(𝑤𝑖), (𝑤‘(𝑖 + 1))} ∈ 𝐸))
3228, 31syl6bi 256 . . . . 5 𝐺 ∈ V → (𝑤 ∈ Word 𝑉 → ¬ (𝑤 ≠ ∅ ∧ ∀𝑖 ∈ (0..^((♯‘𝑤) − 1)){(𝑤𝑖), (𝑤‘(𝑖 + 1))} ∈ 𝐸)))
3332ralrimiv 3094 . . . 4 𝐺 ∈ V → ∀𝑤 ∈ Word 𝑉 ¬ (𝑤 ≠ ∅ ∧ ∀𝑖 ∈ (0..^((♯‘𝑤) − 1)){(𝑤𝑖), (𝑤‘(𝑖 + 1))} ∈ 𝐸))
34 rabeq0 4285 . . . 4 ({𝑤 ∈ Word 𝑉 ∣ (𝑤 ≠ ∅ ∧ ∀𝑖 ∈ (0..^((♯‘𝑤) − 1)){(𝑤𝑖), (𝑤‘(𝑖 + 1))} ∈ 𝐸)} = ∅ ↔ ∀𝑤 ∈ Word 𝑉 ¬ (𝑤 ≠ ∅ ∧ ∀𝑖 ∈ (0..^((♯‘𝑤) − 1)){(𝑤𝑖), (𝑤‘(𝑖 + 1))} ∈ 𝐸))
3533, 34sylibr 237 . . 3 𝐺 ∈ V → {𝑤 ∈ Word 𝑉 ∣ (𝑤 ≠ ∅ ∧ ∀𝑖 ∈ (0..^((♯‘𝑤) − 1)){(𝑤𝑖), (𝑤‘(𝑖 + 1))} ∈ 𝐸)} = ∅)
3621, 35eqtr4d 2774 . 2 𝐺 ∈ V → (WWalks‘𝐺) = {𝑤 ∈ Word 𝑉 ∣ (𝑤 ≠ ∅ ∧ ∀𝑖 ∈ (0..^((♯‘𝑤) − 1)){(𝑤𝑖), (𝑤‘(𝑖 + 1))} ∈ 𝐸)})
3720, 36pm2.61i 185 1 (WWalks‘𝐺) = {𝑤 ∈ Word 𝑉 ∣ (𝑤 ≠ ∅ ∧ ∀𝑖 ∈ (0..^((♯‘𝑤) − 1)){(𝑤𝑖), (𝑤‘(𝑖 + 1))} ∈ 𝐸)}
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wa 399   = wceq 1543  wcel 2112  wne 2932  wral 3051  {crab 3055  Vcvv 3398  c0 4223  {cpr 4529  cfv 6358  (class class class)co 7191  0cc0 10694  1c1 10695   + caddc 10697  cmin 11027  ..^cfzo 13203  chash 13861  Word cword 14034  Vtxcvtx 27041  Edgcedg 27092  WWalkscwwlks 27863
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1803  ax-4 1817  ax-5 1918  ax-6 1976  ax-7 2018  ax-8 2114  ax-9 2122  ax-10 2143  ax-11 2160  ax-12 2177  ax-ext 2708  ax-rep 5164  ax-sep 5177  ax-nul 5184  ax-pow 5243  ax-pr 5307  ax-un 7501  ax-cnex 10750  ax-resscn 10751  ax-1cn 10752  ax-icn 10753  ax-addcl 10754  ax-addrcl 10755  ax-mulcl 10756  ax-mulrcl 10757  ax-mulcom 10758  ax-addass 10759  ax-mulass 10760  ax-distr 10761  ax-i2m1 10762  ax-1ne0 10763  ax-1rid 10764  ax-rnegex 10765  ax-rrecex 10766  ax-cnre 10767  ax-pre-lttri 10768  ax-pre-lttrn 10769  ax-pre-ltadd 10770  ax-pre-mulgt0 10771
This theorem depends on definitions:  df-bi 210  df-an 400  df-or 848  df-3or 1090  df-3an 1091  df-tru 1546  df-fal 1556  df-ex 1788  df-nf 1792  df-sb 2073  df-mo 2539  df-eu 2568  df-clab 2715  df-cleq 2728  df-clel 2809  df-nfc 2879  df-ne 2933  df-nel 3037  df-ral 3056  df-rex 3057  df-reu 3058  df-rab 3060  df-v 3400  df-sbc 3684  df-csb 3799  df-dif 3856  df-un 3858  df-in 3860  df-ss 3870  df-pss 3872  df-nul 4224  df-if 4426  df-pw 4501  df-sn 4528  df-pr 4530  df-tp 4532  df-op 4534  df-uni 4806  df-int 4846  df-iun 4892  df-br 5040  df-opab 5102  df-mpt 5121  df-tr 5147  df-id 5440  df-eprel 5445  df-po 5453  df-so 5454  df-fr 5494  df-we 5496  df-xp 5542  df-rel 5543  df-cnv 5544  df-co 5545  df-dm 5546  df-rn 5547  df-res 5548  df-ima 5549  df-pred 6140  df-ord 6194  df-on 6195  df-lim 6196  df-suc 6197  df-iota 6316  df-fun 6360  df-fn 6361  df-f 6362  df-f1 6363  df-fo 6364  df-f1o 6365  df-fv 6366  df-riota 7148  df-ov 7194  df-oprab 7195  df-mpo 7196  df-om 7623  df-1st 7739  df-2nd 7740  df-wrecs 8025  df-recs 8086  df-rdg 8124  df-1o 8180  df-er 8369  df-map 8488  df-en 8605  df-dom 8606  df-sdom 8607  df-fin 8608  df-card 9520  df-pnf 10834  df-mnf 10835  df-xr 10836  df-ltxr 10837  df-le 10838  df-sub 11029  df-neg 11030  df-nn 11796  df-n0 12056  df-z 12142  df-uz 12404  df-fz 13061  df-fzo 13204  df-hash 13862  df-word 14035  df-wwlks 27868
This theorem is referenced by:  iswwlks  27874
  Copyright terms: Public domain W3C validator