src/HOL/Integ/Group.thy
author wenzelm
Fri, 15 May 1998 11:34:12 +0200
changeset 4932 c90411dde8e8
parent 4230 eb5586526bc9
permissions -rw-r--r--
PureThy.add_typedecls;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2281
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
     1
(*  Title:      HOL/Integ/Group.thy
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
     2
    ID:         $Id$
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
     3
    Author:     Tobias Nipkow
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
     4
    Copyright   1996 TU Muenchen
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
     5
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
     6
A little bit of group theory leading up to rings. Hence groups are additive.
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
     7
*)
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
     8
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
     9
Group = Set +
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    10
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    11
(* 0 already used in Nat *)
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    12
axclass  zero < term
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    13
consts   zero :: "'a::zero"
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    14
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    15
(* additive semigroups *)
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    16
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    17
axclass  add_semigroup < plus
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    18
  plus_assoc   "(x + y) + z = x + (y + z)"
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    19
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    20
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    21
(* additive monoids *)
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    22
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    23
axclass  add_monoid < add_semigroup, zero
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    24
  zeroL    "zero + x = x"
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    25
  zeroR    "x + zero = x"
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    26
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    27
(* additive groups *)
4230
eb5586526bc9 Redesigned the decision procedures for (Abelian) groups and commutative rings.
nipkow
parents: 2281
diff changeset
    28
(*
eb5586526bc9 Redesigned the decision procedures for (Abelian) groups and commutative rings.
nipkow
parents: 2281
diff changeset
    29
The inverse is the binary `-'. Groups with unary and binary inverse are
eb5586526bc9 Redesigned the decision procedures for (Abelian) groups and commutative rings.
nipkow
parents: 2281
diff changeset
    30
interdefinable: x-y := x+(zero-y) and -x := zero-x. The law left_inv is
eb5586526bc9 Redesigned the decision procedures for (Abelian) groups and commutative rings.
nipkow
parents: 2281
diff changeset
    31
simply the translation of (-x)+x = zero. This characterizes groups already,
eb5586526bc9 Redesigned the decision procedures for (Abelian) groups and commutative rings.
nipkow
parents: 2281
diff changeset
    32
provided we only allow (zero-x). Law minus_inv `defines' the general x-y in
eb5586526bc9 Redesigned the decision procedures for (Abelian) groups and commutative rings.
nipkow
parents: 2281
diff changeset
    33
terms of the specific zero-y.
eb5586526bc9 Redesigned the decision procedures for (Abelian) groups and commutative rings.
nipkow
parents: 2281
diff changeset
    34
*)
2281
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    35
axclass  add_group < add_monoid, minus
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    36
  left_inv  "(zero-x)+x = zero"
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    37
  minus_inv "x-y = x + (zero-y)"
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    38
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    39
(* additive abelian groups *)
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    40
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    41
axclass  add_agroup < add_group
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    42
  plus_commute  "x + y = y + x"
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    43
e00c13a29eda Ring Theory.
nipkow
parents:
diff changeset
    44
end