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 43548
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 7735 . . . 4 (𝐴 ∈ On → 𝐴 ∈ On)
213ad2ant1 1134 . . 3 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → 𝐴 ∈ On)
3 eloni 6328 . . . . . . . . 9 (𝐴 ∈ On → Ord 𝐴)
4 unizlim 6442 . . . . . . . . . 10 (Ord 𝐴 → (𝐴 = 𝐴 ↔ (𝐴 = ∅ ∨ Lim 𝐴)))
5 oran 992 . . . . . . . . . . 11 ((𝐴 = ∅ ∨ Lim 𝐴) ↔ ¬ (¬ 𝐴 = ∅ ∧ ¬ Lim 𝐴))
6 df-ne 2934 . . . . . . . . . . . 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, 11biimtrdi 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 7781 . . . . . 6 (𝐴 ∈ On → (𝐴 = 𝐴𝐴 = suc 𝐴))
17163ad2ant1 1134 . . . . 5 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → (𝐴 = 𝐴𝐴 = suc 𝐴))
1814, 15, 17mpjaod 861 . . . 4 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → 𝐴 = suc 𝐴)
192, 18jca 511 . . 3 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → ( 𝐴 ∈ On ∧ 𝐴 = suc 𝐴))
20 eleq1 2825 . . . 4 (𝑏 = 𝐴 → (𝑏 ∈ On ↔ 𝐴 ∈ On))
21 suceq 6386 . . . . 5 (𝑏 = 𝐴 → suc 𝑏 = suc 𝐴)
2221eqeq2d 2748 . . . 4 (𝑏 = 𝐴 → (𝐴 = suc 𝑏𝐴 = suc 𝐴))
2320, 22anbi12d 633 . . 3 (𝑏 = 𝐴 → ((𝑏 ∈ On ∧ 𝐴 = suc 𝑏) ↔ ( 𝐴 ∈ On ∧ 𝐴 = suc 𝐴)))
242, 19, 23spcedv 3553 . 2 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → ∃𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏))
25 onsucf1lem 43547 . . 3 (𝐴 ∈ On → ∃*𝑏 ∈ On 𝐴 = suc 𝑏)
26253ad2ant1 1134 . 2 ((𝐴 ∈ On ∧ 𝐴 ≠ ∅ ∧ ¬ Lim 𝐴) → ∃*𝑏 ∈ On 𝐴 = suc 𝑏)
27 df-eu 2570 . . 3 (∃!𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏) ↔ (∃𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏) ∧ ∃*𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏)))
28 df-reu 3352 . . 3 (∃!𝑏 ∈ On 𝐴 = suc 𝑏 ↔ ∃!𝑏(𝑏 ∈ On ∧ 𝐴 = suc 𝑏))
29 df-rmo 3351 . . . 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 206  wa 395  wo 848  w3a 1087   = wceq 1542  wex 1781  wcel 2114  ∃*wmo 2538  ∃!weu 2569  wne 2933  ∃!wreu 3349  ∃*wrmo 3350  c0 4286   cuni 4864  Ord word 6317  Oncon0 6318  Lim wlim 6319  suc csuc 6320
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1797  ax-4 1811  ax-5 1912  ax-6 1969  ax-7 2010  ax-8 2116  ax-9 2124  ax-10 2147  ax-11 2163  ax-12 2185  ax-ext 2709  ax-sep 5242  ax-nul 5252  ax-pr 5378  ax-un 7682
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 849  df-3or 1088  df-3an 1089  df-tru 1545  df-fal 1555  df-ex 1782  df-nf 1786  df-sb 2069  df-mo 2540  df-eu 2570  df-clab 2716  df-cleq 2729  df-clel 2812  df-ne 2934  df-ral 3053  df-rex 3062  df-rmo 3351  df-reu 3352  df-rab 3401  df-v 3443  df-dif 3905  df-un 3907  df-in 3909  df-ss 3919  df-pss 3922  df-nul 4287  df-if 4481  df-pw 4557  df-sn 4582  df-pr 4584  df-op 4588  df-uni 4865  df-br 5100  df-opab 5162  df-tr 5207  df-eprel 5525  df-po 5533  df-so 5534  df-fr 5578  df-we 5580  df-ord 6321  df-on 6322  df-lim 6323  df-suc 6324
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator