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

Theorem hashle2pr 14484
Description: A nonempty set of size less than or equal to two is an unordered pair of sets. (Contributed by AV, 24-Nov-2021.)
Assertion
Ref Expression
hashle2pr ((𝑃𝑉𝑃 ≠ ∅) → ((♯‘𝑃) ≤ 2 ↔ ∃𝑎𝑏 𝑃 = {𝑎, 𝑏}))
Distinct variable group:   𝑃,𝑎,𝑏
Allowed substitution hints:   𝑉(𝑎,𝑏)

Proof of Theorem hashle2pr
Dummy variable 𝑐 is distinct from all other variables.
StepHypRef Expression
1 hashxnn0 14346 . . . . . . 7 (𝑃𝑉 → (♯‘𝑃) ∈ ℕ0*)
2 xnn0le2is012 13243 . . . . . . 7 (((♯‘𝑃) ∈ ℕ0* ∧ (♯‘𝑃) ≤ 2) → ((♯‘𝑃) = 0 ∨ (♯‘𝑃) = 1 ∨ (♯‘𝑃) = 2))
31, 2sylan 589 . . . . . 6 ((𝑃𝑉 ∧ (♯‘𝑃) ≤ 2) → ((♯‘𝑃) = 0 ∨ (♯‘𝑃) = 1 ∨ (♯‘𝑃) = 2))
43ex 416 . . . . 5 (𝑃𝑉 → ((♯‘𝑃) ≤ 2 → ((♯‘𝑃) = 0 ∨ (♯‘𝑃) = 1 ∨ (♯‘𝑃) = 2)))
5 hasheq0 14370 . . . . . . . . 9 (𝑃𝑉 → ((♯‘𝑃) = 0 ↔ 𝑃 = ∅))
6 eqneqall 2967 . . . . . . . . 9 (𝑃 = ∅ → (𝑃 ≠ ∅ → ∃𝑎𝑏 𝑃 = {𝑎, 𝑏}))
75, 6biimtrdi 255 . . . . . . . 8 (𝑃𝑉 → ((♯‘𝑃) = 0 → (𝑃 ≠ ∅ → ∃𝑎𝑏 𝑃 = {𝑎, 𝑏})))
87com12 32 . . . . . . 7 ((♯‘𝑃) = 0 → (𝑃𝑉 → (𝑃 ≠ ∅ → ∃𝑎𝑏 𝑃 = {𝑎, 𝑏})))
9 hash1snb 14426 . . . . . . . . . . 11 (𝑃𝑉 → ((♯‘𝑃) = 1 ↔ ∃𝑐 𝑃 = {𝑐}))
10 vex 3457 . . . . . . . . . . . . 13 𝑐 ∈ V
11 preq12 4691 . . . . . . . . . . . . . . 15 ((𝑎 = 𝑐𝑏 = 𝑐) → {𝑎, 𝑏} = {𝑐, 𝑐})
12 dfsn2 4592 . . . . . . . . . . . . . . 15 {𝑐} = {𝑐, 𝑐}
1311, 12eqtr4di 2814 . . . . . . . . . . . . . 14 ((𝑎 = 𝑐𝑏 = 𝑐) → {𝑎, 𝑏} = {𝑐})
1413eqeq2d 2772 . . . . . . . . . . . . 13 ((𝑎 = 𝑐𝑏 = 𝑐) → (𝑃 = {𝑎, 𝑏} ↔ 𝑃 = {𝑐}))
1510, 10, 14spc2ev 3565 . . . . . . . . . . . 12 (𝑃 = {𝑐} → ∃𝑎𝑏 𝑃 = {𝑎, 𝑏})
1615exlimiv 1949 . . . . . . . . . . 11 (∃𝑐 𝑃 = {𝑐} → ∃𝑎𝑏 𝑃 = {𝑎, 𝑏})
179, 16biimtrdi 255 . . . . . . . . . 10 (𝑃𝑉 → ((♯‘𝑃) = 1 → ∃𝑎𝑏 𝑃 = {𝑎, 𝑏}))
1817imp 410 . . . . . . . . 9 ((𝑃𝑉 ∧ (♯‘𝑃) = 1) → ∃𝑎𝑏 𝑃 = {𝑎, 𝑏})
1918a1d 25 . . . . . . . 8 ((𝑃𝑉 ∧ (♯‘𝑃) = 1) → (𝑃 ≠ ∅ → ∃𝑎𝑏 𝑃 = {𝑎, 𝑏}))
2019expcom 417 . . . . . . 7 ((♯‘𝑃) = 1 → (𝑃𝑉 → (𝑃 ≠ ∅ → ∃𝑎𝑏 𝑃 = {𝑎, 𝑏})))
21 hash2pr 14476 . . . . . . . . 9 ((𝑃𝑉 ∧ (♯‘𝑃) = 2) → ∃𝑎𝑏 𝑃 = {𝑎, 𝑏})
2221a1d 25 . . . . . . . 8 ((𝑃𝑉 ∧ (♯‘𝑃) = 2) → (𝑃 ≠ ∅ → ∃𝑎𝑏 𝑃 = {𝑎, 𝑏}))
2322expcom 417 . . . . . . 7 ((♯‘𝑃) = 2 → (𝑃𝑉 → (𝑃 ≠ ∅ → ∃𝑎𝑏 𝑃 = {𝑎, 𝑏})))
248, 20, 233jaoi 1446 . . . . . 6 (((♯‘𝑃) = 0 ∨ (♯‘𝑃) = 1 ∨ (♯‘𝑃) = 2) → (𝑃𝑉 → (𝑃 ≠ ∅ → ∃𝑎𝑏 𝑃 = {𝑎, 𝑏})))
2524com12 32 . . . . 5 (𝑃𝑉 → (((♯‘𝑃) = 0 ∨ (♯‘𝑃) = 1 ∨ (♯‘𝑃) = 2) → (𝑃 ≠ ∅ → ∃𝑎𝑏 𝑃 = {𝑎, 𝑏})))
264, 25syld 47 . . . 4 (𝑃𝑉 → ((♯‘𝑃) ≤ 2 → (𝑃 ≠ ∅ → ∃𝑎𝑏 𝑃 = {𝑎, 𝑏})))
2726com23 86 . . 3 (𝑃𝑉 → (𝑃 ≠ ∅ → ((♯‘𝑃) ≤ 2 → ∃𝑎𝑏 𝑃 = {𝑎, 𝑏})))
2827imp 410 . 2 ((𝑃𝑉𝑃 ≠ ∅) → ((♯‘𝑃) ≤ 2 → ∃𝑎𝑏 𝑃 = {𝑎, 𝑏}))
29 fveq2 6862 . . . 4 (𝑃 = {𝑎, 𝑏} → (♯‘𝑃) = (♯‘{𝑎, 𝑏}))
30 hashprlei 14475 . . . . 5 ({𝑎, 𝑏} ∈ Fin ∧ (♯‘{𝑎, 𝑏}) ≤ 2)
3130simpri 489 . . . 4 (♯‘{𝑎, 𝑏}) ≤ 2
3229, 31eqbrtrdi 5136 . . 3 (𝑃 = {𝑎, 𝑏} → (♯‘𝑃) ≤ 2)
3332exlimivv 1951 . 2 (∃𝑎𝑏 𝑃 = {𝑎, 𝑏} → (♯‘𝑃) ≤ 2)
3428, 33impbid1 227 1 ((𝑃𝑉𝑃 ≠ ∅) → ((♯‘𝑃) ≤ 2 ↔ ∃𝑎𝑏 𝑃 = {𝑎, 𝑏}))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 208  wa 399  w3o 1096   = wceq 1559  wex 1798  wcel 2141  wne 2956  c0 4283  {csn 4579  {cpr 4581   class class class wbr 5097  cfv 6516  Fincfn 8921  0cc0 11067  1c1 11068  cle 11211  2c2 12266  0*cxnn0 12548  chash 14337
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1814  ax-4 1828  ax-5 1929  ax-6 1986  ax-7 2027  ax-8 2143  ax-9 2151  ax-10 2174  ax-11 2190  ax-12 2211  ax-ext 2733  ax-sep 5243  ax-nul 5253  ax-pow 5319  ax-pr 5387  ax-un 7713  ax-cnex 11123  ax-resscn 11124  ax-1cn 11125  ax-icn 11126  ax-addcl 11127  ax-addrcl 11128  ax-mulcl 11129  ax-mulrcl 11130  ax-mulcom 11131  ax-addass 11132  ax-mulass 11133  ax-distr 11134  ax-i2m1 11135  ax-1ne0 11136  ax-1rid 11137  ax-rnegex 11138  ax-rrecex 11139  ax-cnre 11140  ax-pre-lttri 11141  ax-pre-lttrn 11142  ax-pre-ltadd 11143  ax-pre-mulgt0 11144
This theorem depends on definitions:  df-bi 209  df-an 400  df-or 859  df-3or 1098  df-3an 1099  df-tru 1562  df-fal 1572  df-ex 1799  df-nf 1803  df-sb 2090  df-mo 2565  df-eu 2595  df-clab 2740  df-cleq 2753  df-clel 2836  df-nfc 2910  df-ne 2957  df-nel 3061  df-ral 3076  df-rex 3086  df-reu 3367  df-rab 3414  df-v 3455  df-sbc 3743  df-csb 3851  df-dif 3905  df-un 3907  df-in 3909  df-ss 3919  df-pss 3922  df-nul 4284  df-if 4478  df-pw 4554  df-sn 4580  df-pr 4582  df-op 4586  df-uni 4863  df-int 4903  df-iun 4948  df-br 5098  df-opab 5160  df-mpt 5179  df-tr 5205  df-id 5538  df-eprel 5543  df-po 5551  df-so 5552  df-fr 5596  df-we 5598  df-xp 5649  df-rel 5650  df-cnv 5651  df-co 5652  df-dm 5653  df-rn 5654  df-res 5655  df-ima 5656  df-pred 6283  df-ord 6344  df-on 6345  df-lim 6346  df-suc 6347  df-iota 6472  df-fun 6518  df-fn 6519  df-f 6520  df-f1 6521  df-fo 6522  df-f1o 6523  df-fv 6524  df-riota 7348  df-ov 7394  df-oprab 7395  df-mpo 7396  df-om 7842  df-1st 7965  df-2nd 7966  df-frecs 8256  df-wrecs 8287  df-recs 8336  df-rdg 8375  df-1o 8431  df-2o 8432  df-oadd 8435  df-er 8672  df-en 8922  df-dom 8923  df-sdom 8924  df-fin 8925  df-dju 9853  df-card 9891  df-pnf 11212  df-mnf 11213  df-xr 11214  df-ltxr 11215  df-le 11216  df-sub 11410  df-neg 11411  df-nn 12205  df-2 12274  df-n0 12476  df-xnn0 12549  df-z 12563  df-uz 12834  df-fz 13507  df-hash 14338
This theorem is referenced by:  hashle2prv  14485
  Copyright terms: Public domain W3C validator