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

Theorem isgrpo 29268
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 6646 . . . . . 6 (𝑔 = 𝐺 → (𝑔:(𝑡 × 𝑡)⟶𝑡𝐺:(𝑡 × 𝑡)⟶𝑡))
2 oveq 7357 . . . . . . . . . 10 (𝑔 = 𝐺 → ((𝑥𝑔𝑦)𝑔𝑧) = ((𝑥𝑔𝑦)𝐺𝑧))
3 oveq 7357 . . . . . . . . . . 11 (𝑔 = 𝐺 → (𝑥𝑔𝑦) = (𝑥𝐺𝑦))
43oveq1d 7366 . . . . . . . . . 10 (𝑔 = 𝐺 → ((𝑥𝑔𝑦)𝐺𝑧) = ((𝑥𝐺𝑦)𝐺𝑧))
52, 4eqtrd 2777 . . . . . . . . 9 (𝑔 = 𝐺 → ((𝑥𝑔𝑦)𝑔𝑧) = ((𝑥𝐺𝑦)𝐺𝑧))
6 oveq 7357 . . . . . . . . . 10 (𝑔 = 𝐺 → (𝑥𝑔(𝑦𝑔𝑧)) = (𝑥𝐺(𝑦𝑔𝑧)))
7 oveq 7357 . . . . . . . . . . 11 (𝑔 = 𝐺 → (𝑦𝑔𝑧) = (𝑦𝐺𝑧))
87oveq2d 7367 . . . . . . . . . 10 (𝑔 = 𝐺 → (𝑥𝐺(𝑦𝑔𝑧)) = (𝑥𝐺(𝑦𝐺𝑧)))
96, 8eqtrd 2777 . . . . . . . . 9 (𝑔 = 𝐺 → (𝑥𝑔(𝑦𝑔𝑧)) = (𝑥𝐺(𝑦𝐺𝑧)))
105, 9eqeq12d 2753 . . . . . . . 8 (𝑔 = 𝐺 → (((𝑥𝑔𝑦)𝑔𝑧) = (𝑥𝑔(𝑦𝑔𝑧)) ↔ ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧))))
1110ralbidv 3172 . . . . . . 7 (𝑔 = 𝐺 → (∀𝑧𝑡 ((𝑥𝑔𝑦)𝑔𝑧) = (𝑥𝑔(𝑦𝑔𝑧)) ↔ ∀𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧))))
12112ralbidv 3210 . . . . . 6 (𝑔 = 𝐺 → (∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝑔𝑦)𝑔𝑧) = (𝑥𝑔(𝑦𝑔𝑧)) ↔ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧))))
13 oveq 7357 . . . . . . . . 9 (𝑔 = 𝐺 → (𝑢𝑔𝑥) = (𝑢𝐺𝑥))
1413eqeq1d 2739 . . . . . . . 8 (𝑔 = 𝐺 → ((𝑢𝑔𝑥) = 𝑥 ↔ (𝑢𝐺𝑥) = 𝑥))
15 oveq 7357 . . . . . . . . . 10 (𝑔 = 𝐺 → (𝑦𝑔𝑥) = (𝑦𝐺𝑥))
1615eqeq1d 2739 . . . . . . . . 9 (𝑔 = 𝐺 → ((𝑦𝑔𝑥) = 𝑢 ↔ (𝑦𝐺𝑥) = 𝑢))
1716rexbidv 3173 . . . . . . . 8 (𝑔 = 𝐺 → (∃𝑦𝑡 (𝑦𝑔𝑥) = 𝑢 ↔ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢))
1814, 17anbi12d 631 . . . . . . 7 (𝑔 = 𝐺 → (((𝑢𝑔𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝑔𝑥) = 𝑢) ↔ ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)))
1918rexralbidv 3212 . . . . . 6 (𝑔 = 𝐺 → (∃𝑢𝑡𝑥𝑡 ((𝑢𝑔𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝑔𝑥) = 𝑢) ↔ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)))
201, 12, 193anbi123d 1436 . . . . 5 (𝑔 = 𝐺 → ((𝑔:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝑔𝑦)𝑔𝑧) = (𝑥𝑔(𝑦𝑔𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝑔𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝑔𝑥) = 𝑢)) ↔ (𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢))))
2120exbidv 1924 . . . 4 (𝑔 = 𝐺 → (∃𝑡(𝑔:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝑔𝑦)𝑔𝑧) = (𝑥𝑔(𝑦𝑔𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝑔𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝑔𝑥) = 𝑢)) ↔ ∃𝑡(𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢))))
22 df-grpo 29264 . . . 4 GrpOp = {𝑔 ∣ ∃𝑡(𝑔:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝑔𝑦)𝑔𝑧) = (𝑥𝑔(𝑦𝑔𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝑔𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝑔𝑥) = 𝑢))}
2321, 22elab2g 3630 . . 3 (𝐺𝐴 → (𝐺 ∈ GrpOp ↔ ∃𝑡(𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢))))
24 simpl 483 . . . . . . . . . . . . . 14 (((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) → (𝑢𝐺𝑥) = 𝑥)
2524ralimi 3084 . . . . . . . . . . . . 13 (∀𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) → ∀𝑥𝑡 (𝑢𝐺𝑥) = 𝑥)
26 oveq2 7359 . . . . . . . . . . . . . . . . 17 (𝑥 = 𝑧 → (𝑢𝐺𝑥) = (𝑢𝐺𝑧))
27 id 22 . . . . . . . . . . . . . . . . 17 (𝑥 = 𝑧𝑥 = 𝑧)
2826, 27eqeq12d 2753 . . . . . . . . . . . . . . . 16 (𝑥 = 𝑧 → ((𝑢𝐺𝑥) = 𝑥 ↔ (𝑢𝐺𝑧) = 𝑧))
29 eqcom 2744 . . . . . . . . . . . . . . . 16 ((𝑢𝐺𝑧) = 𝑧𝑧 = (𝑢𝐺𝑧))
3028, 29bitrdi 286 . . . . . . . . . . . . . . 15 (𝑥 = 𝑧 → ((𝑢𝐺𝑥) = 𝑥𝑧 = (𝑢𝐺𝑧)))
3130rspcv 3575 . . . . . . . . . . . . . 14 (𝑧𝑡 → (∀𝑥𝑡 (𝑢𝐺𝑥) = 𝑥𝑧 = (𝑢𝐺𝑧)))
32 oveq2 7359 . . . . . . . . . . . . . . . 16 (𝑦 = 𝑧 → (𝑢𝐺𝑦) = (𝑢𝐺𝑧))
3332rspceeqv 3593 . . . . . . . . . . . . . . 15 ((𝑧𝑡𝑧 = (𝑢𝐺𝑧)) → ∃𝑦𝑡 𝑧 = (𝑢𝐺𝑦))
3433ex 413 . . . . . . . . . . . . . 14 (𝑧𝑡 → (𝑧 = (𝑢𝐺𝑧) → ∃𝑦𝑡 𝑧 = (𝑢𝐺𝑦)))
3531, 34syld 47 . . . . . . . . . . . . 13 (𝑧𝑡 → (∀𝑥𝑡 (𝑢𝐺𝑥) = 𝑥 → ∃𝑦𝑡 𝑧 = (𝑢𝐺𝑦)))
3625, 35syl5 34 . . . . . . . . . . . 12 (𝑧𝑡 → (∀𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) → ∃𝑦𝑡 𝑧 = (𝑢𝐺𝑦)))
3736reximdv 3165 . . . . . . . . . . 11 (𝑧𝑡 → (∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) → ∃𝑢𝑡𝑦𝑡 𝑧 = (𝑢𝐺𝑦)))
3837impcom 408 . . . . . . . . . 10 ((∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) ∧ 𝑧𝑡) → ∃𝑢𝑡𝑦𝑡 𝑧 = (𝑢𝐺𝑦))
3938ralrimiva 3141 . . . . . . . . 9 (∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) → ∀𝑧𝑡𝑢𝑡𝑦𝑡 𝑧 = (𝑢𝐺𝑦))
4039anim2i 617 . . . . . . . 8 ((𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)) → (𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑧𝑡𝑢𝑡𝑦𝑡 𝑧 = (𝑢𝐺𝑦)))
41 foov 7522 . . . . . . . 8 (𝐺:(𝑡 × 𝑡)–onto𝑡 ↔ (𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑧𝑡𝑢𝑡𝑦𝑡 𝑧 = (𝑢𝐺𝑦)))
4240, 41sylibr 233 . . . . . . 7 ((𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)) → 𝐺:(𝑡 × 𝑡)–onto𝑡)
43 forn 6756 . . . . . . . 8 (𝐺:(𝑡 × 𝑡)–onto𝑡 → ran 𝐺 = 𝑡)
4443eqcomd 2743 . . . . . . 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 7833 . . 3 (𝐺𝐴 → ran 𝐺 ∈ V)
51 isgrp.1 . . . . . 6 𝑋 = ran 𝐺
5251eqeq2i 2750 . . . . 5 (𝑡 = 𝑋𝑡 = ran 𝐺)
53 xpeq1 5645 . . . . . . . . 9 (𝑡 = 𝑋 → (𝑡 × 𝑡) = (𝑋 × 𝑡))
54 xpeq2 5652 . . . . . . . . 9 (𝑡 = 𝑋 → (𝑋 × 𝑡) = (𝑋 × 𝑋))
5553, 54eqtrd 2777 . . . . . . . 8 (𝑡 = 𝑋 → (𝑡 × 𝑡) = (𝑋 × 𝑋))
5655feq2d 6651 . . . . . . 7 (𝑡 = 𝑋 → (𝐺:(𝑡 × 𝑡)⟶𝑡𝐺:(𝑋 × 𝑋)⟶𝑡))
57 feq3 6648 . . . . . . 7 (𝑡 = 𝑋 → (𝐺:(𝑋 × 𝑋)⟶𝑡𝐺:(𝑋 × 𝑋)⟶𝑋))
5856, 57bitrd 278 . . . . . 6 (𝑡 = 𝑋 → (𝐺:(𝑡 × 𝑡)⟶𝑡𝐺:(𝑋 × 𝑋)⟶𝑋))
59 raleq 3307 . . . . . . . 8 (𝑡 = 𝑋 → (∀𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ↔ ∀𝑧𝑋 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧))))
6059raleqbi1dv 3305 . . . . . . 7 (𝑡 = 𝑋 → (∀𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ↔ ∀𝑦𝑋𝑧𝑋 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧))))
6160raleqbi1dv 3305 . . . . . 6 (𝑡 = 𝑋 → (∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ↔ ∀𝑥𝑋𝑦𝑋𝑧𝑋 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧))))
62 rexeq 3308 . . . . . . . . 9 (𝑡 = 𝑋 → (∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢 ↔ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢))
6362anbi2d 629 . . . . . . . 8 (𝑡 = 𝑋 → (((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) ↔ ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢)))
6463raleqbi1dv 3305 . . . . . . 7 (𝑡 = 𝑋 → (∀𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) ↔ ∀𝑥𝑋 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢)))
6564rexeqbi1dv 3306 . . . . . 6 (𝑡 = 𝑋 → (∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) ↔ ∃𝑢𝑋𝑥𝑋 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢)))
6658, 61, 653anbi123d 1436 . . . . 5 (𝑡 = 𝑋 → ((𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)) ↔ (𝐺:(𝑋 × 𝑋)⟶𝑋 ∧ ∀𝑥𝑋𝑦𝑋𝑧𝑋 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑋𝑥𝑋 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢))))
6752, 66sylbir 234 . . . 4 (𝑡 = ran 𝐺 → ((𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)) ↔ (𝐺:(𝑋 × 𝑋)⟶𝑋 ∧ ∀𝑥𝑋𝑦𝑋𝑧𝑋 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑋𝑥𝑋 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢))))
6867ceqsexgv 3602 . . 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 3062  wrex 3071  Vcvv 3443   × cxp 5629  ran crn 5632  wf 6489  ontowfo 6491  (class class class)co 7351  GrpOpcgr 29260
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 2708  ax-sep 5254  ax-nul 5261  ax-pr 5382  ax-un 7664
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 2539  df-eu 2568  df-clab 2715  df-cleq 2729  df-clel 2815  df-nfc 2887  df-ne 2942  df-ral 3063  df-rex 3072  df-rab 3406  df-v 3445  df-sbc 3738  df-csb 3854  df-dif 3911  df-un 3913  df-in 3915  df-ss 3925  df-nul 4281  df-if 4485  df-sn 4585  df-pr 4587  df-op 4591  df-uni 4864  df-iun 4954  df-br 5104  df-opab 5166  df-mpt 5187  df-id 5529  df-xp 5637  df-rel 5638  df-cnv 5639  df-co 5640  df-dm 5641  df-rn 5642  df-iota 6445  df-fun 6495  df-fn 6496  df-f 6497  df-fo 6499  df-fv 6501  df-ov 7354  df-grpo 29264
This theorem is referenced by:  isgrpoi  29269  grpofo  29270  grpolidinv  29272  grpoass  29274  grpomndo  36272  isgrpda  36352
  Copyright terms: Public domain W3C validator