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

Theorem scott0 9502
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 3394 . . 3 (𝐴 = ∅ → {𝑥𝐴 ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)} = {𝑥 ∈ ∅ ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)})
2 rab0 4297 . . 3 {𝑥 ∈ ∅ ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)} = ∅
31, 2eqtrdi 2794 . 2 (𝐴 = ∅ → {𝑥𝐴 ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)} = ∅)
4 n0 4261 . . . . . . . 8 (𝐴 ≠ ∅ ↔ ∃𝑥 𝑥𝐴)
5 nfre1 3225 . . . . . . . . 9 𝑥𝑥𝐴 (rank‘𝑥) = (rank‘𝑥)
6 eqid 2737 . . . . . . . . . 10 (rank‘𝑥) = (rank‘𝑥)
7 rspe 3223 . . . . . . . . . 10 ((𝑥𝐴 ∧ (rank‘𝑥) = (rank‘𝑥)) → ∃𝑥𝐴 (rank‘𝑥) = (rank‘𝑥))
86, 7mpan2 691 . . . . . . . . 9 (𝑥𝐴 → ∃𝑥𝐴 (rank‘𝑥) = (rank‘𝑥))
95, 8exlimi 2215 . . . . . . . 8 (∃𝑥 𝑥𝐴 → ∃𝑥𝐴 (rank‘𝑥) = (rank‘𝑥))
104, 9sylbi 220 . . . . . . 7 (𝐴 ≠ ∅ → ∃𝑥𝐴 (rank‘𝑥) = (rank‘𝑥))
11 fvex 6730 . . . . . . . . . . 11 (rank‘𝑥) ∈ V
12 eqeq1 2741 . . . . . . . . . . . 12 (𝑦 = (rank‘𝑥) → (𝑦 = (rank‘𝑥) ↔ (rank‘𝑥) = (rank‘𝑥)))
1312anbi2d 632 . . . . . . . . . . 11 (𝑦 = (rank‘𝑥) → ((𝑥𝐴𝑦 = (rank‘𝑥)) ↔ (𝑥𝐴 ∧ (rank‘𝑥) = (rank‘𝑥))))
1411, 13spcev 3521 . . . . . . . . . 10 ((𝑥𝐴 ∧ (rank‘𝑥) = (rank‘𝑥)) → ∃𝑦(𝑥𝐴𝑦 = (rank‘𝑥)))
1514eximi 1842 . . . . . . . . 9 (∃𝑥(𝑥𝐴 ∧ (rank‘𝑥) = (rank‘𝑥)) → ∃𝑥𝑦(𝑥𝐴𝑦 = (rank‘𝑥)))
16 excom 2166 . . . . . . . . 9 (∃𝑦𝑥(𝑥𝐴𝑦 = (rank‘𝑥)) ↔ ∃𝑥𝑦(𝑥𝐴𝑦 = (rank‘𝑥)))
1715, 16sylibr 237 . . . . . . . 8 (∃𝑥(𝑥𝐴 ∧ (rank‘𝑥) = (rank‘𝑥)) → ∃𝑦𝑥(𝑥𝐴𝑦 = (rank‘𝑥)))
18 df-rex 3067 . . . . . . . 8 (∃𝑥𝐴 (rank‘𝑥) = (rank‘𝑥) ↔ ∃𝑥(𝑥𝐴 ∧ (rank‘𝑥) = (rank‘𝑥)))
19 df-rex 3067 . . . . . . . . 9 (∃𝑥𝐴 𝑦 = (rank‘𝑥) ↔ ∃𝑥(𝑥𝐴𝑦 = (rank‘𝑥)))
2019exbii 1855 . . . . . . . 8 (∃𝑦𝑥𝐴 𝑦 = (rank‘𝑥) ↔ ∃𝑦𝑥(𝑥𝐴𝑦 = (rank‘𝑥)))
2117, 18, 203imtr4i 295 . . . . . . 7 (∃𝑥𝐴 (rank‘𝑥) = (rank‘𝑥) → ∃𝑦𝑥𝐴 𝑦 = (rank‘𝑥))
2210, 21syl 17 . . . . . 6 (𝐴 ≠ ∅ → ∃𝑦𝑥𝐴 𝑦 = (rank‘𝑥))
23 abn0 4295 . . . . . 6 ({𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ≠ ∅ ↔ ∃𝑦𝑥𝐴 𝑦 = (rank‘𝑥))
2422, 23sylibr 237 . . . . 5 (𝐴 ≠ ∅ → {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ≠ ∅)
2511dfiin2 4943 . . . . . 6 𝑥𝐴 (rank‘𝑥) = {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)}
26 rankon 9411 . . . . . . . . . 10 (rank‘𝑥) ∈ On
27 eleq1 2825 . . . . . . . . . 10 (𝑦 = (rank‘𝑥) → (𝑦 ∈ On ↔ (rank‘𝑥) ∈ On))
2826, 27mpbiri 261 . . . . . . . . 9 (𝑦 = (rank‘𝑥) → 𝑦 ∈ On)
2928rexlimivw 3201 . . . . . . . 8 (∃𝑥𝐴 𝑦 = (rank‘𝑥) → 𝑦 ∈ On)
3029abssi 3983 . . . . . . 7 {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ⊆ On
31 onint 7574 . . . . . . 7 (({𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ⊆ On ∧ {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ≠ ∅) → {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ∈ {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)})
3230, 31mpan 690 . . . . . 6 ({𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ≠ ∅ → {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ∈ {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)})
3325, 32eqeltrid 2842 . . . . 5 ({𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ≠ ∅ → 𝑥𝐴 (rank‘𝑥) ∈ {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)})
34 nfii1 4939 . . . . . . . . 9 𝑥 𝑥𝐴 (rank‘𝑥)
3534nfeq2 2921 . . . . . . . 8 𝑥 𝑦 = 𝑥𝐴 (rank‘𝑥)
36 eqeq1 2741 . . . . . . . 8 (𝑦 = 𝑥𝐴 (rank‘𝑥) → (𝑦 = (rank‘𝑥) ↔ 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥)))
3735, 36rexbid 3239 . . . . . . 7 (𝑦 = 𝑥𝐴 (rank‘𝑥) → (∃𝑥𝐴 𝑦 = (rank‘𝑥) ↔ ∃𝑥𝐴 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥)))
3837elabg 3585 . . . . . 6 ( 𝑥𝐴 (rank‘𝑥) ∈ {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} → ( 𝑥𝐴 (rank‘𝑥) ∈ {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} ↔ ∃𝑥𝐴 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥)))
3938ibi 270 . . . . 5 ( 𝑥𝐴 (rank‘𝑥) ∈ {𝑦 ∣ ∃𝑥𝐴 𝑦 = (rank‘𝑥)} → ∃𝑥𝐴 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥))
40 ssid 3923 . . . . . . . . . 10 (rank‘𝑦) ⊆ (rank‘𝑦)
41 fveq2 6717 . . . . . . . . . . . 12 (𝑥 = 𝑦 → (rank‘𝑥) = (rank‘𝑦))
4241sseq1d 3932 . . . . . . . . . . 11 (𝑥 = 𝑦 → ((rank‘𝑥) ⊆ (rank‘𝑦) ↔ (rank‘𝑦) ⊆ (rank‘𝑦)))
4342rspcev 3537 . . . . . . . . . 10 ((𝑦𝐴 ∧ (rank‘𝑦) ⊆ (rank‘𝑦)) → ∃𝑥𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
4440, 43mpan2 691 . . . . . . . . 9 (𝑦𝐴 → ∃𝑥𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
45 iinss 4965 . . . . . . . . 9 (∃𝑥𝐴 (rank‘𝑥) ⊆ (rank‘𝑦) → 𝑥𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
4644, 45syl 17 . . . . . . . 8 (𝑦𝐴 𝑥𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
47 sseq1 3926 . . . . . . . 8 ( 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥) → ( 𝑥𝐴 (rank‘𝑥) ⊆ (rank‘𝑦) ↔ (rank‘𝑥) ⊆ (rank‘𝑦)))
4846, 47syl5ib 247 . . . . . . 7 ( 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥) → (𝑦𝐴 → (rank‘𝑥) ⊆ (rank‘𝑦)))
4948ralrimiv 3104 . . . . . 6 ( 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥) → ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
5049reximi 3166 . . . . 5 (∃𝑥𝐴 𝑥𝐴 (rank‘𝑥) = (rank‘𝑥) → ∃𝑥𝐴𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
5124, 33, 39, 504syl 19 . . . 4 (𝐴 ≠ ∅ → ∃𝑥𝐴𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
52 rabn0 4300 . . . 4 ({𝑥𝐴 ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)} ≠ ∅ ↔ ∃𝑥𝐴𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦))
5351, 52sylibr 237 . . 3 (𝐴 ≠ ∅ → {𝑥𝐴 ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)} ≠ ∅)
5453necon4i 2976 . 2 ({𝑥𝐴 ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)} = ∅ → 𝐴 = ∅)
553, 54impbii 212 1 (𝐴 = ∅ ↔ {𝑥𝐴 ∣ ∀𝑦𝐴 (rank‘𝑥) ⊆ (rank‘𝑦)} = ∅)
Colors of variables: wff setvar class
Syntax hints:  wb 209  wa 399   = wceq 1543  wex 1787  wcel 2110  {cab 2714  wne 2940  wral 3061  wrex 3062  {crab 3065  wss 3866  c0 4237   cint 4859   ciin 4905  Oncon0 6213  cfv 6380  rankcrnk 9379
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1803  ax-4 1817  ax-5 1918  ax-6 1976  ax-7 2016  ax-8 2112  ax-9 2120  ax-10 2141  ax-11 2158  ax-12 2175  ax-ext 2708  ax-sep 5192  ax-nul 5199  ax-pow 5258  ax-pr 5322  ax-un 7523
This theorem depends on definitions:  df-bi 210  df-an 400  df-or 848  df-3or 1090  df-3an 1091  df-tru 1546  df-fal 1556  df-ex 1788  df-nf 1792  df-sb 2071  df-mo 2539  df-eu 2568  df-clab 2715  df-cleq 2729  df-clel 2816  df-nfc 2886  df-ne 2941  df-ral 3066  df-rex 3067  df-reu 3068  df-rab 3070  df-v 3410  df-sbc 3695  df-csb 3812  df-dif 3869  df-un 3871  df-in 3873  df-ss 3883  df-pss 3885  df-nul 4238  df-if 4440  df-pw 4515  df-sn 4542  df-pr 4544  df-tp 4546  df-op 4548  df-uni 4820  df-int 4860  df-iun 4906  df-iin 4907  df-br 5054  df-opab 5116  df-mpt 5136  df-tr 5162  df-id 5455  df-eprel 5460  df-po 5468  df-so 5469  df-fr 5509  df-we 5511  df-xp 5557  df-rel 5558  df-cnv 5559  df-co 5560  df-dm 5561  df-rn 5562  df-res 5563  df-ima 5564  df-pred 6160  df-ord 6216  df-on 6217  df-lim 6218  df-suc 6219  df-iota 6338  df-fun 6382  df-fn 6383  df-f 6384  df-f1 6385  df-fo 6386  df-f1o 6387  df-fv 6388  df-om 7645  df-wrecs 8047  df-recs 8108  df-rdg 8146  df-r1 9380  df-rank 9381
This theorem is referenced by:  scott0s  9504  cplem1  9505  karden  9511  scott0f  36064  scotteld  41537
  Copyright terms: Public domain W3C validator