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

Theorem isgrpo 30433
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 6669 . . . . . 6 (𝑔 = 𝐺 → (𝑔:(𝑡 × 𝑡)⟶𝑡𝐺:(𝑡 × 𝑡)⟶𝑡))
2 oveq 7396 . . . . . . . . . 10 (𝑔 = 𝐺 → ((𝑥𝑔𝑦)𝑔𝑧) = ((𝑥𝑔𝑦)𝐺𝑧))
3 oveq 7396 . . . . . . . . . . 11 (𝑔 = 𝐺 → (𝑥𝑔𝑦) = (𝑥𝐺𝑦))
43oveq1d 7405 . . . . . . . . . 10 (𝑔 = 𝐺 → ((𝑥𝑔𝑦)𝐺𝑧) = ((𝑥𝐺𝑦)𝐺𝑧))
52, 4eqtrd 2765 . . . . . . . . 9 (𝑔 = 𝐺 → ((𝑥𝑔𝑦)𝑔𝑧) = ((𝑥𝐺𝑦)𝐺𝑧))
6 oveq 7396 . . . . . . . . . 10 (𝑔 = 𝐺 → (𝑥𝑔(𝑦𝑔𝑧)) = (𝑥𝐺(𝑦𝑔𝑧)))
7 oveq 7396 . . . . . . . . . . 11 (𝑔 = 𝐺 → (𝑦𝑔𝑧) = (𝑦𝐺𝑧))
87oveq2d 7406 . . . . . . . . . 10 (𝑔 = 𝐺 → (𝑥𝐺(𝑦𝑔𝑧)) = (𝑥𝐺(𝑦𝐺𝑧)))
96, 8eqtrd 2765 . . . . . . . . 9 (𝑔 = 𝐺 → (𝑥𝑔(𝑦𝑔𝑧)) = (𝑥𝐺(𝑦𝐺𝑧)))
105, 9eqeq12d 2746 . . . . . . . 8 (𝑔 = 𝐺 → (((𝑥𝑔𝑦)𝑔𝑧) = (𝑥𝑔(𝑦𝑔𝑧)) ↔ ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧))))
1110ralbidv 3157 . . . . . . 7 (𝑔 = 𝐺 → (∀𝑧𝑡 ((𝑥𝑔𝑦)𝑔𝑧) = (𝑥𝑔(𝑦𝑔𝑧)) ↔ ∀𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧))))
12112ralbidv 3202 . . . . . 6 (𝑔 = 𝐺 → (∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝑔𝑦)𝑔𝑧) = (𝑥𝑔(𝑦𝑔𝑧)) ↔ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧))))
13 oveq 7396 . . . . . . . . 9 (𝑔 = 𝐺 → (𝑢𝑔𝑥) = (𝑢𝐺𝑥))
1413eqeq1d 2732 . . . . . . . 8 (𝑔 = 𝐺 → ((𝑢𝑔𝑥) = 𝑥 ↔ (𝑢𝐺𝑥) = 𝑥))
15 oveq 7396 . . . . . . . . . 10 (𝑔 = 𝐺 → (𝑦𝑔𝑥) = (𝑦𝐺𝑥))
1615eqeq1d 2732 . . . . . . . . 9 (𝑔 = 𝐺 → ((𝑦𝑔𝑥) = 𝑢 ↔ (𝑦𝐺𝑥) = 𝑢))
1716rexbidv 3158 . . . . . . . 8 (𝑔 = 𝐺 → (∃𝑦𝑡 (𝑦𝑔𝑥) = 𝑢 ↔ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢))
1814, 17anbi12d 632 . . . . . . 7 (𝑔 = 𝐺 → (((𝑢𝑔𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝑔𝑥) = 𝑢) ↔ ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)))
1918rexralbidv 3204 . . . . . 6 (𝑔 = 𝐺 → (∃𝑢𝑡𝑥𝑡 ((𝑢𝑔𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝑔𝑥) = 𝑢) ↔ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)))
201, 12, 193anbi123d 1438 . . . . 5 (𝑔 = 𝐺 → ((𝑔:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝑔𝑦)𝑔𝑧) = (𝑥𝑔(𝑦𝑔𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝑔𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝑔𝑥) = 𝑢)) ↔ (𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢))))
2120exbidv 1921 . . . 4 (𝑔 = 𝐺 → (∃𝑡(𝑔:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝑔𝑦)𝑔𝑧) = (𝑥𝑔(𝑦𝑔𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝑔𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝑔𝑥) = 𝑢)) ↔ ∃𝑡(𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢))))
22 df-grpo 30429 . . . 4 GrpOp = {𝑔 ∣ ∃𝑡(𝑔:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝑔𝑦)𝑔𝑧) = (𝑥𝑔(𝑦𝑔𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝑔𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝑔𝑥) = 𝑢))}
2321, 22elab2g 3650 . . 3 (𝐺𝐴 → (𝐺 ∈ GrpOp ↔ ∃𝑡(𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢))))
24 simpl 482 . . . . . . . . . . . . . 14 (((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) → (𝑢𝐺𝑥) = 𝑥)
2524ralimi 3067 . . . . . . . . . . . . 13 (∀𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) → ∀𝑥𝑡 (𝑢𝐺𝑥) = 𝑥)
26 oveq2 7398 . . . . . . . . . . . . . . . . 17 (𝑥 = 𝑧 → (𝑢𝐺𝑥) = (𝑢𝐺𝑧))
27 id 22 . . . . . . . . . . . . . . . . 17 (𝑥 = 𝑧𝑥 = 𝑧)
2826, 27eqeq12d 2746 . . . . . . . . . . . . . . . 16 (𝑥 = 𝑧 → ((𝑢𝐺𝑥) = 𝑥 ↔ (𝑢𝐺𝑧) = 𝑧))
29 eqcom 2737 . . . . . . . . . . . . . . . 16 ((𝑢𝐺𝑧) = 𝑧𝑧 = (𝑢𝐺𝑧))
3028, 29bitrdi 287 . . . . . . . . . . . . . . 15 (𝑥 = 𝑧 → ((𝑢𝐺𝑥) = 𝑥𝑧 = (𝑢𝐺𝑧)))
3130rspcv 3587 . . . . . . . . . . . . . 14 (𝑧𝑡 → (∀𝑥𝑡 (𝑢𝐺𝑥) = 𝑥𝑧 = (𝑢𝐺𝑧)))
32 oveq2 7398 . . . . . . . . . . . . . . . 16 (𝑦 = 𝑧 → (𝑢𝐺𝑦) = (𝑢𝐺𝑧))
3332rspceeqv 3614 . . . . . . . . . . . . . . 15 ((𝑧𝑡𝑧 = (𝑢𝐺𝑧)) → ∃𝑦𝑡 𝑧 = (𝑢𝐺𝑦))
3433ex 412 . . . . . . . . . . . . . 14 (𝑧𝑡 → (𝑧 = (𝑢𝐺𝑧) → ∃𝑦𝑡 𝑧 = (𝑢𝐺𝑦)))
3531, 34syld 47 . . . . . . . . . . . . 13 (𝑧𝑡 → (∀𝑥𝑡 (𝑢𝐺𝑥) = 𝑥 → ∃𝑦𝑡 𝑧 = (𝑢𝐺𝑦)))
3625, 35syl5 34 . . . . . . . . . . . 12 (𝑧𝑡 → (∀𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) → ∃𝑦𝑡 𝑧 = (𝑢𝐺𝑦)))
3736reximdv 3149 . . . . . . . . . . 11 (𝑧𝑡 → (∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) → ∃𝑢𝑡𝑦𝑡 𝑧 = (𝑢𝐺𝑦)))
3837impcom 407 . . . . . . . . . 10 ((∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) ∧ 𝑧𝑡) → ∃𝑢𝑡𝑦𝑡 𝑧 = (𝑢𝐺𝑦))
3938ralrimiva 3126 . . . . . . . . 9 (∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) → ∀𝑧𝑡𝑢𝑡𝑦𝑡 𝑧 = (𝑢𝐺𝑦))
4039anim2i 617 . . . . . . . 8 ((𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)) → (𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑧𝑡𝑢𝑡𝑦𝑡 𝑧 = (𝑢𝐺𝑦)))
41 foov 7566 . . . . . . . 8 (𝐺:(𝑡 × 𝑡)–onto𝑡 ↔ (𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑧𝑡𝑢𝑡𝑦𝑡 𝑧 = (𝑢𝐺𝑦)))
4240, 41sylibr 234 . . . . . . 7 ((𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)) → 𝐺:(𝑡 × 𝑡)–onto𝑡)
43 forn 6778 . . . . . . . 8 (𝐺:(𝑡 × 𝑡)–onto𝑡 → ran 𝐺 = 𝑡)
4443eqcomd 2736 . . . . . . 7 (𝐺:(𝑡 × 𝑡)–onto𝑡𝑡 = ran 𝐺)
4542, 44syl 17 . . . . . 6 ((𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)) → 𝑡 = ran 𝐺)
46453adant2 1131 . . . . 5 ((𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)) → 𝑡 = ran 𝐺)
4746pm4.71ri 560 . . . 4 ((𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)) ↔ (𝑡 = ran 𝐺 ∧ (𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢))))
4847exbii 1848 . . 3 (∃𝑡(𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)) ↔ ∃𝑡(𝑡 = ran 𝐺 ∧ (𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢))))
4923, 48bitrdi 287 . 2 (𝐺𝐴 → (𝐺 ∈ GrpOp ↔ ∃𝑡(𝑡 = ran 𝐺 ∧ (𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)))))
50 rnexg 7881 . . 3 (𝐺𝐴 → ran 𝐺 ∈ V)
51 isgrp.1 . . . . . 6 𝑋 = ran 𝐺
5251eqeq2i 2743 . . . . 5 (𝑡 = 𝑋𝑡 = ran 𝐺)
53 xpeq1 5655 . . . . . . . . 9 (𝑡 = 𝑋 → (𝑡 × 𝑡) = (𝑋 × 𝑡))
54 xpeq2 5662 . . . . . . . . 9 (𝑡 = 𝑋 → (𝑋 × 𝑡) = (𝑋 × 𝑋))
5553, 54eqtrd 2765 . . . . . . . 8 (𝑡 = 𝑋 → (𝑡 × 𝑡) = (𝑋 × 𝑋))
5655feq2d 6675 . . . . . . 7 (𝑡 = 𝑋 → (𝐺:(𝑡 × 𝑡)⟶𝑡𝐺:(𝑋 × 𝑋)⟶𝑡))
57 feq3 6671 . . . . . . 7 (𝑡 = 𝑋 → (𝐺:(𝑋 × 𝑋)⟶𝑡𝐺:(𝑋 × 𝑋)⟶𝑋))
5856, 57bitrd 279 . . . . . 6 (𝑡 = 𝑋 → (𝐺:(𝑡 × 𝑡)⟶𝑡𝐺:(𝑋 × 𝑋)⟶𝑋))
59 raleq 3298 . . . . . . . 8 (𝑡 = 𝑋 → (∀𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ↔ ∀𝑧𝑋 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧))))
6059raleqbi1dv 3313 . . . . . . 7 (𝑡 = 𝑋 → (∀𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ↔ ∀𝑦𝑋𝑧𝑋 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧))))
6160raleqbi1dv 3313 . . . . . 6 (𝑡 = 𝑋 → (∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ↔ ∀𝑥𝑋𝑦𝑋𝑧𝑋 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧))))
62 rexeq 3297 . . . . . . . . 9 (𝑡 = 𝑋 → (∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢 ↔ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢))
6362anbi2d 630 . . . . . . . 8 (𝑡 = 𝑋 → (((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) ↔ ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢)))
6463raleqbi1dv 3313 . . . . . . 7 (𝑡 = 𝑋 → (∀𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) ↔ ∀𝑥𝑋 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢)))
6564rexeqbi1dv 3314 . . . . . 6 (𝑡 = 𝑋 → (∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢) ↔ ∃𝑢𝑋𝑥𝑋 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢)))
6658, 61, 653anbi123d 1438 . . . . 5 (𝑡 = 𝑋 → ((𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)) ↔ (𝐺:(𝑋 × 𝑋)⟶𝑋 ∧ ∀𝑥𝑋𝑦𝑋𝑧𝑋 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑋𝑥𝑋 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢))))
6752, 66sylbir 235 . . . 4 (𝑡 = ran 𝐺 → ((𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢)) ↔ (𝐺:(𝑋 × 𝑋)⟶𝑋 ∧ ∀𝑥𝑋𝑦𝑋𝑧𝑋 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑋𝑥𝑋 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢))))
6867ceqsexgv 3623 . . 3 (ran 𝐺 ∈ V → (∃𝑡(𝑡 = ran 𝐺 ∧ (𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢))) ↔ (𝐺:(𝑋 × 𝑋)⟶𝑋 ∧ ∀𝑥𝑋𝑦𝑋𝑧𝑋 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑋𝑥𝑋 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢))))
6950, 68syl 17 . 2 (𝐺𝐴 → (∃𝑡(𝑡 = ran 𝐺 ∧ (𝐺:(𝑡 × 𝑡)⟶𝑡 ∧ ∀𝑥𝑡𝑦𝑡𝑧𝑡 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑡𝑥𝑡 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑡 (𝑦𝐺𝑥) = 𝑢))) ↔ (𝐺:(𝑋 × 𝑋)⟶𝑋 ∧ ∀𝑥𝑋𝑦𝑋𝑧𝑋 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑋𝑥𝑋 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢))))
7049, 69bitrd 279 1 (𝐺𝐴 → (𝐺 ∈ GrpOp ↔ (𝐺:(𝑋 × 𝑋)⟶𝑋 ∧ ∀𝑥𝑋𝑦𝑋𝑧𝑋 ((𝑥𝐺𝑦)𝐺𝑧) = (𝑥𝐺(𝑦𝐺𝑧)) ∧ ∃𝑢𝑋𝑥𝑋 ((𝑢𝐺𝑥) = 𝑥 ∧ ∃𝑦𝑋 (𝑦𝐺𝑥) = 𝑢))))
Colors of variables: wff setvar class
Syntax hints:  wi 4  wb 206  wa 395  w3a 1086   = wceq 1540  wex 1779  wcel 2109  wral 3045  wrex 3054  Vcvv 3450   × cxp 5639  ran crn 5642  wf 6510  ontowfo 6512  (class class class)co 7390  GrpOpcgr 30425
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1795  ax-4 1809  ax-5 1910  ax-6 1967  ax-7 2008  ax-8 2111  ax-9 2119  ax-10 2142  ax-11 2158  ax-12 2178  ax-ext 2702  ax-sep 5254  ax-nul 5264  ax-pr 5390  ax-un 7714
This theorem depends on definitions:  df-bi 207  df-an 396  df-or 848  df-3an 1088  df-tru 1543  df-fal 1553  df-ex 1780  df-nf 1784  df-sb 2066  df-mo 2534  df-eu 2563  df-clab 2709  df-cleq 2722  df-clel 2804  df-nfc 2879  df-ne 2927  df-ral 3046  df-rex 3055  df-rab 3409  df-v 3452  df-sbc 3757  df-csb 3866  df-dif 3920  df-un 3922  df-in 3924  df-ss 3934  df-nul 4300  df-if 4492  df-sn 4593  df-pr 4595  df-op 4599  df-uni 4875  df-iun 4960  df-br 5111  df-opab 5173  df-mpt 5192  df-id 5536  df-xp 5647  df-rel 5648  df-cnv 5649  df-co 5650  df-dm 5651  df-rn 5652  df-iota 6467  df-fun 6516  df-fn 6517  df-f 6518  df-fo 6520  df-fv 6522  df-ov 7393  df-grpo 30429
This theorem is referenced by:  isgrpoi  30434  grpofo  30435  grpolidinv  30437  grpoass  30439  grpomndo  37876  isgrpda  37956
  Copyright terms: Public domain W3C validator