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

Theorem fodomacn 9969
Description: A version of fodom 10436 that doesn't require the Axiom of Choice ax-ac 10372. 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 7053 . . . . 5 ((𝐹:𝐴onto𝐵𝑥𝐵) → ∃𝑦𝐴 𝑥 = (𝐹𝑦))
21ralrimiva 3130 . . . 4 (𝐹:𝐴onto𝐵 → ∀𝑥𝐵𝑦𝐴 𝑥 = (𝐹𝑦))
3 fveq2 6834 . . . . . 6 (𝑦 = (𝑓𝑥) → (𝐹𝑦) = (𝐹‘(𝑓𝑥)))
43eqeq2d 2748 . . . . 5 (𝑦 = (𝑓𝑥) → (𝑥 = (𝐹𝑦) ↔ 𝑥 = (𝐹‘(𝑓𝑥))))
54acni3 9960 . . . 4 ((𝐴AC 𝐵 ∧ ∀𝑥𝐵𝑦𝐴 𝑥 = (𝐹𝑦)) → ∃𝑓(𝑓:𝐵𝐴 ∧ ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥))))
62, 5sylan2 594 . . 3 ((𝐴AC 𝐵𝐹:𝐴onto𝐵) → ∃𝑓(𝑓:𝐵𝐴 ∧ ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥))))
7 simpll 767 . . . . 5 (((𝐴AC 𝐵𝐹:𝐴onto𝐵) ∧ (𝑓:𝐵𝐴 ∧ ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)))) → 𝐴AC 𝐵)
8 acnrcl 9955 . . . . 5 (𝐴AC 𝐵𝐵 ∈ V)
97, 8syl 17 . . . 4 (((𝐴AC 𝐵𝐹:𝐴onto𝐵) ∧ (𝑓:𝐵𝐴 ∧ ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)))) → 𝐵 ∈ V)
10 simprl 771 . . . . 5 (((𝐴AC 𝐵𝐹:𝐴onto𝐵) ∧ (𝑓:𝐵𝐴 ∧ ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)))) → 𝑓:𝐵𝐴)
11 fveq2 6834 . . . . . . 7 ((𝑓𝑦) = (𝑓𝑧) → (𝐹‘(𝑓𝑦)) = (𝐹‘(𝑓𝑧)))
12 simprr 773 . . . . . . . 8 (((𝐴AC 𝐵𝐹:𝐴onto𝐵) ∧ (𝑓:𝐵𝐴 ∧ ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)))) → ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)))
13 id 22 . . . . . . . . . . . 12 (𝑥 = 𝑦𝑥 = 𝑦)
14 2fveq3 6839 . . . . . . . . . . . 12 (𝑥 = 𝑦 → (𝐹‘(𝑓𝑥)) = (𝐹‘(𝑓𝑦)))
1513, 14eqeq12d 2753 . . . . . . . . . . 11 (𝑥 = 𝑦 → (𝑥 = (𝐹‘(𝑓𝑥)) ↔ 𝑦 = (𝐹‘(𝑓𝑦))))
1615rspccva 3564 . . . . . . . . . 10 ((∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)) ∧ 𝑦𝐵) → 𝑦 = (𝐹‘(𝑓𝑦)))
17 id 22 . . . . . . . . . . . 12 (𝑥 = 𝑧𝑥 = 𝑧)
18 2fveq3 6839 . . . . . . . . . . . 12 (𝑥 = 𝑧 → (𝐹‘(𝑓𝑥)) = (𝐹‘(𝑓𝑧)))
1917, 18eqeq12d 2753 . . . . . . . . . . 11 (𝑥 = 𝑧 → (𝑥 = (𝐹‘(𝑓𝑥)) ↔ 𝑧 = (𝐹‘(𝑓𝑧))))
2019rspccva 3564 . . . . . . . . . 10 ((∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)) ∧ 𝑧𝐵) → 𝑧 = (𝐹‘(𝑓𝑧)))
2116, 20eqeqan12d 2751 . . . . . . . . 9 (((∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)) ∧ 𝑦𝐵) ∧ (∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)) ∧ 𝑧𝐵)) → (𝑦 = 𝑧 ↔ (𝐹‘(𝑓𝑦)) = (𝐹‘(𝑓𝑧))))
2221anandis 679 . . . . . . . 8 ((∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)) ∧ (𝑦𝐵𝑧𝐵)) → (𝑦 = 𝑧 ↔ (𝐹‘(𝑓𝑦)) = (𝐹‘(𝑓𝑧))))
2312, 22sylan 581 . . . . . . 7 ((((𝐴AC 𝐵𝐹:𝐴onto𝐵) ∧ (𝑓:𝐵𝐴 ∧ ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)))) ∧ (𝑦𝐵𝑧𝐵)) → (𝑦 = 𝑧 ↔ (𝐹‘(𝑓𝑦)) = (𝐹‘(𝑓𝑧))))
2411, 23imbitrrid 246 . . . . . 6 ((((𝐴AC 𝐵𝐹:𝐴onto𝐵) ∧ (𝑓:𝐵𝐴 ∧ ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)))) ∧ (𝑦𝐵𝑧𝐵)) → ((𝑓𝑦) = (𝑓𝑧) → 𝑦 = 𝑧))
2524ralrimivva 3181 . . . . 5 (((𝐴AC 𝐵𝐹:𝐴onto𝐵) ∧ (𝑓:𝐵𝐴 ∧ ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)))) → ∀𝑦𝐵𝑧𝐵 ((𝑓𝑦) = (𝑓𝑧) → 𝑦 = 𝑧))
26 dff13 7202 . . . . 5 (𝑓:𝐵1-1𝐴 ↔ (𝑓:𝐵𝐴 ∧ ∀𝑦𝐵𝑧𝐵 ((𝑓𝑦) = (𝑓𝑧) → 𝑦 = 𝑧)))
2710, 25, 26sylanbrc 584 . . . 4 (((𝐴AC 𝐵𝐹:𝐴onto𝐵) ∧ (𝑓:𝐵𝐴 ∧ ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)))) → 𝑓:𝐵1-1𝐴)
28 f1dom2g 8909 . . . 4 ((𝐵 ∈ V ∧ 𝐴AC 𝐵𝑓:𝐵1-1𝐴) → 𝐵𝐴)
299, 7, 27, 28syl3anc 1374 . . 3 (((𝐴AC 𝐵𝐹:𝐴onto𝐵) ∧ (𝑓:𝐵𝐴 ∧ ∀𝑥𝐵 𝑥 = (𝐹‘(𝑓𝑥)))) → 𝐵𝐴)
306, 29exlimddv 1937 . 2 ((𝐴AC 𝐵𝐹:𝐴onto𝐵) → 𝐵𝐴)
3130ex 412 1 (𝐴AC 𝐵 → (𝐹:𝐴onto𝐵𝐵𝐴))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 206  wa 395   = wceq 1542  wex 1781  wcel 2114  wral 3052  wrex 3062  Vcvv 3430   class class class wbr 5086  wf 6488  1-1wf1 6489  ontowfo 6490  cfv 6492  cdom 8884  AC wacn 9853
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 1912  ax-6 1969  ax-7 2010  ax-8 2116  ax-9 2124  ax-10 2147  ax-11 2163  ax-12 2185  ax-ext 2709  ax-sep 5231  ax-nul 5241  ax-pow 5302  ax-pr 5370  ax-un 7682
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 849  df-3an 1089  df-tru 1545  df-fal 1555  df-ex 1782  df-nf 1786  df-sb 2069  df-mo 2540  df-eu 2570  df-clab 2716  df-cleq 2729  df-clel 2812  df-nfc 2886  df-ne 2934  df-ral 3053  df-rex 3063  df-rab 3391  df-v 3432  df-sbc 3730  df-csb 3839  df-dif 3893  df-un 3895  df-in 3897  df-ss 3907  df-nul 4275  df-if 4468  df-pw 4544  df-sn 4569  df-pr 4571  df-op 4575  df-uni 4852  df-br 5087  df-opab 5149  df-mpt 5168  df-id 5519  df-xp 5630  df-rel 5631  df-cnv 5632  df-co 5633  df-dm 5634  df-rn 5635  df-res 5636  df-ima 5637  df-iota 6448  df-fun 6494  df-fn 6495  df-f 6496  df-f1 6497  df-fo 6498  df-fv 6500  df-ov 7363  df-oprab 7364  df-mpo 7365  df-map 8768  df-dom 8888  df-acn 9857
This theorem is referenced by:  fodomnum  9970  iundomg  10454
  Copyright terms: Public domain W3C validator