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

Theorem tgjustf 28451
Description: Given any function 𝐹, equality of the image by 𝐹 is an equivalence relation. (Contributed by Thierry Arnoux, 25-Jan-2023.)
Assertion
Ref Expression
tgjustf (𝐴𝑉 → ∃𝑟(𝑟 Er 𝐴 ∧ ∀𝑥𝐴𝑦𝐴 (𝑥𝑟𝑦 ↔ (𝐹𝑥) = (𝐹𝑦))))
Distinct variable groups:   𝐴,𝑟,𝑥,𝑦   𝐹,𝑟,𝑥,𝑦
Allowed substitution hints:   𝑉(𝑥,𝑦,𝑟)

Proof of Theorem tgjustf
Dummy variables 𝑢 𝑣 𝑧 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 relopabv 5760 . . 3 Rel {⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}
2 ancom 460 . . . . . 6 ((𝑥𝐴𝑦𝐴) ↔ (𝑦𝐴𝑥𝐴))
3 eqcom 2738 . . . . . 6 ((𝐹𝑥) = (𝐹𝑦) ↔ (𝐹𝑦) = (𝐹𝑥))
42, 3anbi12i 628 . . . . 5 (((𝑥𝐴𝑦𝐴) ∧ (𝐹𝑥) = (𝐹𝑦)) ↔ ((𝑦𝐴𝑥𝐴) ∧ (𝐹𝑦) = (𝐹𝑥)))
5 simpl 482 . . . . . . . 8 ((𝑢 = 𝑥𝑣 = 𝑦) → 𝑢 = 𝑥)
65fveq2d 6826 . . . . . . 7 ((𝑢 = 𝑥𝑣 = 𝑦) → (𝐹𝑢) = (𝐹𝑥))
7 simpr 484 . . . . . . . 8 ((𝑢 = 𝑥𝑣 = 𝑦) → 𝑣 = 𝑦)
87fveq2d 6826 . . . . . . 7 ((𝑢 = 𝑥𝑣 = 𝑦) → (𝐹𝑣) = (𝐹𝑦))
96, 8eqeq12d 2747 . . . . . 6 ((𝑢 = 𝑥𝑣 = 𝑦) → ((𝐹𝑢) = (𝐹𝑣) ↔ (𝐹𝑥) = (𝐹𝑦)))
10 eqid 2731 . . . . . 6 {⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))} = {⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}
119, 10brab2a 5707 . . . . 5 (𝑥{⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}𝑦 ↔ ((𝑥𝐴𝑦𝐴) ∧ (𝐹𝑥) = (𝐹𝑦)))
12 simpl 482 . . . . . . . 8 ((𝑢 = 𝑦𝑣 = 𝑥) → 𝑢 = 𝑦)
1312fveq2d 6826 . . . . . . 7 ((𝑢 = 𝑦𝑣 = 𝑥) → (𝐹𝑢) = (𝐹𝑦))
14 simpr 484 . . . . . . . 8 ((𝑢 = 𝑦𝑣 = 𝑥) → 𝑣 = 𝑥)
1514fveq2d 6826 . . . . . . 7 ((𝑢 = 𝑦𝑣 = 𝑥) → (𝐹𝑣) = (𝐹𝑥))
1613, 15eqeq12d 2747 . . . . . 6 ((𝑢 = 𝑦𝑣 = 𝑥) → ((𝐹𝑢) = (𝐹𝑣) ↔ (𝐹𝑦) = (𝐹𝑥)))
1716, 10brab2a 5707 . . . . 5 (𝑦{⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}𝑥 ↔ ((𝑦𝐴𝑥𝐴) ∧ (𝐹𝑦) = (𝐹𝑥)))
184, 11, 173bitr4i 303 . . . 4 (𝑥{⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}𝑦𝑦{⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}𝑥)
1918biimpi 216 . . 3 (𝑥{⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}𝑦𝑦{⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}𝑥)
20 simplll 774 . . . . 5 ((((𝑥𝐴𝑦𝐴) ∧ (𝐹𝑥) = (𝐹𝑦)) ∧ ((𝑦𝐴𝑧𝐴) ∧ (𝐹𝑦) = (𝐹𝑧))) → 𝑥𝐴)
21 simprlr 779 . . . . 5 ((((𝑥𝐴𝑦𝐴) ∧ (𝐹𝑥) = (𝐹𝑦)) ∧ ((𝑦𝐴𝑧𝐴) ∧ (𝐹𝑦) = (𝐹𝑧))) → 𝑧𝐴)
22 simplr 768 . . . . . 6 ((((𝑥𝐴𝑦𝐴) ∧ (𝐹𝑥) = (𝐹𝑦)) ∧ ((𝑦𝐴𝑧𝐴) ∧ (𝐹𝑦) = (𝐹𝑧))) → (𝐹𝑥) = (𝐹𝑦))
23 simprr 772 . . . . . 6 ((((𝑥𝐴𝑦𝐴) ∧ (𝐹𝑥) = (𝐹𝑦)) ∧ ((𝑦𝐴𝑧𝐴) ∧ (𝐹𝑦) = (𝐹𝑧))) → (𝐹𝑦) = (𝐹𝑧))
2422, 23eqtrd 2766 . . . . 5 ((((𝑥𝐴𝑦𝐴) ∧ (𝐹𝑥) = (𝐹𝑦)) ∧ ((𝑦𝐴𝑧𝐴) ∧ (𝐹𝑦) = (𝐹𝑧))) → (𝐹𝑥) = (𝐹𝑧))
2520, 21, 24jca31 514 . . . 4 ((((𝑥𝐴𝑦𝐴) ∧ (𝐹𝑥) = (𝐹𝑦)) ∧ ((𝑦𝐴𝑧𝐴) ∧ (𝐹𝑦) = (𝐹𝑧))) → ((𝑥𝐴𝑧𝐴) ∧ (𝐹𝑥) = (𝐹𝑧)))
26 simpl 482 . . . . . . . 8 ((𝑢 = 𝑦𝑣 = 𝑧) → 𝑢 = 𝑦)
2726fveq2d 6826 . . . . . . 7 ((𝑢 = 𝑦𝑣 = 𝑧) → (𝐹𝑢) = (𝐹𝑦))
28 simpr 484 . . . . . . . 8 ((𝑢 = 𝑦𝑣 = 𝑧) → 𝑣 = 𝑧)
2928fveq2d 6826 . . . . . . 7 ((𝑢 = 𝑦𝑣 = 𝑧) → (𝐹𝑣) = (𝐹𝑧))
3027, 29eqeq12d 2747 . . . . . 6 ((𝑢 = 𝑦𝑣 = 𝑧) → ((𝐹𝑢) = (𝐹𝑣) ↔ (𝐹𝑦) = (𝐹𝑧)))
3130, 10brab2a 5707 . . . . 5 (𝑦{⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}𝑧 ↔ ((𝑦𝐴𝑧𝐴) ∧ (𝐹𝑦) = (𝐹𝑧)))
3211, 31anbi12i 628 . . . 4 ((𝑥{⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}𝑦𝑦{⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}𝑧) ↔ (((𝑥𝐴𝑦𝐴) ∧ (𝐹𝑥) = (𝐹𝑦)) ∧ ((𝑦𝐴𝑧𝐴) ∧ (𝐹𝑦) = (𝐹𝑧))))
33 simpl 482 . . . . . . 7 ((𝑢 = 𝑥𝑣 = 𝑧) → 𝑢 = 𝑥)
3433fveq2d 6826 . . . . . 6 ((𝑢 = 𝑥𝑣 = 𝑧) → (𝐹𝑢) = (𝐹𝑥))
35 simpr 484 . . . . . . 7 ((𝑢 = 𝑥𝑣 = 𝑧) → 𝑣 = 𝑧)
3635fveq2d 6826 . . . . . 6 ((𝑢 = 𝑥𝑣 = 𝑧) → (𝐹𝑣) = (𝐹𝑧))
3734, 36eqeq12d 2747 . . . . 5 ((𝑢 = 𝑥𝑣 = 𝑧) → ((𝐹𝑢) = (𝐹𝑣) ↔ (𝐹𝑥) = (𝐹𝑧)))
3837, 10brab2a 5707 . . . 4 (𝑥{⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}𝑧 ↔ ((𝑥𝐴𝑧𝐴) ∧ (𝐹𝑥) = (𝐹𝑧)))
3925, 32, 383imtr4i 292 . . 3 ((𝑥{⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}𝑦𝑦{⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}𝑧) → 𝑥{⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}𝑧)
40 eqid 2731 . . . . 5 (𝐹𝑥) = (𝐹𝑥)
4140biantru 529 . . . 4 ((𝑥𝐴𝑥𝐴) ↔ ((𝑥𝐴𝑥𝐴) ∧ (𝐹𝑥) = (𝐹𝑥)))
42 pm4.24 563 . . . 4 (𝑥𝐴 ↔ (𝑥𝐴𝑥𝐴))
43 simpl 482 . . . . . . 7 ((𝑢 = 𝑥𝑣 = 𝑥) → 𝑢 = 𝑥)
4443fveq2d 6826 . . . . . 6 ((𝑢 = 𝑥𝑣 = 𝑥) → (𝐹𝑢) = (𝐹𝑥))
45 simpr 484 . . . . . . 7 ((𝑢 = 𝑥𝑣 = 𝑥) → 𝑣 = 𝑥)
4645fveq2d 6826 . . . . . 6 ((𝑢 = 𝑥𝑣 = 𝑥) → (𝐹𝑣) = (𝐹𝑥))
4744, 46eqeq12d 2747 . . . . 5 ((𝑢 = 𝑥𝑣 = 𝑥) → ((𝐹𝑢) = (𝐹𝑣) ↔ (𝐹𝑥) = (𝐹𝑥)))
4847, 10brab2a 5707 . . . 4 (𝑥{⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}𝑥 ↔ ((𝑥𝐴𝑥𝐴) ∧ (𝐹𝑥) = (𝐹𝑥)))
4941, 42, 483bitr4i 303 . . 3 (𝑥𝐴𝑥{⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}𝑥)
501, 19, 39, 49iseri 8649 . 2 {⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))} Er 𝐴
5111baib 535 . . 3 ((𝑥𝐴𝑦𝐴) → (𝑥{⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}𝑦 ↔ (𝐹𝑥) = (𝐹𝑦)))
5251rgen2 3172 . 2 𝑥𝐴𝑦𝐴 (𝑥{⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}𝑦 ↔ (𝐹𝑥) = (𝐹𝑦))
53 id 22 . . . 4 (𝐴𝑉𝐴𝑉)
54 simprll 778 . . . 4 ((𝐴𝑉 ∧ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))) → 𝑢𝐴)
55 simprlr 779 . . . 4 ((𝐴𝑉 ∧ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))) → 𝑣𝐴)
5653, 53, 54, 55opabex2 7989 . . 3 (𝐴𝑉 → {⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))} ∈ V)
57 ereq1 8629 . . . . 5 (𝑟 = {⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))} → (𝑟 Er 𝐴 ↔ {⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))} Er 𝐴))
58 simpl 482 . . . . . . . 8 ((𝑟 = {⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))} ∧ (𝑥𝐴𝑦𝐴)) → 𝑟 = {⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))})
5958breqd 5100 . . . . . . 7 ((𝑟 = {⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))} ∧ (𝑥𝐴𝑦𝐴)) → (𝑥𝑟𝑦𝑥{⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}𝑦))
6059bibi1d 343 . . . . . 6 ((𝑟 = {⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))} ∧ (𝑥𝐴𝑦𝐴)) → ((𝑥𝑟𝑦 ↔ (𝐹𝑥) = (𝐹𝑦)) ↔ (𝑥{⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}𝑦 ↔ (𝐹𝑥) = (𝐹𝑦))))
61602ralbidva 3194 . . . . 5 (𝑟 = {⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))} → (∀𝑥𝐴𝑦𝐴 (𝑥𝑟𝑦 ↔ (𝐹𝑥) = (𝐹𝑦)) ↔ ∀𝑥𝐴𝑦𝐴 (𝑥{⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}𝑦 ↔ (𝐹𝑥) = (𝐹𝑦))))
6257, 61anbi12d 632 . . . 4 (𝑟 = {⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))} → ((𝑟 Er 𝐴 ∧ ∀𝑥𝐴𝑦𝐴 (𝑥𝑟𝑦 ↔ (𝐹𝑥) = (𝐹𝑦))) ↔ ({⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))} Er 𝐴 ∧ ∀𝑥𝐴𝑦𝐴 (𝑥{⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}𝑦 ↔ (𝐹𝑥) = (𝐹𝑦)))))
6362spcegv 3547 . . 3 ({⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))} ∈ V → (({⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))} Er 𝐴 ∧ ∀𝑥𝐴𝑦𝐴 (𝑥{⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}𝑦 ↔ (𝐹𝑥) = (𝐹𝑦))) → ∃𝑟(𝑟 Er 𝐴 ∧ ∀𝑥𝐴𝑦𝐴 (𝑥𝑟𝑦 ↔ (𝐹𝑥) = (𝐹𝑦)))))
6456, 63syl 17 . 2 (𝐴𝑉 → (({⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))} Er 𝐴 ∧ ∀𝑥𝐴𝑦𝐴 (𝑥{⟨𝑢, 𝑣⟩ ∣ ((𝑢𝐴𝑣𝐴) ∧ (𝐹𝑢) = (𝐹𝑣))}𝑦 ↔ (𝐹𝑥) = (𝐹𝑦))) → ∃𝑟(𝑟 Er 𝐴 ∧ ∀𝑥𝐴𝑦𝐴 (𝑥𝑟𝑦 ↔ (𝐹𝑥) = (𝐹𝑦)))))
6550, 52, 64mp2ani 698 1 (𝐴𝑉 → ∃𝑟(𝑟 Er 𝐴 ∧ ∀𝑥𝐴𝑦𝐴 (𝑥𝑟𝑦 ↔ (𝐹𝑥) = (𝐹𝑦))))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 206  wa 395   = wceq 1541  wex 1780  wcel 2111  wral 3047  Vcvv 3436   class class class wbr 5089  {copab 5151  cfv 6481   Er wer 8619
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 1968  ax-7 2009  ax-8 2113  ax-9 2121  ax-ext 2703  ax-sep 5232  ax-nul 5242  ax-pow 5301  ax-pr 5368  ax-un 7668
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 848  df-3an 1088  df-tru 1544  df-fal 1554  df-ex 1781  df-sb 2068  df-clab 2710  df-cleq 2723  df-clel 2806  df-ral 3048  df-rex 3057  df-rab 3396  df-v 3438  df-dif 3900  df-un 3902  df-in 3904  df-ss 3914  df-nul 4281  df-if 4473  df-pw 4549  df-sn 4574  df-pr 4576  df-op 4580  df-uni 4857  df-br 5090  df-opab 5152  df-xp 5620  df-rel 5621  df-cnv 5622  df-co 5623  df-dm 5624  df-iota 6437  df-fv 6489  df-er 8622
This theorem is referenced by:  tgjustc1  28453
  Copyright terms: Public domain W3C validator