Users' Mathboxes Mathbox for Glauco Siliprandi < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >   Mathboxes  >  disjf1o Structured version   Visualization version   GIF version

Theorem disjf1o 45638
Description: A bijection built from disjoint sets. (Contributed by Glauco Siliprandi, 17-Aug-2020.)
Hypotheses
Ref Expression
disjf1o.xph 𝑥𝜑
disjf1o.f 𝐹 = (𝑥𝐴𝐵)
disjf1o.b ((𝜑𝑥𝐴) → 𝐵𝑉)
disjf1o.dj (𝜑Disj 𝑥𝐴 𝐵)
disjf1o.d 𝐶 = {𝑥𝐴𝐵 ≠ ∅}
disjf1o.e 𝐷 = (ran 𝐹 ∖ {∅})
Assertion
Ref Expression
disjf1o (𝜑 → (𝐹𝐶):𝐶1-1-onto𝐷)
Distinct variable groups:   𝑥,𝐴   𝑥,𝐶   𝑥,𝐷   𝑥,𝑉
Allowed substitution hints:   𝜑(𝑥)   𝐵(𝑥)   𝐹(𝑥)

Proof of Theorem disjf1o
Dummy variable 𝑦 is distinct from all other variables.
StepHypRef Expression
1 disjf1o.xph . . . 4 𝑥𝜑
2 eqid 2739 . . . 4 (𝑥𝐶𝐵) = (𝑥𝐶𝐵)
3 simpl 483 . . . . 5 ((𝜑𝑥𝐶) → 𝜑)
4 disjf1o.d . . . . . . . 8 𝐶 = {𝑥𝐴𝐵 ≠ ∅}
5 ssrab2 4011 . . . . . . . 8 {𝑥𝐴𝐵 ≠ ∅} ⊆ 𝐴
64, 5eqsstri 3961 . . . . . . 7 𝐶𝐴
7 id 22 . . . . . . 7 (𝑥𝐶𝑥𝐶)
86, 7sselid 3913 . . . . . 6 (𝑥𝐶𝑥𝐴)
98adantl 482 . . . . 5 ((𝜑𝑥𝐶) → 𝑥𝐴)
10 disjf1o.b . . . . 5 ((𝜑𝑥𝐴) → 𝐵𝑉)
113, 9, 10syl2anc 590 . . . 4 ((𝜑𝑥𝐶) → 𝐵𝑉)
127, 4eleqtrdi 2849 . . . . . . 7 (𝑥𝐶𝑥 ∈ {𝑥𝐴𝐵 ≠ ∅})
13 rabid 3412 . . . . . . . 8 (𝑥 ∈ {𝑥𝐴𝐵 ≠ ∅} ↔ (𝑥𝐴𝐵 ≠ ∅))
1413a1i 11 . . . . . . 7 (𝑥𝐶 → (𝑥 ∈ {𝑥𝐴𝐵 ≠ ∅} ↔ (𝑥𝐴𝐵 ≠ ∅)))
1512, 14mpbid 233 . . . . . 6 (𝑥𝐶 → (𝑥𝐴𝐵 ≠ ∅))
1615simprd 496 . . . . 5 (𝑥𝐶𝐵 ≠ ∅)
1716adantl 482 . . . 4 ((𝜑𝑥𝐶) → 𝐵 ≠ ∅)
186a1i 11 . . . . 5 (𝜑𝐶𝐴)
19 disjf1o.dj . . . . 5 (𝜑Disj 𝑥𝐴 𝐵)
20 disjss1 5045 . . . . 5 (𝐶𝐴 → (Disj 𝑥𝐴 𝐵Disj 𝑥𝐶 𝐵))
2118, 19, 20sylc 65 . . . 4 (𝜑Disj 𝑥𝐶 𝐵)
221, 2, 11, 17, 21disjf1 45630 . . 3 (𝜑 → (𝑥𝐶𝐵):𝐶1-1𝑉)
23 f1f1orn 6778 . . 3 ((𝑥𝐶𝐵):𝐶1-1𝑉 → (𝑥𝐶𝐵):𝐶1-1-onto→ran (𝑥𝐶𝐵))
2422, 23syl 17 . 2 (𝜑 → (𝑥𝐶𝐵):𝐶1-1-onto→ran (𝑥𝐶𝐵))
25 disjf1o.f . . . . . 6 𝐹 = (𝑥𝐴𝐵)
2625a1i 11 . . . . 5 (𝜑𝐹 = (𝑥𝐴𝐵))
2726reseq1d 5930 . . . 4 (𝜑 → (𝐹𝐶) = ((𝑥𝐴𝐵) ↾ 𝐶))
2818resmptd 5992 . . . 4 (𝜑 → ((𝑥𝐴𝐵) ↾ 𝐶) = (𝑥𝐶𝐵))
2927, 28eqtrd 2774 . . 3 (𝜑 → (𝐹𝐶) = (𝑥𝐶𝐵))
30 eqidd 2740 . . 3 (𝜑𝐶 = 𝐶)
31 simpl 483 . . . . . . 7 ((𝜑𝑦𝐷) → 𝜑)
32 id 22 . . . . . . . . . 10 (𝑦𝐷𝑦𝐷)
33 disjf1o.e . . . . . . . . . 10 𝐷 = (ran 𝐹 ∖ {∅})
3432, 33eleqtrdi 2849 . . . . . . . . 9 (𝑦𝐷𝑦 ∈ (ran 𝐹 ∖ {∅}))
35 eldifsni 4723 . . . . . . . . 9 (𝑦 ∈ (ran 𝐹 ∖ {∅}) → 𝑦 ≠ ∅)
3634, 35syl 17 . . . . . . . 8 (𝑦𝐷𝑦 ≠ ∅)
3736adantl 482 . . . . . . 7 ((𝜑𝑦𝐷) → 𝑦 ≠ ∅)
38 eldifi 4061 . . . . . . . . . 10 (𝑦 ∈ (ran 𝐹 ∖ {∅}) → 𝑦 ∈ ran 𝐹)
3934, 38syl 17 . . . . . . . . 9 (𝑦𝐷𝑦 ∈ ran 𝐹)
4025elrnmpt 5900 . . . . . . . . . 10 (𝑦 ∈ ran 𝐹 → (𝑦 ∈ ran 𝐹 ↔ ∃𝑥𝐴 𝑦 = 𝐵))
4139, 40syl 17 . . . . . . . . 9 (𝑦𝐷 → (𝑦 ∈ ran 𝐹 ↔ ∃𝑥𝐴 𝑦 = 𝐵))
4239, 41mpbid 233 . . . . . . . 8 (𝑦𝐷 → ∃𝑥𝐴 𝑦 = 𝐵)
4342adantl 482 . . . . . . 7 ((𝜑𝑦𝐷) → ∃𝑥𝐴 𝑦 = 𝐵)
44 nfv 1921 . . . . . . . . . 10 𝑥 𝑦 ≠ ∅
451, 44nfan 1906 . . . . . . . . 9 𝑥(𝜑𝑦 ≠ ∅)
46 nfcv 2901 . . . . . . . . . 10 𝑥𝑦
47 nfmpt1 5171 . . . . . . . . . . 11 𝑥(𝑥𝐶𝐵)
4847nfrn 5894 . . . . . . . . . 10 𝑥ran (𝑥𝐶𝐵)
4946, 48nfel 2915 . . . . . . . . 9 𝑥 𝑦 ∈ ran (𝑥𝐶𝐵)
50 simp3 1144 . . . . . . . . . . . 12 ((𝑦 ≠ ∅ ∧ 𝑥𝐴𝑦 = 𝐵) → 𝑦 = 𝐵)
51 simp2 1143 . . . . . . . . . . . . . . . 16 ((𝑦 ≠ ∅ ∧ 𝑥𝐴𝑦 = 𝐵) → 𝑥𝐴)
52 id 22 . . . . . . . . . . . . . . . . . . . 20 (𝑦 = 𝐵𝑦 = 𝐵)
5352eqcomd 2745 . . . . . . . . . . . . . . . . . . 19 (𝑦 = 𝐵𝐵 = 𝑦)
5453adantl 482 . . . . . . . . . . . . . . . . . 18 ((𝑦 ≠ ∅ ∧ 𝑦 = 𝐵) → 𝐵 = 𝑦)
55 simpl 483 . . . . . . . . . . . . . . . . . 18 ((𝑦 ≠ ∅ ∧ 𝑦 = 𝐵) → 𝑦 ≠ ∅)
5654, 55eqnetrd 3001 . . . . . . . . . . . . . . . . 17 ((𝑦 ≠ ∅ ∧ 𝑦 = 𝐵) → 𝐵 ≠ ∅)
57563adant2 1137 . . . . . . . . . . . . . . . 16 ((𝑦 ≠ ∅ ∧ 𝑥𝐴𝑦 = 𝐵) → 𝐵 ≠ ∅)
5851, 57jca 516 . . . . . . . . . . . . . . 15 ((𝑦 ≠ ∅ ∧ 𝑥𝐴𝑦 = 𝐵) → (𝑥𝐴𝐵 ≠ ∅))
5958, 13sylibr 235 . . . . . . . . . . . . . 14 ((𝑦 ≠ ∅ ∧ 𝑥𝐴𝑦 = 𝐵) → 𝑥 ∈ {𝑥𝐴𝐵 ≠ ∅})
604eqcomi 2748 . . . . . . . . . . . . . . 15 {𝑥𝐴𝐵 ≠ ∅} = 𝐶
6160a1i 11 . . . . . . . . . . . . . 14 ((𝑦 ≠ ∅ ∧ 𝑥𝐴𝑦 = 𝐵) → {𝑥𝐴𝐵 ≠ ∅} = 𝐶)
6259, 61eleqtrd 2841 . . . . . . . . . . . . 13 ((𝑦 ≠ ∅ ∧ 𝑥𝐴𝑦 = 𝐵) → 𝑥𝐶)
63 eqvisset 3451 . . . . . . . . . . . . . 14 (𝑦 = 𝐵𝐵 ∈ V)
64633ad2ant3 1141 . . . . . . . . . . . . 13 ((𝑦 ≠ ∅ ∧ 𝑥𝐴𝑦 = 𝐵) → 𝐵 ∈ V)
652elrnmpt1 5902 . . . . . . . . . . . . 13 ((𝑥𝐶𝐵 ∈ V) → 𝐵 ∈ ran (𝑥𝐶𝐵))
6662, 64, 65syl2anc 590 . . . . . . . . . . . 12 ((𝑦 ≠ ∅ ∧ 𝑥𝐴𝑦 = 𝐵) → 𝐵 ∈ ran (𝑥𝐶𝐵))
6750, 66eqeltrd 2839 . . . . . . . . . . 11 ((𝑦 ≠ ∅ ∧ 𝑥𝐴𝑦 = 𝐵) → 𝑦 ∈ ran (𝑥𝐶𝐵))
68673adant1l 1183 . . . . . . . . . 10 (((𝜑𝑦 ≠ ∅) ∧ 𝑥𝐴𝑦 = 𝐵) → 𝑦 ∈ ran (𝑥𝐶𝐵))
69683exp 1125 . . . . . . . . 9 ((𝜑𝑦 ≠ ∅) → (𝑥𝐴 → (𝑦 = 𝐵𝑦 ∈ ran (𝑥𝐶𝐵))))
7045, 49, 69rexlimd 3246 . . . . . . . 8 ((𝜑𝑦 ≠ ∅) → (∃𝑥𝐴 𝑦 = 𝐵𝑦 ∈ ran (𝑥𝐶𝐵)))
7170imp 407 . . . . . . 7 (((𝜑𝑦 ≠ ∅) ∧ ∃𝑥𝐴 𝑦 = 𝐵) → 𝑦 ∈ ran (𝑥𝐶𝐵))
7231, 37, 43, 71syl21anc 843 . . . . . 6 ((𝜑𝑦𝐷) → 𝑦 ∈ ran (𝑥𝐶𝐵))
7372ralrimiva 3131 . . . . 5 (𝜑 → ∀𝑦𝐷 𝑦 ∈ ran (𝑥𝐶𝐵))
74 dfss3 3904 . . . . 5 (𝐷 ⊆ ran (𝑥𝐶𝐵) ↔ ∀𝑦𝐷 𝑦 ∈ ran (𝑥𝐶𝐵))
7573, 74sylibr 235 . . . 4 (𝜑𝐷 ⊆ ran (𝑥𝐶𝐵))
76 simpl 483 . . . . 5 ((𝜑𝑦 ∈ ran (𝑥𝐶𝐵)) → 𝜑)
77 vex 3435 . . . . . . 7 𝑦 ∈ V
782elrnmpt 5900 . . . . . . 7 (𝑦 ∈ V → (𝑦 ∈ ran (𝑥𝐶𝐵) ↔ ∃𝑥𝐶 𝑦 = 𝐵))
7977, 78ax-mp 5 . . . . . 6 (𝑦 ∈ ran (𝑥𝐶𝐵) ↔ ∃𝑥𝐶 𝑦 = 𝐵)
8079bilani 505 . . . . 5 ((𝜑𝑦 ∈ ran (𝑥𝐶𝐵)) → ∃𝑥𝐶 𝑦 = 𝐵)
81 nfv 1921 . . . . . . 7 𝑥 𝑦𝐷
82 simpr 485 . . . . . . . . . . . 12 ((𝑥𝐶𝑦 = 𝐵) → 𝑦 = 𝐵)
838adantr 481 . . . . . . . . . . . . 13 ((𝑥𝐶𝑦 = 𝐵) → 𝑥𝐴)
8482, 63syl 17 . . . . . . . . . . . . 13 ((𝑥𝐶𝑦 = 𝐵) → 𝐵 ∈ V)
8525elrnmpt1 5902 . . . . . . . . . . . . 13 ((𝑥𝐴𝐵 ∈ V) → 𝐵 ∈ ran 𝐹)
8683, 84, 85syl2anc 590 . . . . . . . . . . . 12 ((𝑥𝐶𝑦 = 𝐵) → 𝐵 ∈ ran 𝐹)
8782, 86eqeltrd 2839 . . . . . . . . . . 11 ((𝑥𝐶𝑦 = 𝐵) → 𝑦 ∈ ran 𝐹)
88873adant1 1136 . . . . . . . . . 10 ((𝜑𝑥𝐶𝑦 = 𝐵) → 𝑦 ∈ ran 𝐹)
8916adantr 481 . . . . . . . . . . . . 13 ((𝑥𝐶𝑦 = 𝐵) → 𝐵 ≠ ∅)
9082, 89eqnetrd 3001 . . . . . . . . . . . 12 ((𝑥𝐶𝑦 = 𝐵) → 𝑦 ≠ ∅)
91 nelsn 4598 . . . . . . . . . . . 12 (𝑦 ≠ ∅ → ¬ 𝑦 ∈ {∅})
9290, 91syl 17 . . . . . . . . . . 11 ((𝑥𝐶𝑦 = 𝐵) → ¬ 𝑦 ∈ {∅})
93923adant1 1136 . . . . . . . . . 10 ((𝜑𝑥𝐶𝑦 = 𝐵) → ¬ 𝑦 ∈ {∅})
9488, 93eldifd 3894 . . . . . . . . 9 ((𝜑𝑥𝐶𝑦 = 𝐵) → 𝑦 ∈ (ran 𝐹 ∖ {∅}))
9594, 33eleqtrrdi 2850 . . . . . . . 8 ((𝜑𝑥𝐶𝑦 = 𝐵) → 𝑦𝐷)
96953exp 1125 . . . . . . 7 (𝜑 → (𝑥𝐶 → (𝑦 = 𝐵𝑦𝐷)))
971, 81, 96rexlimd 3246 . . . . . 6 (𝜑 → (∃𝑥𝐶 𝑦 = 𝐵𝑦𝐷))
9897imp 407 . . . . 5 ((𝜑 ∧ ∃𝑥𝐶 𝑦 = 𝐵) → 𝑦𝐷)
9976, 80, 98syl2anc 590 . . . 4 ((𝜑𝑦 ∈ ran (𝑥𝐶𝐵)) → 𝑦𝐷)
10075, 99eqelssd 3936 . . 3 (𝜑𝐷 = ran (𝑥𝐶𝐵))
10129, 30, 100f1oeq123d 6761 . 2 (𝜑 → ((𝐹𝐶):𝐶1-1-onto𝐷 ↔ (𝑥𝐶𝐵):𝐶1-1-onto→ran (𝑥𝐶𝐵)))
10224, 101mpbird 258 1 (𝜑 → (𝐹𝐶):𝐶1-1-onto𝐷)
Colors of variables: wff setvar class
Syntax hints:  ¬ wn 3  wi 4  wb 207  wa 396  w3a 1092   = wceq 1547  wnf 1790  wcel 2119  wne 2934  wral 3053  wrex 3063  {crab 3391  Vcvv 3431  cdif 3880  wss 3883  c0 4261  {csn 4555  Disj wdisj 5039  cmpt 5153  ran crn 5619  cres 5620  1-1wf1 6482  1-1-ontowf1o 6484
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1802  ax-4 1816  ax-5 1917  ax-6 1974  ax-7 2015  ax-8 2121  ax-9 2129  ax-10 2152  ax-11 2168  ax-12 2189  ax-ext 2711  ax-sep 5218  ax-nul 5228  ax-pr 5362
This theorem depends on definitions:  df-bi 208  df-an 397  df-or 854  df-3an 1094  df-tru 1550  df-fal 1560  df-ex 1787  df-nf 1791  df-sb 2074  df-mo 2543  df-eu 2573  df-clab 2718  df-cleq 2731  df-clel 2814  df-nfc 2888  df-ne 2935  df-ral 3054  df-rex 3064  df-rmo 3344  df-rab 3392  df-v 3433  df-sbc 3724  df-csb 3832  df-dif 3886  df-un 3888  df-in 3890  df-ss 3900  df-nul 4262  df-if 4455  df-sn 4556  df-pr 4558  df-op 4562  df-uni 4839  df-disj 5040  df-br 5073  df-opab 5135  df-mpt 5154  df-id 5513  df-xp 5624  df-rel 5625  df-cnv 5626  df-co 5627  df-dm 5628  df-rn 5629  df-res 5630  df-ima 5631  df-iota 6441  df-fun 6487  df-fn 6488  df-f 6489  df-f1 6490  df-fo 6491  df-f1o 6492  df-fv 6493
This theorem is referenced by:  sge0fodjrnlem  46859
  Copyright terms: Public domain W3C validator