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 43508
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 7733 . . . 4 (𝐴 ∈ On → 𝐴 ∈ On)
213ad2ant1 1133 . . 3 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → 𝐴 ∈ On)
3 eloni 6327 . . . . . . . . 9 (𝐴 ∈ On → Ord 𝐴)
4 unizlim 6441 . . . . . . . . . 10 (Ord 𝐴 → (𝐴 = 𝐴 ↔ (𝐴 = ∅ ∨ Lim 𝐴)))
5 oran 991 . . . . . . . . . . 11 ((𝐴 = ∅ ∨ Lim 𝐴) ↔ ¬ (¬ 𝐴 = ∅ ∧ ¬ Lim 𝐴))
6 df-ne 2933 . . . . . . . . . . . 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 7779 . . . . . 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 2824 . . . 4 (𝑏 = 𝐴 → (𝑏 ∈ On ↔ 𝐴 ∈ On))
21 suceq 6385 . . . . 5 (𝑏 = 𝐴 → suc 𝑏 = suc 𝐴)
2221eqeq2d 2747 . . . 4 (𝑏 = 𝐴 → (𝐴 = suc 𝑏𝐴 = suc 𝐴))
2320, 22anbi12d 632 . . 3 (𝑏 = 𝐴 → ((𝑏 ∈ On ∧ 𝐴 = suc 𝑏) ↔ ( 𝐴 ∈ On ∧ 𝐴 = suc 𝐴)))
242, 19, 23spcedv 3552 . 2 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → ∃𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏))
25 onsucf1lem 43507 . . 3 (𝐴 ∈ On → ∃*𝑏 ∈ On 𝐴 = suc 𝑏)
26253ad2ant1 1133 . 2 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → ∃*𝑏 ∈ On 𝐴 = suc 𝑏)
27 df-eu 2569 . . 3 (∃!𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏) ↔ (∃𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏) ∧ ∃*𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏)))
28 df-reu 3351 . . 3 (∃!𝑏 ∈ On 𝐴 = suc 𝑏 ↔ ∃!𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏))
29 df-rmo 3350 . . . 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 2113  ∃*wmo 2537  ∃!weu 2568  wne 2932  ∃!wreu 3348  ∃*wrmo 3349  c0 4285   cuni 4863  Ord word 6316  Oncon0 6317  Lim wlim 6318  suc csuc 6319
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 2115  ax-9 2123  ax-10 2146  ax-11 2162  ax-12 2184  ax-ext 2708  ax-sep 5241  ax-nul 5251  ax-pr 5377  ax-un 7680
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 2068  df-mo 2539  df-eu 2569  df-clab 2715  df-cleq 2728  df-clel 2811  df-ne 2933  df-ral 3052  df-rex 3061  df-rmo 3350  df-reu 3351  df-rab 3400  df-v 3442  df-dif 3904  df-un 3906  df-in 3908  df-ss 3918  df-pss 3921  df-nul 4286  df-if 4480  df-pw 4556  df-sn 4581  df-pr 4583  df-op 4587  df-uni 4864  df-br 5099  df-opab 5161  df-tr 5206  df-eprel 5524  df-po 5532  df-so 5533  df-fr 5577  df-we 5579  df-ord 6320  df-on 6321  df-lim 6322  df-suc 6323
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator