Users' Mathboxes Mathbox for BJ < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >   Mathboxes  >  bj-gabima Structured version   Visualization version   GIF version

Theorem bj-gabima 37302
Description: Generalized class abstraction as a direct image.

TODO: improve the support lemmas elimag 6017 and fvelima 6893 to nonfreeness hypothesis (and for the latter, biconditional). (Contributed by BJ, 4-Oct-2024.)

Hypotheses
Ref Expression
bj-gabima.nf (𝜑 → ∀𝑥𝜑)
bj-gabima.nff (𝜑𝑥𝐹)
bj-gabima.fun (𝜑 → Fun 𝐹)
bj-gabima.dm (𝜑 → {𝑥𝜓} ⊆ dom 𝐹)
Assertion
Ref Expression
bj-gabima (𝜑 → {(𝐹𝑥) ∣ 𝑥𝜓} = (𝐹 “ {𝑥𝜓}))

Proof of Theorem bj-gabima
Dummy variables 𝑦 𝑧 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 bj-gabima.nf . . . 4 (𝜑 → ∀𝑥𝜑)
2 nfcvd 2902 . . . 4 (𝜑𝑥𝑦)
3 vex 3435 . . . . 5 𝑦 ∈ V
43a1i 11 . . . 4 (𝜑𝑦 ∈ V)
5 df-rex 3064 . . . . . 6 (∃𝑧 ∈ {𝑥𝜓} (𝐹𝑧) = 𝑦 ↔ ∃𝑧(𝑧 ∈ {𝑥𝜓} ∧ (𝐹𝑧) = 𝑦))
65a1i 11 . . . . 5 (𝜑 → (∃𝑧 ∈ {𝑥𝜓} (𝐹𝑧) = 𝑦 ↔ ∃𝑧(𝑧 ∈ {𝑥𝜓} ∧ (𝐹𝑧) = 𝑦)))
7 eqcom 2746 . . . . . . . 8 (𝑦 = (𝐹𝑧) ↔ (𝐹𝑧) = 𝑦)
8 df-clab 2718 . . . . . . . . 9 (𝑧 ∈ {𝑥𝜓} ↔ [𝑧 / 𝑥]𝜓)
98bicomi 225 . . . . . . . 8 ([𝑧 / 𝑥]𝜓𝑧 ∈ {𝑥𝜓})
107, 9anbi12ci 635 . . . . . . 7 ((𝑦 = (𝐹𝑧) ∧ [𝑧 / 𝑥]𝜓) ↔ (𝑧 ∈ {𝑥𝜓} ∧ (𝐹𝑧) = 𝑦))
1110exbii 1855 . . . . . 6 (∃𝑧(𝑦 = (𝐹𝑧) ∧ [𝑧 / 𝑥]𝜓) ↔ ∃𝑧(𝑧 ∈ {𝑥𝜓} ∧ (𝐹𝑧) = 𝑦))
1211a1i 11 . . . . 5 (𝜑 → (∃𝑧(𝑦 = (𝐹𝑧) ∧ [𝑧 / 𝑥]𝜓) ↔ ∃𝑧(𝑧 ∈ {𝑥𝜓} ∧ (𝐹𝑧) = 𝑦)))
131nf5i 2157 . . . . . 6 𝑥𝜑
14 nfcv 2901 . . . . . . . . 9 𝑥𝑦
1514a1i 11 . . . . . . . 8 (𝜑𝑥𝑦)
16 bj-gabima.nff . . . . . . . . 9 (𝜑𝑥𝐹)
17 nfcv 2901 . . . . . . . . . 10 𝑥𝑧
1817a1i 11 . . . . . . . . 9 (𝜑𝑥𝑧)
1916, 18nffvd 6840 . . . . . . . 8 (𝜑𝑥(𝐹𝑧))
2015, 19nfeqd 2911 . . . . . . 7 (𝜑 → Ⅎ𝑥 𝑦 = (𝐹𝑧))
21 nfs1v 2167 . . . . . . . 8 𝑥[𝑧 / 𝑥]𝜓
2221a1i 11 . . . . . . 7 (𝜑 → Ⅎ𝑥[𝑧 / 𝑥]𝜓)
2320, 22nfand 1904 . . . . . 6 (𝜑 → Ⅎ𝑥(𝑦 = (𝐹𝑧) ∧ [𝑧 / 𝑥]𝜓))
24 fveq2 6828 . . . . . . . . 9 (𝑧 = 𝑥 → (𝐹𝑧) = (𝐹𝑥))
2524eqeq2d 2750 . . . . . . . 8 (𝑧 = 𝑥 → (𝑦 = (𝐹𝑧) ↔ 𝑦 = (𝐹𝑥)))
26 sbequ12r 2264 . . . . . . . 8 (𝑧 = 𝑥 → ([𝑧 / 𝑥]𝜓𝜓))
2725, 26anbi12d 638 . . . . . . 7 (𝑧 = 𝑥 → ((𝑦 = (𝐹𝑧) ∧ [𝑧 / 𝑥]𝜓) ↔ (𝑦 = (𝐹𝑥) ∧ 𝜓)))
2827a1i 11 . . . . . 6 (𝜑 → (𝑧 = 𝑥 → ((𝑦 = (𝐹𝑧) ∧ [𝑧 / 𝑥]𝜓) ↔ (𝑦 = (𝐹𝑥) ∧ 𝜓))))
2913, 23, 28cbvexdw 2347 . . . . 5 (𝜑 → (∃𝑧(𝑦 = (𝐹𝑧) ∧ [𝑧 / 𝑥]𝜓) ↔ ∃𝑥(𝑦 = (𝐹𝑥) ∧ 𝜓)))
306, 12, 293bitr2rd 309 . . . 4 (𝜑 → (∃𝑥(𝑦 = (𝐹𝑥) ∧ 𝜓) ↔ ∃𝑧 ∈ {𝑥𝜓} (𝐹𝑧) = 𝑦))
311, 2, 4, 30bj-elgab 37301 . . 3 (𝜑 → (𝑦 ∈ {(𝐹𝑥) ∣ 𝑥𝜓} ↔ ∃𝑧 ∈ {𝑥𝜓} (𝐹𝑧) = 𝑦))
32 bj-gabima.fun . . . . 5 (𝜑 → Fun 𝐹)
3332funfnd 6517 . . . 4 (𝜑𝐹 Fn dom 𝐹)
34 bj-gabima.dm . . . 4 (𝜑 → {𝑥𝜓} ⊆ dom 𝐹)
3533, 34fvelimabd 6901 . . 3 (𝜑 → (𝑦 ∈ (𝐹 “ {𝑥𝜓}) ↔ ∃𝑧 ∈ {𝑥𝜓} (𝐹𝑧) = 𝑦))
3631, 35bitr4d 283 . 2 (𝜑 → (𝑦 ∈ {(𝐹𝑥) ∣ 𝑥𝜓} ↔ 𝑦 ∈ (𝐹 “ {𝑥𝜓})))
3736eqrdv 2737 1 (𝜑 → {(𝐹𝑥) ∣ 𝑥𝜓} = (𝐹 “ {𝑥𝜓}))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 207  wa 396  wal 1545   = wceq 1547  wex 1786  wnf 1790  [wsb 2073  wcel 2119  {cab 2717  wnfc 2886  wrex 3063  Vcvv 3431  wss 3883  dom cdm 5619  cima 5622  Fun wfun 6480  cfv 6486  {bj-cgab 37295
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 5219  ax-nul 5229  ax-pr 5363
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-rab 3392  df-v 3433  df-dif 3886  df-un 3888  df-in 3890  df-ss 3900  df-nul 4263  df-if 4456  df-sn 4557  df-pr 4559  df-op 4563  df-uni 4840  df-br 5074  df-opab 5136  df-id 5514  df-xp 5625  df-rel 5626  df-cnv 5627  df-co 5628  df-dm 5629  df-rn 5630  df-res 5631  df-ima 5632  df-iota 6442  df-fun 6488  df-fn 6489  df-fv 6494  df-bj-gab 37296
This theorem is referenced by: (None)
  Copyright terms: Public domain W3C validator