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

Theorem dfacacn 10118
Description: A choice equivalent: every set has choice sets of every length. (Contributed by Mario Carneiro, 31-Aug-2015.)
Assertion
Ref Expression
dfacacn (CHOICE ↔ ∀𝑥AC 𝑥 = V)

Proof of Theorem dfacacn
Dummy variables 𝑓 𝑔 𝑦 𝑧 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 acacni 10117 . . . 4 ((CHOICE𝑥 ∈ V) → AC 𝑥 = V)
21elvd 3480 . . 3 (CHOICEAC 𝑥 = V)
32alrimiv 1930 . 2 (CHOICE → ∀𝑥AC 𝑥 = V)
4 vex 3477 . . . . . . 7 𝑦 ∈ V
54difexi 5321 . . . . . 6 (𝑦 ∖ {∅}) ∈ V
6 acneq 10020 . . . . . . 7 (𝑥 = (𝑦 ∖ {∅}) → AC 𝑥 = AC (𝑦 ∖ {∅}))
76eqeq1d 2733 . . . . . 6 (𝑥 = (𝑦 ∖ {∅}) → (AC 𝑥 = V ↔ AC (𝑦 ∖ {∅}) = V))
85, 7spcv 3592 . . . . 5 (∀𝑥AC 𝑥 = V → AC (𝑦 ∖ {∅}) = V)
9 vuniex 7712 . . . . . . 7 𝑦 ∈ V
10 id 22 . . . . . . 7 (AC (𝑦 ∖ {∅}) = V → AC (𝑦 ∖ {∅}) = V)
119, 10eleqtrrid 2839 . . . . . 6 (AC (𝑦 ∖ {∅}) = V → 𝑦AC (𝑦 ∖ {∅}))
12 eldifi 4122 . . . . . . . . 9 (𝑧 ∈ (𝑦 ∖ {∅}) → 𝑧𝑦)
13 elssuni 4934 . . . . . . . . 9 (𝑧𝑦𝑧 𝑦)
1412, 13syl 17 . . . . . . . 8 (𝑧 ∈ (𝑦 ∖ {∅}) → 𝑧 𝑦)
15 eldifsni 4786 . . . . . . . 8 (𝑧 ∈ (𝑦 ∖ {∅}) → 𝑧 ≠ ∅)
1614, 15jca 512 . . . . . . 7 (𝑧 ∈ (𝑦 ∖ {∅}) → (𝑧 𝑦𝑧 ≠ ∅))
1716rgen 3062 . . . . . 6 𝑧 ∈ (𝑦 ∖ {∅})(𝑧 𝑦𝑧 ≠ ∅)
18 acni2 10023 . . . . . 6 (( 𝑦AC (𝑦 ∖ {∅}) ∧ ∀𝑧 ∈ (𝑦 ∖ {∅})(𝑧 𝑦𝑧 ≠ ∅)) → ∃𝑔(𝑔:(𝑦 ∖ {∅})⟶ 𝑦 ∧ ∀𝑧 ∈ (𝑦 ∖ {∅})(𝑔𝑧) ∈ 𝑧))
1911, 17, 18sylancl 586 . . . . 5 (AC (𝑦 ∖ {∅}) = V → ∃𝑔(𝑔:(𝑦 ∖ {∅})⟶ 𝑦 ∧ ∀𝑧 ∈ (𝑦 ∖ {∅})(𝑔𝑧) ∈ 𝑧))
204mptex 7209 . . . . . . 7 (𝑥𝑦 ↦ (𝑔𝑥)) ∈ V
21 simpr 485 . . . . . . . . 9 ((𝑔:(𝑦 ∖ {∅})⟶ 𝑦 ∧ ∀𝑧 ∈ (𝑦 ∖ {∅})(𝑔𝑧) ∈ 𝑧) → ∀𝑧 ∈ (𝑦 ∖ {∅})(𝑔𝑧) ∈ 𝑧)
22 eldifsn 4783 . . . . . . . . . . . 12 (𝑧 ∈ (𝑦 ∖ {∅}) ↔ (𝑧𝑦𝑧 ≠ ∅))
2322imbi1i 349 . . . . . . . . . . 11 ((𝑧 ∈ (𝑦 ∖ {∅}) → ((𝑥𝑦 ↦ (𝑔𝑥))‘𝑧) ∈ 𝑧) ↔ ((𝑧𝑦𝑧 ≠ ∅) → ((𝑥𝑦 ↦ (𝑔𝑥))‘𝑧) ∈ 𝑧))
24 fveq2 6878 . . . . . . . . . . . . . . 15 (𝑥 = 𝑧 → (𝑔𝑥) = (𝑔𝑧))
25 eqid 2731 . . . . . . . . . . . . . . 15 (𝑥𝑦 ↦ (𝑔𝑥)) = (𝑥𝑦 ↦ (𝑔𝑥))
26 fvex 6891 . . . . . . . . . . . . . . 15 (𝑔𝑧) ∈ V
2724, 25, 26fvmpt 6984 . . . . . . . . . . . . . 14 (𝑧𝑦 → ((𝑥𝑦 ↦ (𝑔𝑥))‘𝑧) = (𝑔𝑧))
2812, 27syl 17 . . . . . . . . . . . . 13 (𝑧 ∈ (𝑦 ∖ {∅}) → ((𝑥𝑦 ↦ (𝑔𝑥))‘𝑧) = (𝑔𝑧))
2928eleq1d 2817 . . . . . . . . . . . 12 (𝑧 ∈ (𝑦 ∖ {∅}) → (((𝑥𝑦 ↦ (𝑔𝑥))‘𝑧) ∈ 𝑧 ↔ (𝑔𝑧) ∈ 𝑧))
3029pm5.74i 270 . . . . . . . . . . 11 ((𝑧 ∈ (𝑦 ∖ {∅}) → ((𝑥𝑦 ↦ (𝑔𝑥))‘𝑧) ∈ 𝑧) ↔ (𝑧 ∈ (𝑦 ∖ {∅}) → (𝑔𝑧) ∈ 𝑧))
31 impexp 451 . . . . . . . . . . 11 (((𝑧𝑦𝑧 ≠ ∅) → ((𝑥𝑦 ↦ (𝑔𝑥))‘𝑧) ∈ 𝑧) ↔ (𝑧𝑦 → (𝑧 ≠ ∅ → ((𝑥𝑦 ↦ (𝑔𝑥))‘𝑧) ∈ 𝑧)))
3223, 30, 313bitr3i 300 . . . . . . . . . 10 ((𝑧 ∈ (𝑦 ∖ {∅}) → (𝑔𝑧) ∈ 𝑧) ↔ (𝑧𝑦 → (𝑧 ≠ ∅ → ((𝑥𝑦 ↦ (𝑔𝑥))‘𝑧) ∈ 𝑧)))
3332ralbii2 3088 . . . . . . . . 9 (∀𝑧 ∈ (𝑦 ∖ {∅})(𝑔𝑧) ∈ 𝑧 ↔ ∀𝑧𝑦 (𝑧 ≠ ∅ → ((𝑥𝑦 ↦ (𝑔𝑥))‘𝑧) ∈ 𝑧))
3421, 33sylib 217 . . . . . . . 8 ((𝑔:(𝑦 ∖ {∅})⟶ 𝑦 ∧ ∀𝑧 ∈ (𝑦 ∖ {∅})(𝑔𝑧) ∈ 𝑧) → ∀𝑧𝑦 (𝑧 ≠ ∅ → ((𝑥𝑦 ↦ (𝑔𝑥))‘𝑧) ∈ 𝑧))
35 fvrn0 6908 . . . . . . . . . . 11 (𝑔𝑥) ∈ (ran 𝑔 ∪ {∅})
3635rgenw 3064 . . . . . . . . . 10 𝑥𝑦 (𝑔𝑥) ∈ (ran 𝑔 ∪ {∅})
3725fmpt 7094 . . . . . . . . . 10 (∀𝑥𝑦 (𝑔𝑥) ∈ (ran 𝑔 ∪ {∅}) ↔ (𝑥𝑦 ↦ (𝑔𝑥)):𝑦⟶(ran 𝑔 ∪ {∅}))
3836, 37mpbi 229 . . . . . . . . 9 (𝑥𝑦 ↦ (𝑔𝑥)):𝑦⟶(ran 𝑔 ∪ {∅})
39 ffn 6704 . . . . . . . . 9 ((𝑥𝑦 ↦ (𝑔𝑥)):𝑦⟶(ran 𝑔 ∪ {∅}) → (𝑥𝑦 ↦ (𝑔𝑥)) Fn 𝑦)
4038, 39ax-mp 5 . . . . . . . 8 (𝑥𝑦 ↦ (𝑔𝑥)) Fn 𝑦
4134, 40jctil 520 . . . . . . 7 ((𝑔:(𝑦 ∖ {∅})⟶ 𝑦 ∧ ∀𝑧 ∈ (𝑦 ∖ {∅})(𝑔𝑧) ∈ 𝑧) → ((𝑥𝑦 ↦ (𝑔𝑥)) Fn 𝑦 ∧ ∀𝑧𝑦 (𝑧 ≠ ∅ → ((𝑥𝑦 ↦ (𝑔𝑥))‘𝑧) ∈ 𝑧)))
42 fneq1 6629 . . . . . . . . 9 (𝑓 = (𝑥𝑦 ↦ (𝑔𝑥)) → (𝑓 Fn 𝑦 ↔ (𝑥𝑦 ↦ (𝑔𝑥)) Fn 𝑦))
43 fveq1 6877 . . . . . . . . . . . 12 (𝑓 = (𝑥𝑦 ↦ (𝑔𝑥)) → (𝑓𝑧) = ((𝑥𝑦 ↦ (𝑔𝑥))‘𝑧))
4443eleq1d 2817 . . . . . . . . . . 11 (𝑓 = (𝑥𝑦 ↦ (𝑔𝑥)) → ((𝑓𝑧) ∈ 𝑧 ↔ ((𝑥𝑦 ↦ (𝑔𝑥))‘𝑧) ∈ 𝑧))
4544imbi2d 340 . . . . . . . . . 10 (𝑓 = (𝑥𝑦 ↦ (𝑔𝑥)) → ((𝑧 ≠ ∅ → (𝑓𝑧) ∈ 𝑧) ↔ (𝑧 ≠ ∅ → ((𝑥𝑦 ↦ (𝑔𝑥))‘𝑧) ∈ 𝑧)))
4645ralbidv 3176 . . . . . . . . 9 (𝑓 = (𝑥𝑦 ↦ (𝑔𝑥)) → (∀𝑧𝑦 (𝑧 ≠ ∅ → (𝑓𝑧) ∈ 𝑧) ↔ ∀𝑧𝑦 (𝑧 ≠ ∅ → ((𝑥𝑦 ↦ (𝑔𝑥))‘𝑧) ∈ 𝑧)))
4742, 46anbi12d 631 . . . . . . . 8 (𝑓 = (𝑥𝑦 ↦ (𝑔𝑥)) → ((𝑓 Fn 𝑦 ∧ ∀𝑧𝑦 (𝑧 ≠ ∅ → (𝑓𝑧) ∈ 𝑧)) ↔ ((𝑥𝑦 ↦ (𝑔𝑥)) Fn 𝑦 ∧ ∀𝑧𝑦 (𝑧 ≠ ∅ → ((𝑥𝑦 ↦ (𝑔𝑥))‘𝑧) ∈ 𝑧))))
4847spcegv 3584 . . . . . . 7 ((𝑥𝑦 ↦ (𝑔𝑥)) ∈ V → (((𝑥𝑦 ↦ (𝑔𝑥)) Fn 𝑦 ∧ ∀𝑧𝑦 (𝑧 ≠ ∅ → ((𝑥𝑦 ↦ (𝑔𝑥))‘𝑧) ∈ 𝑧)) → ∃𝑓(𝑓 Fn 𝑦 ∧ ∀𝑧𝑦 (𝑧 ≠ ∅ → (𝑓𝑧) ∈ 𝑧))))
4920, 41, 48mpsyl 68 . . . . . 6 ((𝑔:(𝑦 ∖ {∅})⟶ 𝑦 ∧ ∀𝑧 ∈ (𝑦 ∖ {∅})(𝑔𝑧) ∈ 𝑧) → ∃𝑓(𝑓 Fn 𝑦 ∧ ∀𝑧𝑦 (𝑧 ≠ ∅ → (𝑓𝑧) ∈ 𝑧)))
5049exlimiv 1933 . . . . 5 (∃𝑔(𝑔:(𝑦 ∖ {∅})⟶ 𝑦 ∧ ∀𝑧 ∈ (𝑦 ∖ {∅})(𝑔𝑧) ∈ 𝑧) → ∃𝑓(𝑓 Fn 𝑦 ∧ ∀𝑧𝑦 (𝑧 ≠ ∅ → (𝑓𝑧) ∈ 𝑧)))
518, 19, 503syl 18 . . . 4 (∀𝑥AC 𝑥 = V → ∃𝑓(𝑓 Fn 𝑦 ∧ ∀𝑧𝑦 (𝑧 ≠ ∅ → (𝑓𝑧) ∈ 𝑧)))
5251alrimiv 1930 . . 3 (∀𝑥AC 𝑥 = V → ∀𝑦𝑓(𝑓 Fn 𝑦 ∧ ∀𝑧𝑦 (𝑧 ≠ ∅ → (𝑓𝑧) ∈ 𝑧)))
53 dfac4 10099 . . 3 (CHOICE ↔ ∀𝑦𝑓(𝑓 Fn 𝑦 ∧ ∀𝑧𝑦 (𝑧 ≠ ∅ → (𝑓𝑧) ∈ 𝑧)))
5452, 53sylibr 233 . 2 (∀𝑥AC 𝑥 = V → CHOICE)
553, 54impbii 208 1 (CHOICE ↔ ∀𝑥AC 𝑥 = V)
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 205  wa 396  wal 1539   = wceq 1541  wex 1781  wcel 2106  wne 2939  wral 3060  Vcvv 3473  cdif 3941  cun 3942  wss 3944  c0 4318  {csn 4622   cuni 4901  cmpt 5224  ran crn 5670   Fn wfn 6527  wf 6528  cfv 6532  AC wacn 9915  CHOICEwac 10092
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 1913  ax-6 1971  ax-7 2011  ax-8 2108  ax-9 2116  ax-10 2137  ax-11 2154  ax-12 2171  ax-ext 2702  ax-rep 5278  ax-sep 5292  ax-nul 5299  ax-pow 5356  ax-pr 5420  ax-un 7708
This theorem depends on definitions:  df-bi 206  df-an 397  df-or 846  df-3or 1088  df-3an 1089  df-tru 1544  df-fal 1554  df-ex 1782  df-nf 1786  df-sb 2068  df-mo 2533  df-eu 2562  df-clab 2709  df-cleq 2723  df-clel 2809  df-nfc 2884  df-ne 2940  df-ral 3061  df-rex 3070  df-rmo 3375  df-reu 3376  df-rab 3432  df-v 3475  df-sbc 3774  df-csb 3890  df-dif 3947  df-un 3949  df-in 3951  df-ss 3961  df-pss 3963  df-nul 4319  df-if 4523  df-pw 4598  df-sn 4623  df-pr 4625  df-op 4629  df-uni 4902  df-int 4944  df-iun 4992  df-br 5142  df-opab 5204  df-mpt 5225  df-tr 5259  df-id 5567  df-eprel 5573  df-po 5581  df-so 5582  df-fr 5624  df-se 5625  df-we 5626  df-xp 5675  df-rel 5676  df-cnv 5677  df-co 5678  df-dm 5679  df-rn 5680  df-res 5681  df-ima 5682  df-pred 6289  df-ord 6356  df-on 6357  df-suc 6359  df-iota 6484  df-fun 6534  df-fn 6535  df-f 6536  df-f1 6537  df-fo 6538  df-f1o 6539  df-fv 6540  df-isom 6541  df-riota 7349  df-ov 7396  df-oprab 7397  df-mpo 7398  df-1st 7957  df-2nd 7958  df-frecs 8248  df-wrecs 8279  df-recs 8353  df-er 8686  df-map 8805  df-en 8923  df-dom 8924  df-card 9916  df-acn 9919  df-ac 10093
This theorem is referenced by:  dfac13  10119
  Copyright terms: Public domain W3C validator