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

Theorem rankunb 9763
Description: The rank of the union of two sets. Theorem 15.17(iii) of [Monk1] p. 112. (Contributed by Mario Carneiro, 10-Jun-2013.) (Revised by Mario Carneiro, 17-Nov-2014.)
Assertion
Ref Expression
rankunb ((𝐴 (𝑅1 “ On) ∧ 𝐵 (𝑅1 “ On)) → (rank‘(𝐴𝐵)) = ((rank‘𝐴) ∪ (rank‘𝐵)))

Proof of Theorem rankunb
Dummy variables 𝑥 𝑦 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 unwf 9723 . . . . . . 7 ((𝐴 (𝑅1 “ On) ∧ 𝐵 (𝑅1 “ On)) ↔ (𝐴𝐵) ∈ (𝑅1 “ On))
2 rankval3b 9739 . . . . . . 7 ((𝐴𝐵) ∈ (𝑅1 “ On) → (rank‘(𝐴𝐵)) = {𝑦 ∈ On ∣ ∀𝑥 ∈ (𝐴𝐵)(rank‘𝑥) ∈ 𝑦})
31, 2sylbi 217 . . . . . 6 ((𝐴 (𝑅1 “ On) ∧ 𝐵 (𝑅1 “ On)) → (rank‘(𝐴𝐵)) = {𝑦 ∈ On ∣ ∀𝑥 ∈ (𝐴𝐵)(rank‘𝑥) ∈ 𝑦})
43eleq2d 2823 . . . . 5 ((𝐴 (𝑅1 “ On) ∧ 𝐵 (𝑅1 “ On)) → (𝑥 ∈ (rank‘(𝐴𝐵)) ↔ 𝑥 {𝑦 ∈ On ∣ ∀𝑥 ∈ (𝐴𝐵)(rank‘𝑥) ∈ 𝑦}))
5 vex 3434 . . . . . 6 𝑥 ∈ V
65elintrab 4903 . . . . 5 (𝑥 {𝑦 ∈ On ∣ ∀𝑥 ∈ (𝐴𝐵)(rank‘𝑥) ∈ 𝑦} ↔ ∀𝑦 ∈ On (∀𝑥 ∈ (𝐴𝐵)(rank‘𝑥) ∈ 𝑦𝑥𝑦))
74, 6bitrdi 287 . . . 4 ((𝐴 (𝑅1 “ On) ∧ 𝐵 (𝑅1 “ On)) → (𝑥 ∈ (rank‘(𝐴𝐵)) ↔ ∀𝑦 ∈ On (∀𝑥 ∈ (𝐴𝐵)(rank‘𝑥) ∈ 𝑦𝑥𝑦)))
8 elun 4094 . . . . . . 7 (𝑥 ∈ (𝐴𝐵) ↔ (𝑥𝐴𝑥𝐵))
9 rankelb 9737 . . . . . . . . 9 (𝐴 (𝑅1 “ On) → (𝑥𝐴 → (rank‘𝑥) ∈ (rank‘𝐴)))
10 elun1 4123 . . . . . . . . 9 ((rank‘𝑥) ∈ (rank‘𝐴) → (rank‘𝑥) ∈ ((rank‘𝐴) ∪ (rank‘𝐵)))
119, 10syl6 35 . . . . . . . 8 (𝐴 (𝑅1 “ On) → (𝑥𝐴 → (rank‘𝑥) ∈ ((rank‘𝐴) ∪ (rank‘𝐵))))
12 rankelb 9737 . . . . . . . . 9 (𝐵 (𝑅1 “ On) → (𝑥𝐵 → (rank‘𝑥) ∈ (rank‘𝐵)))
13 elun2 4124 . . . . . . . . 9 ((rank‘𝑥) ∈ (rank‘𝐵) → (rank‘𝑥) ∈ ((rank‘𝐴) ∪ (rank‘𝐵)))
1412, 13syl6 35 . . . . . . . 8 (𝐵 (𝑅1 “ On) → (𝑥𝐵 → (rank‘𝑥) ∈ ((rank‘𝐴) ∪ (rank‘𝐵))))
1511, 14jaao 957 . . . . . . 7 ((𝐴 (𝑅1 “ On) ∧ 𝐵 (𝑅1 “ On)) → ((𝑥𝐴𝑥𝐵) → (rank‘𝑥) ∈ ((rank‘𝐴) ∪ (rank‘𝐵))))
168, 15biimtrid 242 . . . . . 6 ((𝐴 (𝑅1 “ On) ∧ 𝐵 (𝑅1 “ On)) → (𝑥 ∈ (𝐴𝐵) → (rank‘𝑥) ∈ ((rank‘𝐴) ∪ (rank‘𝐵))))
1716ralrimiv 3129 . . . . 5 ((𝐴 (𝑅1 “ On) ∧ 𝐵 (𝑅1 “ On)) → ∀𝑥 ∈ (𝐴𝐵)(rank‘𝑥) ∈ ((rank‘𝐴) ∪ (rank‘𝐵)))
18 rankon 9708 . . . . . . 7 (rank‘𝐴) ∈ On
19 rankon 9708 . . . . . . 7 (rank‘𝐵) ∈ On
2018, 19onun2i 6438 . . . . . 6 ((rank‘𝐴) ∪ (rank‘𝐵)) ∈ On
21 eleq2 2826 . . . . . . . . 9 (𝑦 = ((rank‘𝐴) ∪ (rank‘𝐵)) → ((rank‘𝑥) ∈ 𝑦 ↔ (rank‘𝑥) ∈ ((rank‘𝐴) ∪ (rank‘𝐵))))
2221ralbidv 3161 . . . . . . . 8 (𝑦 = ((rank‘𝐴) ∪ (rank‘𝐵)) → (∀𝑥 ∈ (𝐴𝐵)(rank‘𝑥) ∈ 𝑦 ↔ ∀𝑥 ∈ (𝐴𝐵)(rank‘𝑥) ∈ ((rank‘𝐴) ∪ (rank‘𝐵))))
23 eleq2 2826 . . . . . . . 8 (𝑦 = ((rank‘𝐴) ∪ (rank‘𝐵)) → (𝑥𝑦𝑥 ∈ ((rank‘𝐴) ∪ (rank‘𝐵))))
2422, 23imbi12d 344 . . . . . . 7 (𝑦 = ((rank‘𝐴) ∪ (rank‘𝐵)) → ((∀𝑥 ∈ (𝐴𝐵)(rank‘𝑥) ∈ 𝑦𝑥𝑦) ↔ (∀𝑥 ∈ (𝐴𝐵)(rank‘𝑥) ∈ ((rank‘𝐴) ∪ (rank‘𝐵)) → 𝑥 ∈ ((rank‘𝐴) ∪ (rank‘𝐵)))))
2524rspcv 3561 . . . . . 6 (((rank‘𝐴) ∪ (rank‘𝐵)) ∈ On → (∀𝑦 ∈ On (∀𝑥 ∈ (𝐴𝐵)(rank‘𝑥) ∈ 𝑦𝑥𝑦) → (∀𝑥 ∈ (𝐴𝐵)(rank‘𝑥) ∈ ((rank‘𝐴) ∪ (rank‘𝐵)) → 𝑥 ∈ ((rank‘𝐴) ∪ (rank‘𝐵)))))
2620, 25ax-mp 5 . . . . 5 (∀𝑦 ∈ On (∀𝑥 ∈ (𝐴𝐵)(rank‘𝑥) ∈ 𝑦𝑥𝑦) → (∀𝑥 ∈ (𝐴𝐵)(rank‘𝑥) ∈ ((rank‘𝐴) ∪ (rank‘𝐵)) → 𝑥 ∈ ((rank‘𝐴) ∪ (rank‘𝐵))))
2717, 26syl5com 31 . . . 4 ((𝐴 (𝑅1 “ On) ∧ 𝐵 (𝑅1 “ On)) → (∀𝑦 ∈ On (∀𝑥 ∈ (𝐴𝐵)(rank‘𝑥) ∈ 𝑦𝑥𝑦) → 𝑥 ∈ ((rank‘𝐴) ∪ (rank‘𝐵))))
287, 27sylbid 240 . . 3 ((𝐴 (𝑅1 “ On) ∧ 𝐵 (𝑅1 “ On)) → (𝑥 ∈ (rank‘(𝐴𝐵)) → 𝑥 ∈ ((rank‘𝐴) ∪ (rank‘𝐵))))
2928ssrdv 3928 . 2 ((𝐴 (𝑅1 “ On) ∧ 𝐵 (𝑅1 “ On)) → (rank‘(𝐴𝐵)) ⊆ ((rank‘𝐴) ∪ (rank‘𝐵)))
30 ssun1 4119 . . . . 5 𝐴 ⊆ (𝐴𝐵)
31 rankssb 9761 . . . . 5 ((𝐴𝐵) ∈ (𝑅1 “ On) → (𝐴 ⊆ (𝐴𝐵) → (rank‘𝐴) ⊆ (rank‘(𝐴𝐵))))
3230, 31mpi 20 . . . 4 ((𝐴𝐵) ∈ (𝑅1 “ On) → (rank‘𝐴) ⊆ (rank‘(𝐴𝐵)))
33 ssun2 4120 . . . . 5 𝐵 ⊆ (𝐴𝐵)
34 rankssb 9761 . . . . 5 ((𝐴𝐵) ∈ (𝑅1 “ On) → (𝐵 ⊆ (𝐴𝐵) → (rank‘𝐵) ⊆ (rank‘(𝐴𝐵))))
3533, 34mpi 20 . . . 4 ((𝐴𝐵) ∈ (𝑅1 “ On) → (rank‘𝐵) ⊆ (rank‘(𝐴𝐵)))
3632, 35unssd 4133 . . 3 ((𝐴𝐵) ∈ (𝑅1 “ On) → ((rank‘𝐴) ∪ (rank‘𝐵)) ⊆ (rank‘(𝐴𝐵)))
371, 36sylbi 217 . 2 ((𝐴 (𝑅1 “ On) ∧ 𝐵 (𝑅1 “ On)) → ((rank‘𝐴) ∪ (rank‘𝐵)) ⊆ (rank‘(𝐴𝐵)))
3829, 37eqssd 3940 1 ((𝐴 (𝑅1 “ On) ∧ 𝐵 (𝑅1 “ On)) → (rank‘(𝐴𝐵)) = ((rank‘𝐴) ∪ (rank‘𝐵)))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wa 395  wo 848   = wceq 1542  wcel 2114  wral 3052  {crab 3390  cun 3888  wss 3890   cuni 4851   cint 4890  cima 5625  Oncon0 6315  cfv 6490  𝑅1cr1 9675  rankcrnk 9676
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 5231  ax-nul 5241  ax-pow 5300  ax-pr 5368  ax-un 7680
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-nfc 2886  df-ne 2934  df-ral 3053  df-rex 3063  df-reu 3344  df-rab 3391  df-v 3432  df-sbc 3730  df-csb 3839  df-dif 3893  df-un 3895  df-in 3897  df-ss 3907  df-pss 3910  df-nul 4275  df-if 4468  df-pw 4544  df-sn 4569  df-pr 4571  df-op 4575  df-uni 4852  df-int 4891  df-iun 4936  df-br 5087  df-opab 5149  df-mpt 5168  df-tr 5194  df-id 5517  df-eprel 5522  df-po 5530  df-so 5531  df-fr 5575  df-we 5577  df-xp 5628  df-rel 5629  df-cnv 5630  df-co 5631  df-dm 5632  df-rn 5633  df-res 5634  df-ima 5635  df-pred 6257  df-ord 6318  df-on 6319  df-lim 6320  df-suc 6321  df-iota 6446  df-fun 6492  df-fn 6493  df-f 6494  df-f1 6495  df-fo 6496  df-f1o 6497  df-fv 6498  df-ov 7361  df-om 7809  df-2nd 7934  df-frecs 8222  df-wrecs 8253  df-recs 8302  df-rdg 8340  df-r1 9677  df-rank 9678
This theorem is referenced by:  rankprb  9764  rankopb  9765  rankun  9769  rankaltopb  36167
  Copyright terms: Public domain W3C validator