| author | nipkow | 
| Wed, 29 Apr 2009 21:10:46 +0200 | |
| changeset 31022 | a438b4516dd3 | 
| parent 30971 | 7fbebf75b3ef | 
| child 32439 | 7a91c7bcfe7e | 
| permissions | -rw-r--r-- | 
| 24333 | 1 | (* | 
| 2 | Author: Jeremy Dawson and Gerwin Klein, NICTA | |
| 3 | ||
| 4 | Basic definition of word type and basic theorems following from | |
| 5 | the definition of the word type | |
| 6 | *) | |
| 7 | ||
| 24350 | 8 | header {* Definition of Word Type *}
 | 
| 24333 | 9 | |
| 26559 | 10 | theory WordDefinition | 
| 27139 
a1f3c7b5ce9c
back to original import order -- thanks to proper deletion of nat cases/induct rules from type_definition;
 wenzelm parents: 
27134diff
changeset | 11 | imports Size BinBoolList TdThs | 
| 26559 | 12 | begin | 
| 24333 | 13 | |
| 29630 | 14 | subsection {* Type definition *}
 | 
| 15 | ||
| 16 | typedef (open word) 'a word = "{(0::int) ..< 2^len_of TYPE('a::len0)}"
 | |
| 17 | morphisms uint Abs_word by auto | |
| 18 | ||
| 19 | definition word_of_int :: "int \<Rightarrow> 'a\<Colon>len0 word" where | |
| 20 |   -- {* representation of words using unsigned or signed bins, 
 | |
| 21 | only difference in these is the type class *} | |
| 22 |   [code del]: "word_of_int w = Abs_word (bintrunc (len_of TYPE ('a)) w)" 
 | |
| 23 | ||
| 24 | lemma uint_word_of_int [code]: "uint (word_of_int w \<Colon> 'a\<Colon>len0 word) = w mod 2 ^ len_of TYPE('a)"
 | |
| 25 | by (auto simp add: word_of_int_def bintrunc_mod2p intro: Abs_word_inverse) | |
| 26 | ||
| 27 | code_datatype word_of_int | |
| 28 | ||
| 29 | ||
| 30 | subsection {* Type conversions and casting *}
 | |
| 31 | ||
| 32 | definition sint :: "'a :: len word => int" where | |
| 33 |   -- {* treats the most-significant-bit as a sign bit *}
 | |
| 34 |   sint_uint: "sint w = sbintrunc (len_of TYPE ('a) - 1) (uint w)"
 | |
| 35 | ||
| 36 | definition unat :: "'a :: len0 word => nat" where | |
| 37 | "unat w = nat (uint w)" | |
| 38 | ||
| 39 | definition uints :: "nat => int set" where | |
| 40 | -- "the sets of integers representing the words" | |
| 41 | "uints n = range (bintrunc n)" | |
| 42 | ||
| 43 | definition sints :: "nat => int set" where | |
| 44 | "sints n = range (sbintrunc (n - 1))" | |
| 45 | ||
| 46 | definition unats :: "nat => nat set" where | |
| 47 |   "unats n = {i. i < 2 ^ n}"
 | |
| 48 | ||
| 49 | definition norm_sint :: "nat => int => int" where | |
| 50 | "norm_sint n w = (w + 2 ^ (n - 1)) mod 2 ^ n - 2 ^ (n - 1)" | |
| 51 | ||
| 52 | definition scast :: "'a :: len word => 'b :: len word" where | |
| 53 | -- "cast a word to a different length" | |
| 54 | "scast w = word_of_int (sint w)" | |
| 55 | ||
| 56 | definition ucast :: "'a :: len0 word => 'b :: len0 word" where | |
| 57 | "ucast w = word_of_int (uint w)" | |
| 24333 | 58 | |
| 25762 | 59 | instantiation word :: (len0) size | 
| 60 | begin | |
| 61 | ||
| 62 | definition | |
| 63 |   word_size: "size (w :: 'a word) = len_of TYPE('a)"
 | |
| 64 | ||
| 65 | instance .. | |
| 66 | ||
| 67 | end | |
| 68 | ||
| 29630 | 69 | definition source_size :: "('a :: len0 word => 'b) => nat" where
 | 
| 70 | -- "whether a cast (or other) function is to a longer or shorter length" | |
| 71 | "source_size c = (let arb = undefined ; x = c arb in size arb)" | |
| 24333 | 72 | |
| 29630 | 73 | definition target_size :: "('a => 'b :: len0 word) => nat" where
 | 
| 74 | "target_size c = size (c undefined)" | |
| 24333 | 75 | |
| 29630 | 76 | definition is_up :: "('a :: len0 word => 'b :: len0 word) => bool" where
 | 
| 77 | "is_up c \<longleftrightarrow> source_size c <= target_size c" | |
| 24333 | 78 | |
| 29630 | 79 | definition is_down :: "('a :: len0 word => 'b :: len0 word) => bool" where
 | 
| 80 | "is_down c \<longleftrightarrow> target_size c <= source_size c" | |
| 24333 | 81 | |
| 29630 | 82 | definition of_bl :: "bool list => 'a :: len0 word" where | 
| 83 | "of_bl bl = word_of_int (bl_to_bin bl)" | |
| 24465 | 84 | |
| 29630 | 85 | definition to_bl :: "'a :: len0 word => bool list" where | 
| 86 |   "to_bl w = bin_to_bl (len_of TYPE ('a)) (uint w)"
 | |
| 24465 | 87 | |
| 29630 | 88 | definition word_reverse :: "'a :: len0 word => 'a word" where | 
| 89 | "word_reverse w = of_bl (rev (to_bl w))" | |
| 24465 | 90 | |
| 29630 | 91 | definition word_int_case :: "(int => 'b) => ('a :: len0 word) => 'b" where
 | 
| 92 | "word_int_case f w = f (uint w)" | |
| 24333 | 93 | |
| 94 | syntax | |
| 95 | of_int :: "int => 'a" | |
| 96 | translations | |
| 29630 | 97 | "case x of of_int y => b" == "CONST word_int_case (%y. b) x" | 
| 24333 | 98 | |
| 99 | ||
| 24350 | 100 | subsection "Arithmetic operations" | 
| 24333 | 101 | |
| 30968 
10fef94f40fc
adaptions due to rearrangment of power operation
 haftmann parents: 
30952diff
changeset | 102 | instantiation word :: (len0) "{number, uminus, minus, plus, one, zero, times, Divides.div, ord, bit}"
 | 
| 25762 | 103 | begin | 
| 104 | ||
| 105 | definition | |
| 106 | word_0_wi: "0 = word_of_int 0" | |
| 107 | ||
| 108 | definition | |
| 109 | word_1_wi: "1 = word_of_int 1" | |
| 110 | ||
| 111 | definition | |
| 112 | word_add_def: "a + b = word_of_int (uint a + uint b)" | |
| 113 | ||
| 114 | definition | |
| 115 | word_sub_wi: "a - b = word_of_int (uint a - uint b)" | |
| 116 | ||
| 117 | definition | |
| 118 | word_minus_def: "- a = word_of_int (- uint a)" | |
| 119 | ||
| 120 | definition | |
| 121 | word_mult_def: "a * b = word_of_int (uint a * uint b)" | |
| 122 | ||
| 123 | definition | |
| 124 | word_div_def: "a div b = word_of_int (uint a div uint b)" | |
| 125 | ||
| 126 | definition | |
| 127 | word_mod_def: "a mod b = word_of_int (uint a mod uint b)" | |
| 128 | ||
| 129 | definition | |
| 130 | word_number_of_def: "number_of w = word_of_int w" | |
| 131 | ||
| 132 | definition | |
| 133 | word_le_def: "a \<le> b \<longleftrightarrow> uint a \<le> uint b" | |
| 24415 | 134 | |
| 25762 | 135 | definition | 
| 136 | word_less_def: "x < y \<longleftrightarrow> x \<le> y \<and> x \<noteq> (y \<Colon> 'a word)" | |
| 137 | ||
| 138 | definition | |
| 139 | word_and_def: | |
| 140 | "(a::'a word) AND b = word_of_int (uint a AND uint b)" | |
| 141 | ||
| 142 | definition | |
| 143 | word_or_def: | |
| 144 | "(a::'a word) OR b = word_of_int (uint a OR uint b)" | |
| 145 | ||
| 146 | definition | |
| 147 | word_xor_def: | |
| 148 | "(a::'a word) XOR b = word_of_int (uint a XOR uint b)" | |
| 149 | ||
| 150 | definition | |
| 151 | word_not_def: | |
| 152 | "NOT (a::'a word) = word_of_int (NOT (uint a))" | |
| 153 | ||
| 154 | instance .. | |
| 155 | ||
| 30968 
10fef94f40fc
adaptions due to rearrangment of power operation
 haftmann parents: 
30952diff
changeset | 156 | end | 
| 25762 | 157 | |
| 158 | definition | |
| 159 | word_succ :: "'a :: len0 word => 'a word" | |
| 160 | where | |
| 25919 
8b1c0d434824
joined theories IntDef, Numeral, IntArith to theory Int
 haftmann parents: 
25762diff
changeset | 161 | "word_succ a = word_of_int (Int.succ (uint a))" | 
| 25762 | 162 | |
| 163 | definition | |
| 164 | word_pred :: "'a :: len0 word => 'a word" | |
| 165 | where | |
| 25919 
8b1c0d434824
joined theories IntDef, Numeral, IntArith to theory Int
 haftmann parents: 
25762diff
changeset | 166 | "word_pred a = word_of_int (Int.pred (uint a))" | 
| 24333 | 167 | |
| 168 | constdefs | |
| 24465 | 169 | udvd :: "'a::len word => 'a::len word => bool" (infixl "udvd" 50) | 
| 170 | "a udvd b == EX n>=0. uint b = n * uint a" | |
| 171 | ||
| 172 |   word_sle :: "'a :: len word => 'a word => bool" ("(_/ <=s _)" [50, 51] 50)
 | |
| 173 | "a <=s b == sint a <= sint b" | |
| 174 | ||
| 175 |   word_sless :: "'a :: len word => 'a word => bool" ("(_/ <s _)" [50, 51] 50)
 | |
| 176 | "(x <s y) == (x <=s y & x ~= y)" | |
| 177 | ||
| 24333 | 178 | |
| 26559 | 179 | |
| 24350 | 180 | subsection "Bit-wise operations" | 
| 24333 | 181 | |
| 26559 | 182 | instantiation word :: (len0) bits | 
| 183 | begin | |
| 24333 | 184 | |
| 26559 | 185 | definition | 
| 186 | word_test_bit_def: "test_bit a = bin_nth (uint a)" | |
| 187 | ||
| 188 | definition | |
| 189 | word_set_bit_def: "set_bit a n x = | |
| 24333 | 190 | word_of_int (bin_sc n (If x bit.B1 bit.B0) (uint a))" | 
| 191 | ||
| 26559 | 192 | definition | 
| 193 |   word_set_bits_def: "(BITS n. f n) = of_bl (bl_of_nth (len_of TYPE ('a)) f)"
 | |
| 194 | ||
| 195 | definition | |
| 196 | word_lsb_def: "lsb a \<longleftrightarrow> bin_last (uint a) = bit.B1" | |
| 197 | ||
| 198 | definition shiftl1 :: "'a word \<Rightarrow> 'a word" where | |
| 199 | "shiftl1 w = word_of_int (uint w BIT bit.B0)" | |
| 200 | ||
| 201 | definition shiftr1 :: "'a word \<Rightarrow> 'a word" where | |
| 202 | -- "shift right as unsigned or as signed, ie logical or arithmetic" | |
| 203 | "shiftr1 w = word_of_int (bin_rest (uint w))" | |
| 204 | ||
| 205 | definition | |
| 30971 | 206 | shiftl_def: "w << n = (shiftl1 ^^ n) w" | 
| 24465 | 207 | |
| 26559 | 208 | definition | 
| 30971 | 209 | shiftr_def: "w >> n = (shiftr1 ^^ n) w" | 
| 26559 | 210 | |
| 211 | instance .. | |
| 212 | ||
| 213 | end | |
| 24333 | 214 | |
| 26559 | 215 | instantiation word :: (len) bitss | 
| 216 | begin | |
| 217 | ||
| 218 | definition | |
| 24333 | 219 | word_msb_def: | 
| 26559 | 220 | "msb a \<longleftrightarrow> bin_sign (sint a) = Int.Min" | 
| 24333 | 221 | |
| 26559 | 222 | instance .. | 
| 223 | ||
| 224 | end | |
| 24333 | 225 | |
| 226 | constdefs | |
| 24465 | 227 | setBit :: "'a :: len0 word => nat => 'a word" | 
| 24333 | 228 | "setBit w n == set_bit w n True" | 
| 229 | ||
| 24465 | 230 | clearBit :: "'a :: len0 word => nat => 'a word" | 
| 24333 | 231 | "clearBit w n == set_bit w n False" | 
| 232 | ||
| 233 | ||
| 24465 | 234 | subsection "Shift operations" | 
| 235 | ||
| 236 | constdefs | |
| 237 | sshiftr1 :: "'a :: len word => 'a word" | |
| 238 | "sshiftr1 w == word_of_int (bin_rest (sint w))" | |
| 239 | ||
| 240 | bshiftr1 :: "bool => 'a :: len word => 'a word" | |
| 241 | "bshiftr1 b w == of_bl (b # butlast (to_bl w))" | |
| 242 | ||
| 243 | sshiftr :: "'a :: len word => nat => 'a word" (infixl ">>>" 55) | |
| 30971 | 244 | "w >>> n == (sshiftr1 ^^ n) w" | 
| 24465 | 245 | |
| 246 | mask :: "nat => 'a::len word" | |
| 247 | "mask n == (1 << n) - 1" | |
| 248 | ||
| 249 | revcast :: "'a :: len0 word => 'b :: len0 word" | |
| 250 |   "revcast w ==  of_bl (takefill False (len_of TYPE('b)) (to_bl w))"
 | |
| 251 | ||
| 252 | slice1 :: "nat => 'a :: len0 word => 'b :: len0 word" | |
| 253 | "slice1 n w == of_bl (takefill False n (to_bl w))" | |
| 254 | ||
| 255 | slice :: "nat => 'a :: len0 word => 'b :: len0 word" | |
| 256 | "slice n w == slice1 (size w - n) w" | |
| 257 | ||
| 258 | ||
| 259 | subsection "Rotation" | |
| 260 | ||
| 261 | constdefs | |
| 262 | rotater1 :: "'a list => 'a list" | |
| 263 | "rotater1 ys == | |
| 264 | case ys of [] => [] | x # xs => last ys # butlast ys" | |
| 265 | ||
| 266 | rotater :: "nat => 'a list => 'a list" | |
| 30971 | 267 | "rotater n == rotater1 ^^ n" | 
| 24465 | 268 | |
| 269 | word_rotr :: "nat => 'a :: len0 word => 'a :: len0 word" | |
| 270 | "word_rotr n w == of_bl (rotater n (to_bl w))" | |
| 271 | ||
| 272 | word_rotl :: "nat => 'a :: len0 word => 'a :: len0 word" | |
| 273 | "word_rotl n w == of_bl (rotate n (to_bl w))" | |
| 274 | ||
| 275 | word_roti :: "int => 'a :: len0 word => 'a :: len0 word" | |
| 276 | "word_roti i w == if i >= 0 then word_rotr (nat i) w | |
| 277 | else word_rotl (nat (- i)) w" | |
| 278 | ||
| 279 | ||
| 280 | subsection "Split and cat operations" | |
| 281 | ||
| 282 | constdefs | |
| 283 | word_cat :: "'a :: len0 word => 'b :: len0 word => 'c :: len0 word" | |
| 284 |   "word_cat a b == word_of_int (bin_cat (uint a) (len_of TYPE ('b)) (uint b))"
 | |
| 285 | ||
| 286 |   word_split :: "'a :: len0 word => ('b :: len0 word) * ('c :: len0 word)"
 | |
| 287 | "word_split a == | |
| 288 |    case bin_split (len_of TYPE ('c)) (uint a) of 
 | |
| 289 | (u, v) => (word_of_int u, word_of_int v)" | |
| 290 | ||
| 291 | word_rcat :: "'a :: len0 word list => 'b :: len0 word" | |
| 292 | "word_rcat ws == | |
| 293 |   word_of_int (bin_rcat (len_of TYPE ('a)) (map uint ws))"
 | |
| 294 | ||
| 295 | word_rsplit :: "'a :: len0 word => 'b :: len word list" | |
| 296 | "word_rsplit w == | |
| 297 |   map word_of_int (bin_rsplit (len_of TYPE ('b)) (len_of TYPE ('a), uint w))"
 | |
| 298 | ||
| 24333 | 299 | constdefs | 
| 300 | -- "Largest representable machine integer." | |
| 24465 | 301 | max_word :: "'a::len word" | 
| 30952 
7ab2716dd93b
power operation on functions with syntax o^; power operation on relations with syntax ^^
 haftmann parents: 
30729diff
changeset | 302 |   "max_word \<equiv> word_of_int (2 ^ len_of TYPE('a) - 1)"
 | 
| 24333 | 303 | |
| 304 | consts | |
| 24465 | 305 | of_bool :: "bool \<Rightarrow> 'a::len word" | 
| 24333 | 306 | primrec | 
| 307 | "of_bool False = 0" | |
| 308 | "of_bool True = 1" | |
| 309 | ||
| 310 | ||
| 24465 | 311 | lemmas of_nth_def = word_set_bits_def | 
| 312 | ||
| 24333 | 313 | lemmas word_size_gt_0 [iff] = | 
| 25762 | 314 | xtr1 [OF word_size len_gt_0, standard] | 
| 24465 | 315 | lemmas lens_gt_0 = word_size_gt_0 len_gt_0 | 
| 24333 | 316 | lemmas lens_not_0 [iff] = lens_gt_0 [THEN gr_implies_not0, standard] | 
| 317 | ||
| 318 | lemma uints_num: "uints n = {i. 0 \<le> i \<and> i < 2 ^ n}"
 | |
| 319 | by (simp add: uints_def range_bintrunc) | |
| 320 | ||
| 321 | lemma sints_num: "sints n = {i. - (2 ^ (n - 1)) \<le> i \<and> i < 2 ^ (n - 1)}"
 | |
| 322 | by (simp add: sints_def range_sbintrunc) | |
| 323 | ||
| 324 | lemmas atLeastLessThan_alt = atLeastLessThan_def [unfolded | |
| 325 | atLeast_def lessThan_def Collect_conj_eq [symmetric]] | |
| 326 | ||
| 327 | lemma mod_in_reps: "m > 0 ==> y mod m : {0::int ..< m}"
 | |
| 328 | unfolding atLeastLessThan_alt by auto | |
| 329 | ||
| 330 | lemma | |
| 29630 | 331 | uint_0:"0 <= uint x" and | 
| 332 |   uint_lt: "uint (x::'a::len0 word) < 2 ^ len_of TYPE('a)"
 | |
| 333 | by (auto simp: uint [simplified]) | |
| 24333 | 334 | |
| 29630 | 335 | lemma uint_mod_same: | 
| 336 |   "uint x mod 2 ^ len_of TYPE('a) = uint (x::'a::len0 word)"
 | |
| 337 | by (simp add: int_mod_eq uint_lt uint_0) | |
| 24333 | 338 | |
| 339 | lemma td_ext_uint: | |
| 24465 | 340 |   "td_ext (uint :: 'a word => int) word_of_int (uints (len_of TYPE('a::len0))) 
 | 
| 341 |     (%w::int. w mod 2 ^ len_of TYPE('a))"
 | |
| 24333 | 342 | apply (unfold td_ext_def') | 
| 29630 | 343 | apply (simp add: uints_num word_of_int_def bintrunc_mod2p) | 
| 344 | apply (simp add: uint_mod_same uint_0 uint_lt | |
| 345 | word.uint_inverse word.Abs_word_inverse int_mod_lem) | |
| 24333 | 346 | done | 
| 347 | ||
| 348 | lemmas int_word_uint = td_ext_uint [THEN td_ext.eq_norm, standard] | |
| 349 | ||
| 30729 
461ee3e49ad3
interpretation/interpret: prefixes are mandatory by default;
 wenzelm parents: 
29630diff
changeset | 350 | interpretation word_uint: | 
| 29234 | 351 | td_ext "uint::'a::len0 word \<Rightarrow> int" | 
| 352 | word_of_int | |
| 353 |          "uints (len_of TYPE('a::len0))"
 | |
| 354 |          "\<lambda>w. w mod 2 ^ len_of TYPE('a::len0)"
 | |
| 24333 | 355 | by (rule td_ext_uint) | 
| 356 | ||
| 357 | lemmas td_uint = word_uint.td_thm | |
| 358 | ||
| 359 | lemmas td_ext_ubin = td_ext_uint | |
| 24465 | 360 | [simplified len_gt_0 no_bintr_alt1 [symmetric]] | 
| 24333 | 361 | |
| 30729 
461ee3e49ad3
interpretation/interpret: prefixes are mandatory by default;
 wenzelm parents: 
29630diff
changeset | 362 | interpretation word_ubin: | 
| 29234 | 363 | td_ext "uint::'a::len0 word \<Rightarrow> int" | 
| 364 | word_of_int | |
| 365 |          "uints (len_of TYPE('a::len0))"
 | |
| 366 |          "bintrunc (len_of TYPE('a::len0))"
 | |
| 24333 | 367 | by (rule td_ext_ubin) | 
| 368 | ||
| 369 | lemma sint_sbintrunc': | |
| 370 | "sint (word_of_int bin :: 'a word) = | |
| 24465 | 371 |     (sbintrunc (len_of TYPE ('a :: len) - 1) bin)"
 | 
| 24333 | 372 | unfolding sint_uint | 
| 373 | by (auto simp: word_ubin.eq_norm sbintrunc_bintrunc_lt) | |
| 374 | ||
| 375 | lemma uint_sint: | |
| 24465 | 376 |   "uint w = bintrunc (len_of TYPE('a)) (sint (w :: 'a :: len word))"
 | 
| 24333 | 377 | unfolding sint_uint by (auto simp: bintrunc_sbintrunc_le) | 
| 378 | ||
| 379 | lemma bintr_uint': | |
| 380 | "n >= size w ==> bintrunc n (uint w) = uint w" | |
| 381 | apply (unfold word_size) | |
| 382 | apply (subst word_ubin.norm_Rep [symmetric]) | |
| 383 | apply (simp only: bintrunc_bintrunc_min word_size min_def) | |
| 384 | apply simp | |
| 385 | done | |
| 386 | ||
| 387 | lemma wi_bintr': | |
| 388 | "wb = word_of_int bin ==> n >= size wb ==> | |
| 389 | word_of_int (bintrunc n bin) = wb" | |
| 390 | unfolding word_size | |
| 391 | by (clarsimp simp add : word_ubin.norm_eq_iff [symmetric] min_def) | |
| 392 | ||
| 393 | lemmas bintr_uint = bintr_uint' [unfolded word_size] | |
| 394 | lemmas wi_bintr = wi_bintr' [unfolded word_size] | |
| 395 | ||
| 396 | lemma td_ext_sbin: | |
| 24465 | 397 |   "td_ext (sint :: 'a word => int) word_of_int (sints (len_of TYPE('a::len))) 
 | 
| 398 |     (sbintrunc (len_of TYPE('a) - 1))"
 | |
| 24333 | 399 | apply (unfold td_ext_def' sint_uint) | 
| 400 | apply (simp add : word_ubin.eq_norm) | |
| 24465 | 401 |   apply (cases "len_of TYPE('a)")
 | 
| 24333 | 402 | apply (auto simp add : sints_def) | 
| 403 | apply (rule sym [THEN trans]) | |
| 404 | apply (rule word_ubin.Abs_norm) | |
| 405 | apply (simp only: bintrunc_sbintrunc) | |
| 406 | apply (drule sym) | |
| 407 | apply simp | |
| 408 | done | |
| 409 | ||
| 410 | lemmas td_ext_sint = td_ext_sbin | |
| 24465 | 411 | [simplified len_gt_0 no_sbintr_alt2 Suc_pred' [symmetric]] | 
| 24333 | 412 | |
| 413 | (* We do sint before sbin, before sint is the user version | |
| 414 | and interpretations do not produce thm duplicates. I.e. | |
| 415 | we get the name word_sint.Rep_eqD, but not word_sbin.Req_eqD, | |
| 416 | because the latter is the same thm as the former *) | |
| 30729 
461ee3e49ad3
interpretation/interpret: prefixes are mandatory by default;
 wenzelm parents: 
29630diff
changeset | 417 | interpretation word_sint: | 
| 29235 | 418 | td_ext "sint ::'a::len word => int" | 
| 24333 | 419 | word_of_int | 
| 24465 | 420 |           "sints (len_of TYPE('a::len))"
 | 
| 421 |           "%w. (w + 2^(len_of TYPE('a::len) - 1)) mod 2^len_of TYPE('a::len) -
 | |
| 29235 | 422 |                2 ^ (len_of TYPE('a::len) - 1)"
 | 
| 24333 | 423 | by (rule td_ext_sint) | 
| 424 | ||
| 30729 
461ee3e49ad3
interpretation/interpret: prefixes are mandatory by default;
 wenzelm parents: 
29630diff
changeset | 425 | interpretation word_sbin: | 
| 29235 | 426 | td_ext "sint ::'a::len word => int" | 
| 24333 | 427 | word_of_int | 
| 24465 | 428 |           "sints (len_of TYPE('a::len))"
 | 
| 29235 | 429 |           "sbintrunc (len_of TYPE('a::len) - 1)"
 | 
| 24333 | 430 | by (rule td_ext_sbin) | 
| 431 | ||
| 432 | lemmas int_word_sint = td_ext_sint [THEN td_ext.eq_norm, standard] | |
| 433 | ||
| 434 | lemmas td_sint = word_sint.td | |
| 435 | ||
| 436 | lemma word_number_of_alt: "number_of b == word_of_int (number_of b)" | |
| 437 | unfolding word_number_of_def by (simp add: number_of_eq) | |
| 438 | ||
| 439 | lemma word_no_wi: "number_of = word_of_int" | |
| 440 | by (auto simp: word_number_of_def intro: ext) | |
| 441 | ||
| 24465 | 442 | lemma to_bl_def': | 
| 443 | "(to_bl :: 'a :: len0 word => bool list) = | |
| 444 |     bin_to_bl (len_of TYPE('a)) o uint"
 | |
| 445 | by (auto simp: to_bl_def intro: ext) | |
| 446 | ||
| 25349 
0d46bea01741
eliminated illegal schematic variables in where/of;
 wenzelm parents: 
25149diff
changeset | 447 | lemmas word_reverse_no_def [simp] = word_reverse_def [of "number_of w", standard] | 
| 24465 | 448 | |
| 24333 | 449 | lemmas uints_mod = uints_def [unfolded no_bintr_alt1] | 
| 450 | ||
| 451 | lemma uint_bintrunc: "uint (number_of bin :: 'a word) = | |
| 24465 | 452 |     number_of (bintrunc (len_of TYPE ('a :: len0)) bin)"
 | 
| 24333 | 453 | unfolding word_number_of_def number_of_eq | 
| 454 | by (auto intro: word_ubin.eq_norm) | |
| 455 | ||
| 456 | lemma sint_sbintrunc: "sint (number_of bin :: 'a word) = | |
| 24465 | 457 |     number_of (sbintrunc (len_of TYPE ('a :: len) - 1) bin)" 
 | 
| 24333 | 458 | unfolding word_number_of_def number_of_eq | 
| 25149 | 459 | by (subst word_sbin.eq_norm) simp | 
| 24333 | 460 | |
| 461 | lemma unat_bintrunc: | |
| 24465 | 462 | "unat (number_of bin :: 'a :: len0 word) = | 
| 463 |     number_of (bintrunc (len_of TYPE('a)) bin)"
 | |
| 24333 | 464 | unfolding unat_def nat_number_of_def | 
| 465 | by (simp only: uint_bintrunc) | |
| 466 | ||
| 467 | (* WARNING - these may not always be helpful *) | |
| 468 | declare | |
| 469 | uint_bintrunc [simp] | |
| 470 | sint_sbintrunc [simp] | |
| 471 | unat_bintrunc [simp] | |
| 472 | ||
| 24465 | 473 | lemma size_0_eq: "size (w :: 'a :: len0 word) = 0 ==> v = w" | 
| 24333 | 474 | apply (unfold word_size) | 
| 475 | apply (rule word_uint.Rep_eqD) | |
| 476 | apply (rule box_equals) | |
| 477 | defer | |
| 478 | apply (rule word_ubin.norm_Rep)+ | |
| 479 | apply simp | |
| 480 | done | |
| 481 | ||
| 482 | lemmas uint_lem = word_uint.Rep [unfolded uints_num mem_Collect_eq] | |
| 483 | lemmas sint_lem = word_sint.Rep [unfolded sints_num mem_Collect_eq] | |
| 484 | lemmas uint_ge_0 [iff] = uint_lem [THEN conjunct1, standard] | |
| 485 | lemmas uint_lt2p [iff] = uint_lem [THEN conjunct2, standard] | |
| 486 | lemmas sint_ge = sint_lem [THEN conjunct1, standard] | |
| 487 | lemmas sint_lt = sint_lem [THEN conjunct2, standard] | |
| 488 | ||
| 489 | lemma sign_uint_Pls [simp]: | |
| 25919 
8b1c0d434824
joined theories IntDef, Numeral, IntArith to theory Int
 haftmann parents: 
25762diff
changeset | 490 | "bin_sign (uint x) = Int.Pls" | 
| 24333 | 491 | by (simp add: sign_Pls_ge_0 number_of_eq) | 
| 492 | ||
| 493 | lemmas uint_m2p_neg = iffD2 [OF diff_less_0_iff_less uint_lt2p, standard] | |
| 494 | lemmas uint_m2p_not_non_neg = | |
| 495 | iffD2 [OF linorder_not_le uint_m2p_neg, standard] | |
| 496 | ||
| 497 | lemma lt2p_lem: | |
| 24465 | 498 |   "len_of TYPE('a) <= n ==> uint (w :: 'a :: len0 word) < 2 ^ n"
 | 
| 24333 | 499 | by (rule xtr8 [OF _ uint_lt2p]) simp | 
| 500 | ||
| 501 | lemmas uint_le_0_iff [simp] = | |
| 502 | uint_ge_0 [THEN leD, THEN linorder_antisym_conv1, standard] | |
| 503 | ||
| 504 | lemma uint_nat: "uint w == int (unat w)" | |
| 505 | unfolding unat_def by auto | |
| 506 | ||
| 507 | lemma uint_number_of: | |
| 24465 | 508 |   "uint (number_of b :: 'a :: len0 word) = number_of b mod 2 ^ len_of TYPE('a)"
 | 
| 24333 | 509 | unfolding word_number_of_alt | 
| 510 | by (simp only: int_word_uint) | |
| 511 | ||
| 512 | lemma unat_number_of: | |
| 25919 
8b1c0d434824
joined theories IntDef, Numeral, IntArith to theory Int
 haftmann parents: 
25762diff
changeset | 513 | "bin_sign b = Int.Pls ==> | 
| 24465 | 514 |   unat (number_of b::'a::len0 word) = number_of b mod 2 ^ len_of TYPE ('a)"
 | 
| 24333 | 515 | apply (unfold unat_def) | 
| 516 | apply (clarsimp simp only: uint_number_of) | |
| 517 | apply (rule nat_mod_distrib [THEN trans]) | |
| 518 | apply (erule sign_Pls_ge_0 [THEN iffD1]) | |
| 519 | apply (simp_all add: nat_power_eq) | |
| 520 | done | |
| 521 | ||
| 24465 | 522 | lemma sint_number_of: "sint (number_of b :: 'a :: len word) = (number_of b + | 
| 523 |     2 ^ (len_of TYPE('a) - 1)) mod 2 ^ len_of TYPE('a) -
 | |
| 524 |     2 ^ (len_of TYPE('a) - 1)"
 | |
| 24333 | 525 | unfolding word_number_of_alt by (rule int_word_sint) | 
| 526 | ||
| 527 | lemma word_of_int_bin [simp] : | |
| 24465 | 528 | "(word_of_int (number_of bin) :: 'a :: len0 word) = (number_of bin)" | 
| 24333 | 529 | unfolding word_number_of_alt by auto | 
| 530 | ||
| 531 | lemma word_int_case_wi: | |
| 532 | "word_int_case f (word_of_int i :: 'b word) = | |
| 24465 | 533 |     f (i mod 2 ^ len_of TYPE('b::len0))"
 | 
| 24333 | 534 | unfolding word_int_case_def by (simp add: word_uint.eq_norm) | 
| 535 | ||
| 536 | lemma word_int_split: | |
| 537 | "P (word_int_case f x) = | |
| 24465 | 538 | (ALL i. x = (word_of_int i :: 'b :: len0 word) & | 
| 539 |       0 <= i & i < 2 ^ len_of TYPE('b) --> P (f i))"
 | |
| 24333 | 540 | unfolding word_int_case_def | 
| 541 | by (auto simp: word_uint.eq_norm int_mod_eq') | |
| 542 | ||
| 543 | lemma word_int_split_asm: | |
| 544 | "P (word_int_case f x) = | |
| 24465 | 545 | (~ (EX n. x = (word_of_int n :: 'b::len0 word) & | 
| 546 |       0 <= n & n < 2 ^ len_of TYPE('b::len0) & ~ P (f n)))"
 | |
| 24333 | 547 | unfolding word_int_case_def | 
| 548 | by (auto simp: word_uint.eq_norm int_mod_eq') | |
| 549 | ||
| 550 | lemmas uint_range' = | |
| 551 | word_uint.Rep [unfolded uints_num mem_Collect_eq, standard] | |
| 552 | lemmas sint_range' = word_sint.Rep [unfolded One_nat_def | |
| 553 | sints_num mem_Collect_eq, standard] | |
| 554 | ||
| 555 | lemma uint_range_size: "0 <= uint w & uint w < 2 ^ size w" | |
| 556 | unfolding word_size by (rule uint_range') | |
| 557 | ||
| 558 | lemma sint_range_size: | |
| 559 | "- (2 ^ (size w - Suc 0)) <= sint w & sint w < 2 ^ (size w - Suc 0)" | |
| 560 | unfolding word_size by (rule sint_range') | |
| 561 | ||
| 562 | lemmas sint_above_size = sint_range_size | |
| 563 | [THEN conjunct2, THEN [2] xtr8, folded One_nat_def, standard] | |
| 564 | ||
| 565 | lemmas sint_below_size = sint_range_size | |
| 566 | [THEN conjunct1, THEN [2] order_trans, folded One_nat_def, standard] | |
| 567 | ||
| 24465 | 568 | lemma test_bit_eq_iff: "(test_bit (u::'a::len0 word) = test_bit v) = (u = v)" | 
| 24333 | 569 | unfolding word_test_bit_def by (simp add: bin_nth_eq_iff) | 
| 570 | ||
| 24465 | 571 | lemma test_bit_size [rule_format] : "(w::'a::len0 word) !! n --> n < size w" | 
| 24333 | 572 | apply (unfold word_test_bit_def) | 
| 573 | apply (subst word_ubin.norm_Rep [symmetric]) | |
| 574 | apply (simp only: nth_bintr word_size) | |
| 575 | apply fast | |
| 576 | done | |
| 577 | ||
| 578 | lemma word_eqI [rule_format] : | |
| 24465 | 579 | fixes u :: "'a::len0 word" | 
| 24333 | 580 | shows "(ALL n. n < size u --> u !! n = v !! n) ==> u = v" | 
| 581 | apply (rule test_bit_eq_iff [THEN iffD1]) | |
| 582 | apply (rule ext) | |
| 583 | apply (erule allE) | |
| 584 | apply (erule impCE) | |
| 585 | prefer 2 | |
| 586 | apply assumption | |
| 587 | apply (auto dest!: test_bit_size simp add: word_size) | |
| 588 | done | |
| 589 | ||
| 590 | lemmas word_eqD = test_bit_eq_iff [THEN iffD2, THEN fun_cong, standard] | |
| 591 | ||
| 592 | lemma test_bit_bin': "w !! n = (n < size w & bin_nth (uint w) n)" | |
| 593 | unfolding word_test_bit_def word_size | |
| 594 | by (simp add: nth_bintr [symmetric]) | |
| 595 | ||
| 596 | lemmas test_bit_bin = test_bit_bin' [unfolded word_size] | |
| 597 | ||
| 598 | lemma bin_nth_uint_imp': "bin_nth (uint w) n --> n < size w" | |
| 599 | apply (unfold word_size) | |
| 600 | apply (rule impI) | |
| 601 | apply (rule nth_bintr [THEN iffD1, THEN conjunct1]) | |
| 602 | apply (subst word_ubin.norm_Rep) | |
| 603 | apply assumption | |
| 604 | done | |
| 605 | ||
| 606 | lemma bin_nth_sint': | |
| 607 | "n >= size w --> bin_nth (sint w) n = bin_nth (sint w) (size w - 1)" | |
| 608 | apply (rule impI) | |
| 609 | apply (subst word_sbin.norm_Rep [symmetric]) | |
| 610 | apply (simp add : nth_sbintr word_size) | |
| 611 | apply auto | |
| 612 | done | |
| 613 | ||
| 614 | lemmas bin_nth_uint_imp = bin_nth_uint_imp' [rule_format, unfolded word_size] | |
| 615 | lemmas bin_nth_sint = bin_nth_sint' [rule_format, unfolded word_size] | |
| 616 | ||
| 24465 | 617 | (* type definitions theorem for in terms of equivalent bool list *) | 
| 618 | lemma td_bl: | |
| 619 | "type_definition (to_bl :: 'a::len0 word => bool list) | |
| 620 | of_bl | |
| 621 |                    {bl. length bl = len_of TYPE('a)}"
 | |
| 622 | apply (unfold type_definition_def of_bl_def to_bl_def) | |
| 623 | apply (simp add: word_ubin.eq_norm) | |
| 624 | apply safe | |
| 625 | apply (drule sym) | |
| 626 | apply simp | |
| 627 | done | |
| 628 | ||
| 30729 
461ee3e49ad3
interpretation/interpret: prefixes are mandatory by default;
 wenzelm parents: 
29630diff
changeset | 629 | interpretation word_bl: | 
| 29235 | 630 | type_definition "to_bl :: 'a::len0 word => bool list" | 
| 631 | of_bl | |
| 632 |                   "{bl. length bl = len_of TYPE('a::len0)}"
 | |
| 24465 | 633 | by (rule td_bl) | 
| 634 | ||
| 635 | lemma word_size_bl: "size w == size (to_bl w)" | |
| 636 | unfolding word_size by auto | |
| 637 | ||
| 638 | lemma to_bl_use_of_bl: | |
| 639 | "(to_bl w = bl) = (w = of_bl bl \<and> length bl = length (to_bl w))" | |
| 640 | by (fastsimp elim!: word_bl.Abs_inverse [simplified]) | |
| 641 | ||
| 642 | lemma to_bl_word_rev: "to_bl (word_reverse w) = rev (to_bl w)" | |
| 643 | unfolding word_reverse_def by (simp add: word_bl.Abs_inverse) | |
| 644 | ||
| 645 | lemma word_rev_rev [simp] : "word_reverse (word_reverse w) = w" | |
| 646 | unfolding word_reverse_def by (simp add : word_bl.Abs_inverse) | |
| 647 | ||
| 648 | lemma word_rev_gal: "word_reverse w = u ==> word_reverse u = w" | |
| 649 | by auto | |
| 650 | ||
| 651 | lemmas word_rev_gal' = sym [THEN word_rev_gal, symmetric, standard] | |
| 652 | ||
| 653 | lemmas length_bl_gt_0 [iff] = xtr1 [OF word_bl.Rep' len_gt_0, standard] | |
| 654 | lemmas bl_not_Nil [iff] = | |
| 655 | length_bl_gt_0 [THEN length_greater_0_conv [THEN iffD1], standard] | |
| 656 | lemmas length_bl_neq_0 [iff] = length_bl_gt_0 [THEN gr_implies_not0] | |
| 657 | ||
| 25919 
8b1c0d434824
joined theories IntDef, Numeral, IntArith to theory Int
 haftmann parents: 
25762diff
changeset | 658 | lemma hd_bl_sign_sint: "hd (to_bl w) = (bin_sign (sint w) = Int.Min)" | 
| 24465 | 659 | apply (unfold to_bl_def sint_uint) | 
| 660 | apply (rule trans [OF _ bl_sbin_sign]) | |
| 661 | apply simp | |
| 662 | done | |
| 663 | ||
| 664 | lemma of_bl_drop': | |
| 665 |   "lend = length bl - len_of TYPE ('a :: len0) ==> 
 | |
| 666 | of_bl (drop lend bl) = (of_bl bl :: 'a word)" | |
| 667 | apply (unfold of_bl_def) | |
| 668 | apply (clarsimp simp add : trunc_bl2bin [symmetric]) | |
| 669 | done | |
| 670 | ||
| 671 | lemmas of_bl_no = of_bl_def [folded word_number_of_def] | |
| 672 | ||
| 673 | lemma test_bit_of_bl: | |
| 674 |   "(of_bl bl::'a::len0 word) !! n = (rev bl ! n \<and> n < len_of TYPE('a) \<and> n < length bl)"
 | |
| 675 | apply (unfold of_bl_def word_test_bit_def) | |
| 676 | apply (auto simp add: word_size word_ubin.eq_norm nth_bintr bin_nth_of_bl) | |
| 677 | done | |
| 678 | ||
| 679 | lemma no_of_bl: | |
| 680 |   "(number_of bin ::'a::len0 word) = of_bl (bin_to_bl (len_of TYPE ('a)) bin)"
 | |
| 681 | unfolding word_size of_bl_no by (simp add : word_number_of_def) | |
| 682 | ||
| 683 | lemma uint_bl: "to_bl w == bin_to_bl (size w) (uint w)" | |
| 684 | unfolding word_size to_bl_def by auto | |
| 685 | ||
| 686 | lemma to_bl_bin: "bl_to_bin (to_bl w) = uint w" | |
| 687 | unfolding uint_bl by (simp add : word_size) | |
| 688 | ||
| 689 | lemma to_bl_of_bin: | |
| 690 |   "to_bl (word_of_int bin::'a::len0 word) = bin_to_bl (len_of TYPE('a)) bin"
 | |
| 691 | unfolding uint_bl by (clarsimp simp add: word_ubin.eq_norm word_size) | |
| 692 | ||
| 693 | lemmas to_bl_no_bin [simp] = to_bl_of_bin [folded word_number_of_def] | |
| 694 | ||
| 695 | lemma to_bl_to_bin [simp] : "bl_to_bin (to_bl w) = uint w" | |
| 696 | unfolding uint_bl by (simp add : word_size) | |
| 697 | ||
| 698 | lemmas uint_bl_bin [simp] = trans [OF bin_bl_bin word_ubin.norm_Rep, standard] | |
| 24333 | 699 | |
| 700 | lemmas num_AB_u [simp] = word_uint.Rep_inverse | |
| 701 | [unfolded o_def word_number_of_def [symmetric], standard] | |
| 702 | lemmas num_AB_s [simp] = word_sint.Rep_inverse | |
| 703 | [unfolded o_def word_number_of_def [symmetric], standard] | |
| 704 | ||
| 705 | (* naturals *) | |
| 706 | lemma uints_unats: "uints n = int ` unats n" | |
| 707 | apply (unfold unats_def uints_num) | |
| 708 | apply safe | |
| 709 | apply (rule_tac image_eqI) | |
| 710 | apply (erule_tac nat_0_le [symmetric]) | |
| 711 | apply auto | |
| 712 | apply (erule_tac nat_less_iff [THEN iffD2]) | |
| 713 | apply (rule_tac [2] zless_nat_eq_int_zless [THEN iffD1]) | |
| 714 | apply (auto simp add : nat_power_eq int_power) | |
| 715 | done | |
| 716 | ||
| 717 | lemma unats_uints: "unats n = nat ` uints n" | |
| 25349 
0d46bea01741
eliminated illegal schematic variables in where/of;
 wenzelm parents: 
25149diff
changeset | 718 | by (auto simp add : uints_unats image_iff) | 
| 24333 | 719 | |
| 720 | lemmas bintr_num = word_ubin.norm_eq_iff | |
| 721 | [symmetric, folded word_number_of_def, standard] | |
| 722 | lemmas sbintr_num = word_sbin.norm_eq_iff | |
| 723 | [symmetric, folded word_number_of_def, standard] | |
| 724 | ||
| 725 | lemmas num_of_bintr = word_ubin.Abs_norm [folded word_number_of_def, standard] | |
| 726 | lemmas num_of_sbintr = word_sbin.Abs_norm [folded word_number_of_def, standard]; | |
| 727 | ||
| 728 | (* don't add these to simpset, since may want bintrunc n w to be simplified; | |
| 729 | may want these in reverse, but loop as simp rules, so use following *) | |
| 730 | ||
| 731 | lemma num_of_bintr': | |
| 24465 | 732 |   "bintrunc (len_of TYPE('a :: len0)) a = b ==> 
 | 
| 24333 | 733 | number_of a = (number_of b :: 'a word)" | 
| 734 | apply safe | |
| 735 | apply (rule_tac num_of_bintr [symmetric]) | |
| 736 | done | |
| 737 | ||
| 738 | lemma num_of_sbintr': | |
| 24465 | 739 |   "sbintrunc (len_of TYPE('a :: len) - 1) a = b ==> 
 | 
| 24333 | 740 | number_of a = (number_of b :: 'a word)" | 
| 741 | apply safe | |
| 742 | apply (rule_tac num_of_sbintr [symmetric]) | |
| 743 | done | |
| 744 | ||
| 745 | lemmas num_abs_bintr = sym [THEN trans, | |
| 25762 | 746 | OF num_of_bintr word_number_of_def, standard] | 
| 24333 | 747 | lemmas num_abs_sbintr = sym [THEN trans, | 
| 25762 | 748 | OF num_of_sbintr word_number_of_def, standard] | 
| 24465 | 749 | |
| 24333 | 750 | (** cast - note, no arg for new length, as it's determined by type of result, | 
| 751 | thus in "cast w = w, the type means cast to length of w! **) | |
| 752 | ||
| 753 | lemma ucast_id: "ucast w = w" | |
| 754 | unfolding ucast_def by auto | |
| 755 | ||
| 756 | lemma scast_id: "scast w = w" | |
| 757 | unfolding scast_def by auto | |
| 758 | ||
| 24465 | 759 | lemma ucast_bl: "ucast w == of_bl (to_bl w)" | 
| 760 | unfolding ucast_def of_bl_def uint_bl | |
| 761 | by (auto simp add : word_size) | |
| 762 | ||
| 24333 | 763 | lemma nth_ucast: | 
| 24465 | 764 |   "(ucast w::'a::len0 word) !! n = (w !! n & n < len_of TYPE('a))"
 | 
| 24333 | 765 | apply (unfold ucast_def test_bit_bin) | 
| 766 | apply (simp add: word_ubin.eq_norm nth_bintr word_size) | |
| 767 | apply (fast elim!: bin_nth_uint_imp) | |
| 768 | done | |
| 769 | ||
| 770 | (* for literal u(s)cast *) | |
| 771 | ||
| 772 | lemma ucast_bintr [simp]: | |
| 24465 | 773 | "ucast (number_of w ::'a::len0 word) = | 
| 774 |    number_of (bintrunc (len_of TYPE('a)) w)"
 | |
| 24333 | 775 | unfolding ucast_def by simp | 
| 776 | ||
| 777 | lemma scast_sbintr [simp]: | |
| 24465 | 778 | "scast (number_of w ::'a::len word) = | 
| 779 |    number_of (sbintrunc (len_of TYPE('a) - Suc 0) w)"
 | |
| 24333 | 780 | unfolding scast_def by simp | 
| 781 | ||
| 782 | lemmas source_size = source_size_def [unfolded Let_def word_size] | |
| 783 | lemmas target_size = target_size_def [unfolded Let_def word_size] | |
| 784 | lemmas is_down = is_down_def [unfolded source_size target_size] | |
| 785 | lemmas is_up = is_up_def [unfolded source_size target_size] | |
| 786 | ||
| 29630 | 787 | lemmas is_up_down = trans [OF is_up is_down [symmetric], standard] | 
| 24333 | 788 | |
| 789 | lemma down_cast_same': "uc = ucast ==> is_down uc ==> uc = scast" | |
| 790 | apply (unfold is_down) | |
| 791 | apply safe | |
| 792 | apply (rule ext) | |
| 793 | apply (unfold ucast_def scast_def uint_sint) | |
| 794 | apply (rule word_ubin.norm_eq_iff [THEN iffD1]) | |
| 795 | apply simp | |
| 796 | done | |
| 797 | ||
| 24465 | 798 | lemma word_rev_tf': | 
| 799 | "r = to_bl (of_bl bl) ==> r = rev (takefill False (length r) (rev bl))" | |
| 800 | unfolding of_bl_def uint_bl | |
| 801 | by (clarsimp simp add: bl_bin_bl_rtf word_ubin.eq_norm word_size) | |
| 802 | ||
| 803 | lemmas word_rev_tf = refl [THEN word_rev_tf', unfolded word_bl.Rep', standard] | |
| 804 | ||
| 805 | lemmas word_rep_drop = word_rev_tf [simplified takefill_alt, | |
| 806 | simplified, simplified rev_take, simplified] | |
| 807 | ||
| 808 | lemma to_bl_ucast: | |
| 809 | "to_bl (ucast (w::'b::len0 word) ::'a::len0 word) = | |
| 810 |    replicate (len_of TYPE('a) - len_of TYPE('b)) False @
 | |
| 811 |    drop (len_of TYPE('b) - len_of TYPE('a)) (to_bl w)"
 | |
| 812 | apply (unfold ucast_bl) | |
| 813 | apply (rule trans) | |
| 814 | apply (rule word_rep_drop) | |
| 815 | apply simp | |
| 816 | done | |
| 817 | ||
| 818 | lemma ucast_up_app': | |
| 819 | "uc = ucast ==> source_size uc + n = target_size uc ==> | |
| 820 | to_bl (uc w) = replicate n False @ (to_bl w)" | |
| 28643 | 821 | by (auto simp add : source_size target_size to_bl_ucast) | 
| 24465 | 822 | |
| 823 | lemma ucast_down_drop': | |
| 824 | "uc = ucast ==> source_size uc = target_size uc + n ==> | |
| 825 | to_bl (uc w) = drop n (to_bl w)" | |
| 826 | by (auto simp add : source_size target_size to_bl_ucast) | |
| 827 | ||
| 828 | lemma scast_down_drop': | |
| 829 | "sc = scast ==> source_size sc = target_size sc + n ==> | |
| 830 | to_bl (sc w) = drop n (to_bl w)" | |
| 831 | apply (subgoal_tac "sc = ucast") | |
| 832 | apply safe | |
| 833 | apply simp | |
| 834 | apply (erule refl [THEN ucast_down_drop']) | |
| 835 | apply (rule refl [THEN down_cast_same', symmetric]) | |
| 836 | apply (simp add : source_size target_size is_down) | |
| 837 | done | |
| 838 | ||
| 24333 | 839 | lemma sint_up_scast': | 
| 840 | "sc = scast ==> is_up sc ==> sint (sc w) = sint w" | |
| 841 | apply (unfold is_up) | |
| 842 | apply safe | |
| 843 | apply (simp add: scast_def word_sbin.eq_norm) | |
| 844 | apply (rule box_equals) | |
| 845 | prefer 3 | |
| 846 | apply (rule word_sbin.norm_Rep) | |
| 847 | apply (rule sbintrunc_sbintrunc_l) | |
| 848 | defer | |
| 849 | apply (subst word_sbin.norm_Rep) | |
| 850 | apply (rule refl) | |
| 851 | apply simp | |
| 852 | done | |
| 853 | ||
| 854 | lemma uint_up_ucast': | |
| 855 | "uc = ucast ==> is_up uc ==> uint (uc w) = uint w" | |
| 856 | apply (unfold is_up) | |
| 857 | apply safe | |
| 858 | apply (rule bin_eqI) | |
| 859 | apply (fold word_test_bit_def) | |
| 860 | apply (auto simp add: nth_ucast) | |
| 861 | apply (auto simp add: test_bit_bin) | |
| 862 | done | |
| 863 | ||
| 864 | lemmas down_cast_same = refl [THEN down_cast_same'] | |
| 24465 | 865 | lemmas ucast_up_app = refl [THEN ucast_up_app'] | 
| 866 | lemmas ucast_down_drop = refl [THEN ucast_down_drop'] | |
| 867 | lemmas scast_down_drop = refl [THEN scast_down_drop'] | |
| 24333 | 868 | lemmas uint_up_ucast = refl [THEN uint_up_ucast'] | 
| 869 | lemmas sint_up_scast = refl [THEN sint_up_scast'] | |
| 870 | ||
| 871 | lemma ucast_up_ucast': "uc = ucast ==> is_up uc ==> ucast (uc w) = ucast w" | |
| 872 | apply (simp (no_asm) add: ucast_def) | |
| 873 | apply (clarsimp simp add: uint_up_ucast) | |
| 874 | done | |
| 875 | ||
| 876 | lemma scast_up_scast': "sc = scast ==> is_up sc ==> scast (sc w) = scast w" | |
| 877 | apply (simp (no_asm) add: scast_def) | |
| 878 | apply (clarsimp simp add: sint_up_scast) | |
| 879 | done | |
| 880 | ||
| 24465 | 881 | lemma ucast_of_bl_up': | 
| 882 | "w = of_bl bl ==> size bl <= size w ==> ucast w = of_bl bl" | |
| 883 | by (auto simp add : nth_ucast word_size test_bit_of_bl intro!: word_eqI) | |
| 884 | ||
| 24333 | 885 | lemmas ucast_up_ucast = refl [THEN ucast_up_ucast'] | 
| 886 | lemmas scast_up_scast = refl [THEN scast_up_scast'] | |
| 24465 | 887 | lemmas ucast_of_bl_up = refl [THEN ucast_of_bl_up'] | 
| 24333 | 888 | |
| 889 | lemmas ucast_up_ucast_id = trans [OF ucast_up_ucast ucast_id] | |
| 890 | lemmas scast_up_scast_id = trans [OF scast_up_scast scast_id] | |
| 891 | ||
| 892 | lemmas isduu = is_up_down [where c = "ucast", THEN iffD2] | |
| 893 | lemmas isdus = is_up_down [where c = "scast", THEN iffD2] | |
| 894 | lemmas ucast_down_ucast_id = isduu [THEN ucast_up_ucast_id] | |
| 895 | lemmas scast_down_scast_id = isdus [THEN ucast_up_ucast_id] | |
| 896 | ||
| 897 | lemma up_ucast_surj: | |
| 24465 | 898 | "is_up (ucast :: 'b::len0 word => 'a::len0 word) ==> | 
| 24333 | 899 | surj (ucast :: 'a word => 'b word)" | 
| 900 | by (rule surjI, erule ucast_up_ucast_id) | |
| 901 | ||
| 902 | lemma up_scast_surj: | |
| 24465 | 903 | "is_up (scast :: 'b::len word => 'a::len word) ==> | 
| 24333 | 904 | surj (scast :: 'a word => 'b word)" | 
| 905 | by (rule surjI, erule scast_up_scast_id) | |
| 906 | ||
| 907 | lemma down_scast_inj: | |
| 24465 | 908 | "is_down (scast :: 'b::len word => 'a::len word) ==> | 
| 24333 | 909 | inj_on (ucast :: 'a word => 'b word) A" | 
| 910 | by (rule inj_on_inverseI, erule scast_down_scast_id) | |
| 911 | ||
| 912 | lemma down_ucast_inj: | |
| 24465 | 913 | "is_down (ucast :: 'b::len0 word => 'a::len0 word) ==> | 
| 24333 | 914 | inj_on (ucast :: 'a word => 'b word) A" | 
| 915 | by (rule inj_on_inverseI, erule ucast_down_ucast_id) | |
| 916 | ||
| 24465 | 917 | lemma of_bl_append_same: "of_bl (X @ to_bl w) = w" | 
| 918 | by (rule word_bl.Rep_eqD) (simp add: word_rep_drop) | |
| 24333 | 919 | |
| 920 | lemma ucast_down_no': | |
| 921 | "uc = ucast ==> is_down uc ==> uc (number_of bin) = number_of bin" | |
| 922 | apply (unfold word_number_of_def is_down) | |
| 923 | apply (clarsimp simp add: ucast_def word_ubin.eq_norm) | |
| 924 | apply (rule word_ubin.norm_eq_iff [THEN iffD1]) | |
| 925 | apply (erule bintrunc_bintrunc_ge) | |
| 926 | done | |
| 927 | ||
| 928 | lemmas ucast_down_no = ucast_down_no' [OF refl] | |
| 929 | ||
| 24465 | 930 | lemma ucast_down_bl': "uc = ucast ==> is_down uc ==> uc (of_bl bl) = of_bl bl" | 
| 931 | unfolding of_bl_no by clarify (erule ucast_down_no) | |
| 932 | ||
| 933 | lemmas ucast_down_bl = ucast_down_bl' [OF refl] | |
| 934 | ||
| 935 | lemmas slice_def' = slice_def [unfolded word_size] | |
| 26559 | 936 | lemmas test_bit_def' = word_test_bit_def [THEN fun_cong] | 
| 24465 | 937 | |
| 938 | lemmas word_log_defs = word_and_def word_or_def word_xor_def word_not_def | |
| 939 | lemmas word_log_bin_defs = word_log_defs | |
| 940 | ||
| 29630 | 941 | text {* Executable equality *}
 | 
| 942 | ||
| 943 | instantiation word :: ("{len0}") eq
 | |
| 944 | begin | |
| 945 | ||
| 946 | definition eq_word :: "'a word \<Rightarrow> 'a word \<Rightarrow> bool" where | |
| 947 | "eq_word k l \<longleftrightarrow> HOL.eq (uint k) (uint l)" | |
| 948 | ||
| 949 | instance proof | |
| 950 | qed (simp add: eq eq_word_def) | |
| 951 | ||
| 24333 | 952 | end | 
| 29630 | 953 | |
| 954 | end |