src/HOL/Word/Bits.thy
author wenzelm
Mon, 08 May 2017 10:27:13 +0200
changeset 65767 222ed8901008
parent 65363 5eb619751b14
child 70175 85fb1a585f52
permissions -rw-r--r--
suppress "Pure" with its special threads=1 (Jenkins log does not provide threads in ISABELLE_BUILD_OPTIONS);
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
55210
d1e3b708d74b tuned headers;
wenzelm
parents: 54854
diff changeset
     1
(*  Title:      HOL/Word/Bits.thy
37655
f4d616d41a59 more speaking theory names
haftmann
parents: 29631
diff changeset
     2
    Author:     Author: Brian Huffman, PSU and Gerwin Klein, NICTA
24334
22863f364531 added header
kleing
parents: 24333
diff changeset
     3
*)
22863f364531 added header
kleing
parents: 24333
diff changeset
     4
61799
4cf66f21b764 isabelle update_cartouches -c -t;
wenzelm
parents: 58874
diff changeset
     5
section \<open>Syntactic classes for bitwise operations\<close>
24333
e77ea0ea7f2c * HOL-Word:
kleing
parents:
diff changeset
     6
54854
3324a0078636 prefer "Bits" as theory name for abstract bit operations, similar to "Orderings", "Lattices", "Groups" etc.
haftmann
parents: 54847
diff changeset
     7
theory Bits
65363
5eb619751b14 misc tuning and modernization;
wenzelm
parents: 61799
diff changeset
     8
  imports Main
24333
e77ea0ea7f2c * HOL-Word:
kleing
parents:
diff changeset
     9
begin
e77ea0ea7f2c * HOL-Word:
kleing
parents:
diff changeset
    10
29608
564ea783ace8 no base sort in class import
haftmann
parents: 26559
diff changeset
    11
class bit =
65363
5eb619751b14 misc tuning and modernization;
wenzelm
parents: 61799
diff changeset
    12
  fixes bitNOT :: "'a \<Rightarrow> 'a"  ("NOT _" [70] 71)
5eb619751b14 misc tuning and modernization;
wenzelm
parents: 61799
diff changeset
    13
    and bitAND :: "'a \<Rightarrow> 'a \<Rightarrow> 'a"  (infixr "AND" 64)
5eb619751b14 misc tuning and modernization;
wenzelm
parents: 61799
diff changeset
    14
    and bitOR :: "'a \<Rightarrow> 'a \<Rightarrow> 'a"  (infixr "OR"  59)
5eb619751b14 misc tuning and modernization;
wenzelm
parents: 61799
diff changeset
    15
    and bitXOR :: "'a \<Rightarrow> 'a \<Rightarrow> 'a"  (infixr "XOR" 59)
24333
e77ea0ea7f2c * HOL-Word:
kleing
parents:
diff changeset
    16
61799
4cf66f21b764 isabelle update_cartouches -c -t;
wenzelm
parents: 58874
diff changeset
    17
text \<open>
24333
e77ea0ea7f2c * HOL-Word:
kleing
parents:
diff changeset
    18
  We want the bitwise operations to bind slightly weaker
65363
5eb619751b14 misc tuning and modernization;
wenzelm
parents: 61799
diff changeset
    19
  than \<open>+\<close> and \<open>-\<close>, but \<open>~~\<close> to
61799
4cf66f21b764 isabelle update_cartouches -c -t;
wenzelm
parents: 58874
diff changeset
    20
  bind slightly stronger than \<open>*\<close>.
4cf66f21b764 isabelle update_cartouches -c -t;
wenzelm
parents: 58874
diff changeset
    21
\<close>
24352
eda777a2785b use class instead of axclass
huffman
parents: 24334
diff changeset
    22
65363
5eb619751b14 misc tuning and modernization;
wenzelm
parents: 61799
diff changeset
    23
text \<open>Testing and shifting operations.\<close>
26559
799983936aad syntactic classes for bit operations
haftmann
parents: 26086
diff changeset
    24
799983936aad syntactic classes for bit operations
haftmann
parents: 26086
diff changeset
    25
class bits = bit +
65363
5eb619751b14 misc tuning and modernization;
wenzelm
parents: 61799
diff changeset
    26
  fixes test_bit :: "'a \<Rightarrow> nat \<Rightarrow> bool"  (infixl "!!" 100)
5eb619751b14 misc tuning and modernization;
wenzelm
parents: 61799
diff changeset
    27
    and lsb :: "'a \<Rightarrow> bool"
5eb619751b14 misc tuning and modernization;
wenzelm
parents: 61799
diff changeset
    28
    and set_bit :: "'a \<Rightarrow> nat \<Rightarrow> bool \<Rightarrow> 'a"
5eb619751b14 misc tuning and modernization;
wenzelm
parents: 61799
diff changeset
    29
    and set_bits :: "(nat \<Rightarrow> bool) \<Rightarrow> 'a"  (binder "BITS " 10)
5eb619751b14 misc tuning and modernization;
wenzelm
parents: 61799
diff changeset
    30
    and shiftl :: "'a \<Rightarrow> nat \<Rightarrow> 'a"  (infixl "<<" 55)
5eb619751b14 misc tuning and modernization;
wenzelm
parents: 61799
diff changeset
    31
    and shiftr :: "'a \<Rightarrow> nat \<Rightarrow> 'a"  (infixl ">>" 55)
26559
799983936aad syntactic classes for bit operations
haftmann
parents: 26086
diff changeset
    32
799983936aad syntactic classes for bit operations
haftmann
parents: 26086
diff changeset
    33
class bitss = bits +
65363
5eb619751b14 misc tuning and modernization;
wenzelm
parents: 61799
diff changeset
    34
  fixes msb :: "'a \<Rightarrow> bool"
24333
e77ea0ea7f2c * HOL-Word:
kleing
parents:
diff changeset
    35
25762
c03e9d04b3e4 splitted class uminus from class minus
haftmann
parents: 25382
diff changeset
    36
end