src/HOL/Library/Saturated.thy
author haftmann
Thu, 11 Sep 2014 23:12:32 +0200
changeset 58320 351810c45a48
parent 57512 cc97b347b301
child 58881 b9556a055632
permissions -rw-r--r--
abstract product over monoid for lists
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
45692
d2567e55af83 tuned header;
wenzelm
parents: 44883
diff changeset
     1
(*  Title:      HOL/Library/Saturated.thy
d2567e55af83 tuned header;
wenzelm
parents: 44883
diff changeset
     2
    Author:     Brian Huffman
d2567e55af83 tuned header;
wenzelm
parents: 44883
diff changeset
     3
    Author:     Peter Gammie
d2567e55af83 tuned header;
wenzelm
parents: 44883
diff changeset
     4
    Author:     Florian Haftmann
d2567e55af83 tuned header;
wenzelm
parents: 44883
diff changeset
     5
*)
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
     6
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
     7
header {* Saturated arithmetic *}
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
     8
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
     9
theory Saturated
51542
738598beeb26 tuned imports;
wenzelm
parents: 51489
diff changeset
    10
imports Numeral_Type "~~/src/HOL/Word/Type_Length"
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    11
begin
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    12
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    13
subsection {* The type of saturated naturals *}
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    14
49834
b27bbb021df1 discontinued obsolete typedef (open) syntax;
wenzelm
parents: 47108
diff changeset
    15
typedef ('a::len) sat = "{.. len_of TYPE('a)}"
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    16
  morphisms nat_of Abs_sat
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    17
  by auto
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    18
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    19
lemma sat_eqI:
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    20
  "nat_of m = nat_of n \<Longrightarrow> m = n"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    21
  by (simp add: nat_of_inject)
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    22
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    23
lemma sat_eq_iff:
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    24
  "m = n \<longleftrightarrow> nat_of m = nat_of n"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    25
  by (simp add: nat_of_inject)
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    26
44883
a7f9c97378b3 Library/Saturated.thy: 'Sat' abbreviates 'of_nat'
huffman
parents: 44849
diff changeset
    27
lemma Abs_sat_nat_of [code abstype]:
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    28
  "Abs_sat (nat_of n) = n"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    29
  by (fact nat_of_inverse)
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    30
44883
a7f9c97378b3 Library/Saturated.thy: 'Sat' abbreviates 'of_nat'
huffman
parents: 44849
diff changeset
    31
definition Abs_sat' :: "nat \<Rightarrow> 'a::len sat" where
a7f9c97378b3 Library/Saturated.thy: 'Sat' abbreviates 'of_nat'
huffman
parents: 44849
diff changeset
    32
  "Abs_sat' n = Abs_sat (min (len_of TYPE('a)) n)"
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    33
44883
a7f9c97378b3 Library/Saturated.thy: 'Sat' abbreviates 'of_nat'
huffman
parents: 44849
diff changeset
    34
lemma nat_of_Abs_sat' [simp]:
a7f9c97378b3 Library/Saturated.thy: 'Sat' abbreviates 'of_nat'
huffman
parents: 44849
diff changeset
    35
  "nat_of (Abs_sat' n :: ('a::len) sat) = min (len_of TYPE('a)) n"
a7f9c97378b3 Library/Saturated.thy: 'Sat' abbreviates 'of_nat'
huffman
parents: 44849
diff changeset
    36
  unfolding Abs_sat'_def by (rule Abs_sat_inverse) simp
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    37
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    38
lemma nat_of_le_len_of [simp]:
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    39
  "nat_of (n :: ('a::len) sat) \<le> len_of TYPE('a)"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    40
  using nat_of [where x = n] by simp
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    41
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    42
lemma min_len_of_nat_of [simp]:
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    43
  "min (len_of TYPE('a)) (nat_of (n::('a::len) sat)) = nat_of n"
54863
82acc20ded73 prefer more canonical names for lemmas on min/max
haftmann
parents: 52729
diff changeset
    44
  by (rule min.absorb2 [OF nat_of_le_len_of])
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    45
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    46
lemma min_nat_of_len_of [simp]:
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    47
  "min (nat_of (n::('a::len) sat)) (len_of TYPE('a)) = nat_of n"
51540
eea5c4ca4a0e explicit sublocale dependency for Min/Max yields more appropriate Min/Max prefix for a couple of facts
haftmann
parents: 51489
diff changeset
    48
  by (subst min.commute) simp
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    49
44883
a7f9c97378b3 Library/Saturated.thy: 'Sat' abbreviates 'of_nat'
huffman
parents: 44849
diff changeset
    50
lemma Abs_sat'_nat_of [simp]:
a7f9c97378b3 Library/Saturated.thy: 'Sat' abbreviates 'of_nat'
huffman
parents: 44849
diff changeset
    51
  "Abs_sat' (nat_of n) = n"
a7f9c97378b3 Library/Saturated.thy: 'Sat' abbreviates 'of_nat'
huffman
parents: 44849
diff changeset
    52
  by (simp add: Abs_sat'_def nat_of_inverse)
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    53
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    54
instantiation sat :: (len) linorder
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    55
begin
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    56
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    57
definition
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    58
  less_eq_sat_def: "x \<le> y \<longleftrightarrow> nat_of x \<le> nat_of y"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    59
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    60
definition
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    61
  less_sat_def: "x < y \<longleftrightarrow> nat_of x < nat_of y"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    62
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    63
instance
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 54863
diff changeset
    64
by default (auto simp add: less_eq_sat_def less_sat_def not_le sat_eq_iff min.coboundedI1 mult.commute)
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    65
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    66
end
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    67
44849
41fddafe20d5 Library/Saturated.thy: number_semiring class instance
huffman
parents: 44848
diff changeset
    68
instantiation sat :: (len) "{minus, comm_semiring_1}"
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    69
begin
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    70
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    71
definition
44883
a7f9c97378b3 Library/Saturated.thy: 'Sat' abbreviates 'of_nat'
huffman
parents: 44849
diff changeset
    72
  "0 = Abs_sat' 0"
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    73
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    74
definition
44883
a7f9c97378b3 Library/Saturated.thy: 'Sat' abbreviates 'of_nat'
huffman
parents: 44849
diff changeset
    75
  "1 = Abs_sat' 1"
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    76
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    77
lemma nat_of_zero_sat [simp, code abstract]:
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    78
  "nat_of 0 = 0"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    79
  by (simp add: zero_sat_def)
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    80
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    81
lemma nat_of_one_sat [simp, code abstract]:
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    82
  "nat_of 1 = min 1 (len_of TYPE('a))"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    83
  by (simp add: one_sat_def)
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    84
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    85
definition
44883
a7f9c97378b3 Library/Saturated.thy: 'Sat' abbreviates 'of_nat'
huffman
parents: 44849
diff changeset
    86
  "x + y = Abs_sat' (nat_of x + nat_of y)"
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    87
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    88
lemma nat_of_plus_sat [simp, code abstract]:
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    89
  "nat_of (x + y) = min (nat_of x + nat_of y) (len_of TYPE('a))"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    90
  by (simp add: plus_sat_def)
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    91
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    92
definition
44883
a7f9c97378b3 Library/Saturated.thy: 'Sat' abbreviates 'of_nat'
huffman
parents: 44849
diff changeset
    93
  "x - y = Abs_sat' (nat_of x - nat_of y)"
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    94
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    95
lemma nat_of_minus_sat [simp, code abstract]:
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    96
  "nat_of (x - y) = nat_of x - nat_of y"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    97
proof -
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    98
  from nat_of_le_len_of [of x] have "nat_of x - nat_of y \<le> len_of TYPE('a)" by arith
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
    99
  then show ?thesis by (simp add: minus_sat_def)
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   100
qed
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   101
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   102
definition
44883
a7f9c97378b3 Library/Saturated.thy: 'Sat' abbreviates 'of_nat'
huffman
parents: 44849
diff changeset
   103
  "x * y = Abs_sat' (nat_of x * nat_of y)"
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   104
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   105
lemma nat_of_times_sat [simp, code abstract]:
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   106
  "nat_of (x * y) = min (nat_of x * nat_of y) (len_of TYPE('a))"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   107
  by (simp add: times_sat_def)
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   108
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   109
instance proof
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   110
  fix a b c :: "('a::len) sat"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   111
  show "a * b * c = a * (b * c)"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   112
  proof(cases "a = 0")
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   113
    case True thus ?thesis by (simp add: sat_eq_iff)
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   114
  next
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   115
    case False show ?thesis
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   116
    proof(cases "c = 0")
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   117
      case True thus ?thesis by (simp add: sat_eq_iff)
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   118
    next
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   119
      case False with `a \<noteq> 0` show ?thesis
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 54863
diff changeset
   120
        by (simp add: sat_eq_iff nat_mult_min_left nat_mult_min_right mult.assoc min.assoc min.absorb2)
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   121
    qed
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   122
  qed
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   123
next
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   124
  fix a :: "('a::len) sat"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   125
  show "1 * a = a"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   126
    apply (simp add: sat_eq_iff)
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 54863
diff changeset
   127
    apply (metis One_nat_def len_gt_0 less_Suc0 less_zeroE linorder_not_less min.absorb_iff1 min_nat_of_len_of nat_mult_1_right mult.commute)
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   128
    done
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   129
next
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   130
  fix a b c :: "('a::len) sat"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   131
  show "(a + b) * c = a * c + b * c"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   132
  proof(cases "c = 0")
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   133
    case True thus ?thesis by (simp add: sat_eq_iff)
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   134
  next
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   135
    case False thus ?thesis
54863
82acc20ded73 prefer more canonical names for lemmas on min/max
haftmann
parents: 52729
diff changeset
   136
      by (simp add: sat_eq_iff nat_mult_min_left add_mult_distrib min_add_distrib_left min_add_distrib_right min.assoc min.absorb2)
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   137
  qed
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   138
qed (simp_all add: sat_eq_iff mult.commute)
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   139
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   140
end
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   141
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   142
instantiation sat :: (len) ordered_comm_semiring
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   143
begin
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   144
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   145
instance
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 54863
diff changeset
   146
by default (auto simp add: less_eq_sat_def less_sat_def not_le sat_eq_iff min.coboundedI1 mult.commute)
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   147
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   148
end
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   149
44883
a7f9c97378b3 Library/Saturated.thy: 'Sat' abbreviates 'of_nat'
huffman
parents: 44849
diff changeset
   150
lemma Abs_sat'_eq_of_nat: "Abs_sat' n = of_nat n"
44849
41fddafe20d5 Library/Saturated.thy: number_semiring class instance
huffman
parents: 44848
diff changeset
   151
  by (rule sat_eqI, induct n, simp_all)
41fddafe20d5 Library/Saturated.thy: number_semiring class instance
huffman
parents: 44848
diff changeset
   152
44883
a7f9c97378b3 Library/Saturated.thy: 'Sat' abbreviates 'of_nat'
huffman
parents: 44849
diff changeset
   153
abbreviation Sat :: "nat \<Rightarrow> 'a::len sat" where
a7f9c97378b3 Library/Saturated.thy: 'Sat' abbreviates 'of_nat'
huffman
parents: 44849
diff changeset
   154
  "Sat \<equiv> of_nat"
a7f9c97378b3 Library/Saturated.thy: 'Sat' abbreviates 'of_nat'
huffman
parents: 44849
diff changeset
   155
a7f9c97378b3 Library/Saturated.thy: 'Sat' abbreviates 'of_nat'
huffman
parents: 44849
diff changeset
   156
lemma nat_of_Sat [simp]:
a7f9c97378b3 Library/Saturated.thy: 'Sat' abbreviates 'of_nat'
huffman
parents: 44849
diff changeset
   157
  "nat_of (Sat n :: ('a::len) sat) = min (len_of TYPE('a)) n"
a7f9c97378b3 Library/Saturated.thy: 'Sat' abbreviates 'of_nat'
huffman
parents: 44849
diff changeset
   158
  by (rule nat_of_Abs_sat' [unfolded Abs_sat'_eq_of_nat])
a7f9c97378b3 Library/Saturated.thy: 'Sat' abbreviates 'of_nat'
huffman
parents: 44849
diff changeset
   159
47108
2a1953f0d20d merged fork with new numeral representation (see NEWS)
huffman
parents: 45994
diff changeset
   160
lemma [code_abbrev]:
2a1953f0d20d merged fork with new numeral representation (see NEWS)
huffman
parents: 45994
diff changeset
   161
  "of_nat (numeral k) = (numeral k :: 'a::len sat)"
2a1953f0d20d merged fork with new numeral representation (see NEWS)
huffman
parents: 45994
diff changeset
   162
  by simp
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   163
47108
2a1953f0d20d merged fork with new numeral representation (see NEWS)
huffman
parents: 45994
diff changeset
   164
definition sat_of_nat :: "nat \<Rightarrow> ('a::len) sat"
2a1953f0d20d merged fork with new numeral representation (see NEWS)
huffman
parents: 45994
diff changeset
   165
  where [code_abbrev]: "sat_of_nat = of_nat"
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   166
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   167
lemma [code abstract]:
47108
2a1953f0d20d merged fork with new numeral representation (see NEWS)
huffman
parents: 45994
diff changeset
   168
  "nat_of (sat_of_nat n :: ('a::len) sat) = min (len_of TYPE('a)) n"
2a1953f0d20d merged fork with new numeral representation (see NEWS)
huffman
parents: 45994
diff changeset
   169
  by (simp add: sat_of_nat_def)
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   170
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   171
instance sat :: (len) finite
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   172
proof
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   173
  show "finite (UNIV::'a sat set)"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   174
    unfolding type_definition.univ [OF type_definition_sat]
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   175
    using finite by simp
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   176
qed
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   177
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   178
instantiation sat :: (len) equal
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   179
begin
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   180
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   181
definition
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   182
  "HOL.equal A B \<longleftrightarrow> nat_of A = nat_of B"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   183
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   184
instance proof
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   185
qed (simp add: equal_sat_def nat_of_inject)
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   186
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   187
end
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   188
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   189
instantiation sat :: (len) "{bounded_lattice, distrib_lattice}"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   190
begin
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   191
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   192
definition
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   193
  "(inf :: 'a sat \<Rightarrow> 'a sat \<Rightarrow> 'a sat) = min"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   194
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   195
definition
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   196
  "(sup :: 'a sat \<Rightarrow> 'a sat \<Rightarrow> 'a sat) = max"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   197
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   198
definition
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   199
  "bot = (0 :: 'a sat)"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   200
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   201
definition
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   202
  "top = Sat (len_of TYPE('a))"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   203
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   204
instance proof
54863
82acc20ded73 prefer more canonical names for lemmas on min/max
haftmann
parents: 52729
diff changeset
   205
qed (simp_all add: inf_sat_def sup_sat_def bot_sat_def top_sat_def max_min_distrib2,
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   206
  simp_all add: less_eq_sat_def)
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   207
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   208
end
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   209
51489
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   210
instantiation sat :: (len) "{Inf, Sup}"
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   211
begin
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   212
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   213
definition
51489
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   214
  "Inf = (semilattice_neutr_set.F min top :: 'a sat set \<Rightarrow> 'a sat)"
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   215
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   216
definition
51489
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   217
  "Sup = (semilattice_neutr_set.F max bot :: 'a sat set \<Rightarrow> 'a sat)"
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   218
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   219
instance ..
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   220
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   221
end
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   222
51489
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   223
interpretation Inf_sat!: semilattice_neutr_set min "top :: 'a::len sat"
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   224
where
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   225
  "semilattice_neutr_set.F min (top :: 'a sat) = Inf"
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   226
proof -
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   227
  show "semilattice_neutr_set min (top :: 'a sat)" by default (simp add: min_def)
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   228
  show "semilattice_neutr_set.F min (top :: 'a sat) = Inf" by (simp add: Inf_sat_def)
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   229
qed
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   230
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   231
interpretation Sup_sat!: semilattice_neutr_set max "bot :: 'a::len sat"
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   232
where
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   233
  "semilattice_neutr_set.F max (bot :: 'a sat) = Sup"
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   234
proof -
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   235
  show "semilattice_neutr_set max (bot :: 'a sat)" by default (simp add: max_def bot.extremum_unique)
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   236
  show "semilattice_neutr_set.F max (bot :: 'a sat) = Sup" by (simp add: Sup_sat_def)
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   237
qed
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   238
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   239
instance sat :: (len) complete_lattice
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   240
proof 
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   241
  fix x :: "'a sat"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   242
  fix A :: "'a sat set"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   243
  note finite
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   244
  moreover assume "x \<in> A"
51489
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   245
  ultimately show "Inf A \<le> x"
54863
82acc20ded73 prefer more canonical names for lemmas on min/max
haftmann
parents: 52729
diff changeset
   246
    by (induct A) (auto intro: min.coboundedI2)
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   247
next
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   248
  fix z :: "'a sat"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   249
  fix A :: "'a sat set"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   250
  note finite
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   251
  moreover assume z: "\<And>x. x \<in> A \<Longrightarrow> z \<le> x"
51489
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   252
  ultimately show "z \<le> Inf A" by (induct A) simp_all
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   253
next
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   254
  fix x :: "'a sat"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   255
  fix A :: "'a sat set"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   256
  note finite
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   257
  moreover assume "x \<in> A"
51489
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   258
  ultimately show "x \<le> Sup A"
54863
82acc20ded73 prefer more canonical names for lemmas on min/max
haftmann
parents: 52729
diff changeset
   259
    by (induct A) (auto intro: max.coboundedI2)
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   260
next
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   261
  fix z :: "'a sat"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   262
  fix A :: "'a sat set"
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   263
  note finite
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   264
  moreover assume z: "\<And>x. x \<in> A \<Longrightarrow> x \<le> z"
51489
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   265
  ultimately show "Sup A \<le> z" by (induct A) auto
52729
412c9e0381a1 factored syntactic type classes for bot and top (by Alessandro Coglio)
haftmann
parents: 51545
diff changeset
   266
next
412c9e0381a1 factored syntactic type classes for bot and top (by Alessandro Coglio)
haftmann
parents: 51545
diff changeset
   267
  show "Inf {} = (top::'a sat)"
412c9e0381a1 factored syntactic type classes for bot and top (by Alessandro Coglio)
haftmann
parents: 51545
diff changeset
   268
    by (auto simp: top_sat_def)
412c9e0381a1 factored syntactic type classes for bot and top (by Alessandro Coglio)
haftmann
parents: 51545
diff changeset
   269
next
412c9e0381a1 factored syntactic type classes for bot and top (by Alessandro Coglio)
haftmann
parents: 51545
diff changeset
   270
  show "Sup {} = (bot::'a sat)"
412c9e0381a1 factored syntactic type classes for bot and top (by Alessandro Coglio)
haftmann
parents: 51545
diff changeset
   271
    by (auto simp: bot_sat_def)
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   272
qed
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   273
47108
2a1953f0d20d merged fork with new numeral representation (see NEWS)
huffman
parents: 45994
diff changeset
   274
hide_const (open) sat_of_nat
2a1953f0d20d merged fork with new numeral representation (see NEWS)
huffman
parents: 45994
diff changeset
   275
44819
fe33d6655186 theory of saturated naturals contributed by Peter Gammie
haftmann
parents:
diff changeset
   276
end
51489
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 49834
diff changeset
   277