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

Theorem scott0 9841
Description: Scott's trick collects all sets that have a certain property and are of the smallest possible rank. This theorem shows that the resulting collection, expressed as in Equation 9.3 of [Jech] p. 72, contains at least one representative with the property, if there is one. In other words, the collection is empty iff no set has the property (i.e. 𝐴 is empty). (Contributed by NM, 15-Oct-2003.)
Assertion
Ref Expression
scott0 (𝐴 = ∅ ↔ {𝑥𝐴 ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)} = ∅)
Distinct variable group:   𝑥,𝑦,𝐴

Proof of Theorem scott0
StepHypRef Expression
1 rabeq 3427 . . 3 (𝐴 = ∅ → {𝑥𝐴 ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)} = {𝑥 ∈ ∅ ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)})
2 rab0 4338 . . 3 {𝑥 ∈ ∅ ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)} = ∅
31, 2eqtrdi 2812 . 2 (𝐴 = ∅ → {𝑥𝐴 ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)} = ∅)
4 n0 4305 . . . . . . . 8 (𝐴 ≠ ∅ ↔ ∃𝑥 𝑥𝐴)
5 nfre1 3286 . . . . . . . . 9 𝑥𝑥𝐴 (rank‘𝑥) = (rank‘𝑥)
6 eqid 2761 . . . . . . . . . 10 (rank‘𝑥) = (rank‘𝑥)
7 rspe 3251 . . . . . . . . . 10 ((𝑥𝐴 ∧ (rank‘𝑥) = (rank‘𝑥)) → ∃𝑥𝐴 (rank‘𝑥) = (rank‘𝑥))
86, 7mpan2 701 . . . . . . . . 9 (𝑥𝐴 → ∃𝑥𝐴 (rank‘𝑥) = (rank‘𝑥))
95, 8exlimi 2251 . . . . . . . 8 (∃𝑥 𝑥𝐴 → ∃𝑥𝐴 (rank‘𝑥) = (rank‘𝑥))
104, 9sylbi 219 . . . . . . 7 (𝐴 ≠ ∅ → ∃𝑥𝐴 (rank‘𝑥) = (rank‘𝑥))
11 fvex 6876 . . . . . . . . . . 11 (rank‘𝑥) ∈ V
12 eqeq1 2765 . . . . . . . . . . . 12 (𝑦 = (rank‘𝑥) → (𝑦 = (rank‘𝑥) ↔ (rank‘𝑥) = (rank‘𝑥)))
1312anbi2d 639 . . . . . . . . . . 11 (𝑦 = (rank‘𝑥) → ((𝑥𝐴𝑦 = (rank‘𝑥)) ↔ (𝑥𝐴 ∧ (rank‘𝑥) = (rank‘𝑥))))
1411, 13spcev 3565 . . . . . . . . . 10 ((𝑥𝐴 ∧ (rank‘𝑥) = (rank‘𝑥)) → ∃𝑦(𝑥𝐴𝑦 = (rank‘𝑥)))
1514eximi 1854 . . . . . . . . 9 (∃𝑥(𝑥𝐴 ∧ (rank‘𝑥) = (rank‘𝑥)) → ∃𝑥𝑦(𝑥𝐴𝑦 = (rank‘𝑥)))
16 excom 2195 . . . . . . . . 9 (∃𝑦𝑥(𝑥𝐴𝑦 = (rank‘𝑥)) ↔ ∃𝑥𝑦(𝑥𝐴𝑦 = (rank‘𝑥)))
1715, 16sylibr 236 . . . . . . . 8 (∃𝑥(𝑥𝐴 ∧ (rank‘𝑥) = (rank‘𝑥)) → ∃𝑦𝑥(𝑥𝐴𝑦 = (rank‘𝑥)))
18 df-rex 3086 . . . . . . . 8 (∃𝑥𝐴 (rank‘𝑥) = (rank‘𝑥) ↔ ∃𝑥(𝑥𝐴 ∧ (rank‘𝑥) = (rank‘𝑥)))
19 df-rex 3086 . . . . . . . . 9 (∃𝑥𝐴 𝑦 = (rank‘𝑥) ↔ ∃𝑥(𝑥𝐴𝑦 = (rank‘𝑥)))
2019exbii 1867 . . . . . . . 8 (∃𝑦𝑥𝐴 𝑦 = (rank‘𝑥) ↔ ∃𝑦𝑥(𝑥𝐴𝑦 = (rank‘𝑥)))
2117, 18, 203imtr4i 294 . . . . . . 7 (∃𝑥𝐴 (rank‘𝑥) = (rank‘𝑥) → ∃𝑦𝑥𝐴 𝑦 = (rank‘𝑥))
2210, 21syl 17 . . . . . 6 (𝐴 ≠ ∅ → ∃𝑦𝑥𝐴 𝑦 = (rank‘𝑥))
23 abn0 4337 . . . . . 6 ({𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ≠ ∅ ↔ ∃𝑦𝑥𝐴 𝑦 = (rank‘𝑥))
2422, 23sylibr 236 . . . . 5 (𝐴 ≠ ∅ → {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ≠ ∅)
2511dfiin2 4989 . . . . . 6 𝑥𝐴 (rank‘𝑥) = {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)}
26 rankon 9750 . . . . . . . . . 10 (rank‘𝑥) ∈ On
27 eleq1 2849 . . . . . . . . . 10 (𝑦 = (rank‘𝑥) → (𝑦 ∈ On ↔ (rank‘𝑥) ∈ On))
2826, 27mpbiri 260 . . . . . . . . 9 (𝑦 = (rank‘𝑥) → 𝑦 ∈ On)
2928rexlimivw 3158 . . . . . . . 8 (∃𝑥𝐴 𝑦 = (rank‘𝑥) → 𝑦 ∈ On)
3029abssi 4021 . . . . . . 7 {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ⊆ On
31 onint 7769 . . . . . . 7 (({𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ⊆ On ∧ {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ≠ ∅) → {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ∈ {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)})
3230, 31mpan 700 . . . . . 6 ({𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ≠ ∅ → {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ∈ {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)})
3325, 32eqeltrid 2865 . . . . 5 ({𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ≠ ∅ → 𝑥𝐴 (rank‘𝑥) ∈ {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)})
34 nfii1 4985 . . . . . . . . 9 𝑥 𝑥𝐴 (rank‘𝑥)
3534nfeq2 2940 . . . . . . . 8 𝑥 𝑦 = 𝑥𝐴 (rank‘𝑥)
36 eqeq1 2765 . . . . . . . 8 (𝑦 = 𝑥𝐴 (rank‘𝑥) → (𝑦 = (rank‘𝑥) ↔ 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥)))
3735, 36rexbid 3275 . . . . . . 7 (𝑦 = 𝑥𝐴 (rank‘𝑥) → (∃𝑥𝐴 𝑦 = (rank‘𝑥) ↔ ∃𝑥𝐴 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥)))
3837elabg 3635 . . . . . 6 ( 𝑥𝐴 (rank‘𝑥) ∈ {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} → ( 𝑥𝐴 (rank‘𝑥) ∈ {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ↔ ∃𝑥𝐴 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥)))
3938ibi 269 . . . . 5 ( 𝑥𝐴 (rank‘𝑥) ∈ {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} → ∃𝑥𝐴 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥))
40 ssid 3958 . . . . . . . . . 10 (rank‘𝑦) ⊆ (rank‘𝑦)
41 fveq2 6863 . . . . . . . . . . . 12 (𝑥 = 𝑦 → (rank‘𝑥) = (rank‘𝑦))
4241sseq1d 3967 . . . . . . . . . . 11 (𝑥 = 𝑦 → ((rank‘𝑥) ⊆ (rank‘𝑦) ↔ (rank‘𝑦) ⊆ (rank‘𝑦)))
4342rspcev 3581 . . . . . . . . . 10 ((𝑦𝐴 ∧ (rank‘𝑦) ⊆ (rank‘𝑦)) → ∃𝑥𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
4440, 43mpan2 701 . . . . . . . . 9 (𝑦𝐴 → ∃𝑥𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
45 iinss 5013 . . . . . . . . 9 (∃𝑥𝐴 (rank‘𝑥) ⊆ (rank‘𝑦) → 𝑥𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
4644, 45syl 17 . . . . . . . 8 (𝑦𝐴 𝑥𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
47 sseq1 3961 . . . . . . . 8 ( 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥) → ( 𝑥𝐴 (rank‘𝑥) ⊆ (rank‘𝑦) ↔ (rank‘𝑥) ⊆ (rank‘𝑦)))
4846, 47imbitrid 246 . . . . . . 7 ( 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥) → (𝑦𝐴 → (rank‘𝑥) ⊆ (rank‘𝑦)))
4948ralrimiv 3152 . . . . . 6 ( 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥) → ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
5049reximi 3099 . . . . 5 (∃𝑥𝐴 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥) → ∃𝑥𝐴𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
5124, 33, 39, 504syl 19 . . . 4 (𝐴 ≠ ∅ → ∃𝑥𝐴𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
52 rabn0 4342 . . . 4 ({𝑥𝐴 ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)} ≠ ∅ ↔ ∃𝑥𝐴𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
5351, 52sylibr 236 . . 3 (𝐴 ≠ ∅ → {𝑥𝐴 ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)} ≠ ∅)
5453necon4i 2991 . 2 ({𝑥𝐴 ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)} = ∅ → 𝐴 = ∅)
553, 54impbii 211 1 (𝐴 = ∅ ↔ {𝑥𝐴 ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)} = ∅)
Colors of variables: wff setvar class
Syntax hints:  wb 208  wa 399   = wceq 1559  wex 1798  wcel 2141  {cab 2739  wne 2956  wral 3075  wrex 3085  {crab 3413  wss 3904  c0 4285   cint 4904   ciin 4949  Oncon0 6342  cfv 6517  rankcrnk 9718
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-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-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-op 4588  df-uni 4865  df-int 4905  df-iun 4950  df-iin 4951  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-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-lim 6347  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-ov 7395  df-om 7843  df-2nd 7967  df-frecs 8257  df-wrecs 8288  df-recs 8337  df-rdg 8376  df-r1 9719  df-rank 9720
This theorem is referenced by:  scott0s  9843  cplem1  9844  karden  9850  scott0f  38632  scotteld  44786
  Copyright terms: Public domain W3C validator