Users' Mathboxes Mathbox for Richard Penner < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >   Mathboxes  >  onsucf1olem Structured version   Visualization version   GIF version

Theorem onsucf1olem 43282
Description: The successor operation is bijective between the ordinals and the class of successor ordinals. Lemma 1.17 of [Schloeder] p. 2. (Contributed by RP, 18-Jan-2025.)
Assertion
Ref Expression
onsucf1olem ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → ∃!𝑏 ∈ On 𝐴 = suc 𝑏)
Distinct variable group:   𝐴,𝑏

Proof of Theorem onsucf1olem
StepHypRef Expression
1 onuni 7716 . . . 4 (𝐴 ∈ On → 𝐴 ∈ On)
213ad2ant1 1133 . . 3 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → 𝐴 ∈ On)
3 eloni 6312 . . . . . . . . 9 (𝐴 ∈ On → Ord 𝐴)
4 unizlim 6426 . . . . . . . . . 10 (Ord 𝐴 → (𝐴 = 𝐴 ↔ (𝐴 = ∅ ∨ Lim 𝐴)))
5 oran 991 . . . . . . . . . . 11 ((𝐴 = ∅ ∨ Lim 𝐴) ↔ ¬ (¬ 𝐴 = ∅ ∧ ¬ Lim 𝐴))
6 df-ne 2927 . . . . . . . . . . . 12 (𝐴 ≠ ∅ ↔ ¬ 𝐴 = ∅)
76anbi1i 624 . . . . . . . . . . 11 ((𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) ↔ (¬ 𝐴 = ∅ ∧ ¬ Lim 𝐴))
85, 7xchbinxr 335 . . . . . . . . . 10 ((𝐴 = ∅ ∨ Lim 𝐴) ↔ ¬ (𝐴 ≠ ∅ ∧ ¬ Lim 𝐴))
94, 8bitrdi 287 . . . . . . . . 9 (Ord 𝐴 → (𝐴 = 𝐴 ↔ ¬ (𝐴 ≠ ∅ ∧ ¬ Lim 𝐴)))
103, 9syl 17 . . . . . . . 8 (𝐴 ∈ On → (𝐴 = 𝐴 ↔ ¬ (𝐴 ≠ ∅ ∧ ¬ Lim 𝐴)))
11 pm2.21 123 . . . . . . . 8 (¬ (𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → ((𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → 𝐴 = suc 𝐴))
1210, 11biimtrdi 253 . . . . . . 7 (𝐴 ∈ On → (𝐴 = 𝐴 → ((𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → 𝐴 = suc 𝐴)))
1312com23 86 . . . . . 6 (𝐴 ∈ On → ((𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → (𝐴 = 𝐴𝐴 = suc 𝐴)))
14133impib 1116 . . . . 5 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → (𝐴 = 𝐴𝐴 = suc 𝐴))
15 idd 24 . . . . 5 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → (𝐴 = suc 𝐴𝐴 = suc 𝐴))
16 onuniorsuc 7762 . . . . . 6 (𝐴 ∈ On → (𝐴 = 𝐴𝐴 = suc 𝐴))
17163ad2ant1 1133 . . . . 5 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → (𝐴 = 𝐴𝐴 = suc 𝐴))
1814, 15, 17mpjaod 860 . . . 4 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → 𝐴 = suc 𝐴)
192, 18jca 511 . . 3 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → ( 𝐴 ∈ On ∧ 𝐴 = suc 𝐴))
20 eleq1 2817 . . . 4 (𝑏 = 𝐴 → (𝑏 ∈ On ↔ 𝐴 ∈ On))
21 suceq 6370 . . . . 5 (𝑏 = 𝐴 → suc 𝑏 = suc 𝐴)
2221eqeq2d 2741 . . . 4 (𝑏 = 𝐴 → (𝐴 = suc 𝑏𝐴 = suc 𝐴))
2320, 22anbi12d 632 . . 3 (𝑏 = 𝐴 → ((𝑏 ∈ On ∧ 𝐴 = suc 𝑏) ↔ ( 𝐴 ∈ On ∧ 𝐴 = suc 𝐴)))
242, 19, 23spcedv 3551 . 2 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → ∃𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏))
25 onsucf1lem 43281 . . 3 (𝐴 ∈ On → ∃*𝑏 ∈ On 𝐴 = suc 𝑏)
26253ad2ant1 1133 . 2 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → ∃*𝑏 ∈ On 𝐴 = suc 𝑏)
27 df-eu 2563 . . 3 (∃!𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏) ↔ (∃𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏) ∧ ∃*𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏)))
28 df-reu 3345 . . 3 (∃!𝑏 ∈ On 𝐴 = suc 𝑏 ↔ ∃!𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏))
29 df-rmo 3344 . . . 4 (∃*𝑏 ∈ On 𝐴 = suc 𝑏 ↔ ∃*𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏))
3029anbi2i 623 . . 3 ((∃𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏) ∧ ∃*𝑏 ∈ On 𝐴 = suc 𝑏) ↔ (∃𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏) ∧ ∃*𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏)))
3127, 28, 303bitr4i 303 . 2 (∃!𝑏 ∈ On 𝐴 = suc 𝑏 ↔ (∃𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏) ∧ ∃*𝑏 ∈ On 𝐴 = suc 𝑏))
3224, 26, 31sylanbrc 583 1 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → ∃!𝑏 ∈ On 𝐴 = suc 𝑏)
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wb 206  wa 395  wo 847  w3a 1086   = wceq 1541  wex 1780  wcel 2110  ∃*wmo 2532  ∃!weu 2562  wne 2926  ∃!wreu 3342  ∃*wrmo 3343  c0 4281   cuni 4857  Ord word 6301  Oncon0 6302  Lim wlim 6303  suc csuc 6304
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1796  ax-4 1810  ax-5 1911  ax-6 1968  ax-7 2009  ax-8 2112  ax-9 2120  ax-10 2143  ax-11 2159  ax-12 2179  ax-ext 2702  ax-sep 5232  ax-nul 5242  ax-pr 5368  ax-un 7663
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 848  df-3or 1087  df-3an 1088  df-tru 1544  df-fal 1554  df-ex 1781  df-nf 1785  df-sb 2067  df-mo 2534  df-eu 2563  df-clab 2709  df-cleq 2722  df-clel 2804  df-ne 2927  df-ral 3046  df-rex 3055  df-rmo 3344  df-reu 3345  df-rab 3394  df-v 3436  df-dif 3903  df-un 3905  df-in 3907  df-ss 3917  df-pss 3920  df-nul 4282  df-if 4474  df-pw 4550  df-sn 4575  df-pr 4577  df-op 4581  df-uni 4858  df-br 5090  df-opab 5152  df-tr 5197  df-eprel 5514  df-po 5522  df-so 5523  df-fr 5567  df-we 5569  df-ord 6305  df-on 6306  df-lim 6307  df-suc 6308
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator