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

Theorem fodomfib 8786
Description: Equivalence of an onto mapping and dominance for a nonempty finite set. Unlike fodomb 9936 for arbitrary sets, this theorem does not require the Axiom of Choice for its proof. (Contributed by NM, 23-Mar-2006.)
Assertion
Ref Expression
fodomfib (𝐴 ∈ Fin → ((𝐴 ≠ ∅ ∧ ∃𝑓 𝑓:𝐴onto𝐵) ↔ (∅ ≺ 𝐵𝐵𝐴)))
Distinct variable groups:   𝐴,𝑓   𝐵,𝑓

Proof of Theorem fodomfib
StepHypRef Expression
1 fof 6583 . . . . . . . . . . . . 13 (𝑓:𝐴onto𝐵𝑓:𝐴𝐵)
21fdmd 6516 . . . . . . . . . . . 12 (𝑓:𝐴onto𝐵 → dom 𝑓 = 𝐴)
32eqeq1d 2820 . . . . . . . . . . 11 (𝑓:𝐴onto𝐵 → (dom 𝑓 = ∅ ↔ 𝐴 = ∅))
4 dm0rn0 5788 . . . . . . . . . . . 12 (dom 𝑓 = ∅ ↔ ran 𝑓 = ∅)
5 forn 6586 . . . . . . . . . . . . 13 (𝑓:𝐴onto𝐵 → ran 𝑓 = 𝐵)
65eqeq1d 2820 . . . . . . . . . . . 12 (𝑓:𝐴onto𝐵 → (ran 𝑓 = ∅ ↔ 𝐵 = ∅))
74, 6syl5bb 284 . . . . . . . . . . 11 (𝑓:𝐴onto𝐵 → (dom 𝑓 = ∅ ↔ 𝐵 = ∅))
83, 7bitr3d 282 . . . . . . . . . 10 (𝑓:𝐴onto𝐵 → (𝐴 = ∅ ↔ 𝐵 = ∅))
98necon3bid 3057 . . . . . . . . 9 (𝑓:𝐴onto𝐵 → (𝐴 ≠ ∅ ↔ 𝐵 ≠ ∅))
109biimpac 479 . . . . . . . 8 ((𝐴 ≠ ∅ ∧ 𝑓:𝐴onto𝐵) → 𝐵 ≠ ∅)
1110adantll 710 . . . . . . 7 (((𝐴 ∈ Fin ∧ 𝐴 ≠ ∅) ∧ 𝑓:𝐴onto𝐵) → 𝐵 ≠ ∅)
12 vex 3495 . . . . . . . . . . . 12 𝑓 ∈ V
1312rnex 7606 . . . . . . . . . . 11 ran 𝑓 ∈ V
145, 13syl6eqelr 2919 . . . . . . . . . 10 (𝑓:𝐴onto𝐵𝐵 ∈ V)
1514adantl 482 . . . . . . . . 9 ((𝐴 ∈ Fin ∧ 𝑓:𝐴onto𝐵) → 𝐵 ∈ V)
16 0sdomg 8634 . . . . . . . . 9 (𝐵 ∈ V → (∅ ≺ 𝐵𝐵 ≠ ∅))
1715, 16syl 17 . . . . . . . 8 ((𝐴 ∈ Fin ∧ 𝑓:𝐴onto𝐵) → (∅ ≺ 𝐵𝐵 ≠ ∅))
1817adantlr 711 . . . . . . 7 (((𝐴 ∈ Fin ∧ 𝐴 ≠ ∅) ∧ 𝑓:𝐴onto𝐵) → (∅ ≺ 𝐵𝐵 ≠ ∅))
1911, 18mpbird 258 . . . . . 6 (((𝐴 ∈ Fin ∧ 𝐴 ≠ ∅) ∧ 𝑓:𝐴onto𝐵) → ∅ ≺ 𝐵)
2019ex 413 . . . . 5 ((𝐴 ∈ Fin ∧ 𝐴 ≠ ∅) → (𝑓:𝐴onto𝐵 → ∅ ≺ 𝐵))
21 fodomfi 8785 . . . . . . 7 ((𝐴 ∈ Fin ∧ 𝑓:𝐴onto𝐵) → 𝐵𝐴)
2221ex 413 . . . . . 6 (𝐴 ∈ Fin → (𝑓:𝐴onto𝐵𝐵𝐴))
2322adantr 481 . . . . 5 ((𝐴 ∈ Fin ∧ 𝐴 ≠ ∅) → (𝑓:𝐴onto𝐵𝐵𝐴))
2420, 23jcad 513 . . . 4 ((𝐴 ∈ Fin ∧ 𝐴 ≠ ∅) → (𝑓:𝐴onto𝐵 → (∅ ≺ 𝐵𝐵𝐴)))
2524exlimdv 1925 . . 3 ((𝐴 ∈ Fin ∧ 𝐴 ≠ ∅) → (∃𝑓 𝑓:𝐴onto𝐵 → (∅ ≺ 𝐵𝐵𝐴)))
2625expimpd 454 . 2 (𝐴 ∈ Fin → ((𝐴 ≠ ∅ ∧ ∃𝑓 𝑓:𝐴onto𝐵) → (∅ ≺ 𝐵𝐵𝐴)))
27 sdomdomtr 8638 . . . 4 ((∅ ≺ 𝐵𝐵𝐴) → ∅ ≺ 𝐴)
28 0sdomg 8634 . . . 4 (𝐴 ∈ Fin → (∅ ≺ 𝐴𝐴 ≠ ∅))
2927, 28syl5ib 245 . . 3 (𝐴 ∈ Fin → ((∅ ≺ 𝐵𝐵𝐴) → 𝐴 ≠ ∅))
30 fodomr 8656 . . 3 ((∅ ≺ 𝐵𝐵𝐴) → ∃𝑓 𝑓:𝐴onto𝐵)
3129, 30jca2 514 . 2 (𝐴 ∈ Fin → ((∅ ≺ 𝐵𝐵𝐴) → (𝐴 ≠ ∅ ∧ ∃𝑓 𝑓:𝐴onto𝐵)))
3226, 31impbid 213 1 (𝐴 ∈ Fin → ((𝐴 ≠ ∅ ∧ ∃𝑓 𝑓:𝐴onto𝐵) ↔ (∅ ≺ 𝐵𝐵𝐴)))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 207  wa 396   = wceq 1528  wex 1771  wcel 2105  wne 3013  Vcvv 3492  c0 4288   class class class wbr 5057  dom cdm 5548  ran crn 5549  ontowfo 6346  cdom 8495  csdm 8496  Fincfn 8497
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1787  ax-4 1801  ax-5 1902  ax-6 1961  ax-7 2006  ax-8 2107  ax-9 2115  ax-10 2136  ax-11 2151  ax-12 2167  ax-ext 2790  ax-sep 5194  ax-nul 5201  ax-pow 5257  ax-pr 5320  ax-un 7450
This theorem depends on definitions:  df-bi 208  df-an 397  df-or 842  df-3or 1080  df-3an 1081  df-tru 1531  df-ex 1772  df-nf 1776  df-sb 2061  df-mo 2615  df-eu 2647  df-clab 2797  df-cleq 2811  df-clel 2890  df-nfc 2960  df-ne 3014  df-ral 3140  df-rex 3141  df-reu 3142  df-rab 3144  df-v 3494  df-sbc 3770  df-dif 3936  df-un 3938  df-in 3940  df-ss 3949  df-pss 3951  df-nul 4289  df-if 4464  df-pw 4537  df-sn 4558  df-pr 4560  df-tp 4562  df-op 4564  df-uni 4831  df-br 5058  df-opab 5120  df-mpt 5138  df-tr 5164  df-id 5453  df-eprel 5458  df-po 5467  df-so 5468  df-fr 5507  df-we 5509  df-xp 5554  df-rel 5555  df-cnv 5556  df-co 5557  df-dm 5558  df-rn 5559  df-res 5560  df-ima 5561  df-ord 6187  df-on 6188  df-lim 6189  df-suc 6190  df-iota 6307  df-fun 6350  df-fn 6351  df-f 6352  df-f1 6353  df-fo 6354  df-f1o 6355  df-fv 6356  df-om 7570  df-1o 8091  df-er 8278  df-en 8498  df-dom 8499  df-sdom 8500  df-fin 8501
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator