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

Theorem scott0 9168
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 3431 . . 3 (𝐴 = ∅ → {𝑥𝐴 ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)} = {𝑥 ∈ ∅ ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)})
2 rab0 4263 . . 3 {𝑥 ∈ ∅ ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)} = ∅
31, 2syl6eq 2849 . 2 (𝐴 = ∅ → {𝑥𝐴 ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)} = ∅)
4 n0 4236 . . . . . . . 8 (𝐴 ≠ ∅ ↔ ∃𝑥 𝑥𝐴)
5 nfre1 3271 . . . . . . . . 9 𝑥𝑥𝐴 (rank‘𝑥) = (rank‘𝑥)
6 eqid 2797 . . . . . . . . . 10 (rank‘𝑥) = (rank‘𝑥)
7 rspe 3269 . . . . . . . . . 10 ((𝑥𝐴 ∧ (rank‘𝑥) = (rank‘𝑥)) → ∃𝑥𝐴 (rank‘𝑥) = (rank‘𝑥))
86, 7mpan2 687 . . . . . . . . 9 (𝑥𝐴 → ∃𝑥𝐴 (rank‘𝑥) = (rank‘𝑥))
95, 8exlimi 2184 . . . . . . . 8 (∃𝑥 𝑥𝐴 → ∃𝑥𝐴 (rank‘𝑥) = (rank‘𝑥))
104, 9sylbi 218 . . . . . . 7 (𝐴 ≠ ∅ → ∃𝑥𝐴 (rank‘𝑥) = (rank‘𝑥))
11 fvex 6558 . . . . . . . . . . 11 (rank‘𝑥) ∈ V
12 eqeq1 2801 . . . . . . . . . . . 12 (𝑦 = (rank‘𝑥) → (𝑦 = (rank‘𝑥) ↔ (rank‘𝑥) = (rank‘𝑥)))
1312anbi2d 628 . . . . . . . . . . 11 (𝑦 = (rank‘𝑥) → ((𝑥𝐴𝑦 = (rank‘𝑥)) ↔ (𝑥𝐴 ∧ (rank‘𝑥) = (rank‘𝑥))))
1411, 13spcev 3551 . . . . . . . . . 10 ((𝑥𝐴 ∧ (rank‘𝑥) = (rank‘𝑥)) → ∃𝑦(𝑥𝐴𝑦 = (rank‘𝑥)))
1514eximi 1820 . . . . . . . . 9 (∃𝑥(𝑥𝐴 ∧ (rank‘𝑥) = (rank‘𝑥)) → ∃𝑥𝑦(𝑥𝐴𝑦 = (rank‘𝑥)))
16 excom 2135 . . . . . . . . 9 (∃𝑦𝑥(𝑥𝐴𝑦 = (rank‘𝑥)) ↔ ∃𝑥𝑦(𝑥𝐴𝑦 = (rank‘𝑥)))
1715, 16sylibr 235 . . . . . . . 8 (∃𝑥(𝑥𝐴 ∧ (rank‘𝑥) = (rank‘𝑥)) → ∃𝑦𝑥(𝑥𝐴𝑦 = (rank‘𝑥)))
18 df-rex 3113 . . . . . . . 8 (∃𝑥𝐴 (rank‘𝑥) = (rank‘𝑥) ↔ ∃𝑥(𝑥𝐴 ∧ (rank‘𝑥) = (rank‘𝑥)))
19 df-rex 3113 . . . . . . . . 9 (∃𝑥𝐴 𝑦 = (rank‘𝑥) ↔ ∃𝑥(𝑥𝐴𝑦 = (rank‘𝑥)))
2019exbii 1833 . . . . . . . 8 (∃𝑦𝑥𝐴 𝑦 = (rank‘𝑥) ↔ ∃𝑦𝑥(𝑥𝐴𝑦 = (rank‘𝑥)))
2117, 18, 203imtr4i 293 . . . . . . 7 (∃𝑥𝐴 (rank‘𝑥) = (rank‘𝑥) → ∃𝑦𝑥𝐴 𝑦 = (rank‘𝑥))
2210, 21syl 17 . . . . . 6 (𝐴 ≠ ∅ → ∃𝑦𝑥𝐴 𝑦 = (rank‘𝑥))
23 abn0 4262 . . . . . 6 ({𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ≠ ∅ ↔ ∃𝑦𝑥𝐴 𝑦 = (rank‘𝑥))
2422, 23sylibr 235 . . . . 5 (𝐴 ≠ ∅ → {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ≠ ∅)
2511dfiin2 4868 . . . . . 6 𝑥𝐴 (rank‘𝑥) = {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)}
26 rankon 9077 . . . . . . . . . 10 (rank‘𝑥) ∈ On
27 eleq1 2872 . . . . . . . . . 10 (𝑦 = (rank‘𝑥) → (𝑦 ∈ On ↔ (rank‘𝑥) ∈ On))
2826, 27mpbiri 259 . . . . . . . . 9 (𝑦 = (rank‘𝑥) → 𝑦 ∈ On)
2928rexlimivw 3247 . . . . . . . 8 (∃𝑥𝐴 𝑦 = (rank‘𝑥) → 𝑦 ∈ On)
3029abssi 3973 . . . . . . 7 {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ⊆ On
31 onint 7373 . . . . . . 7 (({𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ⊆ On ∧ {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ≠ ∅) → {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ∈ {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)})
3230, 31mpan 686 . . . . . 6 ({𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ≠ ∅ → {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ∈ {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)})
3325, 32syl5eqel 2889 . . . . 5 ({𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ≠ ∅ → 𝑥𝐴 (rank‘𝑥) ∈ {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)})
34 nfii1 4863 . . . . . . . . 9 𝑥 𝑥𝐴 (rank‘𝑥)
3534nfeq2 2966 . . . . . . . 8 𝑥 𝑦 = 𝑥𝐴 (rank‘𝑥)
36 eqeq1 2801 . . . . . . . 8 (𝑦 = 𝑥𝐴 (rank‘𝑥) → (𝑦 = (rank‘𝑥) ↔ 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥)))
3735, 36rexbid 3283 . . . . . . 7 (𝑦 = 𝑥𝐴 (rank‘𝑥) → (∃𝑥𝐴 𝑦 = (rank‘𝑥) ↔ ∃𝑥𝐴 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥)))
3837elabg 3607 . . . . . 6 ( 𝑥𝐴 (rank‘𝑥) ∈ {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} → ( 𝑥𝐴 (rank‘𝑥) ∈ {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ↔ ∃𝑥𝐴 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥)))
3938ibi 268 . . . . 5 ( 𝑥𝐴 (rank‘𝑥) ∈ {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} → ∃𝑥𝐴 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥))
40 ssid 3916 . . . . . . . . . 10 (rank‘𝑦) ⊆ (rank‘𝑦)
41 fveq2 6545 . . . . . . . . . . . 12 (𝑥 = 𝑦 → (rank‘𝑥) = (rank‘𝑦))
4241sseq1d 3925 . . . . . . . . . . 11 (𝑥 = 𝑦 → ((rank‘𝑥) ⊆ (rank‘𝑦) ↔ (rank‘𝑦) ⊆ (rank‘𝑦)))
4342rspcev 3561 . . . . . . . . . 10 ((𝑦𝐴 ∧ (rank‘𝑦) ⊆ (rank‘𝑦)) → ∃𝑥𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
4440, 43mpan2 687 . . . . . . . . 9 (𝑦𝐴 → ∃𝑥𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
45 iinss 4885 . . . . . . . . 9 (∃𝑥𝐴 (rank‘𝑥) ⊆ (rank‘𝑦) → 𝑥𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
4644, 45syl 17 . . . . . . . 8 (𝑦𝐴 𝑥𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
47 sseq1 3919 . . . . . . . 8 ( 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥) → ( 𝑥𝐴 (rank‘𝑥) ⊆ (rank‘𝑦) ↔ (rank‘𝑥) ⊆ (rank‘𝑦)))
4846, 47syl5ib 245 . . . . . . 7 ( 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥) → (𝑦𝐴 → (rank‘𝑥) ⊆ (rank‘𝑦)))
4948ralrimiv 3150 . . . . . 6 ( 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥) → ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
5049reximi 3209 . . . . 5 (∃𝑥𝐴 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥) → ∃𝑥𝐴𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
5124, 33, 39, 504syl 19 . . . 4 (𝐴 ≠ ∅ → ∃𝑥𝐴𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
52 rabn0 4265 . . . 4 ({𝑥𝐴 ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)} ≠ ∅ ↔ ∃𝑥𝐴𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
5351, 52sylibr 235 . . 3 (𝐴 ≠ ∅ → {𝑥𝐴 ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)} ≠ ∅)
5453necon4i 3021 . 2 ({𝑥𝐴 ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)} = ∅ → 𝐴 = ∅)
553, 54impbii 210 1 (𝐴 = ∅ ↔ {𝑥𝐴 ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)} = ∅)
Colors of variables: wff setvar class
Syntax hints:  wb 207  wa 396   = wceq 1525  wex 1765  wcel 2083  {cab 2777  wne 2986  wral 3107  wrex 3108  {crab 3111  wss 3865  c0 4217   cint 4788   ciin 4832  Oncon0 6073  cfv 6232  rankcrnk 9045
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1781  ax-4 1795  ax-5 1892  ax-6 1951  ax-7 1996  ax-8 2085  ax-9 2093  ax-10 2114  ax-11 2128  ax-12 2143  ax-13 2346  ax-ext 2771  ax-sep 5101  ax-nul 5108  ax-pow 5164  ax-pr 5228  ax-un 7326
This theorem depends on definitions:  df-bi 208  df-an 397  df-or 843  df-3or 1081  df-3an 1082  df-tru 1528  df-ex 1766  df-nf 1770  df-sb 2045  df-mo 2578  df-eu 2614  df-clab 2778  df-cleq 2790  df-clel 2865  df-nfc 2937  df-ne 2987  df-ral 3112  df-rex 3113  df-reu 3114  df-rab 3116  df-v 3442  df-sbc 3712  df-csb 3818  df-dif 3868  df-un 3870  df-in 3872  df-ss 3880  df-pss 3882  df-nul 4218  df-if 4388  df-pw 4461  df-sn 4479  df-pr 4481  df-tp 4483  df-op 4485  df-uni 4752  df-int 4789  df-iun 4833  df-iin 4834  df-br 4969  df-opab 5031  df-mpt 5048  df-tr 5071  df-id 5355  df-eprel 5360  df-po 5369  df-so 5370  df-fr 5409  df-we 5411  df-xp 5456  df-rel 5457  df-cnv 5458  df-co 5459  df-dm 5460  df-rn 5461  df-res 5462  df-ima 5463  df-pred 6030  df-ord 6076  df-on 6077  df-lim 6078  df-suc 6079  df-iota 6196  df-fun 6234  df-fn 6235  df-f 6236  df-f1 6237  df-fo 6238  df-f1o 6239  df-fv 6240  df-om 7444  df-wrecs 7805  df-recs 7867  df-rdg 7905  df-r1 9046  df-rank 9047
This theorem is referenced by:  scott0s  9170  cplem1  9171  karden  9177  scott0f  35000  scotteld  40100
  Copyright terms: Public domain W3C validator