src/HOL/List.thy
author nipkow
Mon, 31 Oct 2005 01:43:22 +0100
changeset 18049 156bba334c12
parent 17956 369e2af8ee45
child 18336 1a2e30b37ed3
permissions -rw-r--r--
A few new lemmas
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
13462
56610e2ba220 sane interface for simprocs;
wenzelm
parents: 13366
diff changeset
     1
(*  Title:      HOL/List.thy
56610e2ba220 sane interface for simprocs;
wenzelm
parents: 13366
diff changeset
     2
    ID:         $Id$
56610e2ba220 sane interface for simprocs;
wenzelm
parents: 13366
diff changeset
     3
    Author:     Tobias Nipkow
923
ff1574a81019 new version of HOL with curried function application
clasohm
parents:
diff changeset
     4
*)
ff1574a81019 new version of HOL with curried function application
clasohm
parents:
diff changeset
     5
13114
f2b00262bdfc converted;
wenzelm
parents: 12887
diff changeset
     6
header {* The datatype of finite lists *}
13122
wenzelm
parents: 13114
diff changeset
     7
15131
c69542757a4d New theory header syntax.
nipkow
parents: 15113
diff changeset
     8
theory List
15140
322485b816ac import -> imports
nipkow
parents: 15131
diff changeset
     9
imports PreList
15131
c69542757a4d New theory header syntax.
nipkow
parents: 15113
diff changeset
    10
begin
923
ff1574a81019 new version of HOL with curried function application
clasohm
parents:
diff changeset
    11
13142
1ebd8ed5a1a0 tuned document;
wenzelm
parents: 13124
diff changeset
    12
datatype 'a list =
13366
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    13
    Nil    ("[]")
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    14
  | Cons 'a  "'a list"    (infixr "#" 65)
923
ff1574a81019 new version of HOL with curried function application
clasohm
parents:
diff changeset
    15
15392
290bc97038c7 First step in reorganizing Finite_Set
nipkow
parents: 15307
diff changeset
    16
subsection{*Basic list processing functions*}
15302
a643fcbc3468 Restructured List and added "rotate"
nipkow
parents: 15281
diff changeset
    17
923
ff1574a81019 new version of HOL with curried function application
clasohm
parents:
diff changeset
    18
consts
13366
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    19
  "@" :: "'a list => 'a list => 'a list"    (infixr 65)
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    20
  filter:: "('a => bool) => 'a list => 'a list"
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    21
  concat:: "'a list list => 'a list"
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    22
  foldl :: "('b => 'a => 'b) => 'b => 'a list => 'b"
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    23
  foldr :: "('a => 'b => 'b) => 'a list => 'b => 'b"
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    24
  hd:: "'a list => 'a"
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    25
  tl:: "'a list => 'a list"
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    26
  last:: "'a list => 'a"
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    27
  butlast :: "'a list => 'a list"
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    28
  set :: "'a list => 'a set"
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    29
  list_all2 :: "('a => 'b => bool) => 'a list => 'b list => bool"
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    30
  map :: "('a=>'b) => ('a list => 'b list)"
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    31
  nth :: "'a list => nat => 'a"    (infixl "!" 100)
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    32
  list_update :: "'a list => nat => 'a => 'a list"
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    33
  take:: "nat => 'a list => 'a list"
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    34
  drop:: "nat => 'a list => 'a list"
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    35
  takeWhile :: "('a => bool) => 'a list => 'a list"
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    36
  dropWhile :: "('a => bool) => 'a list => 'a list"
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    37
  rev :: "'a list => 'a list"
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    38
  zip :: "'a list => 'b list => ('a * 'b) list"
15425
6356d2523f73 [ .. (] -> [ ..< ]
nipkow
parents: 15392
diff changeset
    39
  upt :: "nat => nat => nat list" ("(1[_..</_'])")
13366
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    40
  remdups :: "'a list => 'a list"
15110
78b5636eabc7 Added a number of new thms and the new function remove1
nipkow
parents: 15072
diff changeset
    41
  remove1 :: "'a => 'a list => 'a list"
13366
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    42
  null:: "'a list => bool"
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    43
  "distinct":: "'a list => bool"
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    44
  replicate :: "nat => 'a => 'a list"
15302
a643fcbc3468 Restructured List and added "rotate"
nipkow
parents: 15281
diff changeset
    45
  rotate1 :: "'a list \<Rightarrow> 'a list"
a643fcbc3468 Restructured List and added "rotate"
nipkow
parents: 15281
diff changeset
    46
  rotate :: "nat \<Rightarrow> 'a list \<Rightarrow> 'a list"
a643fcbc3468 Restructured List and added "rotate"
nipkow
parents: 15281
diff changeset
    47
  sublist :: "'a list => nat set => 'a list"
17086
0eb0c9259dd7 added quite a few functions for code generation
nipkow
parents: 16998
diff changeset
    48
(* For efficiency *)
0eb0c9259dd7 added quite a few functions for code generation
nipkow
parents: 16998
diff changeset
    49
  mem :: "'a => 'a list => bool"    (infixl 55)
0eb0c9259dd7 added quite a few functions for code generation
nipkow
parents: 16998
diff changeset
    50
  list_inter :: "'a list \<Rightarrow> 'a list \<Rightarrow> 'a list"
0eb0c9259dd7 added quite a few functions for code generation
nipkow
parents: 16998
diff changeset
    51
  list_ex :: "('a \<Rightarrow> bool) \<Rightarrow> 'a list \<Rightarrow> bool"
0eb0c9259dd7 added quite a few functions for code generation
nipkow
parents: 16998
diff changeset
    52
  list_all:: "('a => bool) => ('a list => bool)"
0eb0c9259dd7 added quite a few functions for code generation
nipkow
parents: 16998
diff changeset
    53
  itrev :: "'a list \<Rightarrow> 'a list \<Rightarrow> 'a list"
0eb0c9259dd7 added quite a few functions for code generation
nipkow
parents: 16998
diff changeset
    54
  filtermap :: "('a \<Rightarrow> 'b option) \<Rightarrow> 'a list \<Rightarrow> 'b list"
0eb0c9259dd7 added quite a few functions for code generation
nipkow
parents: 16998
diff changeset
    55
  map_filter :: "('a => 'b) => ('a => bool) => 'a list => 'b list"
15302
a643fcbc3468 Restructured List and added "rotate"
nipkow
parents: 15281
diff changeset
    56
923
ff1574a81019 new version of HOL with curried function application
clasohm
parents:
diff changeset
    57
13146
f43153b63361 *** empty log message ***
nipkow
parents: 13145
diff changeset
    58
nonterminals lupdbinds lupdbind
5077
71043526295f * HOL/List: new function list_update written xs[i:=v] that updates the i-th
nipkow
parents: 4643
diff changeset
    59
923
ff1574a81019 new version of HOL with curried function application
clasohm
parents:
diff changeset
    60
syntax
13366
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    61
  -- {* list Enumeration *}
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    62
  "@list" :: "args => 'a list"    ("[(_)]")
923
ff1574a81019 new version of HOL with curried function application
clasohm
parents:
diff changeset
    63
13366
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    64
  -- {* Special syntax for filter *}
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    65
  "@filter" :: "[pttrn, 'a list, bool] => 'a list"    ("(1[_:_./ _])")
923
ff1574a81019 new version of HOL with curried function application
clasohm
parents:
diff changeset
    66
13366
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    67
  -- {* list update *}
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    68
  "_lupdbind":: "['a, 'a] => lupdbind"    ("(2_ :=/ _)")
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    69
  "" :: "lupdbind => lupdbinds"    ("_")
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    70
  "_lupdbinds" :: "[lupdbind, lupdbinds] => lupdbinds"    ("_,/ _")
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    71
  "_LUpdate" :: "['a, lupdbinds] => 'a"    ("_/[(_)]" [900,0] 900)
5077
71043526295f * HOL/List: new function list_update written xs[i:=v] that updates the i-th
nipkow
parents: 4643
diff changeset
    72
13366
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    73
  upto:: "nat => nat => nat list"    ("(1[_../_])")
5427
26c9a7c0b36b Arith: less_diff_conv
nipkow
parents: 5425
diff changeset
    74
923
ff1574a81019 new version of HOL with curried function application
clasohm
parents:
diff changeset
    75
translations
13366
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    76
  "[x, xs]" == "x#[xs]"
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    77
  "[x]" == "x#[]"
114b7c14084a moved stuff from Main.thy;
wenzelm
parents: 13187
diff changeset
    78
  "[x:xs . P]"== "filter (%x. P) xs"