src/HOL/Hyperreal/StarClasses.thy
author haftmann
Fri, 07 Dec 2007 15:07:59 +0100
changeset 25571 c9e39eafc7a0
parent 25304 7491c00f0915
permissions -rw-r--r--
instantiation target rather than legacy instance
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
     1
(*  Title       : HOL/Hyperreal/StarClasses.thy
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
     2
    ID          : $Id$
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
     3
    Author      : Brian Huffman
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
     4
*)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
     5
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
     6
header {* Class Instances *}
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
     7
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
     8
theory StarClasses
17429
e8d6ed3aacfe merged Transfer.thy and StarType.thy into StarDef.thy; renamed Ifun2_of to starfun2; cleaned up
huffman
parents: 17332
diff changeset
     9
imports StarDef
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    10
begin
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    11
17332
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
    12
subsection {* Syntactic classes *}
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
    13
25571
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    14
instantiation star :: (zero) zero
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    15
begin
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    16
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    17
definition
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    18
  star_zero_def:    "0 \<equiv> star_of 0"
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    19
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    20
instance ..
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    21
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    22
end
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    23
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    24
instantiation star :: (one) one
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    25
begin
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    26
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    27
definition
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    28
  star_one_def:     "1 \<equiv> star_of 1"
22316
f662831459de added class "preorder"
haftmann
parents: 21199
diff changeset
    29
25571
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    30
instance ..
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    31
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    32
end
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    33
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    34
instantiation star :: (plus) plus
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    35
begin
22316
f662831459de added class "preorder"
haftmann
parents: 21199
diff changeset
    36
25571
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    37
definition
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    38
  star_add_def:     "(op +) \<equiv> *f2* (op +)"
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    39
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    40
instance ..
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    41
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    42
end
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    43
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    44
instantiation star :: (times) times
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    45
begin
22316
f662831459de added class "preorder"
haftmann
parents: 21199
diff changeset
    46
25571
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    47
definition
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    48
  star_mult_def:    "(op *) \<equiv> *f2* (op *)"
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    49
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    50
instance ..
17332
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
    51
25571
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    52
end
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    53
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    54
instantiation star :: (minus) minus
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    55
begin
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    56
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    57
definition
17429
e8d6ed3aacfe merged Transfer.thy and StarType.thy into StarDef.thy; renamed Ifun2_of to starfun2; cleaned up
huffman
parents: 17332
diff changeset
    58
  star_minus_def:   "uminus \<equiv> *f* uminus"
25571
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    59
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    60
definition
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    61
  star_diff_def:    "(op -) \<equiv> *f2* (op -)"
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    62
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    63
instance ..
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    64
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    65
end
23879
4776af8be741 split class abs from class minus
haftmann
parents: 23551
diff changeset
    66
25571
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    67
instantiation star :: (abs) abs
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    68
begin
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    69
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    70
definition
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    71
  star_abs_def:     "abs \<equiv> *f* abs"
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    72
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    73
instance ..
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    74
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    75
end
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    76
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    77
instantiation star :: (sgn) sgn
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    78
begin
22316
f662831459de added class "preorder"
haftmann
parents: 21199
diff changeset
    79
25571
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    80
definition
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    81
  star_sgn_def:     "sgn \<equiv> *f* sgn"
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    82
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    83
instance ..
24506
020db6ec334a final(?) iteration of sgn saga.
nipkow
parents: 24195
diff changeset
    84
25571
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    85
end
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    86
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    87
instantiation star :: (inverse) inverse
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    88
begin
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    89
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    90
definition
17429
e8d6ed3aacfe merged Transfer.thy and StarType.thy into StarDef.thy; renamed Ifun2_of to starfun2; cleaned up
huffman
parents: 17332
diff changeset
    91
  star_divide_def:  "(op /) \<equiv> *f2* (op /)"
25571
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    92
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    93
definition
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    94
  star_inverse_def: "inverse \<equiv> *f* inverse"
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    95
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    96
instance ..
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    97
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
    98
end
22316
f662831459de added class "preorder"
haftmann
parents: 21199
diff changeset
    99
25571
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   100
instantiation star :: (number) number
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   101
begin
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   102
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   103
definition
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   104
  star_number_def:  "number_of b \<equiv> star_of (number_of b)"
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   105
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   106
instance ..
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   107
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   108
end
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   109
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   110
instantiation star :: (Divides.div) Divides.div
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   111
begin
22316
f662831459de added class "preorder"
haftmann
parents: 21199
diff changeset
   112
25571
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   113
definition
17429
e8d6ed3aacfe merged Transfer.thy and StarType.thy into StarDef.thy; renamed Ifun2_of to starfun2; cleaned up
huffman
parents: 17332
diff changeset
   114
  star_div_def:     "(op div) \<equiv> *f2* (op div)"
25571
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   115
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   116
definition
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   117
  star_mod_def:     "(op mod) \<equiv> *f2* (op mod)"
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   118
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   119
instance ..
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   120
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   121
end
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   122
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   123
instantiation star :: (power) power
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   124
begin
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   125
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   126
definition
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   127
  star_power_def:   "(op ^) \<equiv> \<lambda>x n. ( *f* (\<lambda>x. x ^ n)) x"
22316
f662831459de added class "preorder"
haftmann
parents: 21199
diff changeset
   128
25571
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   129
instance ..
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   130
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   131
end
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   132
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   133
instantiation star :: (ord) ord
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   134
begin
17332
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   135
25571
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   136
definition
22452
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   137
  star_le_def:      "(op \<le>) \<equiv> *p2* (op \<le>)"
25571
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   138
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   139
definition
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   140
  star_less_def:    "(op <) \<equiv> *p2* (op <)"
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   141
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   142
instance ..
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   143
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   144
end
22452
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   145
17332
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   146
lemmas star_class_defs [transfer_unfold] =
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   147
  star_zero_def     star_one_def      star_number_def
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   148
  star_add_def      star_diff_def     star_minus_def
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   149
  star_mult_def     star_divide_def   star_inverse_def
24506
020db6ec334a final(?) iteration of sgn saga.
nipkow
parents: 24195
diff changeset
   150
  star_le_def       star_less_def     star_abs_def       star_sgn_def
17332
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   151
  star_div_def      star_mod_def      star_power_def
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   152
20719
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   153
text {* Class operations preserve standard elements *}
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   154
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   155
lemma Standard_zero: "0 \<in> Standard"
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   156
by (simp add: star_zero_def)
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   157
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   158
lemma Standard_one: "1 \<in> Standard"
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   159
by (simp add: star_one_def)
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   160
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   161
lemma Standard_number_of: "number_of b \<in> Standard"
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   162
by (simp add: star_number_def)
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   163
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   164
lemma Standard_add: "\<lbrakk>x \<in> Standard; y \<in> Standard\<rbrakk> \<Longrightarrow> x + y \<in> Standard"
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   165
by (simp add: star_add_def)
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   166
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   167
lemma Standard_diff: "\<lbrakk>x \<in> Standard; y \<in> Standard\<rbrakk> \<Longrightarrow> x - y \<in> Standard"
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   168
by (simp add: star_diff_def)
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   169
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   170
lemma Standard_minus: "x \<in> Standard \<Longrightarrow> - x \<in> Standard"
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   171
by (simp add: star_minus_def)
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   172
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   173
lemma Standard_mult: "\<lbrakk>x \<in> Standard; y \<in> Standard\<rbrakk> \<Longrightarrow> x * y \<in> Standard"
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   174
by (simp add: star_mult_def)
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   175
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   176
lemma Standard_divide: "\<lbrakk>x \<in> Standard; y \<in> Standard\<rbrakk> \<Longrightarrow> x / y \<in> Standard"
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   177
by (simp add: star_divide_def)
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   178
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   179
lemma Standard_inverse: "x \<in> Standard \<Longrightarrow> inverse x \<in> Standard"
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   180
by (simp add: star_inverse_def)
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   181
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   182
lemma Standard_abs: "x \<in> Standard \<Longrightarrow> abs x \<in> Standard"
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   183
by (simp add: star_abs_def)
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   184
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   185
lemma Standard_div: "\<lbrakk>x \<in> Standard; y \<in> Standard\<rbrakk> \<Longrightarrow> x div y \<in> Standard"
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   186
by (simp add: star_div_def)
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   187
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   188
lemma Standard_mod: "\<lbrakk>x \<in> Standard; y \<in> Standard\<rbrakk> \<Longrightarrow> x mod y \<in> Standard"
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   189
by (simp add: star_mod_def)
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   190
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   191
lemma Standard_power: "x \<in> Standard \<Longrightarrow> x ^ n \<in> Standard"
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   192
by (simp add: star_power_def)
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   193
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   194
lemmas Standard_simps [simp] =
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   195
  Standard_zero  Standard_one  Standard_number_of
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   196
  Standard_add  Standard_diff  Standard_minus
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   197
  Standard_mult  Standard_divide  Standard_inverse
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   198
  Standard_abs  Standard_div  Standard_mod
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   199
  Standard_power
bf00c5935432 define new constant Standard = range star_of
huffman
parents: 20633
diff changeset
   200
17332
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   201
text {* @{term star_of} preserves class operations *}
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   202
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   203
lemma star_of_add: "star_of (x + y) = star_of x + star_of y"
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   204
by transfer (rule refl)
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   205
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   206
lemma star_of_diff: "star_of (x - y) = star_of x - star_of y"
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   207
by transfer (rule refl)
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   208
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   209
lemma star_of_minus: "star_of (-x) = - star_of x"
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   210
by transfer (rule refl)
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   211
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   212
lemma star_of_mult: "star_of (x * y) = star_of x * star_of y"
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   213
by transfer (rule refl)
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   214
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   215
lemma star_of_divide: "star_of (x / y) = star_of x / star_of y"
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   216
by transfer (rule refl)
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   217
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   218
lemma star_of_inverse: "star_of (inverse x) = inverse (star_of x)"
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   219
by transfer (rule refl)
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   220
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   221
lemma star_of_div: "star_of (x div y) = star_of x div star_of y"
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   222
by transfer (rule refl)
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   223
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   224
lemma star_of_mod: "star_of (x mod y) = star_of x mod star_of y"
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   225
by transfer (rule refl)
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   226
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   227
lemma star_of_power: "star_of (x ^ n) = star_of x ^ n"
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   228
by transfer (rule refl)
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   229
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   230
lemma star_of_abs: "star_of (abs x) = abs (star_of x)"
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   231
by transfer (rule refl)
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   232
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   233
text {* @{term star_of} preserves numerals *}
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   234
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   235
lemma star_of_zero: "star_of 0 = 0"
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   236
by transfer (rule refl)
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   237
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   238
lemma star_of_one: "star_of 1 = 1"
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   239
by transfer (rule refl)
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   240
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   241
lemma star_of_number_of: "star_of (number_of x) = number_of x"
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   242
by transfer (rule refl)
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   243
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   244
text {* @{term star_of} preserves orderings *}
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   245
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   246
lemma star_of_less: "(star_of x < star_of y) = (x < y)"
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   247
by transfer (rule refl)
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   248
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   249
lemma star_of_le: "(star_of x \<le> star_of y) = (x \<le> y)"
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   250
by transfer (rule refl)
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   251
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   252
lemma star_of_eq: "(star_of x = star_of y) = (x = y)"
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   253
by transfer (rule refl)
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   254
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   255
text{*As above, for 0*}
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   256
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   257
lemmas star_of_0_less = star_of_less [of 0, simplified star_of_zero]
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   258
lemmas star_of_0_le   = star_of_le   [of 0, simplified star_of_zero]
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   259
lemmas star_of_0_eq   = star_of_eq   [of 0, simplified star_of_zero]
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   260
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   261
lemmas star_of_less_0 = star_of_less [of _ 0, simplified star_of_zero]
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   262
lemmas star_of_le_0   = star_of_le   [of _ 0, simplified star_of_zero]
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   263
lemmas star_of_eq_0   = star_of_eq   [of _ 0, simplified star_of_zero]
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   264
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   265
text{*As above, for 1*}
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   266
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   267
lemmas star_of_1_less = star_of_less [of 1, simplified star_of_one]
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   268
lemmas star_of_1_le   = star_of_le   [of 1, simplified star_of_one]
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   269
lemmas star_of_1_eq   = star_of_eq   [of 1, simplified star_of_one]
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   270
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   271
lemmas star_of_less_1 = star_of_less [of _ 1, simplified star_of_one]
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   272
lemmas star_of_le_1   = star_of_le   [of _ 1, simplified star_of_one]
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   273
lemmas star_of_eq_1   = star_of_eq   [of _ 1, simplified star_of_one]
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   274
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   275
text{*As above, for numerals*}
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   276
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   277
lemmas star_of_number_less =
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   278
  star_of_less [of "number_of w", standard, simplified star_of_number_of]
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   279
lemmas star_of_number_le   =
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   280
  star_of_le   [of "number_of w", standard, simplified star_of_number_of]
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   281
lemmas star_of_number_eq   =
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   282
  star_of_eq   [of "number_of w", standard, simplified star_of_number_of]
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   283
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   284
lemmas star_of_less_number =
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   285
  star_of_less [of _ "number_of w", standard, simplified star_of_number_of]
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   286
lemmas star_of_le_number   =
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   287
  star_of_le   [of _ "number_of w", standard, simplified star_of_number_of]
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   288
lemmas star_of_eq_number   =
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   289
  star_of_eq   [of _ "number_of w", standard, simplified star_of_number_of]
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   290
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   291
lemmas star_of_simps [simp] =
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   292
  star_of_add     star_of_diff    star_of_minus
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   293
  star_of_mult    star_of_divide  star_of_inverse
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   294
  star_of_div     star_of_mod
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   295
  star_of_power   star_of_abs
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   296
  star_of_zero    star_of_one     star_of_number_of
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   297
  star_of_less    star_of_le      star_of_eq
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   298
  star_of_0_less  star_of_0_le    star_of_0_eq
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   299
  star_of_less_0  star_of_le_0    star_of_eq_0
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   300
  star_of_1_less  star_of_1_le    star_of_1_eq
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   301
  star_of_less_1  star_of_le_1    star_of_eq_1
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   302
  star_of_number_less star_of_number_le star_of_number_eq
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   303
  star_of_less_number star_of_le_number star_of_eq_number
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   304
22452
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   305
subsection {* Ordering and lattice classes *}
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   306
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   307
instance star :: (order) order
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   308
apply (intro_classes)
22316
f662831459de added class "preorder"
haftmann
parents: 21199
diff changeset
   309
apply (transfer, rule order_less_le)
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   310
apply (transfer, rule order_refl)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   311
apply (transfer, erule (1) order_trans)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   312
apply (transfer, erule (1) order_antisym)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   313
done
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   314
25571
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   315
instantiation star :: (lower_semilattice) lower_semilattice
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   316
begin
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   317
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   318
definition
22452
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   319
  star_inf_def [transfer_unfold]: "inf \<equiv> *f2* inf"
25571
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   320
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   321
instance
22452
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   322
  by default (transfer star_inf_def, auto)+
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   323
25571
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   324
end
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   325
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   326
instantiation star :: (upper_semilattice) upper_semilattice
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   327
begin
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   328
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   329
definition
22452
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   330
  star_sup_def [transfer_unfold]: "sup \<equiv> *f2* sup"
25571
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   331
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   332
instance
22452
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   333
  by default (transfer star_sup_def, auto)+
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   334
25571
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   335
end
c9e39eafc7a0 instantiation target rather than legacy instance
haftmann
parents: 25304
diff changeset
   336
22452
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   337
instance star :: (lattice) lattice ..
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   338
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   339
instance star :: (distrib_lattice) distrib_lattice
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   340
  by default (transfer, auto simp add: sup_inf_distrib1)
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   341
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   342
lemma Standard_inf [simp]:
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   343
  "\<lbrakk>x \<in> Standard; y \<in> Standard\<rbrakk> \<Longrightarrow> inf x y \<in> Standard"
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   344
by (simp add: star_inf_def)
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   345
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   346
lemma Standard_sup [simp]:
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   347
  "\<lbrakk>x \<in> Standard; y \<in> Standard\<rbrakk> \<Longrightarrow> sup x y \<in> Standard"
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   348
by (simp add: star_sup_def)
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   349
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   350
lemma star_of_inf [simp]: "star_of (inf x y) = inf (star_of x) (star_of y)"
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   351
by transfer (rule refl)
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   352
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   353
lemma star_of_sup [simp]: "star_of (sup x y) = sup (star_of x) (star_of y)"
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   354
by transfer (rule refl)
8a86fd2a1bf0 adjusted to new lattice theory developement in Lattices.thy / FixedPoint.thy
haftmann
parents: 22422
diff changeset
   355
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   356
instance star :: (linorder) linorder
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   357
by (intro_classes, transfer, rule linorder_linear)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   358
20720
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   359
lemma star_max_def [transfer_unfold]: "max = *f2* max"
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   360
apply (rule ext, rule ext)
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   361
apply (unfold max_def, transfer, fold max_def)
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   362
apply (rule refl)
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   363
done
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   364
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   365
lemma star_min_def [transfer_unfold]: "min = *f2* min"
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   366
apply (rule ext, rule ext)
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   367
apply (unfold min_def, transfer, fold min_def)
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   368
apply (rule refl)
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   369
done
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   370
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   371
lemma Standard_max [simp]:
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   372
  "\<lbrakk>x \<in> Standard; y \<in> Standard\<rbrakk> \<Longrightarrow> max x y \<in> Standard"
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   373
by (simp add: star_max_def)
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   374
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   375
lemma Standard_min [simp]:
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   376
  "\<lbrakk>x \<in> Standard; y \<in> Standard\<rbrakk> \<Longrightarrow> min x y \<in> Standard"
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   377
by (simp add: star_min_def)
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   378
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   379
lemma star_of_max [simp]: "star_of (max x y) = max (star_of x) (star_of y)"
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   380
by transfer (rule refl)
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   381
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   382
lemma star_of_min [simp]: "star_of (min x y) = min (star_of x) (star_of y)"
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   383
by transfer (rule refl)
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   384
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   385
17332
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   386
subsection {* Ordered group classes *}
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   387
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   388
instance star :: (semigroup_add) semigroup_add
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   389
by (intro_classes, transfer, rule add_assoc)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   390
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   391
instance star :: (ab_semigroup_add) ab_semigroup_add
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   392
by (intro_classes, transfer, rule add_commute)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   393
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   394
instance star :: (semigroup_mult) semigroup_mult
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   395
by (intro_classes, transfer, rule mult_assoc)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   396
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   397
instance star :: (ab_semigroup_mult) ab_semigroup_mult
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   398
by (intro_classes, transfer, rule mult_commute)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   399
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   400
instance star :: (comm_monoid_add) comm_monoid_add
22384
33a46e6c7f04 prefix of class interpretation not mandatory any longer
haftmann
parents: 22316
diff changeset
   401
by (intro_classes, transfer, rule comm_monoid_add_class.zero_plus.add_0)
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   402
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   403
instance star :: (monoid_mult) monoid_mult
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   404
apply (intro_classes)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   405
apply (transfer, rule mult_1_left)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   406
apply (transfer, rule mult_1_right)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   407
done
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   408
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   409
instance star :: (comm_monoid_mult) comm_monoid_mult
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   410
by (intro_classes, transfer, rule mult_1)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   411
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   412
instance star :: (cancel_semigroup_add) cancel_semigroup_add
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   413
apply (intro_classes)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   414
apply (transfer, erule add_left_imp_eq)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   415
apply (transfer, erule add_right_imp_eq)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   416
done
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   417
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   418
instance star :: (cancel_ab_semigroup_add) cancel_ab_semigroup_add
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   419
by (intro_classes, transfer, rule add_imp_eq)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   420
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   421
instance star :: (ab_group_add) ab_group_add
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   422
apply (intro_classes)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   423
apply (transfer, rule left_minus)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   424
apply (transfer, rule diff_minus)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   425
done
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   426
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   427
instance star :: (pordered_ab_semigroup_add) pordered_ab_semigroup_add
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   428
by (intro_classes, transfer, rule add_left_mono)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   429
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   430
instance star :: (pordered_cancel_ab_semigroup_add) pordered_cancel_ab_semigroup_add ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   431
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   432
instance star :: (pordered_ab_semigroup_add_imp_le) pordered_ab_semigroup_add_imp_le
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   433
by (intro_classes, transfer, rule add_le_imp_le_left)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   434
25304
7491c00f0915 removed subclass edge ordered_ring < lordered_ring
haftmann
parents: 25230
diff changeset
   435
instance star :: (pordered_comm_monoid_add) pordered_comm_monoid_add ..
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   436
instance star :: (pordered_ab_group_add) pordered_ab_group_add ..
25304
7491c00f0915 removed subclass edge ordered_ring < lordered_ring
haftmann
parents: 25230
diff changeset
   437
7491c00f0915 removed subclass edge ordered_ring < lordered_ring
haftmann
parents: 25230
diff changeset
   438
instance star :: (pordered_ab_group_add_abs) pordered_ab_group_add_abs 
7491c00f0915 removed subclass edge ordered_ring < lordered_ring
haftmann
parents: 25230
diff changeset
   439
  by intro_classes (transfer,
7491c00f0915 removed subclass edge ordered_ring < lordered_ring
haftmann
parents: 25230
diff changeset
   440
    simp add: abs_ge_self abs_leI abs_triangle_ineq)+
7491c00f0915 removed subclass edge ordered_ring < lordered_ring
haftmann
parents: 25230
diff changeset
   441
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   442
instance star :: (ordered_cancel_ab_semigroup_add) ordered_cancel_ab_semigroup_add ..
25304
7491c00f0915 removed subclass edge ordered_ring < lordered_ring
haftmann
parents: 25230
diff changeset
   443
instance star :: (lordered_ab_group_add_meet) lordered_ab_group_add_meet ..
7491c00f0915 removed subclass edge ordered_ring < lordered_ring
haftmann
parents: 25230
diff changeset
   444
instance star :: (lordered_ab_group_add_meet) lordered_ab_group_add_meet ..
7491c00f0915 removed subclass edge ordered_ring < lordered_ring
haftmann
parents: 25230
diff changeset
   445
instance star :: (lordered_ab_group_add) lordered_ab_group_add ..
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   446
25304
7491c00f0915 removed subclass edge ordered_ring < lordered_ring
haftmann
parents: 25230
diff changeset
   447
instance star :: (lordered_ab_group_add_abs) lordered_ab_group_add_abs
17332
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   448
by (intro_classes, transfer, rule abs_lattice)
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   449
17429
e8d6ed3aacfe merged Transfer.thy and StarType.thy into StarDef.thy; renamed Ifun2_of to starfun2; cleaned up
huffman
parents: 17332
diff changeset
   450
subsection {* Ring and field classes *}
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   451
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   452
instance star :: (semiring) semiring
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   453
apply (intro_classes)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   454
apply (transfer, rule left_distrib)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   455
apply (transfer, rule right_distrib)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   456
done
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   457
21199
2d83f93c3580 * Added annihilation axioms ("x * 0 = 0") to axclass semiring_0.
krauss
parents: 20720
diff changeset
   458
instance star :: (semiring_0) semiring_0 
2d83f93c3580 * Added annihilation axioms ("x * 0 = 0") to axclass semiring_0.
krauss
parents: 20720
diff changeset
   459
by intro_classes (transfer, simp)+
2d83f93c3580 * Added annihilation axioms ("x * 0 = 0") to axclass semiring_0.
krauss
parents: 20720
diff changeset
   460
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   461
instance star :: (semiring_0_cancel) semiring_0_cancel ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   462
24742
73b8b42a36b6 removal of some "ref"s from res_axioms.ML; a side-effect is that the ordering
paulson
parents: 24506
diff changeset
   463
instance star :: (comm_semiring) comm_semiring 
73b8b42a36b6 removal of some "ref"s from res_axioms.ML; a side-effect is that the ordering
paulson
parents: 24506
diff changeset
   464
by (intro_classes, transfer, rule left_distrib)
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   465
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   466
instance star :: (comm_semiring_0) comm_semiring_0 ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   467
instance star :: (comm_semiring_0_cancel) comm_semiring_0_cancel ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   468
20633
e98f59806244 renamed axclass_xxxx axclasses;
wenzelm
parents: 20553
diff changeset
   469
instance star :: (zero_neq_one) zero_neq_one
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   470
by (intro_classes, transfer, rule zero_neq_one)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   471
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   472
instance star :: (semiring_1) semiring_1 ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   473
instance star :: (comm_semiring_1) comm_semiring_1 ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   474
20633
e98f59806244 renamed axclass_xxxx axclasses;
wenzelm
parents: 20553
diff changeset
   475
instance star :: (no_zero_divisors) no_zero_divisors
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   476
by (intro_classes, transfer, rule no_zero_divisors)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   477
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   478
instance star :: (semiring_1_cancel) semiring_1_cancel ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   479
instance star :: (comm_semiring_1_cancel) comm_semiring_1_cancel ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   480
instance star :: (ring) ring ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   481
instance star :: (comm_ring) comm_ring ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   482
instance star :: (ring_1) ring_1 ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   483
instance star :: (comm_ring_1) comm_ring_1 ..
22992
fc54d5fc4a7a add classes ring_no_zero_divisors and dom
huffman
parents: 22911
diff changeset
   484
instance star :: (ring_no_zero_divisors) ring_no_zero_divisors ..
23551
84f0996a530b rename class dom to ring_1_no_zero_divisors (cf. HOL/Ring_and_Field.thy 1.84 by huffman);
wenzelm
parents: 23282
diff changeset
   485
instance star :: (ring_1_no_zero_divisors) ring_1_no_zero_divisors ..
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   486
instance star :: (idom) idom .. 
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   487
20540
588ba06ba867 add instance for class division_ring
huffman
parents: 17429
diff changeset
   488
instance star :: (division_ring) division_ring
588ba06ba867 add instance for class division_ring
huffman
parents: 17429
diff changeset
   489
apply (intro_classes)
588ba06ba867 add instance for class division_ring
huffman
parents: 17429
diff changeset
   490
apply (transfer, erule left_inverse)
588ba06ba867 add instance for class division_ring
huffman
parents: 17429
diff changeset
   491
apply (transfer, erule right_inverse)
588ba06ba867 add instance for class division_ring
huffman
parents: 17429
diff changeset
   492
done
588ba06ba867 add instance for class division_ring
huffman
parents: 17429
diff changeset
   493
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   494
instance star :: (field) field
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   495
apply (intro_classes)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   496
apply (transfer, erule left_inverse)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   497
apply (transfer, rule divide_inverse)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   498
done
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   499
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   500
instance star :: (division_by_zero) division_by_zero
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   501
by (intro_classes, transfer, rule inverse_zero)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   502
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   503
instance star :: (pordered_semiring) pordered_semiring
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   504
apply (intro_classes)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   505
apply (transfer, erule (1) mult_left_mono)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   506
apply (transfer, erule (1) mult_right_mono)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   507
done
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   508
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   509
instance star :: (pordered_cancel_semiring) pordered_cancel_semiring ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   510
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   511
instance star :: (ordered_semiring_strict) ordered_semiring_strict
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   512
apply (intro_classes)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   513
apply (transfer, erule (1) mult_strict_left_mono)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   514
apply (transfer, erule (1) mult_strict_right_mono)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   515
done
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   516
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   517
instance star :: (pordered_comm_semiring) pordered_comm_semiring
25230
022029099a83 continued localization
haftmann
parents: 25208
diff changeset
   518
by (intro_classes, transfer, rule mult_mono1_class.times_zero_less_eq_less.mult_mono1)
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   519
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   520
instance star :: (pordered_cancel_comm_semiring) pordered_cancel_comm_semiring ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   521
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   522
instance star :: (ordered_comm_semiring_strict) ordered_comm_semiring_strict
25208
1a7318a04068 changed order of class parameters
haftmann
parents: 24742
diff changeset
   523
by (intro_classes, transfer, rule ordered_comm_semiring_strict_class.plus_times_zero_less_eq_less.mult_strict_mono)
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   524
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   525
instance star :: (pordered_ring) pordered_ring ..
25304
7491c00f0915 removed subclass edge ordered_ring < lordered_ring
haftmann
parents: 25230
diff changeset
   526
instance star :: (pordered_ring_abs) pordered_ring_abs
7491c00f0915 removed subclass edge ordered_ring < lordered_ring
haftmann
parents: 25230
diff changeset
   527
  by intro_classes  (transfer, rule abs_eq_mult)
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   528
instance star :: (lordered_ring) lordered_ring ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   529
20633
e98f59806244 renamed axclass_xxxx axclasses;
wenzelm
parents: 20553
diff changeset
   530
instance star :: (abs_if) abs_if
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   531
by (intro_classes, transfer, rule abs_if)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   532
24506
020db6ec334a final(?) iteration of sgn saga.
nipkow
parents: 24195
diff changeset
   533
instance star :: (sgn_if) sgn_if
020db6ec334a final(?) iteration of sgn saga.
nipkow
parents: 24195
diff changeset
   534
by (intro_classes, transfer, rule sgn_if)
020db6ec334a final(?) iteration of sgn saga.
nipkow
parents: 24195
diff changeset
   535
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   536
instance star :: (ordered_ring_strict) ordered_ring_strict ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   537
instance star :: (pordered_comm_ring) pordered_comm_ring ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   538
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   539
instance star :: (ordered_semidom) ordered_semidom
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   540
by (intro_classes, transfer, rule zero_less_one)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   541
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   542
instance star :: (ordered_idom) ordered_idom ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   543
instance star :: (ordered_field) ordered_field ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   544
17332
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   545
subsection {* Power classes *}
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   546
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   547
text {*
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   548
  Proving the class axiom @{thm [source] power_Suc} for type
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   549
  @{typ "'a star"} is a little tricky, because it quantifies
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   550
  over values of type @{typ nat}. The transfer principle does
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   551
  not handle quantification over non-star types in general,
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   552
  but we can work around this by fixing an arbitrary @{typ nat}
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   553
  value, and then applying the transfer principle.
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   554
*}
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   555
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   556
instance star :: (recpower) recpower
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   557
proof
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   558
  show "\<And>a::'a star. a ^ 0 = 1"
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   559
    by transfer (rule power_0)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   560
next
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   561
  fix n show "\<And>a::'a star. a ^ Suc n = a * a ^ n"
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   562
    by transfer (rule power_Suc)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   563
qed
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   564
17332
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   565
subsection {* Number classes *}
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   566
20720
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   567
lemma star_of_nat_def [transfer_unfold]: "of_nat n = star_of (of_nat n)"
25230
022029099a83 continued localization
haftmann
parents: 25208
diff changeset
   568
by (induct n, simp_all)
20720
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   569
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   570
lemma Standard_of_nat [simp]: "of_nat n \<in> Standard"
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   571
by (simp add: star_of_nat_def)
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   572
17332
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   573
lemma star_of_of_nat [simp]: "star_of (of_nat n) = of_nat n"
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   574
by transfer (rule refl)
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   575
20720
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   576
lemma star_of_int_def [transfer_unfold]: "of_int z = star_of (of_int z)"
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   577
by (rule_tac z=z in int_diff_cases, simp)
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   578
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   579
lemma Standard_of_int [simp]: "of_int z \<in> Standard"
4358cd94a449 more lemmas about Standard and star_of
huffman
parents: 20719
diff changeset
   580
by (simp add: star_of_int_def)
17332
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   581
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   582
lemma star_of_of_int [simp]: "star_of (of_int z) = of_int z"
4910cf8c0cd2 added theorem attributes transfer_intro, transfer_unfold, transfer_refold; simplified some proofs; some rearranging
huffman
parents: 17296
diff changeset
   583
by transfer (rule refl)
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   584
23282
dfc459989d24 add axclass semiring_char_0 for types where of_nat is injective
huffman
parents: 22993
diff changeset
   585
instance star :: (semiring_char_0) semiring_char_0
24195
haftmann
parents: 23879
diff changeset
   586
by intro_classes (simp only: star_of_nat_def star_of_eq of_nat_eq_iff)
23282
dfc459989d24 add axclass semiring_char_0 for types where of_nat is injective
huffman
parents: 22993
diff changeset
   587
dfc459989d24 add axclass semiring_char_0 for types where of_nat is injective
huffman
parents: 22993
diff changeset
   588
instance star :: (ring_char_0) ring_char_0 ..
22911
2f5e8d70a179 new axclass ring_char_0 for rings with characteristic 0, used for of_int_eq_iff and related lemmas
huffman
parents: 22518
diff changeset
   589
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   590
instance star :: (number_ring) number_ring
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   591
by (intro_classes, simp only: star_number_def star_of_int_def number_of_eq)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   592
17429
e8d6ed3aacfe merged Transfer.thy and StarType.thy into StarDef.thy; renamed Ifun2_of to starfun2; cleaned up
huffman
parents: 17332
diff changeset
   593
subsection {* Finite class *}
e8d6ed3aacfe merged Transfer.thy and StarType.thy into StarDef.thy; renamed Ifun2_of to starfun2; cleaned up
huffman
parents: 17332
diff changeset
   594
e8d6ed3aacfe merged Transfer.thy and StarType.thy into StarDef.thy; renamed Ifun2_of to starfun2; cleaned up
huffman
parents: 17332
diff changeset
   595
lemma starset_finite: "finite A \<Longrightarrow> *s* A = star_of ` A"
e8d6ed3aacfe merged Transfer.thy and StarType.thy into StarDef.thy; renamed Ifun2_of to starfun2; cleaned up
huffman
parents: 17332
diff changeset
   596
by (erule finite_induct, simp_all)
e8d6ed3aacfe merged Transfer.thy and StarType.thy into StarDef.thy; renamed Ifun2_of to starfun2; cleaned up
huffman
parents: 17332
diff changeset
   597
e8d6ed3aacfe merged Transfer.thy and StarType.thy into StarDef.thy; renamed Ifun2_of to starfun2; cleaned up
huffman
parents: 17332
diff changeset
   598
instance star :: (finite) finite
e8d6ed3aacfe merged Transfer.thy and StarType.thy into StarDef.thy; renamed Ifun2_of to starfun2; cleaned up
huffman
parents: 17332
diff changeset
   599
apply (intro_classes)
e8d6ed3aacfe merged Transfer.thy and StarType.thy into StarDef.thy; renamed Ifun2_of to starfun2; cleaned up
huffman
parents: 17332
diff changeset
   600
apply (subst starset_UNIV [symmetric])
e8d6ed3aacfe merged Transfer.thy and StarType.thy into StarDef.thy; renamed Ifun2_of to starfun2; cleaned up
huffman
parents: 17332
diff changeset
   601
apply (subst starset_finite [OF finite])
e8d6ed3aacfe merged Transfer.thy and StarType.thy into StarDef.thy; renamed Ifun2_of to starfun2; cleaned up
huffman
parents: 17332
diff changeset
   602
apply (rule finite_imageI [OF finite])
e8d6ed3aacfe merged Transfer.thy and StarType.thy into StarDef.thy; renamed Ifun2_of to starfun2; cleaned up
huffman
parents: 17332
diff changeset
   603
done
e8d6ed3aacfe merged Transfer.thy and StarType.thy into StarDef.thy; renamed Ifun2_of to starfun2; cleaned up
huffman
parents: 17332
diff changeset
   604
17296
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   605
end