| author | haftmann | 
| Thu, 11 Sep 2014 23:12:32 +0200 | |
| changeset 58320 | 351810c45a48 | 
| parent 56828 | 08041569357e | 
| child 58881 | b9556a055632 | 
| permissions | -rw-r--r-- | 
| 38622 | 1 | (* Title: HOL/Library/Function_Algebras.thy | 
| 2 | Author: Jeremy Avigad and Kevin Donnelly; Florian Haftmann, TUM | |
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 3 | *) | 
| 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 4 | |
| 38622 | 5 | header {* Pointwise instantiation of functions to algebra type classes *}
 | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 6 | |
| 38622 | 7 | theory Function_Algebras | 
| 30738 | 8 | imports Main | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 9 | begin | 
| 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 10 | |
| 38622 | 11 | text {* Pointwise operations *}
 | 
| 25594 | 12 | |
| 13 | instantiation "fun" :: (type, plus) plus | |
| 14 | begin | |
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 15 | |
| 46575 | 16 | definition "f + g = (\<lambda>x. f x + g x)" | 
| 25594 | 17 | instance .. | 
| 18 | ||
| 19 | end | |
| 20 | ||
| 48173 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 21 | lemma plus_fun_apply [simp]: | 
| 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 22 | "(f + g) x = f x + g x" | 
| 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 23 | by (simp add: plus_fun_def) | 
| 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 24 | |
| 38622 | 25 | instantiation "fun" :: (type, zero) zero | 
| 26 | begin | |
| 27 | ||
| 46575 | 28 | definition "0 = (\<lambda>x. 0)" | 
| 38622 | 29 | instance .. | 
| 30 | ||
| 31 | end | |
| 25594 | 32 | |
| 48173 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 33 | lemma zero_fun_apply [simp]: | 
| 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 34 | "0 x = 0" | 
| 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 35 | by (simp add: zero_fun_def) | 
| 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 36 | |
| 25594 | 37 | instantiation "fun" :: (type, times) times | 
| 38 | begin | |
| 39 | ||
| 46575 | 40 | definition "f * g = (\<lambda>x. f x * g x)" | 
| 25594 | 41 | instance .. | 
| 42 | ||
| 43 | end | |
| 44 | ||
| 48173 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 45 | lemma times_fun_apply [simp]: | 
| 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 46 | "(f * g) x = f x * g x" | 
| 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 47 | by (simp add: times_fun_def) | 
| 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 48 | |
| 25594 | 49 | instantiation "fun" :: (type, one) one | 
| 50 | begin | |
| 51 | ||
| 46575 | 52 | definition "1 = (\<lambda>x. 1)" | 
| 25594 | 53 | instance .. | 
| 54 | ||
| 55 | end | |
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 56 | |
| 48173 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 57 | lemma one_fun_apply [simp]: | 
| 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 58 | "1 x = 1" | 
| 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 59 | by (simp add: one_fun_def) | 
| 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 60 | |
| 38622 | 61 | |
| 62 | text {* Additive structures *}
 | |
| 63 | ||
| 46575 | 64 | instance "fun" :: (type, semigroup_add) semigroup_add | 
| 48173 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 65 | by default (simp add: fun_eq_iff add.assoc) | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 66 | |
| 46575 | 67 | instance "fun" :: (type, cancel_semigroup_add) cancel_semigroup_add | 
| 48173 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 68 | by default (simp_all add: fun_eq_iff) | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 69 | |
| 46575 | 70 | instance "fun" :: (type, ab_semigroup_add) ab_semigroup_add | 
| 48173 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 71 | by default (simp add: fun_eq_iff add.commute) | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 72 | |
| 46575 | 73 | instance "fun" :: (type, cancel_ab_semigroup_add) cancel_ab_semigroup_add | 
| 74 | by default simp | |
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 75 | |
| 46575 | 76 | instance "fun" :: (type, monoid_add) monoid_add | 
| 48173 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 77 | by default (simp_all add: fun_eq_iff) | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 78 | |
| 46575 | 79 | instance "fun" :: (type, comm_monoid_add) comm_monoid_add | 
| 80 | by default simp | |
| 38622 | 81 | |
| 82 | instance "fun" :: (type, cancel_comm_monoid_add) cancel_comm_monoid_add .. | |
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 83 | |
| 46575 | 84 | instance "fun" :: (type, group_add) group_add | 
| 85 | by default | |
| 54230 
b1d955791529
more simplification rules on unary and binary minus
 haftmann parents: 
51489diff
changeset | 86 | (simp_all add: fun_eq_iff) | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 87 | |
| 46575 | 88 | instance "fun" :: (type, ab_group_add) ab_group_add | 
| 54230 
b1d955791529
more simplification rules on unary and binary minus
 haftmann parents: 
51489diff
changeset | 89 | by default simp_all | 
| 38622 | 90 | |
| 91 | ||
| 92 | text {* Multiplicative structures *}
 | |
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 93 | |
| 46575 | 94 | instance "fun" :: (type, semigroup_mult) semigroup_mult | 
| 48173 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 95 | by default (simp add: fun_eq_iff mult.assoc) | 
| 38622 | 96 | |
| 46575 | 97 | instance "fun" :: (type, ab_semigroup_mult) ab_semigroup_mult | 
| 48173 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 98 | by default (simp add: fun_eq_iff mult.commute) | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 99 | |
| 46575 | 100 | instance "fun" :: (type, monoid_mult) monoid_mult | 
| 48173 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 101 | by default (simp_all add: fun_eq_iff) | 
| 38622 | 102 | |
| 46575 | 103 | instance "fun" :: (type, comm_monoid_mult) comm_monoid_mult | 
| 104 | by default simp | |
| 38622 | 105 | |
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 106 | |
| 38622 | 107 | text {* Misc *}
 | 
| 108 | ||
| 109 | instance "fun" :: (type, "Rings.dvd") "Rings.dvd" .. | |
| 110 | ||
| 46575 | 111 | instance "fun" :: (type, mult_zero) mult_zero | 
| 48173 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 112 | by default (simp_all add: fun_eq_iff) | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 113 | |
| 46575 | 114 | instance "fun" :: (type, zero_neq_one) zero_neq_one | 
| 48173 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 115 | by default (simp add: fun_eq_iff) | 
| 19736 | 116 | |
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 117 | |
| 38622 | 118 | text {* Ring structures *}
 | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 119 | |
| 46575 | 120 | instance "fun" :: (type, semiring) semiring | 
| 48173 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 121 | by default (simp_all add: fun_eq_iff algebra_simps) | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 122 | |
| 46575 | 123 | instance "fun" :: (type, comm_semiring) comm_semiring | 
| 48173 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 124 | by default (simp add: fun_eq_iff algebra_simps) | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 125 | |
| 38622 | 126 | instance "fun" :: (type, semiring_0) semiring_0 .. | 
| 127 | ||
| 128 | instance "fun" :: (type, comm_semiring_0) comm_semiring_0 .. | |
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 129 | |
| 38622 | 130 | instance "fun" :: (type, semiring_0_cancel) semiring_0_cancel .. | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 131 | |
| 38622 | 132 | instance "fun" :: (type, comm_semiring_0_cancel) comm_semiring_0_cancel .. | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 133 | |
| 38622 | 134 | instance "fun" :: (type, semiring_1) semiring_1 .. | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 135 | |
| 46575 | 136 | lemma of_nat_fun: "of_nat n = (\<lambda>x::'a. of_nat n)" | 
| 38622 | 137 | proof - | 
| 138 | have comp: "comp = (\<lambda>f g x. f (g x))" | |
| 139 | by (rule ext)+ simp | |
| 140 | have plus_fun: "plus = (\<lambda>f g x. f x + g x)" | |
| 141 | by (rule ext, rule ext) (fact plus_fun_def) | |
| 142 | have "of_nat n = (comp (plus (1::'b)) ^^ n) (\<lambda>x::'a. 0)" | |
| 143 | by (simp add: of_nat_def plus_fun zero_fun_def one_fun_def comp) | |
| 144 | also have "... = comp ((plus 1) ^^ n) (\<lambda>x::'a. 0)" | |
| 145 | by (simp only: comp_funpow) | |
| 146 | finally show ?thesis by (simp add: of_nat_def comp) | |
| 147 | qed | |
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 148 | |
| 48173 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 149 | lemma of_nat_fun_apply [simp]: | 
| 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 150 | "of_nat n x = of_nat n" | 
| 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 151 | by (simp add: of_nat_fun) | 
| 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 152 | |
| 38622 | 153 | instance "fun" :: (type, comm_semiring_1) comm_semiring_1 .. | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 154 | |
| 38622 | 155 | instance "fun" :: (type, semiring_1_cancel) semiring_1_cancel .. | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 156 | |
| 38622 | 157 | instance "fun" :: (type, comm_semiring_1_cancel) comm_semiring_1_cancel .. | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 158 | |
| 46575 | 159 | instance "fun" :: (type, semiring_char_0) semiring_char_0 | 
| 160 | proof | |
| 38622 | 161 | from inj_of_nat have "inj (\<lambda>n (x::'a). of_nat n :: 'b)" | 
| 162 | by (rule inj_fun) | |
| 163 | then have "inj (\<lambda>n. of_nat n :: 'a \<Rightarrow> 'b)" | |
| 164 | by (simp add: of_nat_fun) | |
| 165 | then show "inj (of_nat :: nat \<Rightarrow> 'a \<Rightarrow> 'b)" . | |
| 166 | qed | |
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 167 | |
| 38622 | 168 | instance "fun" :: (type, ring) ring .. | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 169 | |
| 38622 | 170 | instance "fun" :: (type, comm_ring) comm_ring .. | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 171 | |
| 38622 | 172 | instance "fun" :: (type, ring_1) ring_1 .. | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 173 | |
| 38622 | 174 | instance "fun" :: (type, comm_ring_1) comm_ring_1 .. | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 175 | |
| 38622 | 176 | instance "fun" :: (type, ring_char_0) ring_char_0 .. | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 177 | |
| 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 178 | |
| 56828 | 179 | text {* Ordered structures *}
 | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 180 | |
| 46575 | 181 | instance "fun" :: (type, ordered_ab_semigroup_add) ordered_ab_semigroup_add | 
| 48173 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 182 | by default (auto simp add: le_fun_def intro: add_left_mono) | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 183 | |
| 38622 | 184 | instance "fun" :: (type, ordered_cancel_ab_semigroup_add) ordered_cancel_ab_semigroup_add .. | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 185 | |
| 46575 | 186 | instance "fun" :: (type, ordered_ab_semigroup_add_imp_le) ordered_ab_semigroup_add_imp_le | 
| 48173 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 187 | by default (simp add: le_fun_def) | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 188 | |
| 38622 | 189 | instance "fun" :: (type, ordered_comm_monoid_add) ordered_comm_monoid_add .. | 
| 190 | ||
| 191 | instance "fun" :: (type, ordered_ab_group_add) ordered_ab_group_add .. | |
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 192 | |
| 46575 | 193 | instance "fun" :: (type, ordered_semiring) ordered_semiring | 
| 194 | by default | |
| 48173 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 195 | (auto simp add: le_fun_def intro: mult_left_mono mult_right_mono) | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 196 | |
| 46575 | 197 | instance "fun" :: (type, ordered_comm_semiring) ordered_comm_semiring | 
| 198 | by default (fact mult_left_mono) | |
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 199 | |
| 38622 | 200 | instance "fun" :: (type, ordered_cancel_semiring) ordered_cancel_semiring .. | 
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 201 | |
| 38622 | 202 | instance "fun" :: (type, ordered_cancel_comm_semiring) ordered_cancel_comm_semiring .. | 
| 203 | ||
| 204 | instance "fun" :: (type, ordered_ring) ordered_ring .. | |
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 205 | |
| 38622 | 206 | instance "fun" :: (type, ordered_comm_ring) ordered_comm_ring .. | 
| 207 | ||
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 208 | |
| 38622 | 209 | lemmas func_plus = plus_fun_def | 
| 210 | lemmas func_zero = zero_fun_def | |
| 211 | lemmas func_times = times_fun_def | |
| 212 | lemmas func_one = one_fun_def | |
| 19736 | 213 | |
| 16908 
d374530bfaaa
Added two new theories to HOL/Library: SetsAndFunctions.thy and BigO.thy
 avigad parents: diff
changeset | 214 | end | 
| 48173 
c6a5a4336edf
eta-expanded occurences of algebraic functionals are simplified by default
 haftmann parents: 
46575diff
changeset | 215 |