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 41953
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 7771 . . . 4 (𝐴 ∈ On → 𝐴 ∈ On)
213ad2ant1 1134 . . 3 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → 𝐴 ∈ On)
3 eloni 6371 . . . . . . . . 9 (𝐴 ∈ On → Ord 𝐴)
4 unizlim 6484 . . . . . . . . . 10 (Ord 𝐴 → (𝐴 = 𝐴 ↔ (𝐴 = ∅ ∨ Lim 𝐴)))
5 oran 989 . . . . . . . . . . 11 ((𝐴 = ∅ ∨ Lim 𝐴) ↔ ¬ (¬ 𝐴 = ∅ ∧ ¬ Lim 𝐴))
6 df-ne 2942 . . . . . . . . . . . 12 (𝐴 ≠ ∅ ↔ ¬ 𝐴 = ∅)
76anbi1i 625 . . . . . . . . . . 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, 11syl6bi 253 . . . . . . 7 (𝐴 ∈ On → (𝐴 = 𝐴 → ((𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → 𝐴 = suc 𝐴)))
1312com23 86 . . . . . 6 (𝐴 ∈ On → ((𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → (𝐴 = 𝐴𝐴 = suc 𝐴)))
14133impib 1117 . . . . 5 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → (𝐴 = 𝐴𝐴 = suc 𝐴))
15 idd 24 . . . . 5 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → (𝐴 = suc 𝐴𝐴 = suc 𝐴))
16 onuniorsuc 7820 . . . . . 6 (𝐴 ∈ On → (𝐴 = 𝐴𝐴 = suc 𝐴))
17163ad2ant1 1134 . . . . 5 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → (𝐴 = 𝐴𝐴 = suc 𝐴))
1814, 15, 17mpjaod 859 . . . 4 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → 𝐴 = suc 𝐴)
192, 18jca 513 . . 3 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → ( 𝐴 ∈ On ∧ 𝐴 = suc 𝐴))
20 eleq1 2822 . . . 4 (𝑏 = 𝐴 → (𝑏 ∈ On ↔ 𝐴 ∈ On))
21 suceq 6427 . . . . 5 (𝑏 = 𝐴 → suc 𝑏 = suc 𝐴)
2221eqeq2d 2744 . . . 4 (𝑏 = 𝐴 → (𝐴 = suc 𝑏𝐴 = suc 𝐴))
2320, 22anbi12d 632 . . 3 (𝑏 = 𝐴 → ((𝑏 ∈ On ∧ 𝐴 = suc 𝑏) ↔ ( 𝐴 ∈ On ∧ 𝐴 = suc 𝐴)))
242, 19, 23spcedv 3588 . 2 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → ∃𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏))
25 onsucf1lem 41952 . . 3 (𝐴 ∈ On → ∃*𝑏 ∈ On 𝐴 = suc 𝑏)
26253ad2ant1 1134 . 2 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → ∃*𝑏 ∈ On 𝐴 = suc 𝑏)
27 df-eu 2564 . . 3 (∃!𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏) ↔ (∃𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏) ∧ ∃*𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏)))
28 df-reu 3378 . . 3 (∃!𝑏 ∈ On 𝐴 = suc 𝑏 ↔ ∃!𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏))
29 df-rmo 3377 . . . 4 (∃*𝑏 ∈ On 𝐴 = suc 𝑏 ↔ ∃*𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏))
3029anbi2i 624 . . 3 ((∃𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏) ∧ ∃*𝑏 ∈ On 𝐴 = suc 𝑏) ↔ (∃𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏) ∧ ∃*𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏)))
3127, 28, 303bitr4i 303 . 2 (∃!𝑏 ∈ On 𝐴 = suc 𝑏 ↔ (∃𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏) ∧ ∃*𝑏 ∈ On 𝐴 = suc 𝑏))
3224, 26, 31sylanbrc 584 1 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → ∃!𝑏 ∈ On 𝐴 = suc 𝑏)
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wb 205  wa 397  wo 846  w3a 1088   = wceq 1542  wex 1782  wcel 2107  ∃*wmo 2533  ∃!weu 2563  wne 2941  ∃!wreu 3375  ∃*wrmo 3376  c0 4321   cuni 4907  Ord word 6360  Oncon0 6361  Lim wlim 6362  suc csuc 6363
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1798  ax-4 1812  ax-5 1914  ax-6 1972  ax-7 2012  ax-8 2109  ax-9 2117  ax-10 2138  ax-11 2155  ax-12 2172  ax-ext 2704  ax-sep 5298  ax-nul 5305  ax-pr 5426  ax-un 7720
This theorem depends on definitions:  df-bi 206  df-an 398  df-or 847  df-3or 1089  df-3an 1090  df-tru 1545  df-fal 1555  df-ex 1783  df-nf 1787  df-sb 2069  df-mo 2535  df-eu 2564  df-clab 2711  df-cleq 2725  df-clel 2811  df-ne 2942  df-ral 3063  df-rex 3072  df-rmo 3377  df-reu 3378  df-rab 3434  df-v 3477  df-dif 3950  df-un 3952  df-in 3954  df-ss 3964  df-pss 3966  df-nul 4322  df-if 4528  df-pw 4603  df-sn 4628  df-pr 4630  df-op 4634  df-uni 4908  df-br 5148  df-opab 5210  df-tr 5265  df-eprel 5579  df-po 5587  df-so 5588  df-fr 5630  df-we 5632  df-ord 6364  df-on 6365  df-lim 6366  df-suc 6367
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator