Users' Mathboxes Mathbox for Alexander van der Vekens < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >   Mathboxes  >  dfclnbgr6 Structured version   Visualization version   GIF version

Theorem dfclnbgr6 47836
Description: Alternate definition of the closed neighborhood of a vertex as union of the vertex with its semiopen neighborhood. (Contributed by AV, 17-May-2025.)
Hypotheses
Ref Expression
dfvopnbgr2.v 𝑉 = (Vtx‘𝐺)
dfvopnbgr2.e 𝐸 = (Edg‘𝐺)
dfvopnbgr2.u 𝑈 = {𝑛𝑉 ∣ (𝑛 ∈ (𝐺 NeighbVtx 𝑁) ∨ ∃𝑒𝐸 (𝑁 = 𝑛𝑒 = {𝑁}))}
Assertion
Ref Expression
dfclnbgr6 (𝑁𝑉 → (𝐺 ClNeighbVtx 𝑁) = ({𝑁} ∪ 𝑈))
Distinct variable groups:   𝑒,𝐸   𝑒,𝐺   𝑒,𝑁,𝑛   𝑒,𝑉,𝑛   𝑛,𝐸   𝑛,𝐺
Allowed substitution hints:   𝑈(𝑒,𝑛)

Proof of Theorem dfclnbgr6
Dummy variable 𝑣 is distinct from all other variables.
StepHypRef Expression
1 orc 867 . . . . . . 7 (𝑣 = 𝑁 → (𝑣 = 𝑁 ∨ ((𝑣𝑉 ∧ ∃𝑒𝐸 (𝑁𝑒𝑣𝑒)) ↔ (𝑣𝑉 ∧ ∃𝑒𝐸 ((𝑣𝑁𝑁𝑒𝑣𝑒) ∨ (𝑣 = 𝑁𝑒 = {𝑣}))))))
21a1d 25 . . . . . 6 (𝑣 = 𝑁 → (𝑁𝑉 → (𝑣 = 𝑁 ∨ ((𝑣𝑉 ∧ ∃𝑒𝐸 (𝑁𝑒𝑣𝑒)) ↔ (𝑣𝑉 ∧ ∃𝑒𝐸 ((𝑣𝑁𝑁𝑒𝑣𝑒) ∨ (𝑣 = 𝑁𝑒 = {𝑣})))))))
3 simpl 482 . . . . . . . . . . . . . . 15 ((𝑣𝑁𝑁𝑉) → 𝑣𝑁)
43anim1i 615 . . . . . . . . . . . . . 14 (((𝑣𝑁𝑁𝑉) ∧ (𝑁𝑒𝑣𝑒)) → (𝑣𝑁 ∧ (𝑁𝑒𝑣𝑒)))
5 3anass 1094 . . . . . . . . . . . . . 14 ((𝑣𝑁𝑁𝑒𝑣𝑒) ↔ (𝑣𝑁 ∧ (𝑁𝑒𝑣𝑒)))
64, 5sylibr 234 . . . . . . . . . . . . 13 (((𝑣𝑁𝑁𝑉) ∧ (𝑁𝑒𝑣𝑒)) → (𝑣𝑁𝑁𝑒𝑣𝑒))
76orcd 873 . . . . . . . . . . . 12 (((𝑣𝑁𝑁𝑉) ∧ (𝑁𝑒𝑣𝑒)) → ((𝑣𝑁𝑁𝑒𝑣𝑒) ∨ (𝑣 = 𝑁𝑒 = {𝑣})))
87ex 412 . . . . . . . . . . 11 ((𝑣𝑁𝑁𝑉) → ((𝑁𝑒𝑣𝑒) → ((𝑣𝑁𝑁𝑒𝑣𝑒) ∨ (𝑣 = 𝑁𝑒 = {𝑣}))))
9 3simpc 1150 . . . . . . . . . . . . 13 ((𝑣𝑁𝑁𝑒𝑣𝑒) → (𝑁𝑒𝑣𝑒))
109a1i 11 . . . . . . . . . . . 12 ((𝑣𝑁𝑁𝑉) → ((𝑣𝑁𝑁𝑒𝑣𝑒) → (𝑁𝑒𝑣𝑒)))
11 vsnid 4644 . . . . . . . . . . . . . . . . 17 𝑣 ∈ {𝑣}
12 eleq2 2824 . . . . . . . . . . . . . . . . 17 (𝑒 = {𝑣} → (𝑣𝑒𝑣 ∈ {𝑣}))
1311, 12mpbiri 258 . . . . . . . . . . . . . . . 16 (𝑒 = {𝑣} → 𝑣𝑒)
1413adantl 481 . . . . . . . . . . . . . . 15 ((𝑣 = 𝑁𝑒 = {𝑣}) → 𝑣𝑒)
15 eleq1 2823 . . . . . . . . . . . . . . . 16 (𝑣 = 𝑁 → (𝑣𝑒𝑁𝑒))
1615adantr 480 . . . . . . . . . . . . . . 15 ((𝑣 = 𝑁𝑒 = {𝑣}) → (𝑣𝑒𝑁𝑒))
1714, 16mpbid 232 . . . . . . . . . . . . . 14 ((𝑣 = 𝑁𝑒 = {𝑣}) → 𝑁𝑒)
1817, 14jca 511 . . . . . . . . . . . . 13 ((𝑣 = 𝑁𝑒 = {𝑣}) → (𝑁𝑒𝑣𝑒))
1918a1i 11 . . . . . . . . . . . 12 ((𝑣𝑁𝑁𝑉) → ((𝑣 = 𝑁𝑒 = {𝑣}) → (𝑁𝑒𝑣𝑒)))
2010, 19jaod 859 . . . . . . . . . . 11 ((𝑣𝑁𝑁𝑉) → (((𝑣𝑁𝑁𝑒𝑣𝑒) ∨ (𝑣 = 𝑁𝑒 = {𝑣})) → (𝑁𝑒𝑣𝑒)))
218, 20impbid 212 . . . . . . . . . 10 ((𝑣𝑁𝑁𝑉) → ((𝑁𝑒𝑣𝑒) ↔ ((𝑣𝑁𝑁𝑒𝑣𝑒) ∨ (𝑣 = 𝑁𝑒 = {𝑣}))))
2221rexbidv 3165 . . . . . . . . 9 ((𝑣𝑁𝑁𝑉) → (∃𝑒𝐸 (𝑁𝑒𝑣𝑒) ↔ ∃𝑒𝐸 ((𝑣𝑁𝑁𝑒𝑣𝑒) ∨ (𝑣 = 𝑁𝑒 = {𝑣}))))
2322anbi2d 630 . . . . . . . 8 ((𝑣𝑁𝑁𝑉) → ((𝑣𝑉 ∧ ∃𝑒𝐸 (𝑁𝑒𝑣𝑒)) ↔ (𝑣𝑉 ∧ ∃𝑒𝐸 ((𝑣𝑁𝑁𝑒𝑣𝑒) ∨ (𝑣 = 𝑁𝑒 = {𝑣})))))
2423olcd 874 . . . . . . 7 ((𝑣𝑁𝑁𝑉) → (𝑣 = 𝑁 ∨ ((𝑣𝑉 ∧ ∃𝑒𝐸 (𝑁𝑒𝑣𝑒)) ↔ (𝑣𝑉 ∧ ∃𝑒𝐸 ((𝑣𝑁𝑁𝑒𝑣𝑒) ∨ (𝑣 = 𝑁𝑒 = {𝑣}))))))
2524ex 412 . . . . . 6 (𝑣𝑁 → (𝑁𝑉 → (𝑣 = 𝑁 ∨ ((𝑣𝑉 ∧ ∃𝑒𝐸 (𝑁𝑒𝑣𝑒)) ↔ (𝑣𝑉 ∧ ∃𝑒𝐸 ((𝑣𝑁𝑁𝑒𝑣𝑒) ∨ (𝑣 = 𝑁𝑒 = {𝑣})))))))
262, 25pm2.61ine 3016 . . . . 5 (𝑁𝑉 → (𝑣 = 𝑁 ∨ ((𝑣𝑉 ∧ ∃𝑒𝐸 (𝑁𝑒𝑣𝑒)) ↔ (𝑣𝑉 ∧ ∃𝑒𝐸 ((𝑣𝑁𝑁𝑒𝑣𝑒) ∨ (𝑣 = 𝑁𝑒 = {𝑣}))))))
27 orbidi 954 . . . . 5 ((𝑣 = 𝑁 ∨ ((𝑣𝑉 ∧ ∃𝑒𝐸 (𝑁𝑒𝑣𝑒)) ↔ (𝑣𝑉 ∧ ∃𝑒𝐸 ((𝑣𝑁𝑁𝑒𝑣𝑒) ∨ (𝑣 = 𝑁𝑒 = {𝑣}))))) ↔ ((𝑣 = 𝑁 ∨ (𝑣𝑉 ∧ ∃𝑒𝐸 (𝑁𝑒𝑣𝑒))) ↔ (𝑣 = 𝑁 ∨ (𝑣𝑉 ∧ ∃𝑒𝐸 ((𝑣𝑁𝑁𝑒𝑣𝑒) ∨ (𝑣 = 𝑁𝑒 = {𝑣}))))))
2826, 27sylib 218 . . . 4 (𝑁𝑉 → ((𝑣 = 𝑁 ∨ (𝑣𝑉 ∧ ∃𝑒𝐸 (𝑁𝑒𝑣𝑒))) ↔ (𝑣 = 𝑁 ∨ (𝑣𝑉 ∧ ∃𝑒𝐸 ((𝑣𝑁𝑁𝑒𝑣𝑒) ∨ (𝑣 = 𝑁𝑒 = {𝑣}))))))
29 elun 4133 . . . . 5 (𝑣 ∈ ({𝑁} ∪ {𝑛𝑉 ∣ ∃𝑒𝐸 (𝑁𝑒𝑛𝑒)}) ↔ (𝑣 ∈ {𝑁} ∨ 𝑣 ∈ {𝑛𝑉 ∣ ∃𝑒𝐸 (𝑁𝑒𝑛𝑒)}))
30 velsn 4622 . . . . . 6 (𝑣 ∈ {𝑁} ↔ 𝑣 = 𝑁)
31 eleq1 2823 . . . . . . . . 9 (𝑛 = 𝑣 → (𝑛𝑒𝑣𝑒))
3231anbi2d 630 . . . . . . . 8 (𝑛 = 𝑣 → ((𝑁𝑒𝑛𝑒) ↔ (𝑁𝑒𝑣𝑒)))
3332rexbidv 3165 . . . . . . 7 (𝑛 = 𝑣 → (∃𝑒𝐸 (𝑁𝑒𝑛𝑒) ↔ ∃𝑒𝐸 (𝑁𝑒𝑣𝑒)))
3433elrab 3676 . . . . . 6 (𝑣 ∈ {𝑛𝑉 ∣ ∃𝑒𝐸 (𝑁𝑒𝑛𝑒)} ↔ (𝑣𝑉 ∧ ∃𝑒𝐸 (𝑁𝑒𝑣𝑒)))
3530, 34orbi12i 914 . . . . 5 ((𝑣 ∈ {𝑁} ∨ 𝑣 ∈ {𝑛𝑉 ∣ ∃𝑒𝐸 (𝑁𝑒𝑛𝑒)}) ↔ (𝑣 = 𝑁 ∨ (𝑣𝑉 ∧ ∃𝑒𝐸 (𝑁𝑒𝑣𝑒))))
3629, 35bitri 275 . . . 4 (𝑣 ∈ ({𝑁} ∪ {𝑛𝑉 ∣ ∃𝑒𝐸 (𝑁𝑒𝑛𝑒)}) ↔ (𝑣 = 𝑁 ∨ (𝑣𝑉 ∧ ∃𝑒𝐸 (𝑁𝑒𝑣𝑒))))
37 elun 4133 . . . . 5 (𝑣 ∈ ({𝑁} ∪ {𝑛𝑉 ∣ ∃𝑒𝐸 ((𝑛𝑁𝑁𝑒𝑛𝑒) ∨ (𝑛 = 𝑁𝑒 = {𝑛}))}) ↔ (𝑣 ∈ {𝑁} ∨ 𝑣 ∈ {𝑛𝑉 ∣ ∃𝑒𝐸 ((𝑛𝑁𝑁𝑒𝑛𝑒) ∨ (𝑛 = 𝑁𝑒 = {𝑛}))}))
38 neeq1 2995 . . . . . . . . . 10 (𝑛 = 𝑣 → (𝑛𝑁𝑣𝑁))
3938, 313anbi13d 1440 . . . . . . . . 9 (𝑛 = 𝑣 → ((𝑛𝑁𝑁𝑒𝑛𝑒) ↔ (𝑣𝑁𝑁𝑒𝑣𝑒)))
40 eqeq1 2740 . . . . . . . . . 10 (𝑛 = 𝑣 → (𝑛 = 𝑁𝑣 = 𝑁))
41 sneq 4616 . . . . . . . . . . 11 (𝑛 = 𝑣 → {𝑛} = {𝑣})
4241eqeq2d 2747 . . . . . . . . . 10 (𝑛 = 𝑣 → (𝑒 = {𝑛} ↔ 𝑒 = {𝑣}))
4340, 42anbi12d 632 . . . . . . . . 9 (𝑛 = 𝑣 → ((𝑛 = 𝑁𝑒 = {𝑛}) ↔ (𝑣 = 𝑁𝑒 = {𝑣})))
4439, 43orbi12d 918 . . . . . . . 8 (𝑛 = 𝑣 → (((𝑛𝑁𝑁𝑒𝑛𝑒) ∨ (𝑛 = 𝑁𝑒 = {𝑛})) ↔ ((𝑣𝑁𝑁𝑒𝑣𝑒) ∨ (𝑣 = 𝑁𝑒 = {𝑣}))))
4544rexbidv 3165 . . . . . . 7 (𝑛 = 𝑣 → (∃𝑒𝐸 ((𝑛𝑁𝑁𝑒𝑛𝑒) ∨ (𝑛 = 𝑁𝑒 = {𝑛})) ↔ ∃𝑒𝐸 ((𝑣𝑁𝑁𝑒𝑣𝑒) ∨ (𝑣 = 𝑁𝑒 = {𝑣}))))
4645elrab 3676 . . . . . 6 (𝑣 ∈ {𝑛𝑉 ∣ ∃𝑒𝐸 ((𝑛𝑁𝑁𝑒𝑛𝑒) ∨ (𝑛 = 𝑁𝑒 = {𝑛}))} ↔ (𝑣𝑉 ∧ ∃𝑒𝐸 ((𝑣𝑁𝑁𝑒𝑣𝑒) ∨ (𝑣 = 𝑁𝑒 = {𝑣}))))
4730, 46orbi12i 914 . . . . 5 ((𝑣 ∈ {𝑁} ∨ 𝑣 ∈ {𝑛𝑉 ∣ ∃𝑒𝐸 ((𝑛𝑁𝑁𝑒𝑛𝑒) ∨ (𝑛 = 𝑁𝑒 = {𝑛}))}) ↔ (𝑣 = 𝑁 ∨ (𝑣𝑉 ∧ ∃𝑒𝐸 ((𝑣𝑁𝑁𝑒𝑣𝑒) ∨ (𝑣 = 𝑁𝑒 = {𝑣})))))
4837, 47bitri 275 . . . 4 (𝑣 ∈ ({𝑁} ∪ {𝑛𝑉 ∣ ∃𝑒𝐸 ((𝑛𝑁𝑁𝑒𝑛𝑒) ∨ (𝑛 = 𝑁𝑒 = {𝑛}))}) ↔ (𝑣 = 𝑁 ∨ (𝑣𝑉 ∧ ∃𝑒𝐸 ((𝑣𝑁𝑁𝑒𝑣𝑒) ∨ (𝑣 = 𝑁𝑒 = {𝑣})))))
4928, 36, 483bitr4g 314 . . 3 (𝑁𝑉 → (𝑣 ∈ ({𝑁} ∪ {𝑛𝑉 ∣ ∃𝑒𝐸 (𝑁𝑒𝑛𝑒)}) ↔ 𝑣 ∈ ({𝑁} ∪ {𝑛𝑉 ∣ ∃𝑒𝐸 ((𝑛𝑁𝑁𝑒𝑛𝑒) ∨ (𝑛 = 𝑁𝑒 = {𝑛}))})))
5049eqrdv 2734 . 2 (𝑁𝑉 → ({𝑁} ∪ {𝑛𝑉 ∣ ∃𝑒𝐸 (𝑁𝑒𝑛𝑒)}) = ({𝑁} ∪ {𝑛𝑉 ∣ ∃𝑒𝐸 ((𝑛𝑁𝑁𝑒𝑛𝑒) ∨ (𝑛 = 𝑁𝑒 = {𝑛}))}))
51 dfvopnbgr2.v . . 3 𝑉 = (Vtx‘𝐺)
52 dfvopnbgr2.e . . 3 𝐸 = (Edg‘𝐺)
5351, 52dfclnbgr2 47804 . 2 (𝑁𝑉 → (𝐺 ClNeighbVtx 𝑁) = ({𝑁} ∪ {𝑛𝑉 ∣ ∃𝑒𝐸 (𝑁𝑒𝑛𝑒)}))
54 dfvopnbgr2.u . . . 4 𝑈 = {𝑛𝑉 ∣ (𝑛 ∈ (𝐺 NeighbVtx 𝑁) ∨ ∃𝑒𝐸 (𝑁 = 𝑛𝑒 = {𝑁}))}
5551, 52, 54dfvopnbgr2 47833 . . 3 (𝑁𝑉𝑈 = {𝑛𝑉 ∣ ∃𝑒𝐸 ((𝑛𝑁𝑁𝑒𝑛𝑒) ∨ (𝑛 = 𝑁𝑒 = {𝑛}))})
5655uneq2d 4148 . 2 (𝑁𝑉 → ({𝑁} ∪ 𝑈) = ({𝑁} ∪ {𝑛𝑉 ∣ ∃𝑒𝐸 ((𝑛𝑁𝑁𝑒𝑛𝑒) ∨ (𝑛 = 𝑁𝑒 = {𝑛}))}))
5750, 53, 563eqtr4d 2781 1 (𝑁𝑉 → (𝐺 ClNeighbVtx 𝑁) = ({𝑁} ∪ 𝑈))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 206  wa 395  wo 847  w3a 1086   = wceq 1540  wcel 2109  wne 2933  wrex 3061  {crab 3420  cun 3929  {csn 4606  cfv 6536  (class class class)co 7410  Vtxcvtx 28980  Edgcedg 29031   NeighbVtx cnbgr 29316   ClNeighbVtx cclnbgr 47799
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-pr 5407  ax-un 7734
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 848  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-ral 3053  df-rex 3062  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-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-id 5553  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-iota 6489  df-fun 6538  df-fv 6544  df-ov 7413  df-oprab 7414  df-mpo 7415  df-1st 7993  df-2nd 7994  df-nbgr 29317  df-clnbgr 47800
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator