src/HOL/Algebra/Exact_Sequence.thy
author paulson <lp15@cam.ac.uk>
Mon, 02 Jul 2018 22:40:25 +0100
changeset 68578 1f86a092655b
child 68582 b9b9e2985878
permissions -rw-r--r--
more algebra
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
68578
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
     1
(* ************************************************************************** *)
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
     2
(* Title:      Exact_Sequence.thy                                             *)
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
     3
(* Author:     Martin Baillon                                                 *)
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
     4
(* ************************************************************************** *)
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
     5
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
     6
theory Exact_Sequence
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
     7
  imports Group Coset Solvable_Groups
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
     8
    
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
     9
begin
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    10
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    11
section \<open>Exact Sequences\<close>
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    12
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    13
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    14
subsection \<open>Definitions\<close>
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    15
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    16
inductive exact_seq :: "'a monoid list \<times> ('a \<Rightarrow> 'a) list \<Rightarrow> bool"  where
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    17
unity:     " group_hom G1 G2 f \<Longrightarrow> exact_seq ([G2, G1], [f])" |
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    18
extension: "\<lbrakk> exact_seq ((G # K # l), (g # q)); group H ; h \<in> hom G H ;
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    19
              kernel G H h = image g (carrier K) \<rbrakk> \<Longrightarrow> exact_seq (H # G # K # l, h # g # q)"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    20
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    21
abbreviation exact_seq_arrow ::
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    22
  "('a \<Rightarrow> 'a) \<Rightarrow> 'a monoid list \<times> ('a \<Rightarrow> 'a) list \<Rightarrow>  'a monoid \<Rightarrow> 'a monoid list \<times> ('a \<Rightarrow> 'a) list"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    23
  ("(3_ / \<longlongrightarrow>\<index> _)" [1000, 60])
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    24
  where "exact_seq_arrow  f t G \<equiv> (G # (fst t), f # (snd t))"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    25
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    26
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    27
subsection \<open>Basic Properties\<close>
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    28
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    29
lemma exact_seq_length1: "exact_seq t \<Longrightarrow> length (fst t) = Suc (length (snd t))"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    30
  by (induct t rule: exact_seq.induct) auto
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    31
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    32
lemma exact_seq_length2: "exact_seq t \<Longrightarrow> length (snd t) \<ge> Suc 0"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    33
  by (induct t rule: exact_seq.induct) auto
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    34
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    35
lemma dropped_seq_is_exact_seq:
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    36
  assumes "exact_seq (G, F)" and "(i :: nat) < length F"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    37
  shows "exact_seq (drop i G, drop i F)"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    38
proof-
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    39
  { fix t i assume "exact_seq t" "i < length (snd t)"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    40
    hence "exact_seq (drop i (fst t), drop i (snd t))"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    41
    proof (induction arbitrary: i)
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    42
      case (unity G1 G2 f) thus ?case
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    43
        by (simp add: exact_seq.unity)
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    44
    next
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    45
      case (extension G K l g q H h) show ?case
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    46
      proof (cases)
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    47
        assume "i = 0" thus ?case
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    48
          using exact_seq.extension[OF extension.hyps] by simp
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    49
      next
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    50
        assume "i \<noteq> 0" hence "i \<ge> Suc 0" by simp
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    51
        then obtain k where "k < length (snd (G # K # l, g # q))" "i = Suc k"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    52
          using Suc_le_D extension.prems by auto
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    53
        thus ?thesis using extension.IH by simp 
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    54
      qed
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    55
    qed }
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    56
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    57
  thus ?thesis using assms by auto
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    58
qed
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    59
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    60
lemma truncated_seq_is_exact_seq:
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    61
  assumes "exact_seq (l, q)" and "length l \<ge> 3"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    62
  shows "exact_seq (tl l, tl q)"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    63
  using exact_seq_length1[OF assms(1)] dropped_seq_is_exact_seq[OF assms(1), of "Suc 0"]
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    64
        exact_seq_length2[OF assms(1)] assms(2) by (simp add: drop_Suc)
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    65
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    66
lemma exact_seq_imp_exact_hom:
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    67
   assumes "exact_seq (G1 # l,q) \<longlongrightarrow>\<^bsub>g1\<^esub> G2 \<longlongrightarrow>\<^bsub>g2\<^esub> G3"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    68
   shows "g1 ` (carrier G1) = kernel G2 G3 g2"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    69
proof-
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    70
  { fix t assume "exact_seq t" and "length (fst t) \<ge> 3 \<and> length (snd t) \<ge> 2"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    71
    hence "(hd (tl (snd t))) ` (carrier (hd (tl (tl (fst t))))) =
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    72
            kernel (hd (tl (fst t))) (hd (fst t)) (hd (snd t))"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    73
    proof (induction)
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    74
      case (unity G1 G2 f)
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    75
      then show ?case by auto
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    76
    next
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    77
      case (extension G l g q H h)
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    78
      then show ?case by auto
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    79
    qed }
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    80
  thus ?thesis using assms by fastforce
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    81
qed
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    82
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    83
lemma exact_seq_imp_exact_hom_arbitrary:
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    84
   assumes "exact_seq (G, F)"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    85
     and "Suc i < length F"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    86
   shows "(F ! (Suc i)) ` (carrier (G ! (Suc (Suc i)))) = kernel (G ! (Suc i)) (G ! i) (F ! i)"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    87
proof -
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    88
  have "length (drop i F) \<ge> 2" "length (drop i G) \<ge> 3"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    89
    using assms(2) exact_seq_length1[OF assms(1)] by auto
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    90
  then obtain l q
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    91
    where "drop i G = (G ! i) # (G ! (Suc i)) # (G ! (Suc (Suc i))) # l"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    92
     and  "drop i F = (F ! i) # (F ! (Suc i)) # q"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    93
    by (metis Cons_nth_drop_Suc Suc_less_eq assms exact_seq_length1 fst_conv
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    94
        le_eq_less_or_eq le_imp_less_Suc prod.sel(2))
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    95
  thus ?thesis
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    96
  using dropped_seq_is_exact_seq[OF assms(1), of i] assms(2)
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    97
        exact_seq_imp_exact_hom[of "G ! i" "G ! (Suc i)" "G ! (Suc (Suc i))" l q] by auto
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    98
qed
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
    99
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   100
lemma exact_seq_imp_group_hom :
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   101
  assumes "exact_seq ((G # l, q)) \<longlongrightarrow>\<^bsub>g\<^esub> H"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   102
  shows "group_hom G H g"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   103
proof-
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   104
  { fix t assume "exact_seq t"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   105
    hence "group_hom (hd (tl (fst t))) (hd (fst t)) (hd(snd t))"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   106
    proof (induction)
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   107
      case (unity G1 G2 f)
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   108
      then show ?case by auto
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   109
    next
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   110
      case (extension G l g q H h)
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   111
      then show ?case unfolding group_hom_def group_hom_axioms_def by auto
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   112
    qed }
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   113
  note aux_lemma = this
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   114
  show ?thesis using aux_lemma[OF assms]
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   115
    by simp
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   116
qed
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   117
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   118
lemma exact_seq_imp_group_hom_arbitrary:
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   119
  assumes "exact_seq (G, F)" and "(i :: nat) < length F"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   120
  shows "group_hom (G ! (Suc i)) (G ! i) (F ! i)"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   121
proof -
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   122
  have "length (drop i F) \<ge> 1" "length (drop i G) \<ge> 2"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   123
    using assms(2) exact_seq_length1[OF assms(1)] by auto
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   124
  then obtain l q
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   125
    where "drop i G = (G ! i) # (G ! (Suc i)) # l"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   126
     and  "drop i F = (F ! i) # q"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   127
    by (metis Cons_nth_drop_Suc Suc_leI assms exact_seq_length1 fst_conv
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   128
        le_eq_less_or_eq le_imp_less_Suc prod.sel(2))
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   129
  thus ?thesis
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   130
  using dropped_seq_is_exact_seq[OF assms(1), of i] assms(2)
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   131
        exact_seq_imp_group_hom[of "G ! i" "G ! (Suc i)" l q "F ! i"] by simp
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   132
qed
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   133
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   134
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   135
subsection \<open>Link Between Exact Sequences and Solvable Conditions\<close>
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   136
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   137
lemma exact_seq_solvable_imp :
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   138
  assumes "exact_seq ([G1],[]) \<longlongrightarrow>\<^bsub>g1\<^esub> G2 \<longlongrightarrow>\<^bsub>g2\<^esub> G3"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   139
    and "inj_on g1 (carrier G1)"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   140
    and "g2 ` (carrier G2) = carrier G3"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   141
  shows "solvable G2 \<Longrightarrow> (solvable G1) \<and> (solvable G3)"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   142
proof -
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   143
  assume G2: "solvable G2"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   144
  have "group_hom G1 G2 g1"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   145
    using exact_seq_imp_group_hom_arbitrary[OF assms(1), of "Suc 0"] by simp
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   146
  hence "solvable G1"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   147
    using group_hom.inj_hom_imp_solvable[of G1 G2 g1] assms(2) G2 by simp
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   148
  moreover have "group_hom G2 G3 g2"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   149
    using exact_seq_imp_group_hom_arbitrary[OF assms(1), of 0] by simp
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   150
  hence "solvable G3"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   151
    using group_hom.surj_hom_imp_solvable[of G2 G3 g2] assms(3) G2 by simp
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   152
  ultimately show ?thesis by simp
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   153
qed
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   154
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   155
lemma exact_seq_solvable_recip :
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   156
  assumes "exact_seq ([G1],[]) \<longlongrightarrow>\<^bsub>g1\<^esub> G2 \<longlongrightarrow>\<^bsub>g2\<^esub> G3"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   157
    and "inj_on g1 (carrier G1)"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   158
    and "g2 ` (carrier G2) = carrier G3"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   159
  shows "(solvable G1) \<and> (solvable G3) \<Longrightarrow> solvable G2"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   160
proof -
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   161
  assume "(solvable G1) \<and> (solvable G3)"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   162
  hence G1: "solvable G1" and G3: "solvable G3" by auto
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   163
  have g1: "group_hom G1 G2 g1" and g2: "group_hom G2 G3 g2"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   164
    using exact_seq_imp_group_hom_arbitrary[OF assms(1), of "Suc 0"]
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   165
          exact_seq_imp_group_hom_arbitrary[OF assms(1), of 0] by auto
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   166
  show ?thesis
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   167
    using solvable_condition[OF g1 g2 assms(3)]
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   168
          exact_seq_imp_exact_hom[OF assms(1)] G1 G3 by auto
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   169
qed
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   170
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   171
proposition exact_seq_solvable_iff :
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   172
  assumes "exact_seq ([G1],[]) \<longlongrightarrow>\<^bsub>g1\<^esub> G2 \<longlongrightarrow>\<^bsub>g2\<^esub> G3"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   173
    and "inj_on g1 (carrier G1)"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   174
    and "g2 ` (carrier G2) = carrier G3"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   175
  shows "(solvable G1) \<and> (solvable G3) \<longleftrightarrow>  solvable G2"
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   176
  using exact_seq_solvable_recip exact_seq_solvable_imp assms by blast
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   177
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   178
end
1f86a092655b more algebra
paulson <lp15@cam.ac.uk>
parents:
diff changeset
   179