Library GroupTheory.gr
Require Import Ensembles.
Require Import Laws.
Require Import Group_definitions.
Section group_trivialities.
Variable U : Type.
Variable Gr : Group U.
Let G : Ensemble U := G_ U Gr.
Let star : U → U → U := star_ U Gr.
Let inv : U → U := inv_ U Gr.
Let e : U := e_ U Gr.
Definition G0 : ∀ a b : U, In U G a → In U G b → In U G (star a b) :=
G0_ U Gr.
Definition G1 : ∀ a b c : U, star a (star b c) = star (star a b) c :=
G1_ U Gr.
Definition G2a : In U G e := G2a_ U Gr.
Definition G2b : ∀ a : U, star e a = a := G2b_ U Gr.
Definition G2c : ∀ a : U, star a e = a := G2c_ U Gr.
Definition G3a : ∀ a : U, In U G a → In U G (inv a) := G3a_ U Gr.
Definition G3b : ∀ a : U, star a (inv a) = e := G3b_ U Gr.
Definition G3c : ∀ a : U, star (inv a) a = e := G3c_ U Gr.
Hint Resolve G1.
Hint Resolve G2a G2b G2c.
Hint Resolve G3a G3b G3c.
Hint Resolve G0.
Theorem triv1 : ∀ a b : U, star (inv a) (star a b) = b.
intros a b; try assumption.
rewrite (G1 (inv a) a b); auto with v62.
rewrite G3c; auto with v62.
Qed.
Theorem triv2 : ∀ a b : U, star (star b a) (inv a) = b.
intros a b; try assumption.
rewrite <- (G1 b a (inv a)); auto with v62.
rewrite (G3b a); auto with v62.
Qed.
Theorem resolve : ∀ a b : U, star b a = e → b = inv a.
intros a b H'1.
cut (star (star b a) (inv a) = inv a).
rewrite <- (G1 b a (inv a)); auto with v62.
rewrite (G3b a); auto with v62.
rewrite (G2c b); auto with v62.
rewrite H'1.
rewrite (G2b (inv a)); auto with v62.
Qed.
Theorem self_inv : e = inv e.
apply resolve; auto with v62.
Qed.
Theorem inv_star : ∀ a b : U, star (inv b) (inv a) = inv (star a b).
intros a b.
apply resolve.
rewrite <- (G1 (inv b) (inv a) (star a b)).
rewrite (G1 (inv a) a b).
rewrite (G3c a).
rewrite (G2b b); auto with v62.
Qed.
Theorem cancellation : ∀ a b : U, star a b = a → b = e.
intros a b H'.
cut (star (inv a) (star a b) = b).
rewrite H'.
rewrite (G3c a); auto with v62.
rewrite (G1 (inv a) a b).
rewrite (G3c a); auto with v62.
Qed.
Theorem inv_involution : ∀ a : U, a = inv (inv a).
intro a; apply resolve; auto with v62.
Qed.
End group_trivialities.
Hint Resolve G1.
Hint Resolve G2a G2b G2c.
Hint Resolve G3a G3b G3c.
Hint Resolve G0.
Hint Resolve triv1 triv2 resolve self_inv inv_star inv_involution.
