Users' Mathboxes Mathbox for Stefan O'Rear < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >   Mathboxes  >  fphpd Structured version   Visualization version   GIF version

Theorem fphpd 39433
Description: Pigeonhole principle expressed with implicit substitution. If the range is smaller than the domain, two inputs must be mapped to the same output. (Contributed by Stefan O'Rear, 19-Oct-2014.) (Revised by Stefan O'Rear, 6-May-2015.)
Hypotheses
Ref Expression
fphpd.a (𝜑𝐵𝐴)
fphpd.b ((𝜑𝑥𝐴) → 𝐶𝐵)
fphpd.c (𝑥 = 𝑦𝐶 = 𝐷)
Assertion
Ref Expression
fphpd (𝜑 → ∃𝑥𝐴𝑦𝐴 (𝑥𝑦𝐶 = 𝐷))
Distinct variable groups:   𝑥,𝐴,𝑦   𝑥,𝐵,𝑦   𝑦,𝐶   𝑥,𝐷   𝜑,𝑥,𝑦
Allowed substitution hints:   𝐶(𝑥)   𝐷(𝑦)

Proof of Theorem fphpd
Dummy variables 𝑎 𝑏 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 domnsym 8643 . . . 4 (𝐴𝐵 → ¬ 𝐵𝐴)
2 fphpd.a . . . 4 (𝜑𝐵𝐴)
31, 2nsyl3 140 . . 3 (𝜑 → ¬ 𝐴𝐵)
4 relsdom 8516 . . . . . . 7 Rel ≺
54brrelex1i 5608 . . . . . 6 (𝐵𝐴𝐵 ∈ V)
62, 5syl 17 . . . . 5 (𝜑𝐵 ∈ V)
76adantr 483 . . . 4 ((𝜑 ∧ ∀𝑥𝐴𝑦𝐴 (𝐶 = 𝐷𝑥 = 𝑦)) → 𝐵 ∈ V)
8 nfv 1915 . . . . . . . . 9 𝑥(𝜑𝑎𝐴)
9 nfcsb1v 3907 . . . . . . . . . 10 𝑥𝑎 / 𝑥𝐶
109nfel1 2994 . . . . . . . . 9 𝑥𝑎 / 𝑥𝐶𝐵
118, 10nfim 1897 . . . . . . . 8 𝑥((𝜑𝑎𝐴) → 𝑎 / 𝑥𝐶𝐵)
12 eleq1w 2895 . . . . . . . . . 10 (𝑥 = 𝑎 → (𝑥𝐴𝑎𝐴))
1312anbi2d 630 . . . . . . . . 9 (𝑥 = 𝑎 → ((𝜑𝑥𝐴) ↔ (𝜑𝑎𝐴)))
14 csbeq1a 3897 . . . . . . . . . 10 (𝑥 = 𝑎𝐶 = 𝑎 / 𝑥𝐶)
1514eleq1d 2897 . . . . . . . . 9 (𝑥 = 𝑎 → (𝐶𝐵𝑎 / 𝑥𝐶𝐵))
1613, 15imbi12d 347 . . . . . . . 8 (𝑥 = 𝑎 → (((𝜑𝑥𝐴) → 𝐶𝐵) ↔ ((𝜑𝑎𝐴) → 𝑎 / 𝑥𝐶𝐵)))
17 fphpd.b . . . . . . . 8 ((𝜑𝑥𝐴) → 𝐶𝐵)
1811, 16, 17chvarfv 2242 . . . . . . 7 ((𝜑𝑎𝐴) → 𝑎 / 𝑥𝐶𝐵)
1918ex 415 . . . . . 6 (𝜑 → (𝑎𝐴𝑎 / 𝑥𝐶𝐵))
2019adantr 483 . . . . 5 ((𝜑 ∧ ∀𝑥𝐴𝑦𝐴 (𝐶 = 𝐷𝑥 = 𝑦)) → (𝑎𝐴𝑎 / 𝑥𝐶𝐵))
21 csbid 3896 . . . . . . . . . . 11 𝑥 / 𝑥𝐶 = 𝐶
22 vex 3497 . . . . . . . . . . . 12 𝑦 ∈ V
23 fphpd.c . . . . . . . . . . . 12 (𝑥 = 𝑦𝐶 = 𝐷)
2422, 23csbie 3918 . . . . . . . . . . 11 𝑦 / 𝑥𝐶 = 𝐷
2521, 24eqeq12i 2836 . . . . . . . . . 10 (𝑥 / 𝑥𝐶 = 𝑦 / 𝑥𝐶𝐶 = 𝐷)
2625imbi1i 352 . . . . . . . . 9 ((𝑥 / 𝑥𝐶 = 𝑦 / 𝑥𝐶𝑥 = 𝑦) ↔ (𝐶 = 𝐷𝑥 = 𝑦))
27262ralbii 3166 . . . . . . . 8 (∀𝑥𝐴𝑦𝐴 (𝑥 / 𝑥𝐶 = 𝑦 / 𝑥𝐶𝑥 = 𝑦) ↔ ∀𝑥𝐴𝑦𝐴 (𝐶 = 𝐷𝑥 = 𝑦))
28 nfcsb1v 3907 . . . . . . . . . . . 12 𝑥𝑦 / 𝑥𝐶
299, 28nfeq 2991 . . . . . . . . . . 11 𝑥𝑎 / 𝑥𝐶 = 𝑦 / 𝑥𝐶
30 nfv 1915 . . . . . . . . . . 11 𝑥 𝑎 = 𝑦
3129, 30nfim 1897 . . . . . . . . . 10 𝑥(𝑎 / 𝑥𝐶 = 𝑦 / 𝑥𝐶𝑎 = 𝑦)
32 nfv 1915 . . . . . . . . . 10 𝑦(𝑎 / 𝑥𝐶 = 𝑏 / 𝑥𝐶𝑎 = 𝑏)
33 csbeq1 3886 . . . . . . . . . . . 12 (𝑥 = 𝑎𝑥 / 𝑥𝐶 = 𝑎 / 𝑥𝐶)
3433eqeq1d 2823 . . . . . . . . . . 11 (𝑥 = 𝑎 → (𝑥 / 𝑥𝐶 = 𝑦 / 𝑥𝐶𝑎 / 𝑥𝐶 = 𝑦 / 𝑥𝐶))
35 equequ1 2032 . . . . . . . . . . 11 (𝑥 = 𝑎 → (𝑥 = 𝑦𝑎 = 𝑦))
3634, 35imbi12d 347 . . . . . . . . . 10 (𝑥 = 𝑎 → ((𝑥 / 𝑥𝐶 = 𝑦 / 𝑥𝐶𝑥 = 𝑦) ↔ (𝑎 / 𝑥𝐶 = 𝑦 / 𝑥𝐶𝑎 = 𝑦)))
37 csbeq1 3886 . . . . . . . . . . . 12 (𝑦 = 𝑏𝑦 / 𝑥𝐶 = 𝑏 / 𝑥𝐶)
3837eqeq2d 2832 . . . . . . . . . . 11 (𝑦 = 𝑏 → (𝑎 / 𝑥𝐶 = 𝑦 / 𝑥𝐶𝑎 / 𝑥𝐶 = 𝑏 / 𝑥𝐶))
39 equequ2 2033 . . . . . . . . . . 11 (𝑦 = 𝑏 → (𝑎 = 𝑦𝑎 = 𝑏))
4038, 39imbi12d 347 . . . . . . . . . 10 (𝑦 = 𝑏 → ((𝑎 / 𝑥𝐶 = 𝑦 / 𝑥𝐶𝑎 = 𝑦) ↔ (𝑎 / 𝑥𝐶 = 𝑏 / 𝑥𝐶𝑎 = 𝑏)))
4131, 32, 36, 40rspc2 3631 . . . . . . . . 9 ((𝑎𝐴𝑏𝐴) → (∀𝑥𝐴𝑦𝐴 (𝑥 / 𝑥𝐶 = 𝑦 / 𝑥𝐶𝑥 = 𝑦) → (𝑎 / 𝑥𝐶 = 𝑏 / 𝑥𝐶𝑎 = 𝑏)))
4241com12 32 . . . . . . . 8 (∀𝑥𝐴𝑦𝐴 (𝑥 / 𝑥𝐶 = 𝑦 / 𝑥𝐶𝑥 = 𝑦) → ((𝑎𝐴𝑏𝐴) → (𝑎 / 𝑥𝐶 = 𝑏 / 𝑥𝐶𝑎 = 𝑏)))
4327, 42sylbir 237 . . . . . . 7 (∀𝑥𝐴𝑦𝐴 (𝐶 = 𝐷𝑥 = 𝑦) → ((𝑎𝐴𝑏𝐴) → (𝑎 / 𝑥𝐶 = 𝑏 / 𝑥𝐶𝑎 = 𝑏)))
44 id 22 . . . . . . . 8 ((𝑎 / 𝑥𝐶 = 𝑏 / 𝑥𝐶𝑎 = 𝑏) → (𝑎 / 𝑥𝐶 = 𝑏 / 𝑥𝐶𝑎 = 𝑏))
45 csbeq1 3886 . . . . . . . 8 (𝑎 = 𝑏𝑎 / 𝑥𝐶 = 𝑏 / 𝑥𝐶)
4644, 45impbid1 227 . . . . . . 7 ((𝑎 / 𝑥𝐶 = 𝑏 / 𝑥𝐶𝑎 = 𝑏) → (𝑎 / 𝑥𝐶 = 𝑏 / 𝑥𝐶𝑎 = 𝑏))
4743, 46syl6 35 . . . . . 6 (∀𝑥𝐴𝑦𝐴 (𝐶 = 𝐷𝑥 = 𝑦) → ((𝑎𝐴𝑏𝐴) → (𝑎 / 𝑥𝐶 = 𝑏 / 𝑥𝐶𝑎 = 𝑏)))
4847adantl 484 . . . . 5 ((𝜑 ∧ ∀𝑥𝐴𝑦𝐴 (𝐶 = 𝐷𝑥 = 𝑦)) → ((𝑎𝐴𝑏𝐴) → (𝑎 / 𝑥𝐶 = 𝑏 / 𝑥𝐶𝑎 = 𝑏)))
4920, 48dom2d 8550 . . . 4 ((𝜑 ∧ ∀𝑥𝐴𝑦𝐴 (𝐶 = 𝐷𝑥 = 𝑦)) → (𝐵 ∈ V → 𝐴𝐵))
507, 49mpd 15 . . 3 ((𝜑 ∧ ∀𝑥𝐴𝑦𝐴 (𝐶 = 𝐷𝑥 = 𝑦)) → 𝐴𝐵)
513, 50mtand 814 . 2 (𝜑 → ¬ ∀𝑥𝐴𝑦𝐴 (𝐶 = 𝐷𝑥 = 𝑦))
52 ancom 463 . . . . . . 7 ((¬ 𝑥 = 𝑦𝐶 = 𝐷) ↔ (𝐶 = 𝐷 ∧ ¬ 𝑥 = 𝑦))
53 df-ne 3017 . . . . . . . 8 (𝑥𝑦 ↔ ¬ 𝑥 = 𝑦)
5453anbi1i 625 . . . . . . 7 ((𝑥𝑦𝐶 = 𝐷) ↔ (¬ 𝑥 = 𝑦𝐶 = 𝐷))
55 pm4.61 407 . . . . . . 7 (¬ (𝐶 = 𝐷𝑥 = 𝑦) ↔ (𝐶 = 𝐷 ∧ ¬ 𝑥 = 𝑦))
5652, 54, 553bitr4i 305 . . . . . 6 ((𝑥𝑦𝐶 = 𝐷) ↔ ¬ (𝐶 = 𝐷𝑥 = 𝑦))
5756rexbii 3247 . . . . 5 (∃𝑦𝐴 (𝑥𝑦𝐶 = 𝐷) ↔ ∃𝑦𝐴 ¬ (𝐶 = 𝐷𝑥 = 𝑦))
58 rexnal 3238 . . . . 5 (∃𝑦𝐴 ¬ (𝐶 = 𝐷𝑥 = 𝑦) ↔ ¬ ∀𝑦𝐴 (𝐶 = 𝐷𝑥 = 𝑦))
5957, 58bitri 277 . . . 4 (∃𝑦𝐴 (𝑥𝑦𝐶 = 𝐷) ↔ ¬ ∀𝑦𝐴 (𝐶 = 𝐷𝑥 = 𝑦))
6059rexbii 3247 . . 3 (∃𝑥𝐴𝑦𝐴 (𝑥𝑦𝐶 = 𝐷) ↔ ∃𝑥𝐴 ¬ ∀𝑦𝐴 (𝐶 = 𝐷𝑥 = 𝑦))
61 rexnal 3238 . . 3 (∃𝑥𝐴 ¬ ∀𝑦𝐴 (𝐶 = 𝐷𝑥 = 𝑦) ↔ ¬ ∀𝑥𝐴𝑦𝐴 (𝐶 = 𝐷𝑥 = 𝑦))
6260, 61bitri 277 . 2 (∃𝑥𝐴𝑦𝐴 (𝑥𝑦𝐶 = 𝐷) ↔ ¬ ∀𝑥𝐴𝑦𝐴 (𝐶 = 𝐷𝑥 = 𝑦))
6351, 62sylibr 236 1 (𝜑 → ∃𝑥𝐴𝑦𝐴 (𝑥𝑦𝐶 = 𝐷))
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wb 208  wa 398   = wceq 1537  wcel 2114  wne 3016  wral 3138  wrex 3139  Vcvv 3494  csb 3883   class class class wbr 5066  cdom 8507  csdm 8508
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1796  ax-4 1810  ax-5 1911  ax-6 1970  ax-7 2015  ax-8 2116  ax-9 2124  ax-10 2145  ax-11 2161  ax-12 2177  ax-ext 2793  ax-rep 5190  ax-sep 5203  ax-nul 5210  ax-pow 5266  ax-pr 5330  ax-un 7461
This theorem depends on definitions:  df-bi 209  df-an 399  df-or 844  df-3an 1085  df-tru 1540  df-ex 1781  df-nf 1785  df-sb 2070  df-mo 2622  df-eu 2654  df-clab 2800  df-cleq 2814  df-clel 2893  df-nfc 2963  df-ne 3017  df-ral 3143  df-rex 3144  df-reu 3145  df-rab 3147  df-v 3496  df-sbc 3773  df-csb 3884  df-dif 3939  df-un 3941  df-in 3943  df-ss 3952  df-nul 4292  df-if 4468  df-pw 4541  df-sn 4568  df-pr 4570  df-op 4574  df-uni 4839  df-iun 4921  df-br 5067  df-opab 5129  df-mpt 5147  df-id 5460  df-xp 5561  df-rel 5562  df-cnv 5563  df-co 5564  df-dm 5565  df-rn 5566  df-res 5567  df-ima 5568  df-iota 6314  df-fun 6357  df-fn 6358  df-f 6359  df-f1 6360  df-fo 6361  df-f1o 6362  df-fv 6363  df-er 8289  df-en 8510  df-dom 8511  df-sdom 8512
This theorem is referenced by:  fphpdo  39434  pellex  39452
  Copyright terms: Public domain W3C validator