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

Theorem onmulscl 28348
Description: The surreal ordinals are closed under multiplication. (Contributed by Scott Fenton, 22-Aug-2025.)
Assertion
Ref Expression
onmulscl ((𝐴 ∈ Ons𝐵 ∈ Ons) → (𝐴 ·s 𝐵) ∈ Ons)

Proof of Theorem onmulscl
Dummy variables 𝑥 𝑦 𝑧 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 fvex 6876 . . . 4 ( L ‘𝐴) ∈ V
2 fvex 6876 . . . 4 ( L ‘𝐵) ∈ V
31, 2ab2rexex 7956 . . 3 {𝑥 ∣ ∃𝑦 ∈ ( L ‘𝐴)∃𝑧 ∈ ( L ‘𝐵)𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))} ∈ V
43a1i 11 . 2 ((𝐴 ∈ Ons𝐵 ∈ Ons) → {𝑥 ∣ ∃𝑦 ∈ ( L ‘𝐴)∃𝑧 ∈ ( L ‘𝐵)𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))} ∈ V)
5 leftno 27947 . . . . . . . . . 10 (𝑦 ∈ ( L ‘𝐴) → 𝑦 No )
65adantr 484 . . . . . . . . 9 ((𝑦 ∈ ( L ‘𝐴) ∧ 𝑧 ∈ ( L ‘𝐵)) → 𝑦 No )
76adantl 485 . . . . . . . 8 (((𝐴 ∈ Ons𝐵 ∈ Ons) ∧ (𝑦 ∈ ( L ‘𝐴) ∧ 𝑧 ∈ ( L ‘𝐵))) → 𝑦 No )
8 onno 28325 . . . . . . . . . 10 (𝐵 ∈ Ons𝐵 No )
98adantl 485 . . . . . . . . 9 ((𝐴 ∈ Ons𝐵 ∈ Ons) → 𝐵 No )
109adantr 484 . . . . . . . 8 (((𝐴 ∈ Ons𝐵 ∈ Ons) ∧ (𝑦 ∈ ( L ‘𝐴) ∧ 𝑧 ∈ ( L ‘𝐵))) → 𝐵 No )
117, 10mulscld 28205 . . . . . . 7 (((𝐴 ∈ Ons𝐵 ∈ Ons) ∧ (𝑦 ∈ ( L ‘𝐴) ∧ 𝑧 ∈ ( L ‘𝐵))) → (𝑦 ·s 𝐵) ∈ No )
12 onno 28325 . . . . . . . . . 10 (𝐴 ∈ Ons𝐴 No )
1312adantr 484 . . . . . . . . 9 ((𝐴 ∈ Ons𝐵 ∈ Ons) → 𝐴 No )
1413adantr 484 . . . . . . . 8 (((𝐴 ∈ Ons𝐵 ∈ Ons) ∧ (𝑦 ∈ ( L ‘𝐴) ∧ 𝑧 ∈ ( L ‘𝐵))) → 𝐴 No )
15 leftno 27947 . . . . . . . . . 10 (𝑧 ∈ ( L ‘𝐵) → 𝑧 No )
1615adantl 485 . . . . . . . . 9 ((𝑦 ∈ ( L ‘𝐴) ∧ 𝑧 ∈ ( L ‘𝐵)) → 𝑧 No )
1716adantl 485 . . . . . . . 8 (((𝐴 ∈ Ons𝐵 ∈ Ons) ∧ (𝑦 ∈ ( L ‘𝐴) ∧ 𝑧 ∈ ( L ‘𝐵))) → 𝑧 No )
1814, 17mulscld 28205 . . . . . . 7 (((𝐴 ∈ Ons𝐵 ∈ Ons) ∧ (𝑦 ∈ ( L ‘𝐴) ∧ 𝑧 ∈ ( L ‘𝐵))) → (𝐴 ·s 𝑧) ∈ No )
1911, 18addscld 28050 . . . . . 6 (((𝐴 ∈ Ons𝐵 ∈ Ons) ∧ (𝑦 ∈ ( L ‘𝐴) ∧ 𝑧 ∈ ( L ‘𝐵))) → ((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) ∈ No )
207, 17mulscld 28205 . . . . . 6 (((𝐴 ∈ Ons𝐵 ∈ Ons) ∧ (𝑦 ∈ ( L ‘𝐴) ∧ 𝑧 ∈ ( L ‘𝐵))) → (𝑦 ·s 𝑧) ∈ No )
2119, 20subscld 28133 . . . . 5 (((𝐴 ∈ Ons𝐵 ∈ Ons) ∧ (𝑦 ∈ ( L ‘𝐴) ∧ 𝑧 ∈ ( L ‘𝐵))) → (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧)) ∈ No )
22 eleq1 2849 . . . . 5 (𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧)) → (𝑥 No ↔ (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧)) ∈ No ))
2321, 22syl5ibrcom 249 . . . 4 (((𝐴 ∈ Ons𝐵 ∈ Ons) ∧ (𝑦 ∈ ( L ‘𝐴) ∧ 𝑧 ∈ ( L ‘𝐵))) → (𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧)) → 𝑥 No ))
2423rexlimdvva 3218 . . 3 ((𝐴 ∈ Ons𝐵 ∈ Ons) → (∃𝑦 ∈ ( L ‘𝐴)∃𝑧 ∈ ( L ‘𝐵)𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧)) → 𝑥 No ))
2524abssdv 4020 . 2 ((𝐴 ∈ Ons𝐵 ∈ Ons) → {𝑥 ∣ ∃𝑦 ∈ ( L ‘𝐴)∃𝑧 ∈ ( L ‘𝐵)𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))} ⊆ No )
26 leftssno 27943 . . . . . 6 ( L ‘𝐴) ⊆ No
271elpw 4558 . . . . . 6 (( L ‘𝐴) ∈ 𝒫 No ↔ ( L ‘𝐴) ⊆ No )
2826, 27mpbir 233 . . . . 5 ( L ‘𝐴) ∈ 𝒫 No
29 nulsgts 27846 . . . . 5 (( L ‘𝐴) ∈ 𝒫 No → ( L ‘𝐴) <<s ∅)
3028, 29mp1i 13 . . . 4 ((𝐴 ∈ Ons𝐵 ∈ Ons) → ( L ‘𝐴) <<s ∅)
31 leftssno 27943 . . . . . 6 ( L ‘𝐵) ⊆ No
322elpw 4558 . . . . . 6 (( L ‘𝐵) ∈ 𝒫 No ↔ ( L ‘𝐵) ⊆ No )
3331, 32mpbir 233 . . . . 5 ( L ‘𝐵) ∈ 𝒫 No
34 nulsgts 27846 . . . . 5 (( L ‘𝐵) ∈ 𝒫 No → ( L ‘𝐵) <<s ∅)
3533, 34mp1i 13 . . . 4 ((𝐴 ∈ Ons𝐵 ∈ Ons) → ( L ‘𝐵) <<s ∅)
36 oncutleft 28333 . . . . 5 (𝐴 ∈ Ons𝐴 = (( L ‘𝐴) |s ∅))
3736adantr 484 . . . 4 ((𝐴 ∈ Ons𝐵 ∈ Ons) → 𝐴 = (( L ‘𝐴) |s ∅))
38 oncutleft 28333 . . . . 5 (𝐵 ∈ Ons𝐵 = (( L ‘𝐵) |s ∅))
3938adantl 485 . . . 4 ((𝐴 ∈ Ons𝐵 ∈ Ons) → 𝐵 = (( L ‘𝐵) |s ∅))
4030, 35, 37, 39mulsunif 28220 . . 3 ((𝐴 ∈ Ons𝐵 ∈ Ons) → (𝐴 ·s 𝐵) = (({𝑥 ∣ ∃𝑦 ∈ ( L ‘𝐴)∃𝑧 ∈ ( L ‘𝐵)𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))} ∪ {𝑥 ∣ ∃𝑦 ∈ ∅ ∃𝑧 ∈ ∅ 𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))}) |s ({𝑥 ∣ ∃𝑦 ∈ ( L ‘𝐴)∃𝑧 ∈ ∅ 𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))} ∪ {𝑥 ∣ ∃𝑦 ∈ ∅ ∃𝑧 ∈ ( L ‘𝐵)𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))})))
41 rex0 4312 . . . . . . 7 ¬ ∃𝑦 ∈ ∅ ∃𝑧 ∈ ∅ 𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))
4241abf 4359 . . . . . 6 {𝑥 ∣ ∃𝑦 ∈ ∅ ∃𝑧 ∈ ∅ 𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))} = ∅
4342uneq2i 4118 . . . . 5 ({𝑥 ∣ ∃𝑦 ∈ ( L ‘𝐴)∃𝑧 ∈ ( L ‘𝐵)𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))} ∪ {𝑥 ∣ ∃𝑦 ∈ ∅ ∃𝑧 ∈ ∅ 𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))}) = ({𝑥 ∣ ∃𝑦 ∈ ( L ‘𝐴)∃𝑧 ∈ ( L ‘𝐵)𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))} ∪ ∅)
44 un0 4347 . . . . 5 ({𝑥 ∣ ∃𝑦 ∈ ( L ‘𝐴)∃𝑧 ∈ ( L ‘𝐵)𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))} ∪ ∅) = {𝑥 ∣ ∃𝑦 ∈ ( L ‘𝐴)∃𝑧 ∈ ( L ‘𝐵)𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))}
4543, 44eqtri 2784 . . . 4 ({𝑥 ∣ ∃𝑦 ∈ ( L ‘𝐴)∃𝑧 ∈ ( L ‘𝐵)𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))} ∪ {𝑥 ∣ ∃𝑦 ∈ ∅ ∃𝑧 ∈ ∅ 𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))}) = {𝑥 ∣ ∃𝑦 ∈ ( L ‘𝐴)∃𝑧 ∈ ( L ‘𝐵)𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))}
46 rex0 4312 . . . . . . . . 9 ¬ ∃𝑧 ∈ ∅ 𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))
4746a1i 11 . . . . . . . 8 (𝑦 ∈ ( L ‘𝐴) → ¬ ∃𝑧 ∈ ∅ 𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧)))
4847nrex 3089 . . . . . . 7 ¬ ∃𝑦 ∈ ( L ‘𝐴)∃𝑧 ∈ ∅ 𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))
4948abf 4359 . . . . . 6 {𝑥 ∣ ∃𝑦 ∈ ( L ‘𝐴)∃𝑧 ∈ ∅ 𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))} = ∅
50 rex0 4312 . . . . . . 7 ¬ ∃𝑦 ∈ ∅ ∃𝑧 ∈ ( L ‘𝐵)𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))
5150abf 4359 . . . . . 6 {𝑥 ∣ ∃𝑦 ∈ ∅ ∃𝑧 ∈ ( L ‘𝐵)𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))} = ∅
5249, 51uneq12i 4119 . . . . 5 ({𝑥 ∣ ∃𝑦 ∈ ( L ‘𝐴)∃𝑧 ∈ ∅ 𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))} ∪ {𝑥 ∣ ∃𝑦 ∈ ∅ ∃𝑧 ∈ ( L ‘𝐵)𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))}) = (∅ ∪ ∅)
53 un0 4347 . . . . 5 (∅ ∪ ∅) = ∅
5452, 53eqtri 2784 . . . 4 ({𝑥 ∣ ∃𝑦 ∈ ( L ‘𝐴)∃𝑧 ∈ ∅ 𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))} ∪ {𝑥 ∣ ∃𝑦 ∈ ∅ ∃𝑧 ∈ ( L ‘𝐵)𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))}) = ∅
5545, 54oveq12i 7404 . . 3 (({𝑥 ∣ ∃𝑦 ∈ ( L ‘𝐴)∃𝑧 ∈ ( L ‘𝐵)𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))} ∪ {𝑥 ∣ ∃𝑦 ∈ ∅ ∃𝑧 ∈ ∅ 𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))}) |s ({𝑥 ∣ ∃𝑦 ∈ ( L ‘𝐴)∃𝑧 ∈ ∅ 𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))} ∪ {𝑥 ∣ ∃𝑦 ∈ ∅ ∃𝑧 ∈ ( L ‘𝐵)𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))})) = ({𝑥 ∣ ∃𝑦 ∈ ( L ‘𝐴)∃𝑧 ∈ ( L ‘𝐵)𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))} |s ∅)
5640, 55eqtrdi 2812 . 2 ((𝐴 ∈ Ons𝐵 ∈ Ons) → (𝐴 ·s 𝐵) = ({𝑥 ∣ ∃𝑦 ∈ ( L ‘𝐴)∃𝑧 ∈ ( L ‘𝐵)𝑥 = (((𝑦 ·s 𝐵) +s (𝐴 ·s 𝑧)) -s (𝑦 ·s 𝑧))} |s ∅))
574, 25, 56elons2d 28329 1 ((𝐴 ∈ Ons𝐵 ∈ Ons) → (𝐴 ·s 𝐵) ∈ Ons)
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wa 399   = wceq 1559  wcel 2141  {cab 2739  wrex 3085  Vcvv 3453  cun 3902  wss 3904  c0 4285  𝒫 cpw 4554   class class class wbr 5099  cfv 6517  (class class class)co 7392   No csur 27681   <<s cslts 27827   |s ccuts 27829   L cleft 27895   +s cadds 28029   -s csubs 28090   ·s cmuls 28176  Onscons 28321
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1814  ax-4 1828  ax-5 1929  ax-6 1986  ax-7 2027  ax-8 2143  ax-9 2151  ax-10 2174  ax-11 2190  ax-12 2211  ax-ext 2733  ax-rep 5226  ax-sep 5245  ax-nul 5255  ax-pow 5321  ax-pr 5389  ax-un 7714
This theorem depends on definitions:  df-bi 209  df-an 400  df-or 859  df-3or 1098  df-3an 1099  df-tru 1562  df-fal 1572  df-ex 1799  df-nf 1803  df-sb 2090  df-mo 2565  df-eu 2595  df-clab 2740  df-cleq 2753  df-clel 2836  df-nfc 2910  df-ne 2957  df-ral 3076  df-rex 3086  df-rmo 3366  df-reu 3367  df-rab 3414  df-v 3455  df-sbc 3745  df-csb 3853  df-dif 3907  df-un 3909  df-in 3911  df-ss 3921  df-pss 3924  df-nul 4286  df-if 4480  df-pw 4556  df-sn 4582  df-pr 4584  df-tp 4586  df-op 4588  df-ot 4590  df-uni 4865  df-int 4905  df-iun 4950  df-br 5100  df-opab 5162  df-mpt 5181  df-tr 5207  df-id 5540  df-eprel 5545  df-po 5553  df-so 5554  df-fr 5598  df-se 5599  df-we 5600  df-xp 5651  df-rel 5652  df-cnv 5653  df-co 5654  df-dm 5655  df-rn 5656  df-res 5657  df-ima 5658  df-pred 6284  df-ord 6345  df-on 6346  df-suc 6348  df-iota 6473  df-fun 6519  df-fn 6520  df-f 6521  df-f1 6522  df-fo 6523  df-f1o 6524  df-fv 6525  df-riota 7349  df-ov 7395  df-oprab 7396  df-mpo 7397  df-1st 7966  df-2nd 7967  df-frecs 8257  df-wrecs 8288  df-recs 8337  df-1o 8432  df-2o 8433  df-nadd 8631  df-no 27684  df-lts 27685  df-bday 27686  df-les 27786  df-slts 27828  df-cuts 27830  df-0s 27877  df-made 27897  df-old 27898  df-left 27900  df-right 27901  df-norec 28008  df-norec2 28019  df-adds 28030  df-negs 28091  df-subs 28092  df-muls 28177  df-ons 28322
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator