src/HOL/Algebra/Module.thy
author wenzelm
Fri, 03 May 2019 20:03:45 +0200
changeset 70244 2ca87b481077
parent 68596 81086e6f5429
child 80914 d97fdabd9e2b
permissions -rw-r--r--
back to gz for macos: more robust;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
14706
71590b7733b7 tuned document;
wenzelm
parents: 14651
diff changeset
     1
(*  Title:      HOL/Algebra/Module.thy
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
     2
    Author:     Clemens Ballarin, started 15 April 2003
68581
0793e5ad25ec eliminated hard TABs, assuming tabsize=8;
wenzelm
parents: 68552
diff changeset
     3
                with contributions by Martin Baillon
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
     4
*)
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
     5
35849
b5522b51cb1e standard headers;
wenzelm
parents: 29237
diff changeset
     6
theory Module
b5522b51cb1e standard headers;
wenzelm
parents: 29237
diff changeset
     7
imports Ring
b5522b51cb1e standard headers;
wenzelm
parents: 29237
diff changeset
     8
begin
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
     9
61382
efac889fccbc isabelle update_cartouches;
wenzelm
parents: 58860
diff changeset
    10
section \<open>Modules over an Abelian Group\<close>
20318
0e0ea63fe768 Restructured algebra library, added ideals and quotient rings.
ballarin
parents: 20168
diff changeset
    11
61382
efac889fccbc isabelle update_cartouches;
wenzelm
parents: 58860
diff changeset
    12
subsection \<open>Definitions\<close>
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    13
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    14
record ('a, 'b) module = "'b ring" +
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    15
  smult :: "['a, 'b] => 'b" (infixl "\<odot>\<index>" 70)
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    16
61565
352c73a689da Qualifiers in locale expressions default to mandatory regardless of the command.
ballarin
parents: 61382
diff changeset
    17
locale module = R?: cring + M?: abelian_group M for M (structure) +
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    18
  assumes smult_closed [simp, intro]:
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
    19
      "[| a \<in> carrier R; x \<in> carrier M |] ==> a \<odot>\<^bsub>M\<^esub> x \<in> carrier M"
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    20
    and smult_l_distr:
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    21
      "[| a \<in> carrier R; b \<in> carrier R; x \<in> carrier M |] ==>
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
    22
      (a \<oplus> b) \<odot>\<^bsub>M\<^esub> x = a \<odot>\<^bsub>M\<^esub> x \<oplus>\<^bsub>M\<^esub> b \<odot>\<^bsub>M\<^esub> x"
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    23
    and smult_r_distr:
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    24
      "[| a \<in> carrier R; x \<in> carrier M; y \<in> carrier M |] ==>
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
    25
      a \<odot>\<^bsub>M\<^esub> (x \<oplus>\<^bsub>M\<^esub> y) = a \<odot>\<^bsub>M\<^esub> x \<oplus>\<^bsub>M\<^esub> a \<odot>\<^bsub>M\<^esub> y"
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    26
    and smult_assoc1:
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    27
      "[| a \<in> carrier R; b \<in> carrier R; x \<in> carrier M |] ==>
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
    28
      (a \<otimes> b) \<odot>\<^bsub>M\<^esub> x = a \<odot>\<^bsub>M\<^esub> (b \<odot>\<^bsub>M\<^esub> x)"
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    29
    and smult_one [simp]:
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
    30
      "x \<in> carrier M ==> \<one> \<odot>\<^bsub>M\<^esub> x = x"
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    31
29237
e90d9d51106b More porting to new locales.
ballarin
parents: 28823
diff changeset
    32
locale algebra = module + cring M +
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    33
  assumes smult_assoc2:
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    34
      "[| a \<in> carrier R; x \<in> carrier M; y \<in> carrier M |] ==>
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
    35
      (a \<odot>\<^bsub>M\<^esub> x) \<otimes>\<^bsub>M\<^esub> y = a \<odot>\<^bsub>M\<^esub> (x \<otimes>\<^bsub>M\<^esub> y)"
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    36
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    37
lemma moduleI:
19783
82f365a14960 Improved parameter management of locales.
ballarin
parents: 16417
diff changeset
    38
  fixes R (structure) and M (structure)
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    39
  assumes cring: "cring R"
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    40
    and abelian_group: "abelian_group M"
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    41
    and smult_closed:
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
    42
      "!!a x. [| a \<in> carrier R; x \<in> carrier M |] ==> a \<odot>\<^bsub>M\<^esub> x \<in> carrier M"
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    43
    and smult_l_distr:
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    44
      "!!a b x. [| a \<in> carrier R; b \<in> carrier R; x \<in> carrier M |] ==>
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
    45
      (a \<oplus> b) \<odot>\<^bsub>M\<^esub> x = (a \<odot>\<^bsub>M\<^esub> x) \<oplus>\<^bsub>M\<^esub> (b \<odot>\<^bsub>M\<^esub> x)"
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    46
    and smult_r_distr:
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    47
      "!!a x y. [| a \<in> carrier R; x \<in> carrier M; y \<in> carrier M |] ==>
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
    48
      a \<odot>\<^bsub>M\<^esub> (x \<oplus>\<^bsub>M\<^esub> y) = (a \<odot>\<^bsub>M\<^esub> x) \<oplus>\<^bsub>M\<^esub> (a \<odot>\<^bsub>M\<^esub> y)"
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    49
    and smult_assoc1:
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    50
      "!!a b x. [| a \<in> carrier R; b \<in> carrier R; x \<in> carrier M |] ==>
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
    51
      (a \<otimes> b) \<odot>\<^bsub>M\<^esub> x = a \<odot>\<^bsub>M\<^esub> (b \<odot>\<^bsub>M\<^esub> x)"
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    52
    and smult_one:
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
    53
      "!!x. x \<in> carrier M ==> \<one> \<odot>\<^bsub>M\<^esub> x = x"
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    54
  shows "module R M"
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    55
  by (auto intro: module.intro cring.axioms abelian_group.axioms
27714
27b4d7c01f8b Tuned (for the sake of a meaningless log entry).
ballarin
parents: 20318
diff changeset
    56
    module_axioms.intro assms)
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    57
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    58
lemma algebraI:
19783
82f365a14960 Improved parameter management of locales.
ballarin
parents: 16417
diff changeset
    59
  fixes R (structure) and M (structure)
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    60
  assumes R_cring: "cring R"
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    61
    and M_cring: "cring M"
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    62
    and smult_closed:
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
    63
      "!!a x. [| a \<in> carrier R; x \<in> carrier M |] ==> a \<odot>\<^bsub>M\<^esub> x \<in> carrier M"
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    64
    and smult_l_distr:
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    65
      "!!a b x. [| a \<in> carrier R; b \<in> carrier R; x \<in> carrier M |] ==>
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
    66
      (a \<oplus> b) \<odot>\<^bsub>M\<^esub> x = (a \<odot>\<^bsub>M\<^esub> x) \<oplus>\<^bsub>M\<^esub> (b \<odot>\<^bsub>M\<^esub> x)"
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    67
    and smult_r_distr:
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    68
      "!!a x y. [| a \<in> carrier R; x \<in> carrier M; y \<in> carrier M |] ==>
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
    69
      a \<odot>\<^bsub>M\<^esub> (x \<oplus>\<^bsub>M\<^esub> y) = (a \<odot>\<^bsub>M\<^esub> x) \<oplus>\<^bsub>M\<^esub> (a \<odot>\<^bsub>M\<^esub> y)"
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    70
    and smult_assoc1:
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    71
      "!!a b x. [| a \<in> carrier R; b \<in> carrier R; x \<in> carrier M |] ==>
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
    72
      (a \<otimes> b) \<odot>\<^bsub>M\<^esub> x = a \<odot>\<^bsub>M\<^esub> (b \<odot>\<^bsub>M\<^esub> x)"
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    73
    and smult_one:
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
    74
      "!!x. x \<in> carrier M ==> (one R) \<odot>\<^bsub>M\<^esub> x = x"
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    75
    and smult_assoc2:
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    76
      "!!a x y. [| a \<in> carrier R; x \<in> carrier M; y \<in> carrier M |] ==>
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
    77
      (a \<odot>\<^bsub>M\<^esub> x) \<otimes>\<^bsub>M\<^esub> y = a \<odot>\<^bsub>M\<^esub> (x \<otimes>\<^bsub>M\<^esub> y)"
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    78
  shows "algebra R M"
68551
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
    79
  apply intro_locales
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
    80
             apply (rule cring.axioms ring.axioms abelian_group.axioms comm_monoid.axioms assms)+
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
    81
      apply (rule module_axioms.intro)
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
    82
          apply (simp add: smult_closed)
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
    83
         apply (simp add: smult_l_distr)
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
    84
        apply (simp add: smult_r_distr)
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
    85
       apply (simp add: smult_assoc1)
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
    86
      apply (simp add: smult_one)
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
    87
     apply (rule cring.axioms ring.axioms abelian_group.axioms comm_monoid.axioms assms)+
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
    88
  apply (rule algebra_axioms.intro)
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
    89
  apply (simp add: smult_assoc2)
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
    90
  done
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    91
68551
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
    92
lemma (in algebra) R_cring: "cring R" ..
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    93
68551
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
    94
lemma (in algebra) M_cring: "cring M" ..
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    95
68551
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
    96
lemma (in algebra) module: "module R M"
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
    97
  by (auto intro: moduleI R_cring is_abelian_group smult_l_distr smult_r_distr smult_assoc1)
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
    98
14651
02b8f3bcf7fe improved notation;
wenzelm
parents: 14577
diff changeset
    99
68551
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   100
subsection \<open>Basic Properties of Modules\<close>
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
   101
68551
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   102
lemma (in module) smult_l_null [simp]:
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   103
 "x \<in> carrier M ==> \<zero> \<odot>\<^bsub>M\<^esub> x = \<zero>\<^bsub>M\<^esub>"
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   104
proof-
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   105
  assume M : "x \<in> carrier M"
20168
ed7bced29e1b Reimplemented algebra method; now controlled by attribute.
ballarin
parents: 19984
diff changeset
   106
  note facts = M smult_closed [OF R.zero_closed]
68551
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   107
  from facts have "\<zero> \<odot>\<^bsub>M\<^esub> x = (\<zero> \<oplus> \<zero>) \<odot>\<^bsub>M\<^esub> x "
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   108
    using smult_l_distr by auto
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   109
  also have "... = \<zero> \<odot>\<^bsub>M\<^esub> x \<oplus>\<^bsub>M\<^esub> \<zero> \<odot>\<^bsub>M\<^esub> x"
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   110
    using smult_l_distr[of \<zero> \<zero> x] facts by auto
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   111
  finally show "\<zero> \<odot>\<^bsub>M\<^esub> x = \<zero>\<^bsub>M\<^esub>" using facts
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   112
    by (metis M.add.r_cancel_one')
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
   113
qed
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
   114
68551
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   115
lemma (in module) smult_r_null [simp]:
58860
fee7cfa69c50 eliminated spurious semicolons;
wenzelm
parents: 35849
diff changeset
   116
  "a \<in> carrier R ==> a \<odot>\<^bsub>M\<^esub> \<zero>\<^bsub>M\<^esub> = \<zero>\<^bsub>M\<^esub>"
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
   117
proof -
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
   118
  assume R: "a \<in> carrier R"
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
   119
  note facts = R smult_closed
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
   120
  from facts have "a \<odot>\<^bsub>M\<^esub> \<zero>\<^bsub>M\<^esub> = (a \<odot>\<^bsub>M\<^esub> \<zero>\<^bsub>M\<^esub> \<oplus>\<^bsub>M\<^esub> a \<odot>\<^bsub>M\<^esub> \<zero>\<^bsub>M\<^esub>) \<oplus>\<^bsub>M\<^esub> \<ominus>\<^bsub>M\<^esub> (a \<odot>\<^bsub>M\<^esub> \<zero>\<^bsub>M\<^esub>)"
68551
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   121
    by (simp add: M.add.inv_solve_right)
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
   122
  also from R have "... = a \<odot>\<^bsub>M\<^esub> (\<zero>\<^bsub>M\<^esub> \<oplus>\<^bsub>M\<^esub> \<zero>\<^bsub>M\<^esub>) \<oplus>\<^bsub>M\<^esub> \<ominus>\<^bsub>M\<^esub> (a \<odot>\<^bsub>M\<^esub> \<zero>\<^bsub>M\<^esub>)"
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
   123
    by (simp add: smult_r_distr del: M.l_zero M.r_zero)
68551
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   124
  also from facts have "... = \<zero>\<^bsub>M\<^esub>"
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   125
    by (simp add: M.r_neg)
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
   126
  finally show ?thesis .
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
   127
qed
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
   128
68551
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   129
lemma (in module) smult_l_minus:
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   130
"\<lbrakk> a \<in> carrier R; x \<in> carrier M \<rbrakk> \<Longrightarrow> (\<ominus>a) \<odot>\<^bsub>M\<^esub> x = \<ominus>\<^bsub>M\<^esub> (a \<odot>\<^bsub>M\<^esub> x)"
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   131
proof-
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
   132
  assume RM: "a \<in> carrier R" "x \<in> carrier M"
20168
ed7bced29e1b Reimplemented algebra method; now controlled by attribute.
ballarin
parents: 19984
diff changeset
   133
  from RM have a_smult: "a \<odot>\<^bsub>M\<^esub> x \<in> carrier M" by simp
ed7bced29e1b Reimplemented algebra method; now controlled by attribute.
ballarin
parents: 19984
diff changeset
   134
  from RM have ma_smult: "\<ominus>a \<odot>\<^bsub>M\<^esub> x \<in> carrier M" by simp
ed7bced29e1b Reimplemented algebra method; now controlled by attribute.
ballarin
parents: 19984
diff changeset
   135
  note facts = RM a_smult ma_smult
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
   136
  from facts have "(\<ominus>a) \<odot>\<^bsub>M\<^esub> x = (\<ominus>a \<odot>\<^bsub>M\<^esub> x \<oplus>\<^bsub>M\<^esub> a \<odot>\<^bsub>M\<^esub> x) \<oplus>\<^bsub>M\<^esub> \<ominus>\<^bsub>M\<^esub>(a \<odot>\<^bsub>M\<^esub> x)"
68551
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   137
    by (simp add: M.add.inv_solve_right)
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
   138
  also from RM have "... = (\<ominus>a \<oplus> a) \<odot>\<^bsub>M\<^esub> x \<oplus>\<^bsub>M\<^esub> \<ominus>\<^bsub>M\<^esub>(a \<odot>\<^bsub>M\<^esub> x)"
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
   139
    by (simp add: smult_l_distr)
20168
ed7bced29e1b Reimplemented algebra method; now controlled by attribute.
ballarin
parents: 19984
diff changeset
   140
  also from facts smult_l_null have "... = \<ominus>\<^bsub>M\<^esub>(a \<odot>\<^bsub>M\<^esub> x)"
68551
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   141
    by (simp add: R.l_neg)
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
   142
  finally show ?thesis .
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
   143
qed
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
   144
68551
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   145
lemma (in module) smult_r_minus:
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
   146
  "[| a \<in> carrier R; x \<in> carrier M |] ==> a \<odot>\<^bsub>M\<^esub> (\<ominus>\<^bsub>M\<^esub>x) = \<ominus>\<^bsub>M\<^esub> (a \<odot>\<^bsub>M\<^esub> x)"
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
   147
proof -
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
   148
  assume RM: "a \<in> carrier R" "x \<in> carrier M"
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
   149
  note facts = RM smult_closed
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
   150
  from facts have "a \<odot>\<^bsub>M\<^esub> (\<ominus>\<^bsub>M\<^esub>x) = (a \<odot>\<^bsub>M\<^esub> \<ominus>\<^bsub>M\<^esub>x \<oplus>\<^bsub>M\<^esub> a \<odot>\<^bsub>M\<^esub> x) \<oplus>\<^bsub>M\<^esub> \<ominus>\<^bsub>M\<^esub>(a \<odot>\<^bsub>M\<^esub> x)"
68551
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   151
    by (simp add: M.add.inv_solve_right)
15095
63f5f4c265dd Theories now take advantage of recent syntax improvements with (structure).
ballarin
parents: 14706
diff changeset
   152
  also from RM have "... = a \<odot>\<^bsub>M\<^esub> (\<ominus>\<^bsub>M\<^esub>x \<oplus>\<^bsub>M\<^esub> x) \<oplus>\<^bsub>M\<^esub> \<ominus>\<^bsub>M\<^esub>(a \<odot>\<^bsub>M\<^esub> x)"
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
   153
    by (simp add: smult_r_distr)
68551
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   154
  also from facts smult_l_null have "... = \<ominus>\<^bsub>M\<^esub>(a \<odot>\<^bsub>M\<^esub> x)"
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   155
    by (metis M.add.inv_closed M.add.inv_solve_right M.l_neg R.zero_closed r_null smult_assoc1)
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
   156
  finally show ?thesis .
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
   157
qed
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
   158
68551
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   159
lemma (in module) finsum_smult_ldistr:
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   160
  "\<lbrakk> finite A; a \<in> carrier R; f: A \<rightarrow> carrier M \<rbrakk> \<Longrightarrow>
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   161
     a \<odot>\<^bsub>M\<^esub> (\<Oplus>\<^bsub>M\<^esub> i \<in> A. (f i)) = (\<Oplus>\<^bsub>M\<^esub> i \<in> A. ( a \<odot>\<^bsub>M\<^esub> (f i)))"
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   162
proof (induct set: finite)
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   163
  case empty then show ?case
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   164
    by (metis M.finsum_empty M.zero_closed R.zero_closed r_null smult_assoc1 smult_l_null)
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   165
next
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   166
  case (insert x F) then show ?case
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   167
    by (simp add: Pi_def smult_r_distr)
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   168
qed
b680e74eb6f2 More on Algebra by Paulo and Martin
paulson <lp15@cam.ac.uk>
parents: 61565
diff changeset
   169
68592
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   170
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   171
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   172
subsection \<open>Submodules\<close>
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   173
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   174
locale submodule = subgroup H "add_monoid M" for H and R :: "('a, 'b) ring_scheme" and M (structure)
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   175
+ assumes smult_closed [simp, intro]:
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   176
      "\<lbrakk>a \<in> carrier R; x \<in> H\<rbrakk> \<Longrightarrow> a \<odot>\<^bsub>M\<^esub> x \<in> H"
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   177
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   178
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   179
lemma (in module) submoduleI :
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   180
  assumes subset: "H \<subseteq> carrier M"
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   181
    and zero: "\<zero>\<^bsub>M\<^esub> \<in> H"
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   182
    and a_inv: "!!a. a \<in> H \<Longrightarrow> \<ominus>\<^bsub>M\<^esub> a \<in> H"
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   183
    and add : "\<And> a b. \<lbrakk>a \<in> H ; b \<in> H\<rbrakk> \<Longrightarrow> a \<oplus>\<^bsub>M\<^esub> b \<in> H"
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   184
    and smult_closed : "\<And> a x. \<lbrakk>a \<in> carrier R; x \<in> H\<rbrakk> \<Longrightarrow> a \<odot>\<^bsub>M\<^esub> x \<in> H"
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   185
  shows "submodule H R M"
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   186
  apply (intro submodule.intro subgroup.intro)
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   187
  using assms unfolding submodule_axioms_def
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   188
  by (simp_all add : a_inv_def)
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   189
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   190
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   191
lemma (in module) submoduleE :
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   192
  assumes "submodule H R M"
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   193
  shows "H \<subseteq> carrier M"
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   194
    and "H \<noteq> {}"
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   195
    and "\<And>a. a \<in> H \<Longrightarrow> \<ominus>\<^bsub>M\<^esub> a \<in> H"
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   196
    and "\<And>a b. \<lbrakk>a \<in> carrier R; b \<in> H\<rbrakk> \<Longrightarrow> a \<odot>\<^bsub>M\<^esub> b \<in> H"
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   197
    and "\<And> a b. \<lbrakk>a \<in> H ; b \<in> H\<rbrakk> \<Longrightarrow> a \<oplus>\<^bsub>M\<^esub> b \<in> H"
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   198
    and "\<And> x. x \<in> H \<Longrightarrow> (a_inv M x) \<in> H"
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   199
  using group.subgroupE[of "add_monoid M" H, OF _ submodule.axioms(1)[OF assms]] a_comm_group
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   200
        submodule.smult_closed[OF assms]
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   201
  unfolding comm_group_def a_inv_def
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   202
  by auto
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   203
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   204
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   205
lemma (in module) carrier_is_submodule :
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   206
"submodule (carrier M) R M"
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   207
  apply (intro  submoduleI)
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   208
  using a_comm_group group.inv_closed unfolding comm_group_def a_inv_def group_def monoid_def
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   209
  by auto
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   210
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   211
lemma (in submodule) submodule_is_module :
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   212
  assumes "module R M"
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   213
  shows "module R (M\<lparr>carrier := H\<rparr>)"
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   214
proof (auto intro! : moduleI abelian_group.intro)
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   215
  show "cring (R)" using assms unfolding module_def by auto
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   216
  show "abelian_monoid (M\<lparr>carrier := H\<rparr>)"
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   217
    using comm_monoid.submonoid_is_comm_monoid[OF _ subgroup_is_submonoid] assms
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   218
    unfolding abelian_monoid_def module_def abelian_group_def
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   219
    by auto
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   220
  thus "abelian_group_axioms (M\<lparr>carrier := H\<rparr>)"
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   221
    using subgroup_is_group assms
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   222
    unfolding abelian_group_axioms_def comm_group_def abelian_monoid_def module_def abelian_group_def
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   223
    by auto
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   224
  show "\<And>z. z \<in> H \<Longrightarrow> \<one>\<^bsub>R\<^esub> \<odot> z = z"
68596
81086e6f5429 replaced subgroup_imp_subset in Modules
paulson <lp15@cam.ac.uk>
parents: 68592
diff changeset
   225
    using subgroup.subset[OF subgroup_axioms] module.smult_one[OF assms]
68592
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   226
    by auto
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   227
  fix a b x y assume a : "a \<in> carrier R" and b : "b \<in> carrier R" and x : "x \<in> H" and y : "y \<in> H"
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   228
  show "(a \<oplus>\<^bsub>R\<^esub> b) \<odot> x = a \<odot> x \<oplus> b \<odot> x"
68596
81086e6f5429 replaced subgroup_imp_subset in Modules
paulson <lp15@cam.ac.uk>
parents: 68592
diff changeset
   229
    using a b x module.smult_l_distr[OF assms] subgroup.subset[OF subgroup_axioms]
68592
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   230
    by auto
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   231
  show "a \<odot> (x \<oplus> y) = a \<odot> x \<oplus> a \<odot> y"
68596
81086e6f5429 replaced subgroup_imp_subset in Modules
paulson <lp15@cam.ac.uk>
parents: 68592
diff changeset
   232
    using a x y module.smult_r_distr[OF assms] subgroup.subset[OF subgroup_axioms]
68592
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   233
    by auto
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   234
  show "a \<otimes>\<^bsub>R\<^esub> b \<odot> x = a \<odot> (b \<odot> x)"
68596
81086e6f5429 replaced subgroup_imp_subset in Modules
paulson <lp15@cam.ac.uk>
parents: 68592
diff changeset
   235
    using a b x module.smult_assoc1[OF assms] subgroup.subset[OF subgroup_axioms]
68592
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   236
    by auto
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   237
qed
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   238
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   239
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   240
lemma (in module) module_incl_imp_submodule :
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   241
  assumes "H \<subseteq> carrier M"
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   242
    and "module R (M\<lparr>carrier := H\<rparr>)"
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   243
  shows "submodule H R M"
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   244
  apply (intro submodule.intro)
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   245
  using add.group_incl_imp_subgroup[OF assms(1)] assms module.axioms(2)[OF assms(2)]
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   246
        module.smult_closed[OF assms(2)]
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   247
  unfolding abelian_group_def abelian_group_axioms_def comm_group_def submodule_axioms_def
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   248
  by simp_all
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   249
6366129107ad submodules
paulson <lp15@cam.ac.uk>
parents: 68581
diff changeset
   250
13936
d3671b878828 Greatly extended CRing. Added Module.
ballarin
parents:
diff changeset
   251
end