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

Theorem fodomacn 9743
Description: A version of fodom 10210 that doesn't require the Axiom of Choice ax-ac 10146. If 𝐴 has choice sequences of length 𝐵, then any surjection from 𝐴 to 𝐵 can be inverted to an injection the other way. (Contributed by Mario Carneiro, 31-Aug-2015.)
Assertion
Ref Expression
fodomacn (𝐴AC 𝐵 → (𝐹:𝐴onto𝐵𝐵𝐴))

Proof of Theorem fodomacn
Dummy variables 𝑥 𝑓 𝑦 𝑧 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 foelrn 6964 . . . . 5 ((𝐹:𝐴onto𝐵𝑥𝐵) → ∃𝑦𝐴 𝑥 = (𝐹𝑦))
21ralrimiva 3107 . . . 4 (𝐹:𝐴onto𝐵 → ∀𝑥𝐵𝑦𝐴 𝑥 = (𝐹𝑦))
3 fveq2 6756 . . . . . 6 (𝑦 = (𝑓𝑥) → (𝐹𝑦) = (𝐹‘(𝑓𝑥)))
43eqeq2d 2749 . . . . 5 (𝑦 = (𝑓𝑥) → (𝑥 = (𝐹𝑦) ↔ 𝑥 = (𝐹‘(𝑓𝑥))))
54acni3 9734 . . . 4 ((𝐴AC 𝐵 ∧ ∀𝑥𝐵𝑦𝐴 𝑥 = (𝐹𝑦)) → ∃𝑓(𝑓:𝐵𝐴 ∧ ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥))))
62, 5sylan2 592 . . 3 ((𝐴AC 𝐵𝐹:𝐴onto𝐵) → ∃𝑓(𝑓:𝐵𝐴 ∧ ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥))))
7 simpll 763 . . . . 5 (((𝐴AC 𝐵𝐹:𝐴onto𝐵) ∧ (𝑓:𝐵𝐴 ∧ ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)))) → 𝐴AC 𝐵)
8 acnrcl 9729 . . . . 5 (𝐴AC 𝐵𝐵 ∈ V)
97, 8syl 17 . . . 4 (((𝐴AC 𝐵𝐹:𝐴onto𝐵) ∧ (𝑓:𝐵𝐴 ∧ ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)))) → 𝐵 ∈ V)
10 simprl 767 . . . . 5 (((𝐴AC 𝐵𝐹:𝐴onto𝐵) ∧ (𝑓:𝐵𝐴 ∧ ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)))) → 𝑓:𝐵𝐴)
11 fveq2 6756 . . . . . . 7 ((𝑓𝑦) = (𝑓𝑧) → (𝐹‘(𝑓𝑦)) = (𝐹‘(𝑓𝑧)))
12 simprr 769 . . . . . . . 8 (((𝐴AC 𝐵𝐹:𝐴onto𝐵) ∧ (𝑓:𝐵𝐴 ∧ ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)))) → ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)))
13 id 22 . . . . . . . . . . . 12 (𝑥 = 𝑦𝑥 = 𝑦)
14 2fveq3 6761 . . . . . . . . . . . 12 (𝑥 = 𝑦 → (𝐹‘(𝑓𝑥)) = (𝐹‘(𝑓𝑦)))
1513, 14eqeq12d 2754 . . . . . . . . . . 11 (𝑥 = 𝑦 → (𝑥 = (𝐹‘(𝑓𝑥)) ↔ 𝑦 = (𝐹‘(𝑓𝑦))))
1615rspccva 3551 . . . . . . . . . 10 ((∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)) ∧ 𝑦𝐵) → 𝑦 = (𝐹‘(𝑓𝑦)))
17 id 22 . . . . . . . . . . . 12 (𝑥 = 𝑧𝑥 = 𝑧)
18 2fveq3 6761 . . . . . . . . . . . 12 (𝑥 = 𝑧 → (𝐹‘(𝑓𝑥)) = (𝐹‘(𝑓𝑧)))
1917, 18eqeq12d 2754 . . . . . . . . . . 11 (𝑥 = 𝑧 → (𝑥 = (𝐹‘(𝑓𝑥)) ↔ 𝑧 = (𝐹‘(𝑓𝑧))))
2019rspccva 3551 . . . . . . . . . 10 ((∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)) ∧ 𝑧𝐵) → 𝑧 = (𝐹‘(𝑓𝑧)))
2116, 20eqeqan12d 2752 . . . . . . . . 9 (((∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)) ∧ 𝑦𝐵) ∧ (∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)) ∧ 𝑧𝐵)) → (𝑦 = 𝑧 ↔ (𝐹‘(𝑓𝑦)) = (𝐹‘(𝑓𝑧))))
2221anandis 674 . . . . . . . 8 ((∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)) ∧ (𝑦𝐵𝑧𝐵)) → (𝑦 = 𝑧 ↔ (𝐹‘(𝑓𝑦)) = (𝐹‘(𝑓𝑧))))
2312, 22sylan 579 . . . . . . 7 ((((𝐴AC 𝐵𝐹:𝐴onto𝐵) ∧ (𝑓:𝐵𝐴 ∧ ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)))) ∧ (𝑦𝐵𝑧𝐵)) → (𝑦 = 𝑧 ↔ (𝐹‘(𝑓𝑦)) = (𝐹‘(𝑓𝑧))))
2411, 23syl5ibr 245 . . . . . 6 ((((𝐴AC 𝐵𝐹:𝐴onto𝐵) ∧ (𝑓:𝐵𝐴 ∧ ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)))) ∧ (𝑦𝐵𝑧𝐵)) → ((𝑓𝑦) = (𝑓𝑧) → 𝑦 = 𝑧))
2524ralrimivva 3114 . . . . 5 (((𝐴AC 𝐵𝐹:𝐴onto𝐵) ∧ (𝑓:𝐵𝐴 ∧ ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)))) → ∀𝑦𝐵𝑧𝐵 ((𝑓𝑦) = (𝑓𝑧) → 𝑦 = 𝑧))
26 dff13 7109 . . . . 5 (𝑓:𝐵1-1𝐴 ↔ (𝑓:𝐵𝐴 ∧ ∀𝑦𝐵𝑧𝐵 ((𝑓𝑦) = (𝑓𝑧) → 𝑦 = 𝑧)))
2710, 25, 26sylanbrc 582 . . . 4 (((𝐴AC 𝐵𝐹:𝐴onto𝐵) ∧ (𝑓:𝐵𝐴 ∧ ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)))) → 𝑓:𝐵1-1𝐴)
28 f1dom2g 8712 . . . 4 ((𝐵 ∈ V ∧ 𝐴AC 𝐵𝑓:𝐵1-1𝐴) → 𝐵𝐴)
299, 7, 27, 28syl3anc 1369 . . 3 (((𝐴AC 𝐵𝐹:𝐴onto𝐵) ∧ (𝑓:𝐵𝐴 ∧ ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)))) → 𝐵𝐴)
306, 29exlimddv 1939 . 2 ((𝐴AC 𝐵𝐹:𝐴onto𝐵) → 𝐵𝐴)
3130ex 412 1 (𝐴AC 𝐵 → (𝐹:𝐴onto𝐵𝐵𝐴))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 205  wa 395   = wceq 1539  wex 1783  wcel 2108  wral 3063  wrex 3064  Vcvv 3422   class class class wbr 5070  wf 6414  1-1wf1 6415  ontowfo 6416  cfv 6418  cdom 8689  AC wacn 9627
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1799  ax-4 1813  ax-5 1914  ax-6 1972  ax-7 2012  ax-8 2110  ax-9 2118  ax-10 2139  ax-11 2156  ax-12 2173  ax-ext 2709  ax-sep 5218  ax-nul 5225  ax-pow 5283  ax-pr 5347  ax-un 7566
This theorem depends on definitions:  df-bi 206  df-an 396  df-or 844  df-3an 1087  df-tru 1542  df-fal 1552  df-ex 1784  df-nf 1788  df-sb 2069  df-mo 2540  df-eu 2569  df-clab 2716  df-cleq 2730  df-clel 2817  df-nfc 2888  df-ne 2943  df-ral 3068  df-rex 3069  df-rab 3072  df-v 3424  df-sbc 3712  df-csb 3829  df-dif 3886  df-un 3888  df-in 3890  df-ss 3900  df-nul 4254  df-if 4457  df-pw 4532  df-sn 4559  df-pr 4561  df-op 4565  df-uni 4837  df-br 5071  df-opab 5133  df-mpt 5154  df-id 5480  df-xp 5586  df-rel 5587  df-cnv 5588  df-co 5589  df-dm 5590  df-rn 5591  df-res 5592  df-ima 5593  df-iota 6376  df-fun 6420  df-fn 6421  df-f 6422  df-f1 6423  df-fo 6424  df-fv 6426  df-ov 7258  df-oprab 7259  df-mpo 7260  df-map 8575  df-dom 8693  df-acn 9631
This theorem is referenced by:  fodomnum  9744  iundomg  10228
  Copyright terms: Public domain W3C validator