File: V3.v

package info (click to toggle)
coq-hierarchy-builder 1.8.1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,988 kB
  • sloc: makefile: 109
file content (37 lines) | stat: -rw-r--r-- 1,008 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
Require Import ZArith ssreflect ssrfun.
From HB Require Import structures.

HB.mixin Record is_semigroup (S : Type) := {
  add   : S -> S -> S;
  addrA : associative add;
}.
HB.structure Definition SemiGroup :=
  { S & is_semigroup S }.

HB.mixin Record monoid_of_semigroup (M : Type)
  & is_semigroup M := {
  zero  : M;
  add0r : left_id  zero add;
  addr0 : right_id zero add;
}.

HB.factory Record is_monoid (M : Type) := {
  zero  : M;
  add   : M -> M -> M;
  addrA : associative add;
  add0r : left_id  zero add;
  addr0 : right_id zero add;
}.
HB.builders Context (M : Type) (f : is_monoid M).
  HB.instance Definition is_monoid_semigroup : is_semigroup M :=
    is_semigroup.Build M add addrA.
  HB.instance Definition is_monoid_monoid : monoid_of_semigroup M :=
    monoid_of_semigroup.Build M zero add0r addr0.
HB.end.

HB.structure Definition Monoid :=
  { M & is_monoid M }.

HB.instance Definition Z_is_monoid : is_monoid Z :=
  is_monoid.Build Z 0%Z Z.add
    Z.add_assoc Z.add_0_l Z.add_0_r.