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

Theorem dfom3 9335
Description: The class of natural numbers ω can be defined as the intersection of all inductive sets (which is the smallest inductive set, since inductive sets are closed under intersection), which is valid provided we assume the Axiom of Infinity. Definition 6.3 of [Eisenberg] p. 82. (Contributed by NM, 6-Aug-1994.)
Assertion
Ref Expression
dfom3 ω = {𝑥 ∣ (∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥)}
Distinct variable group:   𝑥,𝑦

Proof of Theorem dfom3
Dummy variable 𝑧 is distinct from all other variables.
StepHypRef Expression
1 0ex 5226 . . . . 5 ∅ ∈ V
21elintab 4887 . . . 4 (∅ ∈ {𝑥 ∣ (∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥)} ↔ ∀𝑥((∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥) → ∅ ∈ 𝑥))
3 simpl 482 . . . 4 ((∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥) → ∅ ∈ 𝑥)
42, 3mpgbir 1803 . . 3 ∅ ∈ {𝑥 ∣ (∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥)}
5 suceq 6316 . . . . . . . . . 10 (𝑦 = 𝑧 → suc 𝑦 = suc 𝑧)
65eleq1d 2823 . . . . . . . . 9 (𝑦 = 𝑧 → (suc 𝑦𝑥 ↔ suc 𝑧𝑥))
76rspccv 3549 . . . . . . . 8 (∀𝑦𝑥 suc 𝑦𝑥 → (𝑧𝑥 → suc 𝑧𝑥))
87adantl 481 . . . . . . 7 ((∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥) → (𝑧𝑥 → suc 𝑧𝑥))
98a2i 14 . . . . . 6 (((∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥) → 𝑧𝑥) → ((∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥) → suc 𝑧𝑥))
109alimi 1815 . . . . 5 (∀𝑥((∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥) → 𝑧𝑥) → ∀𝑥((∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥) → suc 𝑧𝑥))
11 vex 3426 . . . . . 6 𝑧 ∈ V
1211elintab 4887 . . . . 5 (𝑧 {𝑥 ∣ (∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥)} ↔ ∀𝑥((∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥) → 𝑧𝑥))
1311sucex 7633 . . . . . 6 suc 𝑧 ∈ V
1413elintab 4887 . . . . 5 (suc 𝑧 {𝑥 ∣ (∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥)} ↔ ∀𝑥((∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥) → suc 𝑧𝑥))
1510, 12, 143imtr4i 291 . . . 4 (𝑧 {𝑥 ∣ (∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥)} → suc 𝑧 {𝑥 ∣ (∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥)})
1615rgenw 3075 . . 3 𝑧 ∈ ω (𝑧 {𝑥 ∣ (∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥)} → suc 𝑧 {𝑥 ∣ (∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥)})
17 peano5 7714 . . 3 ((∅ ∈ {𝑥 ∣ (∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥)} ∧ ∀𝑧 ∈ ω (𝑧 {𝑥 ∣ (∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥)} → suc 𝑧 {𝑥 ∣ (∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥)})) → ω ⊆ {𝑥 ∣ (∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥)})
184, 16, 17mp2an 688 . 2 ω ⊆ {𝑥 ∣ (∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥)}
19 peano1 7710 . . . 4 ∅ ∈ ω
20 peano2 7711 . . . . 5 (𝑦 ∈ ω → suc 𝑦 ∈ ω)
2120rgen 3073 . . . 4 𝑦 ∈ ω suc 𝑦 ∈ ω
22 omex 9331 . . . . . 6 ω ∈ V
23 eleq2 2827 . . . . . . . 8 (𝑥 = ω → (∅ ∈ 𝑥 ↔ ∅ ∈ ω))
24 eleq2 2827 . . . . . . . . 9 (𝑥 = ω → (suc 𝑦𝑥 ↔ suc 𝑦 ∈ ω))
2524raleqbi1dv 3331 . . . . . . . 8 (𝑥 = ω → (∀𝑦𝑥 suc 𝑦𝑥 ↔ ∀𝑦 ∈ ω suc 𝑦 ∈ ω))
2623, 25anbi12d 630 . . . . . . 7 (𝑥 = ω → ((∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥) ↔ (∅ ∈ ω ∧ ∀𝑦 ∈ ω suc 𝑦 ∈ ω)))
27 eleq2 2827 . . . . . . 7 (𝑥 = ω → (𝑧𝑥𝑧 ∈ ω))
2826, 27imbi12d 344 . . . . . 6 (𝑥 = ω → (((∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥) → 𝑧𝑥) ↔ ((∅ ∈ ω ∧ ∀𝑦 ∈ ω suc 𝑦 ∈ ω) → 𝑧 ∈ ω)))
2922, 28spcv 3534 . . . . 5 (∀𝑥((∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥) → 𝑧𝑥) → ((∅ ∈ ω ∧ ∀𝑦 ∈ ω suc 𝑦 ∈ ω) → 𝑧 ∈ ω))
3012, 29sylbi 216 . . . 4 (𝑧 {𝑥 ∣ (∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥)} → ((∅ ∈ ω ∧ ∀𝑦 ∈ ω suc 𝑦 ∈ ω) → 𝑧 ∈ ω))
3119, 21, 30mp2ani 694 . . 3 (𝑧 {𝑥 ∣ (∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥)} → 𝑧 ∈ ω)
3231ssriv 3921 . 2 {𝑥 ∣ (∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥)} ⊆ ω
3318, 32eqssi 3933 1 ω = {𝑥 ∣ (∅ ∈ 𝑥 ∧ ∀𝑦𝑥 suc 𝑦𝑥)}
Colors of variables: wff setvar class
Syntax hints:  wi 4  wa 395  wal 1537   = wceq 1539  wcel 2108  {cab 2715  wral 3063  wss 3883  c0 4253   cint 4876  suc csuc 6253  ωcom 7687
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1799  ax-4 1813  ax-5 1914  ax-6 1972  ax-7 2012  ax-8 2110  ax-9 2118  ax-10 2139  ax-11 2156  ax-12 2173  ax-ext 2709  ax-sep 5218  ax-nul 5225  ax-pr 5347  ax-un 7566  ax-inf2 9329
This theorem depends on definitions:  df-bi 206  df-an 396  df-or 844  df-3or 1086  df-3an 1087  df-tru 1542  df-fal 1552  df-ex 1784  df-nf 1788  df-sb 2069  df-clab 2716  df-cleq 2730  df-clel 2817  df-ne 2943  df-ral 3068  df-rex 3069  df-rab 3072  df-v 3424  df-dif 3886  df-un 3888  df-in 3890  df-ss 3900  df-pss 3902  df-nul 4254  df-if 4457  df-pw 4532  df-sn 4559  df-pr 4561  df-tp 4563  df-op 4565  df-uni 4837  df-int 4877  df-br 5071  df-opab 5133  df-tr 5188  df-eprel 5486  df-po 5494  df-so 5495  df-fr 5535  df-we 5537  df-ord 6254  df-on 6255  df-lim 6256  df-suc 6257  df-om 7688
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator