src/HOL/Library/IArray.thy
author haftmann
Wed, 18 Jul 2018 20:51:22 +0200
changeset 68659 db0c70767d86
parent 68658 16cc1161ad7f
child 69272 15e9ed5b28fb
permissions -rw-r--r--
setup for Haskell taken over from AFP / Gauss_Jordan
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
68657
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
     1
(*  Title:      HOL/Library/IArray.thy
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
     2
    Author:     Tobias Nipkow, TU Muenchen
68659
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
     3
    Author:     Jose Divasón <jose.divasonm at unirioja.es>
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
     4
    Author:     Jesús Aransay <jesus-maria.aransay at unirioja.es>
68657
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
     5
*)
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
     6
68654
81639cc48d0a more cartouches
haftmann
parents: 67613
diff changeset
     7
section \<open>Immutable Arrays with Code Generation\<close>
50138
ca989d793b34 new theory of immutable arrays
nipkow
parents:
diff changeset
     8
ca989d793b34 new theory of immutable arrays
nipkow
parents:
diff changeset
     9
theory IArray
51094
84b03c49c223 IArray ignorant of particular representation of nat
haftmann
parents: 50138
diff changeset
    10
imports Main
50138
ca989d793b34 new theory of immutable arrays
nipkow
parents:
diff changeset
    11
begin
ca989d793b34 new theory of immutable arrays
nipkow
parents:
diff changeset
    12
68657
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
    13
subsection \<open>Fundamental operations\<close>
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
    14
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
    15
text \<open>Immutable arrays are lists wrapped up in an additional constructor.
50138
ca989d793b34 new theory of immutable arrays
nipkow
parents:
diff changeset
    16
There are no update operations. Hence code generation can safely implement
ca989d793b34 new theory of immutable arrays
nipkow
parents:
diff changeset
    17
this type by efficient target language arrays.  Currently only SML is
68657
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
    18
provided. Could be extended to other target languages and more operations.\<close>
50138
ca989d793b34 new theory of immutable arrays
nipkow
parents:
diff changeset
    19
61115
3a4400985780 modernized name space management -- more uniform qualification;
wenzelm
parents: 60500
diff changeset
    20
context
3a4400985780 modernized name space management -- more uniform qualification;
wenzelm
parents: 60500
diff changeset
    21
begin
3a4400985780 modernized name space management -- more uniform qualification;
wenzelm
parents: 60500
diff changeset
    22
58310
91ea607a34d8 updated news
blanchet
parents: 58269
diff changeset
    23
datatype 'a iarray = IArray "'a list"
50138
ca989d793b34 new theory of immutable arrays
nipkow
parents:
diff changeset
    24
61115
3a4400985780 modernized name space management -- more uniform qualification;
wenzelm
parents: 60500
diff changeset
    25
qualified primrec list_of :: "'a iarray \<Rightarrow> 'a list" where
50138
ca989d793b34 new theory of immutable arrays
nipkow
parents:
diff changeset
    26
"list_of (IArray xs) = xs"
ca989d793b34 new theory of immutable arrays
nipkow
parents:
diff changeset
    27
61115
3a4400985780 modernized name space management -- more uniform qualification;
wenzelm
parents: 60500
diff changeset
    28
qualified definition of_fun :: "(nat \<Rightarrow> 'a) \<Rightarrow> nat \<Rightarrow> 'a iarray" where
51094
84b03c49c223 IArray ignorant of particular representation of nat
haftmann
parents: 50138
diff changeset
    29
[simp]: "of_fun f n = IArray (map f [0..<n])"
84b03c49c223 IArray ignorant of particular representation of nat
haftmann
parents: 50138
diff changeset
    30
61115
3a4400985780 modernized name space management -- more uniform qualification;
wenzelm
parents: 60500
diff changeset
    31
qualified definition sub :: "'a iarray \<Rightarrow> nat \<Rightarrow> 'a" (infixl "!!" 100) where
51094
84b03c49c223 IArray ignorant of particular representation of nat
haftmann
parents: 50138
diff changeset
    32
[simp]: "as !! n = IArray.list_of as ! n"
84b03c49c223 IArray ignorant of particular representation of nat
haftmann
parents: 50138
diff changeset
    33
61115
3a4400985780 modernized name space management -- more uniform qualification;
wenzelm
parents: 60500
diff changeset
    34
qualified definition length :: "'a iarray \<Rightarrow> nat" where
51094
84b03c49c223 IArray ignorant of particular representation of nat
haftmann
parents: 50138
diff changeset
    35
[simp]: "length as = List.length (IArray.list_of as)"
84b03c49c223 IArray ignorant of particular representation of nat
haftmann
parents: 50138
diff changeset
    36
68659
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
    37
qualified definition all :: "('a \<Rightarrow> bool) \<Rightarrow> 'a iarray \<Rightarrow> bool" where
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
    38
[simp]: "all p as \<longleftrightarrow> (\<forall>a \<in> set (list_of as). p a)"
54459
f43ae1afd08a added functions all and exists to IArray
nipkow
parents: 52435
diff changeset
    39
68659
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
    40
qualified definition exists :: "('a \<Rightarrow> bool) \<Rightarrow> 'a iarray \<Rightarrow> bool" where
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
    41
[simp]: "exists p as \<longleftrightarrow> (\<exists>a \<in> set (list_of as). p a)"
51094
84b03c49c223 IArray ignorant of particular representation of nat
haftmann
parents: 50138
diff changeset
    42
68655
90652333fae2 taken over from AFP / Gauss_Jordan
haftmann
parents: 68654
diff changeset
    43
lemma of_fun_nth:
90652333fae2 taken over from AFP / Gauss_Jordan
haftmann
parents: 68654
diff changeset
    44
"IArray.of_fun f n !! i = f i" if "i < n"
90652333fae2 taken over from AFP / Gauss_Jordan
haftmann
parents: 68654
diff changeset
    45
using that by (simp add: map_nth)
90652333fae2 taken over from AFP / Gauss_Jordan
haftmann
parents: 68654
diff changeset
    46
61115
3a4400985780 modernized name space management -- more uniform qualification;
wenzelm
parents: 60500
diff changeset
    47
end
3a4400985780 modernized name space management -- more uniform qualification;
wenzelm
parents: 60500
diff changeset
    48
50138
ca989d793b34 new theory of immutable arrays
nipkow
parents:
diff changeset
    49
68657
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
    50
subsection \<open>Generic code equations\<close>
51094
84b03c49c223 IArray ignorant of particular representation of nat
haftmann
parents: 50138
diff changeset
    51
51161
6ed12ae3b3e1 attempt to re-establish conventions which theories are loaded into the grand unified library theory;
haftmann
parents: 51143
diff changeset
    52
lemma [code]:
68658
16cc1161ad7f tuned equation
haftmann
parents: 68657
diff changeset
    53
  "size (as :: 'a iarray) = Suc (IArray.length as)"
58269
ad644790cbbb tuned IArray code generator w.r.t. map rel set
blanchet
parents: 58266
diff changeset
    54
  by (cases as) simp
51161
6ed12ae3b3e1 attempt to re-establish conventions which theories are loaded into the grand unified library theory;
haftmann
parents: 51143
diff changeset
    55
6ed12ae3b3e1 attempt to re-establish conventions which theories are loaded into the grand unified library theory;
haftmann
parents: 51143
diff changeset
    56
lemma [code]:
58269
ad644790cbbb tuned IArray code generator w.r.t. map rel set
blanchet
parents: 58266
diff changeset
    57
  "size_iarray f as = Suc (size_list f (IArray.list_of as))"
ad644790cbbb tuned IArray code generator w.r.t. map rel set
blanchet
parents: 58266
diff changeset
    58
  by (cases as) simp
ad644790cbbb tuned IArray code generator w.r.t. map rel set
blanchet
parents: 58266
diff changeset
    59
ad644790cbbb tuned IArray code generator w.r.t. map rel set
blanchet
parents: 58266
diff changeset
    60
lemma [code]:
ad644790cbbb tuned IArray code generator w.r.t. map rel set
blanchet
parents: 58266
diff changeset
    61
  "rec_iarray f as = f (IArray.list_of as)"
ad644790cbbb tuned IArray code generator w.r.t. map rel set
blanchet
parents: 58266
diff changeset
    62
  by (cases as) simp
ad644790cbbb tuned IArray code generator w.r.t. map rel set
blanchet
parents: 58266
diff changeset
    63
ad644790cbbb tuned IArray code generator w.r.t. map rel set
blanchet
parents: 58266
diff changeset
    64
lemma [code]:
ad644790cbbb tuned IArray code generator w.r.t. map rel set
blanchet
parents: 58266
diff changeset
    65
  "case_iarray f as = f (IArray.list_of as)"
ad644790cbbb tuned IArray code generator w.r.t. map rel set
blanchet
parents: 58266
diff changeset
    66
  by (cases as) simp
51161
6ed12ae3b3e1 attempt to re-establish conventions which theories are loaded into the grand unified library theory;
haftmann
parents: 51143
diff changeset
    67
6ed12ae3b3e1 attempt to re-establish conventions which theories are loaded into the grand unified library theory;
haftmann
parents: 51143
diff changeset
    68
lemma [code]:
58269
ad644790cbbb tuned IArray code generator w.r.t. map rel set
blanchet
parents: 58266
diff changeset
    69
  "set_iarray as = set (IArray.list_of as)"
63649
e690d6f2185b tuned proofs;
wenzelm
parents: 61115
diff changeset
    70
  by (cases as) auto
58269
ad644790cbbb tuned IArray code generator w.r.t. map rel set
blanchet
parents: 58266
diff changeset
    71
ad644790cbbb tuned IArray code generator w.r.t. map rel set
blanchet
parents: 58266
diff changeset
    72
lemma [code]:
ad644790cbbb tuned IArray code generator w.r.t. map rel set
blanchet
parents: 58266
diff changeset
    73
  "map_iarray f as = IArray (map f (IArray.list_of as))"
63649
e690d6f2185b tuned proofs;
wenzelm
parents: 61115
diff changeset
    74
  by (cases as) auto
51161
6ed12ae3b3e1 attempt to re-establish conventions which theories are loaded into the grand unified library theory;
haftmann
parents: 51143
diff changeset
    75
6ed12ae3b3e1 attempt to re-establish conventions which theories are loaded into the grand unified library theory;
haftmann
parents: 51143
diff changeset
    76
lemma [code]:
58269
ad644790cbbb tuned IArray code generator w.r.t. map rel set
blanchet
parents: 58266
diff changeset
    77
  "rel_iarray r as bs = list_all2 r (IArray.list_of as) (IArray.list_of bs)"
63649
e690d6f2185b tuned proofs;
wenzelm
parents: 61115
diff changeset
    78
  by (cases as, cases bs) auto
51161
6ed12ae3b3e1 attempt to re-establish conventions which theories are loaded into the grand unified library theory;
haftmann
parents: 51143
diff changeset
    79
68659
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
    80
lemma list_of_code [code]:
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
    81
  "IArray.list_of as = map (\<lambda>n. as !! n) [0 ..< IArray.length as]"
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
    82
  by (cases as) (simp add: map_nth)
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
    83
51161
6ed12ae3b3e1 attempt to re-establish conventions which theories are loaded into the grand unified library theory;
haftmann
parents: 51143
diff changeset
    84
lemma [code]:
58269
ad644790cbbb tuned IArray code generator w.r.t. map rel set
blanchet
parents: 58266
diff changeset
    85
  "HOL.equal as bs \<longleftrightarrow> HOL.equal (IArray.list_of as) (IArray.list_of bs)"
ad644790cbbb tuned IArray code generator w.r.t. map rel set
blanchet
parents: 58266
diff changeset
    86
  by (cases as, cases bs) (simp add: equal)
51161
6ed12ae3b3e1 attempt to re-establish conventions which theories are loaded into the grand unified library theory;
haftmann
parents: 51143
diff changeset
    87
68659
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
    88
lemma [code]:
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
    89
  "IArray.all p = Not \<circ> IArray.exists (Not \<circ> p)"
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
    90
  by (simp add: fun_eq_iff)
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
    91
59457
c4f044389c28 proper term_of for iarray
haftmann
parents: 58881
diff changeset
    92
context term_syntax
c4f044389c28 proper term_of for iarray
haftmann
parents: 58881
diff changeset
    93
begin
c4f044389c28 proper term_of for iarray
haftmann
parents: 58881
diff changeset
    94
c4f044389c28 proper term_of for iarray
haftmann
parents: 58881
diff changeset
    95
lemma [code]:
c4f044389c28 proper term_of for iarray
haftmann
parents: 58881
diff changeset
    96
  "Code_Evaluation.term_of (as :: 'a::typerep iarray) =
c4f044389c28 proper term_of for iarray
haftmann
parents: 58881
diff changeset
    97
    Code_Evaluation.Const (STR ''IArray.iarray.IArray'') (TYPEREP('a list \<Rightarrow> 'a iarray)) <\<cdot>> (Code_Evaluation.term_of (IArray.list_of as))"
c4f044389c28 proper term_of for iarray
haftmann
parents: 58881
diff changeset
    98
  by (subst term_of_anything) rule
c4f044389c28 proper term_of for iarray
haftmann
parents: 58881
diff changeset
    99
c4f044389c28 proper term_of for iarray
haftmann
parents: 58881
diff changeset
   100
end
c4f044389c28 proper term_of for iarray
haftmann
parents: 58881
diff changeset
   101
68657
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   102
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   103
subsection \<open>Auxiliary operations for code generation\<close>
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   104
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   105
context
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   106
begin
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   107
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   108
qualified primrec tabulate :: "integer \<times> (integer \<Rightarrow> 'a) \<Rightarrow> 'a iarray" where
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   109
  "tabulate (n, f) = IArray (map (f \<circ> integer_of_nat) [0..<nat_of_integer n])"
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   110
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   111
lemma [code]:
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   112
  "IArray.of_fun f n = IArray.tabulate (integer_of_nat n, f \<circ> nat_of_integer)"
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   113
  by simp
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   114
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   115
qualified primrec sub' :: "'a iarray \<times> integer \<Rightarrow> 'a" where
68659
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   116
  "sub' (as, n) = as !! nat_of_integer n"
68657
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   117
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   118
lemma [code]:
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   119
  "IArray.sub' (IArray as, n) = as ! nat_of_integer n"
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   120
  by simp
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   121
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   122
lemma [code]:
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   123
  "as !! n = IArray.sub' (as, integer_of_nat n)"
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   124
  by simp
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   125
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   126
qualified definition length' :: "'a iarray \<Rightarrow> integer" where
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   127
  [simp]: "length' as = integer_of_nat (List.length (IArray.list_of as))"
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   128
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   129
lemma [code]:
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   130
  "IArray.length' (IArray as) = integer_of_nat (List.length as)"
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   131
  by simp
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   132
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   133
lemma [code]:
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   134
  "IArray.length as = nat_of_integer (IArray.length' as)"
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   135
  by simp
50138
ca989d793b34 new theory of immutable arrays
nipkow
parents:
diff changeset
   136
68659
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   137
qualified definition exists_upto :: "('a \<Rightarrow> bool) \<Rightarrow> integer \<Rightarrow> 'a iarray \<Rightarrow> bool" where
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   138
  [simp]: "exists_upto p k as \<longleftrightarrow> (\<exists>l. 0 \<le> l \<and> l < k \<and> p (sub' (as, l)))"
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   139
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   140
lemma exists_upto_of_nat:
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   141
  "exists_upto p (of_nat n) as \<longleftrightarrow> (\<exists>m<n. p (as !! m))"
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   142
  including integer.lifting by (simp, transfer)
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   143
    (metis nat_int nat_less_iff of_nat_0_le_iff)
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   144
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   145
lemma [code]:
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   146
  "exists_upto p k as \<longleftrightarrow> (if k \<le> 0 then False else
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   147
    let l = k - 1 in p (sub' (as, l)) \<or> exists_upto p l as)"
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   148
proof (cases "k \<ge> 1")
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   149
  case False
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   150
  then show ?thesis
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   151
    by (auto simp add: not_le discrete)
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   152
next
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   153
  case True
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   154
  then have less: "k \<le> 0 \<longleftrightarrow> False"
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   155
    by simp
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   156
  define n where "n = nat_of_integer (k - 1)"
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   157
  with True have k: "k - 1 = of_nat n" "k = of_nat (Suc n)"
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   158
    by simp_all
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   159
  show ?thesis unfolding less Let_def k(1) unfolding k(2) exists_upto_of_nat
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   160
    using less_Suc_eq by auto
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   161
qed
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   162
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   163
lemma [code]:
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   164
  "IArray.exists p as \<longleftrightarrow> exists_upto p (length' as) as"
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   165
  including integer.lifting by (simp, transfer)
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   166
   (auto, metis in_set_conv_nth less_imp_of_nat_less nat_int of_nat_0_le_iff)
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   167
50138
ca989d793b34 new theory of immutable arrays
nipkow
parents:
diff changeset
   168
end
68657
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   169
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   170
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   171
subsection \<open>Code Generation for SML\<close>
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   172
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   173
text \<open>Note that arrays cannot be printed directly but only by turning them into
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   174
lists first. Arrays could be converted back into lists for printing if they
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   175
were wrapped up in an additional constructor.\<close>
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   176
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   177
code_reserved SML Vector
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   178
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   179
code_printing
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   180
  type_constructor iarray \<rightharpoonup> (SML) "_ Vector.vector"
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   181
| constant IArray \<rightharpoonup> (SML) "Vector.fromList"
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   182
| constant IArray.all \<rightharpoonup> (SML) "Vector.all"
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   183
| constant IArray.exists \<rightharpoonup> (SML) "Vector.exists"
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   184
| constant IArray.tabulate \<rightharpoonup> (SML) "Vector.tabulate"
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   185
| constant IArray.sub' \<rightharpoonup> (SML) "Vector.sub"
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   186
| constant IArray.length' \<rightharpoonup> (SML) "Vector.length"
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   187
68659
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   188
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   189
subsection \<open>Code Generation for Haskell\<close>
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   190
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   191
text \<open>We map @{typ "'a iarray"}s in Isabelle/HOL to @{text Data.Array.IArray.array}
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   192
  in Haskell.  Performance mapping to @{text Data.Array.Unboxed.Array} and
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   193
  @{text Data.Array.Array} is similar.\<close>
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   194
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   195
code_printing
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   196
  code_module "IArray" \<rightharpoonup> (Haskell) \<open>
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   197
  import Prelude (Bool(True, False), not, Maybe(Nothing, Just),
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   198
    Integer, (+), (-), (<), fromInteger, toInteger, map, seq, (.));
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   199
  import qualified Prelude;
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   200
  import qualified Data.Array.IArray;
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   201
  import qualified Data.Array.Base;
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   202
  import qualified Data.Ix;
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   203
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   204
  newtype IArray e = IArray (Data.Array.IArray.Array Integer e);
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   205
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   206
  tabulate :: (Integer, (Integer -> e)) -> IArray e;
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   207
  tabulate (k, f) = IArray (Data.Array.IArray.array (0, k - 1) (map (\i -> let fi = f i in fi `seq` (i, fi)) [0..k - 1]));
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   208
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   209
  of_list :: [e] -> IArray e;
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   210
  of_list l = IArray (Data.Array.IArray.listArray (0, (toInteger . Prelude.length) l - 1) l);
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   211
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   212
  sub :: (IArray e, Integer) -> e;
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   213
  sub (IArray v, i) = v `Data.Array.Base.unsafeAt` fromInteger i;
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   214
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   215
  length :: IArray e -> Integer;
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   216
  length (IArray v) = toInteger (Data.Ix.rangeSize (Data.Array.IArray.bounds v));\<close>
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   217
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   218
code_reserved Haskell IArray_Impl
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   219
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   220
code_printing
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   221
  type_constructor iarray \<rightharpoonup> (Haskell) "IArray.IArray _"
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   222
| constant IArray \<rightharpoonup> (Haskell) "IArray.of'_list"
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   223
| constant IArray.tabulate \<rightharpoonup> (Haskell) "IArray.tabulate"
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   224
| constant IArray.sub' \<rightharpoonup> (Haskell)  "IArray.sub"
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   225
| constant IArray.length' \<rightharpoonup> (Haskell) "IArray.length"
db0c70767d86 setup for Haskell taken over from AFP / Gauss_Jordan
haftmann
parents: 68658
diff changeset
   226
68657
65ad2bfc19d2 restructured for future incorporation of Haskell
haftmann
parents: 68656
diff changeset
   227
end