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

Theorem rankxpsuc 9308
Description: The rank of a Cartesian product when the rank of the union of its arguments is a successor ordinal. Part of Exercise 4 of [Kunen] p. 107. See rankxplim 9305 for the limit ordinal case. (Contributed by NM, 19-Sep-2006.)
Hypotheses
Ref Expression
rankxplim.1 𝐴 ∈ V
rankxplim.2 𝐵 ∈ V
Assertion
Ref Expression
rankxpsuc (((rank‘(𝐴𝐵)) = suc 𝐶 ∧ (𝐴 × 𝐵) ≠ ∅) → (rank‘(𝐴 × 𝐵)) = suc suc (rank‘(𝐴𝐵)))

Proof of Theorem rankxpsuc
Dummy variable 𝑥 is distinct from all other variables.
StepHypRef Expression
1 rankuni 9289 . . . . . . . 8 (rank‘ (𝐴 × 𝐵)) = (rank‘ (𝐴 × 𝐵))
2 rankuni 9289 . . . . . . . . 9 (rank‘ (𝐴 × 𝐵)) = (rank‘(𝐴 × 𝐵))
32unieqi 4837 . . . . . . . 8 (rank‘ (𝐴 × 𝐵)) = (rank‘(𝐴 × 𝐵))
41, 3eqtri 2847 . . . . . . 7 (rank‘ (𝐴 × 𝐵)) = (rank‘(𝐴 × 𝐵))
5 unixp 6120 . . . . . . . 8 ((𝐴 × 𝐵) ≠ ∅ → (𝐴 × 𝐵) = (𝐴𝐵))
65fveq2d 6665 . . . . . . 7 ((𝐴 × 𝐵) ≠ ∅ → (rank‘ (𝐴 × 𝐵)) = (rank‘(𝐴𝐵)))
74, 6syl5reqr 2874 . . . . . 6 ((𝐴 × 𝐵) ≠ ∅ → (rank‘(𝐴𝐵)) = (rank‘(𝐴 × 𝐵)))
8 suc11reg 9079 . . . . . 6 (suc (rank‘(𝐴𝐵)) = suc (rank‘(𝐴 × 𝐵)) ↔ (rank‘(𝐴𝐵)) = (rank‘(𝐴 × 𝐵)))
97, 8sylibr 237 . . . . 5 ((𝐴 × 𝐵) ≠ ∅ → suc (rank‘(𝐴𝐵)) = suc (rank‘(𝐴 × 𝐵)))
109adantl 485 . . . 4 (((rank‘(𝐴𝐵)) = suc 𝐶 ∧ (𝐴 × 𝐵) ≠ ∅) → suc (rank‘(𝐴𝐵)) = suc (rank‘(𝐴 × 𝐵)))
11 fvex 6674 . . . . . . . . . . . . . 14 (rank‘(𝐴𝐵)) ∈ V
12 eleq1 2903 . . . . . . . . . . . . . 14 ((rank‘(𝐴𝐵)) = suc 𝐶 → ((rank‘(𝐴𝐵)) ∈ V ↔ suc 𝐶 ∈ V))
1311, 12mpbii 236 . . . . . . . . . . . . 13 ((rank‘(𝐴𝐵)) = suc 𝐶 → suc 𝐶 ∈ V)
14 sucexb 7518 . . . . . . . . . . . . 13 (𝐶 ∈ V ↔ suc 𝐶 ∈ V)
1513, 14sylibr 237 . . . . . . . . . . . 12 ((rank‘(𝐴𝐵)) = suc 𝐶𝐶 ∈ V)
16 nlimsucg 7551 . . . . . . . . . . . 12 (𝐶 ∈ V → ¬ Lim suc 𝐶)
1715, 16syl 17 . . . . . . . . . . 11 ((rank‘(𝐴𝐵)) = suc 𝐶 → ¬ Lim suc 𝐶)
18 limeq 6190 . . . . . . . . . . 11 ((rank‘(𝐴𝐵)) = suc 𝐶 → (Lim (rank‘(𝐴𝐵)) ↔ Lim suc 𝐶))
1917, 18mtbird 328 . . . . . . . . . 10 ((rank‘(𝐴𝐵)) = suc 𝐶 → ¬ Lim (rank‘(𝐴𝐵)))
20 rankxplim.1 . . . . . . . . . . 11 𝐴 ∈ V
21 rankxplim.2 . . . . . . . . . . 11 𝐵 ∈ V
2220, 21rankxplim2 9306 . . . . . . . . . 10 (Lim (rank‘(𝐴 × 𝐵)) → Lim (rank‘(𝐴𝐵)))
2319, 22nsyl 142 . . . . . . . . 9 ((rank‘(𝐴𝐵)) = suc 𝐶 → ¬ Lim (rank‘(𝐴 × 𝐵)))
2420, 21xpex 7470 . . . . . . . . . . . . . 14 (𝐴 × 𝐵) ∈ V
2524rankeq0 9287 . . . . . . . . . . . . 13 ((𝐴 × 𝐵) = ∅ ↔ (rank‘(𝐴 × 𝐵)) = ∅)
2625necon3abii 3060 . . . . . . . . . . . 12 ((𝐴 × 𝐵) ≠ ∅ ↔ ¬ (rank‘(𝐴 × 𝐵)) = ∅)
27 rankon 9221 . . . . . . . . . . . . . . . 16 (rank‘(𝐴 × 𝐵)) ∈ On
2827onordi 6282 . . . . . . . . . . . . . . 15 Ord (rank‘(𝐴 × 𝐵))
29 ordzsl 7554 . . . . . . . . . . . . . . 15 (Ord (rank‘(𝐴 × 𝐵)) ↔ ((rank‘(𝐴 × 𝐵)) = ∅ ∨ ∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥 ∨ Lim (rank‘(𝐴 × 𝐵))))
3028, 29mpbi 233 . . . . . . . . . . . . . 14 ((rank‘(𝐴 × 𝐵)) = ∅ ∨ ∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥 ∨ Lim (rank‘(𝐴 × 𝐵)))
31 3orass 1087 . . . . . . . . . . . . . 14 (((rank‘(𝐴 × 𝐵)) = ∅ ∨ ∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥 ∨ Lim (rank‘(𝐴 × 𝐵))) ↔ ((rank‘(𝐴 × 𝐵)) = ∅ ∨ (∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥 ∨ Lim (rank‘(𝐴 × 𝐵)))))
3230, 31mpbi 233 . . . . . . . . . . . . 13 ((rank‘(𝐴 × 𝐵)) = ∅ ∨ (∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥 ∨ Lim (rank‘(𝐴 × 𝐵))))
3332ori 858 . . . . . . . . . . . 12 (¬ (rank‘(𝐴 × 𝐵)) = ∅ → (∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥 ∨ Lim (rank‘(𝐴 × 𝐵))))
3426, 33sylbi 220 . . . . . . . . . . 11 ((𝐴 × 𝐵) ≠ ∅ → (∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥 ∨ Lim (rank‘(𝐴 × 𝐵))))
3534ord 861 . . . . . . . . . 10 ((𝐴 × 𝐵) ≠ ∅ → (¬ ∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥 → Lim (rank‘(𝐴 × 𝐵))))
3635con1d 147 . . . . . . . . 9 ((𝐴 × 𝐵) ≠ ∅ → (¬ Lim (rank‘(𝐴 × 𝐵)) → ∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥))
3723, 36syl5com 31 . . . . . . . 8 ((rank‘(𝐴𝐵)) = suc 𝐶 → ((𝐴 × 𝐵) ≠ ∅ → ∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥))
38 nlimsucg 7551 . . . . . . . . . . . 12 (𝑥 ∈ V → ¬ Lim suc 𝑥)
3938elv 3485 . . . . . . . . . . 11 ¬ Lim suc 𝑥
40 limeq 6190 . . . . . . . . . . 11 ((rank‘(𝐴 × 𝐵)) = suc 𝑥 → (Lim (rank‘(𝐴 × 𝐵)) ↔ Lim suc 𝑥))
4139, 40mtbiri 330 . . . . . . . . . 10 ((rank‘(𝐴 × 𝐵)) = suc 𝑥 → ¬ Lim (rank‘(𝐴 × 𝐵)))
4241rexlimivw 3274 . . . . . . . . 9 (∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥 → ¬ Lim (rank‘(𝐴 × 𝐵)))
4320, 21rankxplim3 9307 . . . . . . . . 9 (Lim (rank‘(𝐴 × 𝐵)) ↔ Lim (rank‘(𝐴 × 𝐵)))
4442, 43sylnib 331 . . . . . . . 8 (∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥 → ¬ Lim (rank‘(𝐴 × 𝐵)))
4537, 44syl6com 37 . . . . . . 7 ((𝐴 × 𝐵) ≠ ∅ → ((rank‘(𝐴𝐵)) = suc 𝐶 → ¬ Lim (rank‘(𝐴 × 𝐵))))
46 unixp0 6121 . . . . . . . . . . . 12 ((𝐴 × 𝐵) = ∅ ↔ (𝐴 × 𝐵) = ∅)
4724uniex 7461 . . . . . . . . . . . . 13 (𝐴 × 𝐵) ∈ V
4847rankeq0 9287 . . . . . . . . . . . 12 ( (𝐴 × 𝐵) = ∅ ↔ (rank‘ (𝐴 × 𝐵)) = ∅)
492eqeq1i 2829 . . . . . . . . . . . 12 ((rank‘ (𝐴 × 𝐵)) = ∅ ↔ (rank‘(𝐴 × 𝐵)) = ∅)
5046, 48, 493bitri 300 . . . . . . . . . . 11 ((𝐴 × 𝐵) = ∅ ↔ (rank‘(𝐴 × 𝐵)) = ∅)
5150necon3abii 3060 . . . . . . . . . 10 ((𝐴 × 𝐵) ≠ ∅ ↔ ¬ (rank‘(𝐴 × 𝐵)) = ∅)
52 onuni 7502 . . . . . . . . . . . . . . 15 ((rank‘(𝐴 × 𝐵)) ∈ On → (rank‘(𝐴 × 𝐵)) ∈ On)
5327, 52ax-mp 5 . . . . . . . . . . . . . 14 (rank‘(𝐴 × 𝐵)) ∈ On
5453onordi 6282 . . . . . . . . . . . . 13 Ord (rank‘(𝐴 × 𝐵))
55 ordzsl 7554 . . . . . . . . . . . . 13 (Ord (rank‘(𝐴 × 𝐵)) ↔ ( (rank‘(𝐴 × 𝐵)) = ∅ ∨ ∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥 ∨ Lim (rank‘(𝐴 × 𝐵))))
5654, 55mpbi 233 . . . . . . . . . . . 12 ( (rank‘(𝐴 × 𝐵)) = ∅ ∨ ∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥 ∨ Lim (rank‘(𝐴 × 𝐵)))
57 3orass 1087 . . . . . . . . . . . 12 (( (rank‘(𝐴 × 𝐵)) = ∅ ∨ ∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥 ∨ Lim (rank‘(𝐴 × 𝐵))) ↔ ( (rank‘(𝐴 × 𝐵)) = ∅ ∨ (∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥 ∨ Lim (rank‘(𝐴 × 𝐵)))))
5856, 57mpbi 233 . . . . . . . . . . 11 ( (rank‘(𝐴 × 𝐵)) = ∅ ∨ (∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥 ∨ Lim (rank‘(𝐴 × 𝐵))))
5958ori 858 . . . . . . . . . 10 (rank‘(𝐴 × 𝐵)) = ∅ → (∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥 ∨ Lim (rank‘(𝐴 × 𝐵))))
6051, 59sylbi 220 . . . . . . . . 9 ((𝐴 × 𝐵) ≠ ∅ → (∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥 ∨ Lim (rank‘(𝐴 × 𝐵))))
6160ord 861 . . . . . . . 8 ((𝐴 × 𝐵) ≠ ∅ → (¬ ∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥 → Lim (rank‘(𝐴 × 𝐵))))
6261con1d 147 . . . . . . 7 ((𝐴 × 𝐵) ≠ ∅ → (¬ Lim (rank‘(𝐴 × 𝐵)) → ∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥))
6345, 62syld 47 . . . . . 6 ((𝐴 × 𝐵) ≠ ∅ → ((rank‘(𝐴𝐵)) = suc 𝐶 → ∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥))
6463impcom 411 . . . . 5 (((rank‘(𝐴𝐵)) = suc 𝐶 ∧ (𝐴 × 𝐵) ≠ ∅) → ∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥)
65 onsucuni2 7543 . . . . . . 7 (( (rank‘(𝐴 × 𝐵)) ∈ On ∧ (rank‘(𝐴 × 𝐵)) = suc 𝑥) → suc (rank‘(𝐴 × 𝐵)) = (rank‘(𝐴 × 𝐵)))
6653, 65mpan 689 . . . . . 6 ( (rank‘(𝐴 × 𝐵)) = suc 𝑥 → suc (rank‘(𝐴 × 𝐵)) = (rank‘(𝐴 × 𝐵)))
6766rexlimivw 3274 . . . . 5 (∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥 → suc (rank‘(𝐴 × 𝐵)) = (rank‘(𝐴 × 𝐵)))
6864, 67syl 17 . . . 4 (((rank‘(𝐴𝐵)) = suc 𝐶 ∧ (𝐴 × 𝐵) ≠ ∅) → suc (rank‘(𝐴 × 𝐵)) = (rank‘(𝐴 × 𝐵)))
6910, 68eqtrd 2859 . . 3 (((rank‘(𝐴𝐵)) = suc 𝐶 ∧ (𝐴 × 𝐵) ≠ ∅) → suc (rank‘(𝐴𝐵)) = (rank‘(𝐴 × 𝐵)))
70 suc11reg 9079 . . 3 (suc suc (rank‘(𝐴𝐵)) = suc (rank‘(𝐴 × 𝐵)) ↔ suc (rank‘(𝐴𝐵)) = (rank‘(𝐴 × 𝐵)))
7169, 70sylibr 237 . 2 (((rank‘(𝐴𝐵)) = suc 𝐶 ∧ (𝐴 × 𝐵) ≠ ∅) → suc suc (rank‘(𝐴𝐵)) = suc (rank‘(𝐴 × 𝐵)))
7237imp 410 . . 3 (((rank‘(𝐴𝐵)) = suc 𝐶 ∧ (𝐴 × 𝐵) ≠ ∅) → ∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥)
73 onsucuni2 7543 . . . . 5 (((rank‘(𝐴 × 𝐵)) ∈ On ∧ (rank‘(𝐴 × 𝐵)) = suc 𝑥) → suc (rank‘(𝐴 × 𝐵)) = (rank‘(𝐴 × 𝐵)))
7427, 73mpan 689 . . . 4 ((rank‘(𝐴 × 𝐵)) = suc 𝑥 → suc (rank‘(𝐴 × 𝐵)) = (rank‘(𝐴 × 𝐵)))
7574rexlimivw 3274 . . 3 (∃𝑥 ∈ On (rank‘(𝐴 × 𝐵)) = suc 𝑥 → suc (rank‘(𝐴 × 𝐵)) = (rank‘(𝐴 × 𝐵)))
7672, 75syl 17 . 2 (((rank‘(𝐴𝐵)) = suc 𝐶 ∧ (𝐴 × 𝐵) ≠ ∅) → suc (rank‘(𝐴 × 𝐵)) = (rank‘(𝐴 × 𝐵)))
7771, 76eqtr2d 2860 1 (((rank‘(𝐴𝐵)) = suc 𝐶 ∧ (𝐴 × 𝐵) ≠ ∅) → (rank‘(𝐴 × 𝐵)) = suc suc (rank‘(𝐴𝐵)))
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wa 399  wo 844  w3o 1083   = wceq 1538  wcel 2115  wne 3014  wrex 3134  Vcvv 3480  cun 3917  c0 4276   cuni 4824   × cxp 5540  Ord word 6177  Oncon0 6178  Lim wlim 6179  suc csuc 6180  cfv 6343  rankcrnk 9189
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 1971  ax-7 2016  ax-8 2117  ax-9 2125  ax-10 2146  ax-11 2162  ax-12 2179  ax-ext 2796  ax-rep 5176  ax-sep 5189  ax-nul 5196  ax-pow 5253  ax-pr 5317  ax-un 7455  ax-reg 9053  ax-inf2 9101
This theorem depends on definitions:  df-bi 210  df-an 400  df-or 845  df-3or 1085  df-3an 1086  df-tru 1541  df-ex 1782  df-nf 1786  df-sb 2071  df-mo 2624  df-eu 2655  df-clab 2803  df-cleq 2817  df-clel 2896  df-nfc 2964  df-ne 3015  df-ral 3138  df-rex 3139  df-reu 3140  df-rab 3142  df-v 3482  df-sbc 3759  df-csb 3867  df-dif 3922  df-un 3924  df-in 3926  df-ss 3936  df-pss 3938  df-nul 4277  df-if 4451  df-pw 4524  df-sn 4551  df-pr 4553  df-tp 4555  df-op 4557  df-uni 4825  df-int 4863  df-iun 4907  df-br 5053  df-opab 5115  df-mpt 5133  df-tr 5159  df-id 5447  df-eprel 5452  df-po 5461  df-so 5462  df-fr 5501  df-we 5503  df-xp 5548  df-rel 5549  df-cnv 5550  df-co 5551  df-dm 5552  df-rn 5553  df-res 5554  df-ima 5555  df-pred 6135  df-ord 6181  df-on 6182  df-lim 6183  df-suc 6184  df-iota 6302  df-fun 6345  df-fn 6346  df-f 6347  df-f1 6348  df-fo 6349  df-f1o 6350  df-fv 6351  df-om 7575  df-wrecs 7943  df-recs 8004  df-rdg 8042  df-r1 9190  df-rank 9191
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator