src/HOL/ex/Code_Timing.thy
author wenzelm
Sat, 04 Feb 2017 19:10:12 +0100
changeset 64982 c515464b4652
parent 63165 c12845e8e80a
child 65062 dc746d43f40e
permissions -rw-r--r--
tuned;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
63165
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
     1
(*  Title: HOL/ex/Code_Timing.thy
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
     2
    Author: Florian Haftmann, TU Muenchen, 2016
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
     3
*)
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
     4
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
     5
section \<open>Examples for code generation timing measures\<close>
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
     6
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
     7
theory Code_Timing
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
     8
imports "~~/src/HOL/Number_Theory/Eratosthenes"
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
     9
begin
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    10
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    11
declare [[code_timing]]
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    12
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    13
definition primes_upto :: "nat \<Rightarrow> int list"
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    14
where
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    15
  "primes_upto = map int \<circ> Eratosthenes.primes_upto"
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    16
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    17
definition "required_symbols _ = (primes_upto, 0 :: nat, Suc, 1 :: nat,
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    18
  numeral :: num \<Rightarrow> nat, Num.One, Num.Bit0, Num.Bit1,
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    19
  Code_Evaluation.TERM_OF_EQUAL :: int list itself)"
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    20
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    21
ML \<open>
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    22
local
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    23
  val ctxt = @{context};
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    24
  val consts = [@{const_name required_symbols}];
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    25
in
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    26
  val simp = Code_Simp.static_conv
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    27
    { ctxt = ctxt, consts = consts, simpset = NONE };
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    28
  val nbe = Nbe.static_conv
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    29
    { ctxt = ctxt, consts = consts };
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    30
  val eval = Code_Evaluation.static_conv
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    31
    { ctxt = ctxt, consts = consts };
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    32
end;
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    33
\<close>
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    34
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    35
ML_val \<open>
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    36
  simp @{context} @{cterm "primes_upto 100"}
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    37
\<close>
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    38
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    39
ML_val \<open>
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    40
  simp @{context} @{cterm "primes_upto 200"}
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    41
\<close>
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    42
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    43
ML_val \<open>
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    44
  nbe @{context} @{cterm "primes_upto 200"}
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    45
\<close>
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    46
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    47
ML_val \<open>
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    48
  nbe @{context} @{cterm "primes_upto 400"}
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    49
\<close>
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    50
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    51
ML_val \<open>
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    52
  nbe @{context} @{cterm "primes_upto 600"}
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    53
\<close>
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    54
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    55
ML_val \<open>
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    56
  eval @{context} @{cterm "primes_upto 800"}
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    57
\<close>
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    58
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    59
ML_val \<open>
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    60
  eval @{context} @{cterm "primes_upto 1000"}
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    61
\<close>
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    62
c12845e8e80a examples and documentation for code generator time measurements
haftmann
parents:
diff changeset
    63
end