From dcc21b2189f46fb9f4751814079deb386a129ca6 Mon Sep 17 00:00:00 2001 From: Ali Caglayan Date: Fri, 3 Jan 2025 21:06:07 +0000 Subject: [PATCH 1/4] quotient by a trivial group Signed-off-by: Ali Caglayan --- theories/Algebra/Groups/QuotientGroup.v | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/theories/Algebra/Groups/QuotientGroup.v b/theories/Algebra/Groups/QuotientGroup.v index 55bcd3f3ae..ca4af7c9bf 100644 --- a/theories/Algebra/Groups/QuotientGroup.v +++ b/theories/Algebra/Groups/QuotientGroup.v @@ -304,3 +304,16 @@ Proof. + srapply path_sigma_hprop. reflexivity. Defined. + +(** The group quotient by a trivial group is isomorphic to the original group. *) +Definition grp_quotient_trivial (G : Group) (N : NormalSubgroup G) + : IsTrivialGroup N -> G / N ≅ G. +Proof. + intros T. + snrapply cate_adjointify. + - srapply (grp_quotient_rec _ _ (Id _)). + apply T. + - srapply grp_quotient_map. + - reflexivity. + - by srapply grp_quotient_ind_hprop. +Defined. From fa9e7ee2ff70d5297d2685044c91965b1dae21e3 Mon Sep 17 00:00:00 2001 From: Ali Caglayan Date: Mon, 6 Jan 2025 17:30:29 +0000 Subject: [PATCH 2/4] trivial kernel iff isembedding Signed-off-by: Ali Caglayan --- theories/Algebra/Groups/Kernel.v | 40 ++++++++++++++------ theories/Algebra/Groups/ShortExactSequence.v | 5 +-- theories/Algebra/Groups/Subgroup.v | 4 ++ 3 files changed, 35 insertions(+), 14 deletions(-) diff --git a/theories/Algebra/Groups/Kernel.v b/theories/Algebra/Groups/Kernel.v index 221d34f2a9..48dbbe6593 100644 --- a/theories/Algebra/Groups/Kernel.v +++ b/theories/Algebra/Groups/Kernel.v @@ -2,6 +2,7 @@ Require Import Basics Types. Require Import Algebra.Groups.Group. Require Import Algebra.Groups.Subgroup. Require Import WildCat.Core. +Require Import Universes.HSet. (** * Kernels of group homomorphisms *) @@ -55,17 +56,34 @@ Proof. apply path_sigma_hprop; reflexivity. Defined. -(** ** Characterisation of group embeddings *) -Proposition equiv_kernel_isembedding `{Univalence} {A B : Group} (f : A $-> B) - : (grp_kernel f = trivial_subgroup A :> Subgroup A) <~> IsEmbedding f. +(** The underlying map of a group homomorphism with a trivial kernel is an embedding. *) +Global Instance isembedding_istrivial_kernel {G H : Group} (f : G $-> H) + (triv : IsTrivialGroup (grp_kernel f)) + : IsEmbedding f. +Proof. + apply isembedding_grouphomomorphism. + intros g p. + apply triv. + exact p. +Defined. + +(** If the underlying map of a group homomorphism is an embedding then the kernel is trivial. *) +Definition istrivial_kernel_isembedding {G H : Group} (f : G $-> H) + (emb : IsEmbedding f) + : IsTrivialGroup (grp_kernel f). +Proof. + intros g p. + rapply (isinj_embedding f). + rhs nrapply grp_homo_unit. + exact p. +Defined. +Global Hint Immediate istrivial_kernel_isembedding : typeclass_instances. + +(** Characterisation of group embeddings *) +Proposition equiv_istrivial_kernel_isembedding `{F : Funext} + {G H : Group} (f : G $-> H) + : IsTrivialGroup (grp_kernel f) <~> IsEmbedding f. Proof. - refine (_ oE (equiv_path_subgroup' _ _)^-1%equiv). apply equiv_iff_hprop_uncurried. - refine (iff_compose _ (isembedding_grouphomomorphism f)); split. - - intros E ? ?. - by apply E. - - intros e a; split. - + apply e. - + intro p. - exact (ap _ p @ grp_homo_unit f). + split; exact _. Defined. diff --git a/theories/Algebra/Groups/ShortExactSequence.v b/theories/Algebra/Groups/ShortExactSequence.v index 659759c739..29973f191c 100644 --- a/theories/Algebra/Groups/ShortExactSequence.v +++ b/theories/Algebra/Groups/ShortExactSequence.v @@ -51,7 +51,6 @@ Defined. (** A complex 0 -> A -> B is purely exact if and only if the kernel of the map A -> B is trivial. *) Definition equiv_grp_isexact_kernel `{Univalence} {A B : Group} (f : A $-> B) - : IsExact purely (grp_trivial_rec A) f - <~> (grp_kernel f = trivial_subgroup A :> Subgroup _) - := (equiv_kernel_isembedding f)^-1%equiv + : IsExact purely (grp_trivial_rec A) f <~> IsTrivialGroup (grp_kernel f) + := (equiv_istrivial_kernel_isembedding f)^-1%equiv oE equiv_iff_hprop_uncurried (iff_grp_isexact_isembedding f). diff --git a/theories/Algebra/Groups/Subgroup.v b/theories/Algebra/Groups/Subgroup.v index 0878378979..4f6de7ad32 100644 --- a/theories/Algebra/Groups/Subgroup.v +++ b/theories/Algebra/Groups/Subgroup.v @@ -499,6 +499,10 @@ Defined. Class IsTrivialGroup@{i} {G : Group@{i}} (H : Subgroup@{i i} G) := istrivialgroup : forall x, H x -> trivial_subgroup G x. +Global Instance ishprop_istrivialgroup `{F : Funext} {G : Group} (H : Subgroup G) + : IsHProp (IsTrivialGroup H) + := istrunc_forall. + Global Instance istrivial_trivial_subgroup {G : Group} : IsTrivialGroup (trivial_subgroup G) := fun x => idmap. From 6bc6f735a84bd183590b8823de6b1e35b87b325a Mon Sep 17 00:00:00 2001 From: Ali Caglayan Date: Tue, 7 Jan 2025 12:55:37 +0000 Subject: [PATCH 3/4] update according to review comments Signed-off-by: Ali Caglayan --- theories/Algebra/Groups/QuotientGroup.v | 21 +++++++++++++-------- 1 file changed, 13 insertions(+), 8 deletions(-) diff --git a/theories/Algebra/Groups/QuotientGroup.v b/theories/Algebra/Groups/QuotientGroup.v index ca4af7c9bf..f8b22f2729 100644 --- a/theories/Algebra/Groups/QuotientGroup.v +++ b/theories/Algebra/Groups/QuotientGroup.v @@ -305,15 +305,20 @@ Proof. reflexivity. Defined. -(** The group quotient by a trivial group is isomorphic to the original group. *) -Definition grp_quotient_trivial (G : Group) (N : NormalSubgroup G) - : IsTrivialGroup N -> G / N ≅ G. +(** When the normal subgroup [N] is trivial, the inclusion map [G $-> G / N] is an isomorphism. *) +Global Instance catie_grp_quotient_map_trivial {G : Group} (N : NormalSubgroup G) + (triv : IsTrivialGroup N) + : CatIsEquiv (@grp_quotient_map G N). Proof. - intros T. - snrapply cate_adjointify. + snrapply catie_adjointify. - srapply (grp_quotient_rec _ _ (Id _)). - apply T. - - srapply grp_quotient_map. - - reflexivity. + apply triv. - by srapply grp_quotient_ind_hprop. + - reflexivity. Defined. + +(** The group quotient by a trivial group is isomorphic to the original group. *) +Definition grp_quotient_trivial (G : Group) (N : NormalSubgroup G) + (triv : IsTrivialGroup N) + : G $<~> G / N + := Build_CatEquiv grp_quotient_map. From 21dc47a89cc5e314c32e2cc5f9c859fe6c4d13dc Mon Sep 17 00:00:00 2001 From: Ali Caglayan Date: Tue, 7 Jan 2025 13:13:11 +0000 Subject: [PATCH 4/4] explode isembedding_grouphomomorphism into both directions Signed-off-by: Ali Caglayan --- theories/Algebra/AbSES/Core.v | 2 +- .../Algebra/AbSES/PullbackFiberSequence.v | 2 +- theories/Algebra/Groups/Group.v | 19 -------------- theories/Algebra/Groups/Kernel.v | 25 +++++++++++-------- 4 files changed, 17 insertions(+), 31 deletions(-) diff --git a/theories/Algebra/AbSES/Core.v b/theories/Algebra/AbSES/Core.v index 9b6d9486bd..1e232084c2 100644 --- a/theories/Algebra/AbSES/Core.v +++ b/theories/Algebra/AbSES/Core.v @@ -172,7 +172,7 @@ Proof. refine ((grp_assoc _ _ _)^ @ _). refine (ap _ (left_inverse (phi e0.1)) @ _). apply grp_unit_r. - - apply isembedding_grouphomomorphism. + - apply isembedding_istrivial_kernel. intros e p. assert (a : Tr (-1) (hfiber (inclusion E) e)). 1: { refine (isexact_preimage _ (inclusion E) (projection E) _ _). diff --git a/theories/Algebra/AbSES/PullbackFiberSequence.v b/theories/Algebra/AbSES/PullbackFiberSequence.v index 04598af852..6969ca630c 100644 --- a/theories/Algebra/AbSES/PullbackFiberSequence.v +++ b/theories/Algebra/AbSES/PullbackFiberSequence.v @@ -71,7 +71,7 @@ Proof. intro b. refine (ap (projection E) (abses_pullback_inclusion_transpose_beta (inclusion E) F p b) @ _). apply iscomplex_abses. - - apply isembedding_grouphomomorphism. + - apply isembedding_istrivial_kernel. intros a q0. (* Since [inclusion F a] is killed by [grp_quotient_map], its in the image of [B]. *) pose proof (in_coset := related_quotient_paths _ _ _ q0). diff --git a/theories/Algebra/Groups/Group.v b/theories/Algebra/Groups/Group.v index 76d1d782d8..4eabe756de 100644 --- a/theories/Algebra/Groups/Group.v +++ b/theories/Algebra/Groups/Group.v @@ -1098,25 +1098,6 @@ Global Instance isfreegroup_isfreegroupon (S : Type) (F_S : Group) (i : S -> F_S (** ** Further properties of group homomorphisms. *) -(** Characterisation of injective group homomorphisms. *) -Lemma isembedding_grouphomomorphism {A B : Group} (f : A $-> B) - : (forall a, f a = group_unit -> a = group_unit) <-> IsEmbedding f. -Proof. - split. - - intros h b. - apply hprop_allpath. - intros [a0 p0] [a1 p1]. - srapply path_sigma_hprop; simpl. - apply grp_moveL_1M. - apply h. - rewrite grp_homo_op, grp_homo_inv. - rewrite p0, p1. - apply right_inverse. - - intros E a p. - rapply (isinj_embedding f). - exact (p @ (grp_homo_unit f)^). -Defined. - (** Commutativity can be transferred across isomorphisms. *) Definition commutative_iso_commutative {G H : Group} {C : Commutative (@group_sgop G)} (f : GroupIsomorphism G H) diff --git a/theories/Algebra/Groups/Kernel.v b/theories/Algebra/Groups/Kernel.v index 48dbbe6593..34f5977771 100644 --- a/theories/Algebra/Groups/Kernel.v +++ b/theories/Algebra/Groups/Kernel.v @@ -8,12 +8,11 @@ Require Import Universes.HSet. Local Open Scope mc_scope. Local Open Scope mc_mult_scope. -Local Open Scope path_scope. Definition grp_kernel {A B : Group} (f : GroupHomomorphism A B) : NormalSubgroup A. Proof. snrapply Build_NormalSubgroup. - - srapply (Build_Subgroup' (fun x => f x = group_unit)); cbn beta. + - srapply (Build_Subgroup' (fun x => f x = 1)); cbn beta. 1: apply grp_homo_unit. intros x y p q. apply (grp_homo_moveL_1M _ _ _)^-1. @@ -21,8 +20,8 @@ Proof. - intros x y; cbn; intros p. apply (grp_homo_moveL_1V _ _ _)^-1. lhs_V nrapply grp_inv_inv. - apply (ap (-)). - exact (grp_homo_moveL_1V f x y p)^. + nrapply (ap (-) _^). + by apply grp_homo_moveL_1V. Defined. (** ** Corecursion principle for group kernels *) @@ -61,10 +60,17 @@ Global Instance isembedding_istrivial_kernel {G H : Group} (f : G $-> H) (triv : IsTrivialGroup (grp_kernel f)) : IsEmbedding f. Proof. - apply isembedding_grouphomomorphism. - intros g p. - apply triv. - exact p. + intros h. + apply hprop_allpath. + intros [x p] [y q]. + srapply path_sigma_hprop; unfold pr1. + apply grp_moveL_1M. + apply triv; simpl. + rhs_V nrapply (grp_inv_r h). + lhs nrapply grp_homo_op. + nrapply (ap011 (.*.) p). + lhs nrapply grp_homo_inv. + exact (ap (^) q). Defined. (** If the underlying map of a group homomorphism is an embedding then the kernel is trivial. *) @@ -74,8 +80,7 @@ Definition istrivial_kernel_isembedding {G H : Group} (f : G $-> H) Proof. intros g p. rapply (isinj_embedding f). - rhs nrapply grp_homo_unit. - exact p. + exact (p @ (grp_homo_unit f)^). Defined. Global Hint Immediate istrivial_kernel_isembedding : typeclass_instances.