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

Theorem isgrpo 29737
Description: The predicate "is a group operation." Note that 𝑋 is the base set of the group. (Contributed by NM, 10-Oct-2006.) (New usage is discouraged.)
Hypothesis
Ref Expression
isgrp.1 𝑋 = ran 𝐺
Assertion
Ref Expression
isgrpo (𝐺𝐴 → (𝐺 ∈ GrpOp ↔ (𝐺:(𝑋 × 𝑋)⟶𝑋 ∧ ∀𝑥𝑋𝑦𝑋𝑧𝑋 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑋𝑥𝑋 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢))))
Distinct variable groups:   𝑥,𝑢,𝑦,𝑧,𝐺   𝑢,𝑋,𝑥,𝑦,𝑧
Allowed substitution hints:   𝐴(𝑥,𝑦,𝑧,𝑢)

Proof of Theorem isgrpo
Dummy variables 𝑡 𝑔 are mutually distinct and distinct from all other variables.
StepHypRef Expression
1 feq1 6695 . . . . . 6 (𝑔 = 𝐺 → (𝑔:(𝑡 × 𝑡)⟶𝑡𝐺:(𝑡 × 𝑡)⟶𝑡))
2 oveq 7411 . . . . . . . . . 10 (𝑔 = 𝐺 → ((𝑥𝑔𝑦)𝑔𝑧) = ((𝑥𝑔𝑦)𝐺𝑧))
3 oveq 7411 . . . . . . . . . . 11 (𝑔 = 𝐺 → (𝑥𝑔𝑦) = (𝑥𝐺𝑦))
43oveq1d 7420 . . . . . . . . . 10 (𝑔 = 𝐺 → ((𝑥𝑔𝑦)𝐺𝑧) = ((𝑥𝐺𝑦)𝐺𝑧))
52, 4eqtrd 2772 . . . . . . . . 9 (𝑔 = 𝐺 → ((𝑥𝑔𝑦)𝑔𝑧) = ((𝑥𝐺𝑦)𝐺𝑧))
6 oveq 7411 . . . . . . . . . 10 (𝑔 = 𝐺 → (𝑥𝑔(𝑦𝑔𝑧)) = (𝑥𝐺(𝑦𝑔𝑧)))
7 oveq 7411 . . . . . . . . . . 11 (𝑔 = 𝐺 → (𝑦𝑔𝑧) = (𝑦𝐺𝑧))
87oveq2d 7421 . . . . . . . . . 10 (𝑔 = 𝐺 → (𝑥𝐺(𝑦𝑔𝑧)) = (𝑥𝐺(𝑦𝐺𝑧)))
96, 8eqtrd 2772 . . . . . . . . 9 (𝑔 = 𝐺 → (𝑥𝑔(𝑦𝑔𝑧)) = (𝑥𝐺(𝑦𝐺𝑧)))
105, 9eqeq12d 2748 . . . . . . . 8 (𝑔 = 𝐺 → (((𝑥𝑔𝑦)𝑔𝑧) = (𝑥𝑔(𝑦𝑔𝑧)) ↔ ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧))))
1110ralbidv 3177 . . . . . . 7 (𝑔 = 𝐺 → (∀𝑧𝑡 ((𝑥𝑔𝑦)𝑔𝑧) = (𝑥𝑔(𝑦𝑔𝑧)) ↔ ∀𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧))))
12112ralbidv 3218 . . . . . 6 (𝑔 = 𝐺 → (∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝑔𝑦)𝑔𝑧) = (𝑥𝑔(𝑦𝑔𝑧)) ↔ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧))))
13 oveq 7411 . . . . . . . . 9 (𝑔 = 𝐺 → (𝑢𝑔𝑥) = (𝑢𝐺𝑥))
1413eqeq1d 2734 . . . . . . . 8 (𝑔 = 𝐺 → ((𝑢𝑔𝑥) = 𝑥 ↔ (𝑢𝐺𝑥) = 𝑥))
15 oveq 7411 . . . . . . . . . 10 (𝑔 = 𝐺 → (𝑦𝑔𝑥) = (𝑦𝐺𝑥))
1615eqeq1d 2734 . . . . . . . . 9 (𝑔 = 𝐺 → ((𝑦𝑔𝑥) = 𝑢 ↔ (𝑦𝐺𝑥) = 𝑢))
1716rexbidv 3178 . . . . . . . 8 (𝑔 = 𝐺 → (∃𝑦𝑡 (𝑦𝑔𝑥) = 𝑢 ↔ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢))
1814, 17anbi12d 631 . . . . . . 7 (𝑔 = 𝐺 → (((𝑢𝑔𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝑔𝑥) = 𝑢) ↔ ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)))
1918rexralbidv 3220 . . . . . 6 (𝑔 = 𝐺 → (∃𝑢𝑡𝑥𝑡 ((𝑢𝑔𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝑔𝑥) = 𝑢) ↔ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)))
201, 12, 193anbi123d 1436 . . . . 5 (𝑔 = 𝐺 → ((𝑔:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝑔𝑦)𝑔𝑧) = (𝑥𝑔(𝑦𝑔𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝑔𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝑔𝑥) = 𝑢)) ↔ (𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢))))
2120exbidv 1924 . . . 4 (𝑔 = 𝐺 → (∃𝑡(𝑔:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝑔𝑦)𝑔𝑧) = (𝑥𝑔(𝑦𝑔𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝑔𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝑔𝑥) = 𝑢)) ↔ ∃𝑡(𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢))))
22 df-grpo 29733 . . . 4 GrpOp = {𝑔 ∣ ∃𝑡(𝑔:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝑔𝑦)𝑔𝑧) = (𝑥𝑔(𝑦𝑔𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝑔𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝑔𝑥) = 𝑢))}
2321, 22elab2g 3669 . . 3 (𝐺𝐴 → (𝐺 ∈ GrpOp ↔ ∃𝑡(𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢))))
24 simpl 483 . . . . . . . . . . . . . 14 (((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) → (𝑢𝐺𝑥) = 𝑥)
2524ralimi 3083 . . . . . . . . . . . . 13 (∀𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) → ∀𝑥𝑡 (𝑢𝐺𝑥) = 𝑥)
26 oveq2 7413 . . . . . . . . . . . . . . . . 17 (𝑥 = 𝑧 → (𝑢𝐺𝑥) = (𝑢𝐺𝑧))
27 id 22 . . . . . . . . . . . . . . . . 17 (𝑥 = 𝑧𝑥 = 𝑧)
2826, 27eqeq12d 2748 . . . . . . . . . . . . . . . 16 (𝑥 = 𝑧 → ((𝑢𝐺𝑥) = 𝑥 ↔ (𝑢𝐺𝑧) = 𝑧))
29 eqcom 2739 . . . . . . . . . . . . . . . 16 ((𝑢𝐺𝑧) = 𝑧𝑧 = (𝑢𝐺𝑧))
3028, 29bitrdi 286 . . . . . . . . . . . . . . 15 (𝑥 = 𝑧 → ((𝑢𝐺𝑥) = 𝑥𝑧 = (𝑢𝐺𝑧)))
3130rspcv 3608 . . . . . . . . . . . . . 14 (𝑧𝑡 → (∀𝑥𝑡 (𝑢𝐺𝑥) = 𝑥𝑧 = (𝑢𝐺𝑧)))
32 oveq2 7413 . . . . . . . . . . . . . . . 16 (𝑦 = 𝑧 → (𝑢𝐺𝑦) = (𝑢𝐺𝑧))
3332rspceeqv 3632 . . . . . . . . . . . . . . 15 ((𝑧𝑡𝑧 = (𝑢𝐺𝑧)) → ∃𝑦𝑡 𝑧 = (𝑢𝐺𝑦))
3433ex 413 . . . . . . . . . . . . . 14 (𝑧𝑡 → (𝑧 = (𝑢𝐺𝑧) → ∃𝑦𝑡 𝑧 = (𝑢𝐺𝑦)))
3531, 34syld 47 . . . . . . . . . . . . 13 (𝑧𝑡 → (∀𝑥𝑡 (𝑢𝐺𝑥) = 𝑥 → ∃𝑦𝑡 𝑧 = (𝑢𝐺𝑦)))
3625, 35syl5 34 . . . . . . . . . . . 12 (𝑧𝑡 → (∀𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) → ∃𝑦𝑡 𝑧 = (𝑢𝐺𝑦)))
3736reximdv 3170 . . . . . . . . . . 11 (𝑧𝑡 → (∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) → ∃𝑢𝑡𝑦𝑡 𝑧 = (𝑢𝐺𝑦)))
3837impcom 408 . . . . . . . . . 10 ((∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) ∧ 𝑧𝑡) → ∃𝑢𝑡𝑦𝑡 𝑧 = (𝑢𝐺𝑦))
3938ralrimiva 3146 . . . . . . . . 9 (∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) → ∀𝑧𝑡𝑢𝑡𝑦𝑡 𝑧 = (𝑢𝐺𝑦))
4039anim2i 617 . . . . . . . 8 ((𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)) → (𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑧𝑡𝑢𝑡𝑦𝑡 𝑧 = (𝑢𝐺𝑦)))
41 foov 7577 . . . . . . . 8 (𝐺:(𝑡 × 𝑡)–onto𝑡 ↔ (𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑧𝑡𝑢𝑡𝑦𝑡 𝑧 = (𝑢𝐺𝑦)))
4240, 41sylibr 233 . . . . . . 7 ((𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)) → 𝐺:(𝑡 × 𝑡)–onto𝑡)
43 forn 6805 . . . . . . . 8 (𝐺:(𝑡 × 𝑡)–onto𝑡 → ran 𝐺 = 𝑡)
4443eqcomd 2738 . . . . . . 7 (𝐺:(𝑡 × 𝑡)–onto𝑡𝑡 = ran 𝐺)
4542, 44syl 17 . . . . . 6 ((𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)) → 𝑡 = ran 𝐺)
46453adant2 1131 . . . . 5 ((𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)) → 𝑡 = ran 𝐺)
4746pm4.71ri 561 . . . 4 ((𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)) ↔ (𝑡 = ran 𝐺 ∧ (𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢))))
4847exbii 1850 . . 3 (∃𝑡(𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)) ↔ ∃𝑡(𝑡 = ran 𝐺 ∧ (𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢))))
4923, 48bitrdi 286 . 2 (𝐺𝐴 → (𝐺 ∈ GrpOp ↔ ∃𝑡(𝑡 = ran 𝐺 ∧ (𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)))))
50 rnexg 7891 . . 3 (𝐺𝐴 → ran 𝐺 ∈ V)
51 isgrp.1 . . . . . 6 𝑋 = ran 𝐺
5251eqeq2i 2745 . . . . 5 (𝑡 = 𝑋𝑡 = ran 𝐺)
53 xpeq1 5689 . . . . . . . . 9 (𝑡 = 𝑋 → (𝑡 × 𝑡) = (𝑋 × 𝑡))
54 xpeq2 5696 . . . . . . . . 9 (𝑡 = 𝑋 → (𝑋 × 𝑡) = (𝑋 × 𝑋))
5553, 54eqtrd 2772 . . . . . . . 8 (𝑡 = 𝑋 → (𝑡 × 𝑡) = (𝑋 × 𝑋))
5655feq2d 6700 . . . . . . 7 (𝑡 = 𝑋 → (𝐺:(𝑡 × 𝑡)⟶𝑡𝐺:(𝑋 × 𝑋)⟶𝑡))
57 feq3 6697 . . . . . . 7 (𝑡 = 𝑋 → (𝐺:(𝑋 × 𝑋)⟶𝑡𝐺:(𝑋 × 𝑋)⟶𝑋))
5856, 57bitrd 278 . . . . . 6 (𝑡 = 𝑋 → (𝐺:(𝑡 × 𝑡)⟶𝑡𝐺:(𝑋 × 𝑋)⟶𝑋))
59 raleq 3322 . . . . . . . 8 (𝑡 = 𝑋 → (∀𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ↔ ∀𝑧𝑋 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧))))
6059raleqbi1dv 3333 . . . . . . 7 (𝑡 = 𝑋 → (∀𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ↔ ∀𝑦𝑋𝑧𝑋 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧))))
6160raleqbi1dv 3333 . . . . . 6 (𝑡 = 𝑋 → (∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ↔ ∀𝑥𝑋𝑦𝑋𝑧𝑋 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧))))
62 rexeq 3321 . . . . . . . . 9 (𝑡 = 𝑋 → (∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢 ↔ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢))
6362anbi2d 629 . . . . . . . 8 (𝑡 = 𝑋 → (((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) ↔ ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢)))
6463raleqbi1dv 3333 . . . . . . 7 (𝑡 = 𝑋 → (∀𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) ↔ ∀𝑥𝑋 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢)))
6564rexeqbi1dv 3334 . . . . . 6 (𝑡 = 𝑋 → (∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) ↔ ∃𝑢𝑋𝑥𝑋 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢)))
6658, 61, 653anbi123d 1436 . . . . 5 (𝑡 = 𝑋 → ((𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)) ↔ (𝐺:(𝑋 × 𝑋)⟶𝑋 ∧ ∀𝑥𝑋𝑦𝑋𝑧𝑋 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑋𝑥𝑋 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢))))
6752, 66sylbir 234 . . . 4 (𝑡 = ran 𝐺 → ((𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)) ↔ (𝐺:(𝑋 × 𝑋)⟶𝑋 ∧ ∀𝑥𝑋𝑦𝑋𝑧𝑋 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑋𝑥𝑋 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢))))
6867ceqsexgv 3641 . . 3 (ran 𝐺 ∈ V → (∃𝑡(𝑡 = ran 𝐺 ∧ (𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢))) ↔ (𝐺:(𝑋 × 𝑋)⟶𝑋 ∧ ∀𝑥𝑋𝑦𝑋𝑧𝑋 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑋𝑥𝑋 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢))))
6950, 68syl 17 . 2 (𝐺𝐴 → (∃𝑡(𝑡 = ran 𝐺 ∧ (𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢))) ↔ (𝐺:(𝑋 × 𝑋)⟶𝑋 ∧ ∀𝑥𝑋𝑦𝑋𝑧𝑋 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑋𝑥𝑋 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢))))
7049, 69bitrd 278 1 (𝐺𝐴 → (𝐺 ∈ GrpOp ↔ (𝐺:(𝑋 × 𝑋)⟶𝑋 ∧ ∀𝑥𝑋𝑦𝑋𝑧𝑋 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑋𝑥𝑋 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢))))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 205  wa 396  w3a 1087   = wceq 1541  wex 1781  wcel 2106  wral 3061  wrex 3070  Vcvv 3474   × cxp 5673  ran crn 5676  wf 6536  ontowfo 6538  (class class class)co 7405  GrpOpcgr 29729
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1797  ax-4 1811  ax-5 1913  ax-6 1971  ax-7 2011  ax-8 2108  ax-9 2116  ax-10 2137  ax-11 2154  ax-12 2171  ax-ext 2703  ax-sep 5298  ax-nul 5305  ax-pr 5426  ax-un 7721
This theorem depends on definitions:  df-bi 206  df-an 397  df-or 846  df-3an 1089  df-tru 1544  df-fal 1554  df-ex 1782  df-nf 1786  df-sb 2068  df-mo 2534  df-eu 2563  df-clab 2710  df-cleq 2724  df-clel 2810  df-nfc 2885  df-ne 2941  df-ral 3062  df-rex 3071  df-rab 3433  df-v 3476  df-sbc 3777  df-csb 3893  df-dif 3950  df-un 3952  df-in 3954  df-ss 3964  df-nul 4322  df-if 4528  df-sn 4628  df-pr 4630  df-op 4634  df-uni 4908  df-iun 4998  df-br 5148  df-opab 5210  df-mpt 5231  df-id 5573  df-xp 5681  df-rel 5682  df-cnv 5683  df-co 5684  df-dm 5685  df-rn 5686  df-iota 6492  df-fun 6542  df-fn 6543  df-f 6544  df-fo 6546  df-fv 6548  df-ov 7408  df-grpo 29733
This theorem is referenced by:  isgrpoi  29738  grpofo  29739  grpolidinv  29741  grpoass  29743  grpomndo  36731  isgrpda  36811
  Copyright terms: Public domain W3C validator