src/HOL/Hyperreal/StarClasses.thy
author huffman
Tue, 06 Sep 2005 23:11:46 +0200
changeset 17296 d0e0905d548e
child 17332 4910cf8c0cd2
permissions -rw-r--r--
class instances for nonstandard types
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
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
     9
imports Transfer
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    10
begin
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    11
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    12
subsection "HOL.thy"
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    13
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    14
instance star :: (order) order
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    15
apply (intro_classes)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    16
apply (transfer, rule order_refl)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    17
apply (transfer, erule (1) order_trans)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    18
apply (transfer, erule (1) order_antisym)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    19
apply (transfer, rule order_less_le)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    20
done
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    21
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    22
instance star :: (linorder) linorder
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    23
by (intro_classes, transfer, rule linorder_linear)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    24
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    25
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    26
subsection "LOrder.thy"
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    27
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    28
text {*
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    29
  Some extra trouble is necessary because the class axioms 
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    30
  for @{term meet} and @{term join} use quantification over
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    31
  function spaces.
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    32
*}
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    33
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    34
lemma ex_star_fun:
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    35
  "\<exists>f::('a \<Rightarrow> 'b) star. P (Ifun f)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    36
   \<Longrightarrow> \<exists>f::'a star \<Rightarrow> 'b star. P f"
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    37
by (erule exE, erule exI)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    38
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    39
lemma ex_star_fun2:
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    40
  "\<exists>f::('a \<Rightarrow> 'b \<Rightarrow> 'c) star. P (Ifun2 f)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    41
   \<Longrightarrow> \<exists>f::'a star \<Rightarrow> 'b star \<Rightarrow> 'c star. P f"
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    42
by (erule exE, erule exI)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    43
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    44
instance star :: (join_semilorder) join_semilorder
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    45
apply (intro_classes)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    46
apply (rule ex_star_fun2)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    47
apply (transfer is_join_def)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    48
apply (rule join_exists)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    49
done
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    50
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    51
instance star :: (meet_semilorder) meet_semilorder
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    52
apply (intro_classes)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    53
apply (rule ex_star_fun2)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    54
apply (transfer is_meet_def)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    55
apply (rule meet_exists)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    56
done
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    57
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    58
instance star :: (lorder) lorder ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    59
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    60
lemma star_join_def: "join \<equiv> Ifun2_of join"
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    61
 apply (rule is_join_unique[OF is_join_join, THEN eq_reflection])
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    62
 apply (transfer is_join_def, rule is_join_join)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    63
done
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    64
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    65
lemma star_meet_def: "meet \<equiv> Ifun2_of meet"
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    66
 apply (rule is_meet_unique[OF is_meet_meet, THEN eq_reflection])
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    67
 apply (transfer is_meet_def, rule is_meet_meet)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    68
done
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    69
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    70
subsection "OrderedGroup.thy"
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    71
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    72
instance star :: (semigroup_add) semigroup_add
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    73
by (intro_classes, transfer, rule add_assoc)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    74
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    75
instance star :: (ab_semigroup_add) ab_semigroup_add
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    76
by (intro_classes, transfer, rule add_commute)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    77
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    78
instance star :: (semigroup_mult) semigroup_mult
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    79
by (intro_classes, transfer, rule mult_assoc)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    80
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    81
instance star :: (ab_semigroup_mult) ab_semigroup_mult
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    82
by (intro_classes, transfer, rule mult_commute)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    83
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    84
instance star :: (comm_monoid_add) comm_monoid_add
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    85
by (intro_classes, transfer, rule comm_monoid_add_class.add_0)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    86
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    87
instance star :: (monoid_mult) monoid_mult
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    88
apply (intro_classes)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    89
apply (transfer, rule mult_1_left)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    90
apply (transfer, rule mult_1_right)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    91
done
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    92
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    93
instance star :: (comm_monoid_mult) comm_monoid_mult
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    94
by (intro_classes, transfer, rule mult_1)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    95
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    96
instance star :: (cancel_semigroup_add) cancel_semigroup_add
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    97
apply (intro_classes)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    98
apply (transfer, erule add_left_imp_eq)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
    99
apply (transfer, erule add_right_imp_eq)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   100
done
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   101
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   102
instance star :: (cancel_ab_semigroup_add) cancel_ab_semigroup_add
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   103
by (intro_classes, transfer, rule add_imp_eq)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   104
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   105
instance star :: (ab_group_add) ab_group_add
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   106
apply (intro_classes)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   107
apply (transfer, rule left_minus)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   108
apply (transfer, rule diff_minus)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   109
done
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   110
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   111
instance star :: (pordered_ab_semigroup_add) pordered_ab_semigroup_add
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   112
by (intro_classes, transfer, rule add_left_mono)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   113
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   114
instance star :: (pordered_cancel_ab_semigroup_add) pordered_cancel_ab_semigroup_add ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   115
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   116
instance star :: (pordered_ab_semigroup_add_imp_le) pordered_ab_semigroup_add_imp_le
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   117
by (intro_classes, transfer, rule add_le_imp_le_left)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   118
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   119
instance star :: (pordered_ab_group_add) pordered_ab_group_add ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   120
instance star :: (ordered_cancel_ab_semigroup_add) ordered_cancel_ab_semigroup_add ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   121
instance star :: (lordered_ab_group_meet) lordered_ab_group_meet ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   122
instance star :: (lordered_ab_group_meet) lordered_ab_group_meet ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   123
instance star :: (lordered_ab_group) lordered_ab_group ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   124
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   125
instance star :: (lordered_ab_group_abs) lordered_ab_group_abs
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   126
apply (intro_classes)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   127
apply (transfer star_join_def, rule abs_lattice)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   128
done
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   129
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   130
text "Ring-and-Field.thy"
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   131
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   132
instance star :: (semiring) semiring
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   133
apply (intro_classes)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   134
apply (transfer, rule left_distrib)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   135
apply (transfer, rule right_distrib)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   136
done
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   137
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   138
instance star :: (semiring_0) semiring_0 ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   139
instance star :: (semiring_0_cancel) semiring_0_cancel ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   140
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   141
instance star :: (comm_semiring) comm_semiring
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   142
by (intro_classes, transfer, rule distrib)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   143
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   144
instance star :: (comm_semiring_0) comm_semiring_0 ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   145
instance star :: (comm_semiring_0_cancel) comm_semiring_0_cancel ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   146
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   147
instance star :: (axclass_0_neq_1) axclass_0_neq_1
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   148
by (intro_classes, transfer, rule zero_neq_one)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   149
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   150
instance star :: (semiring_1) semiring_1 ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   151
instance star :: (comm_semiring_1) comm_semiring_1 ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   152
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   153
instance star :: (axclass_no_zero_divisors) axclass_no_zero_divisors
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   154
by (intro_classes, transfer, rule no_zero_divisors)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   155
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   156
instance star :: (semiring_1_cancel) semiring_1_cancel ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   157
instance star :: (comm_semiring_1_cancel) comm_semiring_1_cancel ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   158
instance star :: (ring) ring ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   159
instance star :: (comm_ring) comm_ring ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   160
instance star :: (ring_1) ring_1 ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   161
instance star :: (comm_ring_1) comm_ring_1 ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   162
instance star :: (idom) idom .. 
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   163
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   164
instance star :: (field) field
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   165
apply (intro_classes)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   166
apply (transfer, erule left_inverse)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   167
apply (transfer, rule divide_inverse)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   168
done
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   169
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   170
instance star :: (division_by_zero) division_by_zero
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   171
by (intro_classes, transfer, rule inverse_zero)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   172
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   173
instance star :: (pordered_semiring) pordered_semiring
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   174
apply (intro_classes)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   175
apply (transfer, erule (1) mult_left_mono)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   176
apply (transfer, erule (1) mult_right_mono)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   177
done
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   178
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   179
instance star :: (pordered_cancel_semiring) pordered_cancel_semiring ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   180
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   181
instance star :: (ordered_semiring_strict) ordered_semiring_strict
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   182
apply (intro_classes)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   183
apply (transfer, erule (1) mult_strict_left_mono)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   184
apply (transfer, erule (1) mult_strict_right_mono)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   185
done
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   186
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   187
instance star :: (pordered_comm_semiring) pordered_comm_semiring
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   188
by (intro_classes, transfer, rule pordered_comm_semiring_class.mult_mono)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   189
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   190
instance star :: (pordered_cancel_comm_semiring) pordered_cancel_comm_semiring ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   191
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   192
instance star :: (ordered_comm_semiring_strict) ordered_comm_semiring_strict
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   193
by (intro_classes, transfer, rule ordered_comm_semiring_strict_class.mult_strict_mono)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   194
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   195
instance star :: (pordered_ring) pordered_ring ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   196
instance star :: (lordered_ring) lordered_ring ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   197
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   198
instance star :: (axclass_abs_if) axclass_abs_if
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   199
by (intro_classes, transfer, rule abs_if)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   200
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   201
instance star :: (ordered_ring_strict) ordered_ring_strict ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   202
instance star :: (pordered_comm_ring) pordered_comm_ring ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   203
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   204
instance star :: (ordered_semidom) ordered_semidom
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   205
by (intro_classes, transfer, rule zero_less_one)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   206
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   207
instance star :: (ordered_idom) ordered_idom ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   208
instance star :: (ordered_field) ordered_field ..
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   209
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   210
subsection "Power.thy"
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   211
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   212
text {*
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   213
  Proving the class axiom @{thm [source] power_Suc} for type
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   214
  @{typ "'a star"} is a little tricky, because it quantifies
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   215
  over values of type @{typ nat}. The transfer principle does
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   216
  not handle quantification over non-star types in general,
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   217
  but we can work around this by fixing an arbitrary @{typ nat}
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   218
  value, and then applying the transfer principle.
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   219
*}
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   220
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   221
instance star :: (recpower) recpower
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   222
proof
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   223
  show "\<And>a::'a star. a ^ 0 = 1"
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   224
    by transfer (rule power_0)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   225
next
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   226
  fix n show "\<And>a::'a star. a ^ Suc n = a * a ^ n"
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   227
    by transfer (rule power_Suc)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   228
qed
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   229
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   230
subsection "Integ/Number.thy"
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   231
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   232
lemma star_of_nat_def: "of_nat n \<equiv> star_of (of_nat n)"
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   233
by (rule eq_reflection, induct_tac n, simp_all)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   234
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   235
lemma int_diff_cases:
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   236
assumes prem: "\<And>m n. z = int m - int n \<Longrightarrow> P" shows "P"
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   237
 apply (rule_tac z=z in int_cases)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   238
  apply (rule_tac m=n and n=0 in prem, simp)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   239
 apply (rule_tac m=0 and n="Suc n" in prem, simp)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   240
done -- "Belongs in Integ/IntDef.thy"
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   241
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   242
lemma star_of_int_def: "of_int z \<equiv> star_of (of_int z)"
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   243
 apply (rule eq_reflection)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   244
 apply (rule_tac z=z in int_diff_cases)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   245
 apply (simp add: star_of_nat_def)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   246
done
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   247
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   248
instance star :: (number_ring) number_ring
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   249
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
   250
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   251
lemma star_of_of_nat [simp]: "star_of (of_nat n) = of_nat n"
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   252
by (simp add: star_of_nat_def)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   253
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   254
lemma star_of_of_int [simp]: "star_of (of_int z) = of_int z"
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   255
by (simp add: star_of_int_def)
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   256
d0e0905d548e class instances for nonstandard types
huffman
parents:
diff changeset
   257
end