src/ZF/ex/Ring.thy
author wenzelm
Fri, 24 Jan 2025 19:25:31 +0100
changeset 81970 6a2f889fa3b9
parent 81128 5b201b24d99b
permissions -rw-r--r--
proper executable from "isabelle ocaml_opam env";
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
     1
(* Title:  ZF/ex/Ring.thy
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
     2
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
     3
*)
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
     4
60770
240563fbf41d isabelle update_cartouches;
wenzelm
parents: 58871
diff changeset
     5
section \<open>Rings\<close>
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
     6
16417
9bc16273c2d4 migrated theory headers to new format
haftmann
parents: 14883
diff changeset
     7
theory Ring imports Group begin
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
     8
81128
5b201b24d99b tuned whitespace, to simplify hypersearch;
wenzelm
parents: 80917
diff changeset
     9
no_notation cadd  (infixl \<open>\<oplus>\<close> 65) and cmult  (infixl \<open>\<otimes>\<close> 70)
46821
ff6b0c1087f2 Using mathematical notation for <-> and cardinal arithmetic
paulson
parents: 41524
diff changeset
    10
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    11
(*First, we must simulate a record declaration:
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    12
record ring = monoid +
76215
a642599ffdea More syntactic cleanup. LaTeX markup working
paulson <lp15@cam.ac.uk>
parents: 76214
diff changeset
    13
  add :: "[i, i] \<Rightarrow> i" (infixl "\<oplus>\<index>" 65)
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    14
  zero :: i ("\<zero>\<index>")
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    15
*)
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    16
21233
5a5c8ea5f66a tuned specifications;
wenzelm
parents: 17258
diff changeset
    17
definition
76215
a642599ffdea More syntactic cleanup. LaTeX markup working
paulson <lp15@cam.ac.uk>
parents: 76214
diff changeset
    18
  add_field :: "i \<Rightarrow> i" where
21233
5a5c8ea5f66a tuned specifications;
wenzelm
parents: 17258
diff changeset
    19
  "add_field(M) = fst(snd(snd(snd(M))))"
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    20
21404
eb85850d3eb7 more robust syntax for definition/abbreviation/notation;
wenzelm
parents: 21233
diff changeset
    21
definition
76215
a642599ffdea More syntactic cleanup. LaTeX markup working
paulson <lp15@cam.ac.uk>
parents: 76214
diff changeset
    22
  ring_add :: "[i, i, i] \<Rightarrow> i" (infixl \<open>\<oplus>\<index>\<close> 65) where
a642599ffdea More syntactic cleanup. LaTeX markup working
paulson <lp15@cam.ac.uk>
parents: 76214
diff changeset
    23
  "ring_add(M,x,y) = add_field(M) ` \<langle>x,y\<rangle>"
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    24
21404
eb85850d3eb7 more robust syntax for definition/abbreviation/notation;
wenzelm
parents: 21233
diff changeset
    25
definition
76215
a642599ffdea More syntactic cleanup. LaTeX markup working
paulson <lp15@cam.ac.uk>
parents: 76214
diff changeset
    26
  zero :: "i \<Rightarrow> i" (\<open>\<zero>\<index>\<close>) where
21233
5a5c8ea5f66a tuned specifications;
wenzelm
parents: 17258
diff changeset
    27
  "zero(M) = fst(snd(snd(snd(snd(M)))))"
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    28
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    29
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    30
lemma add_field_eq [simp]: "add_field(<C,M,I,A,z>) = A"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    31
  by (simp add: add_field_def)
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    32
76215
a642599ffdea More syntactic cleanup. LaTeX markup working
paulson <lp15@cam.ac.uk>
parents: 76214
diff changeset
    33
lemma add_eq [simp]: "ring_add(<C,M,I,A,z>, x, y) = A ` \<langle>x,y\<rangle>"
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    34
  by (simp add: ring_add_def)
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    35
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    36
lemma zero_eq [simp]: "zero(<C,M,I,A,Z,z>) = Z"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    37
  by (simp add: zero_def)
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    38
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    39
60770
240563fbf41d isabelle update_cartouches;
wenzelm
parents: 58871
diff changeset
    40
text \<open>Derived operations.\<close>
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    41
21233
5a5c8ea5f66a tuned specifications;
wenzelm
parents: 17258
diff changeset
    42
definition
76215
a642599ffdea More syntactic cleanup. LaTeX markup working
paulson <lp15@cam.ac.uk>
parents: 76214
diff changeset
    43
  a_inv :: "[i,i] \<Rightarrow> i" (\<open>\<ominus>\<index> _\<close> [81] 80) where
76213
e44d86131648 Removal of obsolete ASCII syntax
paulson <lp15@cam.ac.uk>
parents: 69587
diff changeset
    44
  "a_inv(R) \<equiv> m_inv (<carrier(R), add_field(R), zero(R), 0>)"
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    45
21404
eb85850d3eb7 more robust syntax for definition/abbreviation/notation;
wenzelm
parents: 21233
diff changeset
    46
definition
80917
2a77bc3b4eac more inner syntax markup: minor object-logics;
wenzelm
parents: 76215
diff changeset
    47
  minus :: "[i,i,i] \<Rightarrow> i" (\<open>(\<open>notation=\<open>infix \<ominus>\<close>\<close>_ \<ominus>\<index> _)\<close> [65,66] 65) where
21233
5a5c8ea5f66a tuned specifications;
wenzelm
parents: 17258
diff changeset
    48
  "\<lbrakk>x \<in> carrier(R); y \<in> carrier(R)\<rbrakk> \<Longrightarrow> x \<ominus>\<^bsub>R\<^esub> y = x \<oplus>\<^bsub>R\<^esub> (\<ominus>\<^bsub>R\<^esub> y)"
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    49
29223
e09c53289830 Conversion of HOL-Main and ZF to new locales.
ballarin
parents: 28952
diff changeset
    50
locale abelian_monoid = fixes G (structure)
46821
ff6b0c1087f2 Using mathematical notation for <-> and cardinal arithmetic
paulson
parents: 41524
diff changeset
    51
  assumes a_comm_monoid:
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    52
    "comm_monoid (<carrier(G), add_field(G), zero(G), 0>)"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    53
60770
240563fbf41d isabelle update_cartouches;
wenzelm
parents: 58871
diff changeset
    54
text \<open>
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    55
  The following definition is redundant but simple to use.
60770
240563fbf41d isabelle update_cartouches;
wenzelm
parents: 58871
diff changeset
    56
\<close>
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    57
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    58
locale abelian_group = abelian_monoid +
46821
ff6b0c1087f2 Using mathematical notation for <-> and cardinal arithmetic
paulson
parents: 41524
diff changeset
    59
  assumes a_comm_group:
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    60
    "comm_group (<carrier(G), add_field(G), zero(G), 0>)"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    61
29223
e09c53289830 Conversion of HOL-Main and ZF to new locales.
ballarin
parents: 28952
diff changeset
    62
locale ring = abelian_group R + monoid R for R (structure) +
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    63
  assumes l_distr: "\<lbrakk>x \<in> carrier(R); y \<in> carrier(R); z \<in> carrier(R)\<rbrakk>
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    64
      \<Longrightarrow> (x \<oplus> y) \<cdot> z = x \<cdot> z \<oplus> y \<cdot> z"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    65
    and r_distr: "\<lbrakk>x \<in> carrier(R); y \<in> carrier(R); z \<in> carrier(R)\<rbrakk>
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    66
      \<Longrightarrow> z \<cdot> (x \<oplus> y) = z \<cdot> x \<oplus> z \<cdot> y"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    67
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    68
locale cring = ring + comm_monoid R
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    69
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    70
locale "domain" = cring +
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    71
  assumes one_not_zero [simp]: "\<one> \<noteq> \<zero>"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    72
    and integral: "\<lbrakk>a \<cdot> b = \<zero>; a \<in> carrier(R); b \<in> carrier(R)\<rbrakk> \<Longrightarrow>
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    73
                  a = \<zero> | b = \<zero>"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    74
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    75
60770
240563fbf41d isabelle update_cartouches;
wenzelm
parents: 58871
diff changeset
    76
subsection \<open>Basic Properties\<close>
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    77
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    78
lemma (in abelian_monoid) a_monoid:
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    79
     "monoid (<carrier(G), add_field(G), zero(G), 0>)"
46821
ff6b0c1087f2 Using mathematical notation for <-> and cardinal arithmetic
paulson
parents: 41524
diff changeset
    80
apply (insert a_comm_monoid)
ff6b0c1087f2 Using mathematical notation for <-> and cardinal arithmetic
paulson
parents: 41524
diff changeset
    81
apply (simp add: comm_monoid_def)
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    82
done
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    83
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    84
lemma (in abelian_group) a_group:
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    85
     "group (<carrier(G), add_field(G), zero(G), 0>)"
46821
ff6b0c1087f2 Using mathematical notation for <-> and cardinal arithmetic
paulson
parents: 41524
diff changeset
    86
apply (insert a_comm_group)
ff6b0c1087f2 Using mathematical notation for <-> and cardinal arithmetic
paulson
parents: 41524
diff changeset
    87
apply (simp add: comm_group_def group_def)
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    88
done
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    89
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    90
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    91
lemma (in abelian_monoid) l_zero [simp]:
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    92
     "x \<in> carrier(G) \<Longrightarrow> \<zero> \<oplus> x = x"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    93
apply (insert monoid.l_one [OF a_monoid])
46821
ff6b0c1087f2 Using mathematical notation for <-> and cardinal arithmetic
paulson
parents: 41524
diff changeset
    94
apply (simp add: ring_add_def)
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    95
done
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    96
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    97
lemma (in abelian_monoid) zero_closed [intro, simp]:
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    98
     "\<zero> \<in> carrier(G)"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
    99
by (rule monoid.one_closed [OF a_monoid, simplified])
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   100
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   101
lemma (in abelian_group) a_inv_closed [intro, simp]:
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   102
     "x \<in> carrier(G) \<Longrightarrow> \<ominus> x \<in> carrier(G)"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   103
by (simp add: a_inv_def  group.inv_closed [OF a_group, simplified])
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   104
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   105
lemma (in abelian_monoid) a_closed [intro, simp]:
76213
e44d86131648 Removal of obsolete ASCII syntax
paulson <lp15@cam.ac.uk>
parents: 69587
diff changeset
   106
     "\<lbrakk>x \<in> carrier(G); y \<in> carrier(G)\<rbrakk> \<Longrightarrow> x \<oplus> y \<in> carrier(G)"
46821
ff6b0c1087f2 Using mathematical notation for <-> and cardinal arithmetic
paulson
parents: 41524
diff changeset
   107
by (rule monoid.m_closed [OF a_monoid,
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   108
                  simplified, simplified ring_add_def [symmetric]])
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   109
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   110
lemma (in abelian_group) minus_closed [intro, simp]:
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   111
     "\<lbrakk>x \<in> carrier(G); y \<in> carrier(G)\<rbrakk> \<Longrightarrow> x \<ominus> y \<in> carrier(G)"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   112
by (simp add: minus_def)
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   113
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   114
lemma (in abelian_group) a_l_cancel [simp]:
46821
ff6b0c1087f2 Using mathematical notation for <-> and cardinal arithmetic
paulson
parents: 41524
diff changeset
   115
     "\<lbrakk>x \<in> carrier(G); y \<in> carrier(G); z \<in> carrier(G)\<rbrakk>
46822
95f1e700b712 mathematical symbols for Isabelle/ZF example theories
paulson
parents: 46821
diff changeset
   116
      \<Longrightarrow> (x \<oplus> y = x \<oplus> z) \<longleftrightarrow> (y = z)"
46821
ff6b0c1087f2 Using mathematical notation for <-> and cardinal arithmetic
paulson
parents: 41524
diff changeset
   117
by (rule group.l_cancel [OF a_group,
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   118
             simplified, simplified ring_add_def [symmetric]])
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   119
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   120
lemma (in abelian_group) a_r_cancel [simp]:
46821
ff6b0c1087f2 Using mathematical notation for <-> and cardinal arithmetic
paulson
parents: 41524
diff changeset
   121
     "\<lbrakk>x \<in> carrier(G); y \<in> carrier(G); z \<in> carrier(G)\<rbrakk>
46822
95f1e700b712 mathematical symbols for Isabelle/ZF example theories
paulson
parents: 46821
diff changeset
   122
      \<Longrightarrow> (y \<oplus> x = z \<oplus> x) \<longleftrightarrow> (y = z)"
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   123
by (rule group.r_cancel [OF a_group, simplified, simplified ring_add_def [symmetric]])
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   124
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   125
lemma (in abelian_monoid) a_assoc:
46821
ff6b0c1087f2 Using mathematical notation for <-> and cardinal arithmetic
paulson
parents: 41524
diff changeset
   126
  "\<lbrakk>x \<in> carrier(G); y \<in> carrier(G); z \<in> carrier(G)\<rbrakk>
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   127
   \<Longrightarrow> (x \<oplus> y) \<oplus> z = x \<oplus> (y \<oplus> z)"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   128
by (rule monoid.m_assoc [OF a_monoid, simplified, simplified ring_add_def [symmetric]])
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   129
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   130
lemma (in abelian_group) l_neg:
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   131
     "x \<in> carrier(G) \<Longrightarrow> \<ominus> x \<oplus> x = \<zero>"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   132
by (simp add: a_inv_def
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   133
     group.l_inv [OF a_group, simplified, simplified ring_add_def [symmetric]])
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   134
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   135
lemma (in abelian_monoid) a_comm:
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   136
     "\<lbrakk>x \<in> carrier(G); y \<in> carrier(G)\<rbrakk> \<Longrightarrow> x \<oplus> y = y \<oplus> x"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   137
by (rule comm_monoid.m_comm [OF a_comm_monoid,
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   138
    simplified, simplified ring_add_def [symmetric]])
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   139
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   140
lemma (in abelian_monoid) a_lcomm:
46821
ff6b0c1087f2 Using mathematical notation for <-> and cardinal arithmetic
paulson
parents: 41524
diff changeset
   141
     "\<lbrakk>x \<in> carrier(G); y \<in> carrier(G); z \<in> carrier(G)\<rbrakk>
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   142
      \<Longrightarrow> x \<oplus> (y \<oplus> z) = y \<oplus> (x \<oplus> z)"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   143
by (rule comm_monoid.m_lcomm [OF a_comm_monoid,
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   144
    simplified, simplified ring_add_def [symmetric]])
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   145
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   146
lemma (in abelian_monoid) r_zero [simp]:
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   147
     "x \<in> carrier(G) \<Longrightarrow> x \<oplus> \<zero> = x"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   148
  using monoid.r_one [OF a_monoid]
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   149
  by (simp add: ring_add_def [symmetric])
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   150
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   151
lemma (in abelian_group) r_neg:
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   152
     "x \<in> carrier(G) \<Longrightarrow> x \<oplus> (\<ominus> x) = \<zero>"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   153
  using group.r_inv [OF a_group]
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   154
  by (simp add: a_inv_def ring_add_def [symmetric])
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   155
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   156
lemma (in abelian_group) minus_zero [simp]:
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   157
     "\<ominus> \<zero> = \<zero>"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   158
  by (simp add: a_inv_def
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   159
    group.inv_one [OF a_group, simplified ])
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   160
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   161
lemma (in abelian_group) minus_minus [simp]:
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   162
     "x \<in> carrier(G) \<Longrightarrow> \<ominus> (\<ominus> x) = x"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   163
  using group.inv_inv [OF a_group, simplified]
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   164
  by (simp add: a_inv_def)
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   165
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   166
lemma (in abelian_group) minus_add:
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   167
     "\<lbrakk>x \<in> carrier(G); y \<in> carrier(G)\<rbrakk> \<Longrightarrow> \<ominus> (x \<oplus> y) = \<ominus> x \<oplus> \<ominus> y"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   168
  using comm_group.inv_mult [OF a_comm_group]
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   169
  by (simp add: a_inv_def ring_add_def [symmetric])
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   170
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   171
lemmas (in abelian_monoid) a_ac = a_assoc a_comm a_lcomm
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   172
60770
240563fbf41d isabelle update_cartouches;
wenzelm
parents: 58871
diff changeset
   173
text \<open>
76213
e44d86131648 Removal of obsolete ASCII syntax
paulson <lp15@cam.ac.uk>
parents: 69587
diff changeset
   174
  The following proofs are from Jacobson, Basic Algebra I, pp.\<not>88--89
60770
240563fbf41d isabelle update_cartouches;
wenzelm
parents: 58871
diff changeset
   175
\<close>
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   176
21233
5a5c8ea5f66a tuned specifications;
wenzelm
parents: 17258
diff changeset
   177
context ring
5a5c8ea5f66a tuned specifications;
wenzelm
parents: 17258
diff changeset
   178
begin
5a5c8ea5f66a tuned specifications;
wenzelm
parents: 17258
diff changeset
   179
5a5c8ea5f66a tuned specifications;
wenzelm
parents: 17258
diff changeset
   180
lemma l_null [simp]: "x \<in> carrier(R) \<Longrightarrow> \<zero> \<cdot> x = \<zero>"
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   181
proof -
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   182
  assume R: "x \<in> carrier(R)"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   183
  then have "\<zero> \<cdot> x \<oplus> \<zero> \<cdot> x = (\<zero> \<oplus> \<zero>) \<cdot> x"
46821
ff6b0c1087f2 Using mathematical notation for <-> and cardinal arithmetic
paulson
parents: 41524
diff changeset
   184
    by (blast intro: l_distr [THEN sym])
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   185
  also from R have "... = \<zero> \<cdot> x \<oplus> \<zero>" by simp
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   186
  finally have "\<zero> \<cdot> x \<oplus> \<zero> \<cdot> x = \<zero> \<cdot> x \<oplus> \<zero>" .
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   187
  with R show ?thesis by (simp del: r_zero)
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   188
qed
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   189
21233
5a5c8ea5f66a tuned specifications;
wenzelm
parents: 17258
diff changeset
   190
lemma r_null [simp]: "x \<in> carrier(R) \<Longrightarrow> x \<cdot> \<zero> = \<zero>"
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   191
proof -
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   192
  assume R: "x \<in> carrier(R)"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   193
  then have "x \<cdot> \<zero> \<oplus> x \<cdot> \<zero> = x \<cdot> (\<zero> \<oplus> \<zero>)"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   194
    by (simp add: r_distr del: l_zero r_zero)
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   195
  also from R have "... = x \<cdot> \<zero> \<oplus> \<zero>" by simp
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   196
  finally have "x \<cdot> \<zero> \<oplus> x \<cdot> \<zero> = x \<cdot> \<zero> \<oplus> \<zero>" .
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   197
  with R show ?thesis by (simp del: r_zero)
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   198
qed
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   199
21233
5a5c8ea5f66a tuned specifications;
wenzelm
parents: 17258
diff changeset
   200
lemma l_minus:
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   201
  "\<lbrakk>x \<in> carrier(R); y \<in> carrier(R)\<rbrakk> \<Longrightarrow> \<ominus> x \<cdot> y = \<ominus> (x \<cdot> y)"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   202
proof -
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   203
  assume R: "x \<in> carrier(R)" "y \<in> carrier(R)"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   204
  then have "(\<ominus> x) \<cdot> y \<oplus> x \<cdot> y = (\<ominus> x \<oplus> x) \<cdot> y" by (simp add: l_distr)
41524
4d2f9a1c24c7 eliminated global prems;
wenzelm
parents: 29223
diff changeset
   205
  also from R have "... = \<zero>" by (simp add: l_neg)
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   206
  finally have "(\<ominus> x) \<cdot> y \<oplus> x \<cdot> y = \<zero>" .
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   207
  with R have "(\<ominus> x) \<cdot> y \<oplus> x \<cdot> y \<oplus> \<ominus> (x \<cdot> y) = \<zero> \<oplus> \<ominus> (x \<cdot> y)" by simp
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   208
  with R show ?thesis by (simp add: a_assoc r_neg)
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   209
qed
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   210
21233
5a5c8ea5f66a tuned specifications;
wenzelm
parents: 17258
diff changeset
   211
lemma r_minus:
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   212
  "\<lbrakk>x \<in> carrier(R); y \<in> carrier(R)\<rbrakk> \<Longrightarrow> x \<cdot> \<ominus> y = \<ominus> (x \<cdot> y)"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   213
proof -
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   214
  assume R: "x \<in> carrier(R)" "y \<in> carrier(R)"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   215
  then have "x \<cdot> (\<ominus> y) \<oplus> x \<cdot> y = x \<cdot> (\<ominus> y \<oplus> y)" by (simp add: r_distr)
41524
4d2f9a1c24c7 eliminated global prems;
wenzelm
parents: 29223
diff changeset
   216
  also from R have "... = \<zero>" by (simp add: l_neg)
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   217
  finally have "x \<cdot> (\<ominus> y) \<oplus> x \<cdot> y = \<zero>" .
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   218
  with R have "x \<cdot> (\<ominus> y) \<oplus> x \<cdot> y \<oplus> \<ominus> (x \<cdot> y) = \<zero> \<oplus> \<ominus> (x \<cdot> y)" by simp
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   219
  with R show ?thesis by (simp add: a_assoc r_neg)
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   220
qed
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   221
21233
5a5c8ea5f66a tuned specifications;
wenzelm
parents: 17258
diff changeset
   222
lemma minus_eq:
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   223
  "\<lbrakk>x \<in> carrier(R); y \<in> carrier(R)\<rbrakk> \<Longrightarrow> x \<ominus> y = x \<oplus> \<ominus> y"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   224
  by (simp only: minus_def)
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   225
21233
5a5c8ea5f66a tuned specifications;
wenzelm
parents: 17258
diff changeset
   226
end
5a5c8ea5f66a tuned specifications;
wenzelm
parents: 17258
diff changeset
   227
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   228
60770
240563fbf41d isabelle update_cartouches;
wenzelm
parents: 58871
diff changeset
   229
subsection \<open>Morphisms\<close>
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   230
21233
5a5c8ea5f66a tuned specifications;
wenzelm
parents: 17258
diff changeset
   231
definition
76215
a642599ffdea More syntactic cleanup. LaTeX markup working
paulson <lp15@cam.ac.uk>
parents: 76214
diff changeset
   232
  ring_hom :: "[i,i] \<Rightarrow> i" where
76213
e44d86131648 Removal of obsolete ASCII syntax
paulson <lp15@cam.ac.uk>
parents: 69587
diff changeset
   233
  "ring_hom(R,S) \<equiv>
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   234
    {h \<in> carrier(R) -> carrier(S).
76214
0c18df79b1c8 more modernisation of syntax
paulson <lp15@cam.ac.uk>
parents: 76213
diff changeset
   235
      (\<forall>x y. x \<in> carrier(R) \<and> y \<in> carrier(R) \<longrightarrow>
0c18df79b1c8 more modernisation of syntax
paulson <lp15@cam.ac.uk>
parents: 76213
diff changeset
   236
        h ` (x \<cdot>\<^bsub>R\<^esub> y) = (h ` x) \<cdot>\<^bsub>S\<^esub> (h ` y) \<and>
0c18df79b1c8 more modernisation of syntax
paulson <lp15@cam.ac.uk>
parents: 76213
diff changeset
   237
        h ` (x \<oplus>\<^bsub>R\<^esub> y) = (h ` x) \<oplus>\<^bsub>S\<^esub> (h ` y)) \<and>
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   238
      h ` \<one>\<^bsub>R\<^esub> = \<one>\<^bsub>S\<^esub>}"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   239
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   240
lemma ring_hom_memI:
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   241
  assumes hom_type: "h \<in> carrier(R) \<rightarrow> carrier(S)"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   242
    and hom_mult: "\<And>x y. \<lbrakk>x \<in> carrier(R); y \<in> carrier(R)\<rbrakk> \<Longrightarrow>
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   243
      h ` (x \<cdot>\<^bsub>R\<^esub> y) = (h ` x) \<cdot>\<^bsub>S\<^esub> (h ` y)"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   244
    and hom_add: "\<And>x y. \<lbrakk>x \<in> carrier(R); y \<in> carrier(R)\<rbrakk> \<Longrightarrow>
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   245
      h ` (x \<oplus>\<^bsub>R\<^esub> y) = (h ` x) \<oplus>\<^bsub>S\<^esub> (h ` y)"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   246
    and hom_one: "h ` \<one>\<^bsub>R\<^esub> = \<one>\<^bsub>S\<^esub>"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   247
  shows "h \<in> ring_hom(R,S)"
41524
4d2f9a1c24c7 eliminated global prems;
wenzelm
parents: 29223
diff changeset
   248
by (auto simp add: ring_hom_def assms)
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   249
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   250
lemma ring_hom_closed:
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   251
     "\<lbrakk>h \<in> ring_hom(R,S); x \<in> carrier(R)\<rbrakk> \<Longrightarrow> h ` x \<in> carrier(S)"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   252
by (auto simp add: ring_hom_def)
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   253
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   254
lemma ring_hom_mult:
46821
ff6b0c1087f2 Using mathematical notation for <-> and cardinal arithmetic
paulson
parents: 41524
diff changeset
   255
     "\<lbrakk>h \<in> ring_hom(R,S); x \<in> carrier(R); y \<in> carrier(R)\<rbrakk>
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   256
      \<Longrightarrow> h ` (x \<cdot>\<^bsub>R\<^esub> y) = (h ` x) \<cdot>\<^bsub>S\<^esub> (h ` y)"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   257
by (simp add: ring_hom_def)
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   258
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   259
lemma ring_hom_add:
46821
ff6b0c1087f2 Using mathematical notation for <-> and cardinal arithmetic
paulson
parents: 41524
diff changeset
   260
     "\<lbrakk>h \<in> ring_hom(R,S); x \<in> carrier(R); y \<in> carrier(R)\<rbrakk>
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   261
      \<Longrightarrow> h ` (x \<oplus>\<^bsub>R\<^esub> y) = (h ` x) \<oplus>\<^bsub>S\<^esub> (h ` y)"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   262
by (simp add: ring_hom_def)
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   263
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   264
lemma ring_hom_one: "h \<in> ring_hom(R,S) \<Longrightarrow> h ` \<one>\<^bsub>R\<^esub> = \<one>\<^bsub>S\<^esub>"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   265
by (simp add: ring_hom_def)
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   266
29223
e09c53289830 Conversion of HOL-Main and ZF to new locales.
ballarin
parents: 28952
diff changeset
   267
locale ring_hom_cring = R: cring R + S: cring S
e09c53289830 Conversion of HOL-Main and ZF to new locales.
ballarin
parents: 28952
diff changeset
   268
  for R (structure) and S (structure) and h +
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   269
  assumes homh [simp, intro]: "h \<in> ring_hom(R,S)"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   270
  notes hom_closed [simp, intro] = ring_hom_closed [OF homh]
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   271
    and hom_mult [simp] = ring_hom_mult [OF homh]
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   272
    and hom_add [simp] = ring_hom_add [OF homh]
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   273
    and hom_one [simp] = ring_hom_one [OF homh]
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   274
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   275
lemma (in ring_hom_cring) hom_zero [simp]:
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   276
     "h ` \<zero>\<^bsub>R\<^esub> = \<zero>\<^bsub>S\<^esub>"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   277
proof -
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   278
  have "h ` \<zero>\<^bsub>R\<^esub> \<oplus>\<^bsub>S\<^esub> h ` \<zero> = h ` \<zero>\<^bsub>R\<^esub> \<oplus>\<^bsub>S\<^esub> \<zero>\<^bsub>S\<^esub>"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   279
    by (simp add: hom_add [symmetric] del: hom_add)
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   280
  then show ?thesis by (simp del: S.r_zero)
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   281
qed
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   282
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   283
lemma (in ring_hom_cring) hom_a_inv [simp]:
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   284
     "x \<in> carrier(R) \<Longrightarrow> h ` (\<ominus>\<^bsub>R\<^esub> x) = \<ominus>\<^bsub>S\<^esub> h ` x"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   285
proof -
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   286
  assume R: "x \<in> carrier(R)"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   287
  then have "h ` x \<oplus>\<^bsub>S\<^esub> h ` (\<ominus> x) = h ` x \<oplus>\<^bsub>S\<^esub> (\<ominus>\<^bsub>S\<^esub> (h ` x))"
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   288
    by (simp add: hom_add [symmetric] R.r_neg S.r_neg del: hom_add)
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   289
  with R show ?thesis by simp
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   290
qed
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   291
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   292
lemma (in ring) id_ring_hom [simp]: "id(carrier(R)) \<in> ring_hom(R,R)"
46821
ff6b0c1087f2 Using mathematical notation for <-> and cardinal arithmetic
paulson
parents: 41524
diff changeset
   293
apply (rule ring_hom_memI)
ff6b0c1087f2 Using mathematical notation for <-> and cardinal arithmetic
paulson
parents: 41524
diff changeset
   294
apply (auto simp add: id_type)
14883
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   295
done
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   296
ca000a495448 Groups, Rings and supporting lemmas
paulson
parents:
diff changeset
   297
end