Timings for Monoid.v
Require Import Basics.Overture Basics.Tactics Basics.Equivalences Basics.Trunc.
Require Import Types.Sigma Types.Forall Types.Prod.
Require Import WildCat.Core WildCat.Induced WildCat.Equiv WildCat.Universe
WildCat.Products.
Require Import (notations) Classes.interfaces.canonical_names.
Require Export (hints) Classes.interfaces.abstract_algebra.
Require Export (hints) Classes.interfaces.canonical_names.
Require Export Classes.interfaces.canonical_names (SgOp, sg_op,
MonUnit, mon_unit, LeftIdentity, left_identity, RightIdentity, right_identity,
Associative, simple_associativity, associativity,
LeftInverse, left_inverse, RightInverse, right_inverse, Commutative, commutativity).
Export canonical_names.BinOpNotations.
Require Export Classes.interfaces.abstract_algebra (IsSemiGroup(..), sg_set, sg_ass,
IsMonoid(..), monoid_left_id, monoid_right_id, monoid_semigroup,
IsMonoidPreserving(..), monmor_unitmor, monmor_sgmor,
IsSemiGroupPreserving, preserves_sg_op, IsUnitPreserving, preserves_mon_unit).
Local Set Polymorphic Inductive Cumulativity.
Local Set Universe Minimization ToSet.
Local Open Scope mc_mult_scope.
(** * Monoids *)
(** ** Definition *)
Record Monoid := {
monoid_type :> Type;
monoid_sgop :: SgOp monoid_type;
monoid_unit :: MonUnit monoid_type;
monoid_ismonoid :: IsMonoid monoid_type;
}.
Arguments monoid_sgop {_}.
Arguments monoid_unit {_}.
Arguments monoid_ismonoid {_}.
Global Opaque monoid_ismonoid.
Definition issig_monoid : _ <~> Monoid := ltac:(issig).
Context {M : Monoid} (x y z : M).
Definition mnd_assoc := associativity x y z.
Definition mnd_unit_l := left_identity x.
Definition mnd_unit_r := right_identity x.
(** ** Monoid homomorphisms *)
Record MonoidHomomorphism (M N : Monoid) := {
mnd_homo_map :> monoid_type M -> monoid_type N;
ismonoidpreserving_mnd_homo :: IsMonoidPreserving mnd_homo_map;
}.
Arguments mnd_homo_map {M N}.
Arguments Build_MonoidHomomorphism {M N} _ _.
Arguments ismonoidpreserving_mnd_homo {M N} f : rename.
Definition issig_MonoidHomomorphism (M N : Monoid)
: _ <~> MonoidHomomorphism M N
:= ltac:(issig).
(** ** Basics properties of monoid homomorphisms *)
Definition mnd_homo_op {M N : Monoid} (f : MonoidHomomorphism M N)
: forall (x y : M), f (x * y) = f x * f y
:= monmor_sgmor.
Definition mnd_homo_unit {M N : Monoid} (f : MonoidHomomorphism M N)
: f mon_unit = mon_unit
:= monmor_unitmor.
Definition equiv_path_monoidhomomorphism `{Funext} {M N : Monoid}
{f g : MonoidHomomorphism M N}
: f == g <~> f = g.
refine ((equiv_ap (issig_MonoidHomomorphism M N)^-1 _ _)^-1 oE _).
refine (equiv_path_sigma_hprop _ _ oE _).
Instance ishset_monoidhomomorphism `{Funext} {M N : Monoid}
: IsHSet (MonoidHomomorphism M N).
intros f g; apply (istrunc_equiv_istrunc _ equiv_path_monoidhomomorphism).
Definition mnd_homo_id {M : Monoid} : MonoidHomomorphism M M
:= Build_MonoidHomomorphism idmap _.
Definition mnd_homo_compose {M N P : Monoid}
: MonoidHomomorphism N P -> MonoidHomomorphism M N
-> MonoidHomomorphism M P
:= fun f g => Build_MonoidHomomorphism (f o g) _.
(** ** Monoid Isomorphisms *)
Record MonoidIsomorphism (M N : Monoid) := {
mnd_iso_homo :> MonoidHomomorphism M N;
isequiv_mnd_iso :: IsEquiv mnd_iso_homo;
}.
Definition Build_MonoidIsomorphism' {M N : Monoid}
(f : M <~> N) (h : IsMonoidPreserving f)
: MonoidHomomorphism M N.
snapply Build_MonoidIsomorphism.
1: srapply Build_MonoidHomomorphism.
Definition issig_MonoidIsomorphism (M N : Monoid)
: _ <~> MonoidIsomorphism M N
:= ltac:(issig).
Coercion equiv_mnd_iso {M N : Monoid}
: MonoidIsomorphism M N -> M <~> N
:= fun f => Build_Equiv M N f _.
Definition mnd_iso_id {M : Monoid} : MonoidIsomorphism M M
:= Build_MonoidIsomorphism _ _ mnd_homo_id _.
Definition mnd_iso_compose {M N P : Monoid}
: MonoidIsomorphism N P -> MonoidIsomorphism M N
-> MonoidIsomorphism M P
:= fun g f => Build_MonoidIsomorphism _ _ (mnd_homo_compose g f) _.
Definition mnd_iso_inverse {M N : Monoid}
: MonoidIsomorphism M N -> MonoidIsomorphism N M
:= fun f => Build_MonoidIsomorphism _ _ (Build_MonoidHomomorphism f^-1 _) _.
Instance reflexive_monoidisomorphism
: Reflexive MonoidIsomorphism
:= fun M => mnd_iso_id.
Instance symmetric_monoidisomorphism
: Symmetric MonoidIsomorphism
:= fun M N => mnd_iso_inverse.
Instance transitive_monoidisomorphism
: Transitive MonoidIsomorphism
:= fun M N P f g => mnd_iso_compose g f.
(** ** The category of monoids *)
Instance isgraph_monoid : IsGraph Monoid
:= Build_IsGraph Monoid MonoidHomomorphism.
Instance is01cat_monoid : Is01Cat Monoid
:= Build_Is01Cat Monoid _ (@mnd_homo_id) (@mnd_homo_compose).
Local Notation mnd_homo_map' M N
:= (@mnd_homo_map M N : _ -> (monoid_type M $-> _)).
Instance is2graph_monoid : Is2Graph Monoid
:= fun M N => isgraph_induced (mnd_homo_map' M N).
Instance isgraph_monoidhomomorphism {M N : Monoid} : IsGraph (M $-> N)
:= isgraph_induced (mnd_homo_map' M N).
Instance is01cat_monoidhomomorphism {M N : Monoid} : Is01Cat (M $-> N)
:= is01cat_induced (mnd_homo_map' M N).
Instance is0gpd_monoidhomomorphism {M N : Monoid} : Is0Gpd (M $-> N)
:= is0gpd_induced (mnd_homo_map' M N).
Instance is0functor_postcomp_monoidhomomorphism
{M N P : Monoid} (h : N $-> P)
: Is0Functor (@cat_postcomp Monoid _ _ M N P h).
intros ? ? p a; exact (ap h (p a)).
Instance is0functor_precomp_monoidhomomorphism
{M N P : Monoid} (h : M $-> N)
: Is0Functor (@cat_precomp Monoid _ _ M N P h).
intros ? ? p; exact (p o h).
Instance is1cat_monoid : Is1Cat Monoid.
Instance hasequivs_monoid : HasEquivs Monoid.
exact (fun M N f => IsEquiv f).
exact Build_MonoidIsomorphism.
intros M N; exact mnd_iso_inverse.
intros ????; apply eissect.
intros ????; apply eisretr.
intros M N; exact isequiv_adjointify.
Instance is0functor_monoid_type : Is0Functor monoid_type
:= Build_Is0Functor _ _ _ _ monoid_type (@mnd_homo_map).
Instance is1functor_monoid_type : Is1Functor monoid_type.
by apply Build_Is1Functor.
(** ** Direct product of monoids *)
Definition mnd_prod : Monoid -> Monoid -> Monoid.
snapply (Build_Monoid (M * N)).
exact (m1 * m2, n1 * n2).
exact (mon_unit, mon_unit).
intros x y z; snapply path_prod; napply mnd_assoc.
intros x; snapply path_prod; napply mnd_unit_l.
intros x; snapply path_prod; napply mnd_unit_r.
Definition mnd_prod_pr1 {M N : Monoid}
: MonoidHomomorphism (mnd_prod M N) M.
snapply Build_MonoidHomomorphism.
Definition mnd_prod_pr2 {M N : Monoid}
: MonoidHomomorphism (mnd_prod M N) N.
snapply Build_MonoidHomomorphism.
Definition mnd_prod_corec {M N P : Monoid}
(f : MonoidHomomorphism P M)
(g : MonoidHomomorphism P N)
: MonoidHomomorphism P (mnd_prod M N).
snapply Build_MonoidHomomorphism.
exact (fun x => (f x, g x)).
intros x y; snapply path_prod; napply mnd_homo_op.
snapply path_prod; napply mnd_homo_unit.
Instance hasbinaryproducts_monoid : HasBinaryProducts Monoid.
snapply Build_BinaryProduct.
intros P; exact mnd_prod_corec.
intros P f g; exact (Id _).
intros P f g; exact (Id _).
intros P f g p q a; exact (path_prod' (p a) (q a)).