5199
|
1 |
(* Title: HOL/ex/MonoidGroup.thy
|
|
2 |
ID: $Id$
|
|
3 |
Author: Markus Wenzel
|
|
4 |
Copyright 1996 TU Muenchen
|
|
5 |
|
|
6 |
Monoids and Groups as predicates over record schemes.
|
|
7 |
*)
|
|
8 |
|
|
9 |
MonoidGroup = HOL + Record +
|
|
10 |
|
|
11 |
|
|
12 |
record 'a monoid_sig =
|
|
13 |
times :: "['a, 'a] => 'a"
|
|
14 |
one :: 'a
|
|
15 |
|
|
16 |
record 'a group_sig = 'a monoid_sig +
|
|
17 |
inv :: "'a => 'a"
|
|
18 |
|
|
19 |
constdefs
|
9279
|
20 |
monoid :: "(| times :: ['a, 'a] => 'a, one :: 'a, ... :: 'more::more |) => bool"
|
5199
|
21 |
"monoid M == ALL x y z.
|
|
22 |
times M (times M x y) z = times M x (times M y z) &
|
9279
|
23 |
times M (one M) x = x & times M x (one M) = x"
|
5199
|
24 |
|
9279
|
25 |
group :: "(| times :: ['a, 'a] => 'a, one :: 'a, inv :: 'a => 'a, ... :: 'more::more |) => bool"
|
5199
|
26 |
"group G == monoid G & (ALL x. times G (inv G x) x = one G)"
|
|
27 |
|
9279
|
28 |
reverse :: "(| times :: ['a, 'a] => 'a, one :: 'a, ... :: 'more::more |) =>
|
5199
|
29 |
(| times :: ['a, 'a] => 'a, one :: 'a, ... :: 'more |)"
|
|
30 |
"reverse M == M (| times := %x y. times M y x |)"
|
|
31 |
|
|
32 |
|
|
33 |
end
|