CookBook/Recipes/Timing.thy
author Christian Urban <urbanc@in.tum.de>
Mon, 16 Mar 2009 00:12:32 +0100
changeset 178 fb8f22dd8ad0
parent 175 7c09bd3227c5
child 185 043ef82000b4
permissions -rw-r--r--
adapted to latest Attrib.setup changes and more work on the simple induct chapter
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
154
e81ebb37aa83 updated to repository version; added a section about timing
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     1
theory Timing
e81ebb37aa83 updated to repository version; added a section about timing
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     2
imports "../Base"
e81ebb37aa83 updated to repository version; added a section about timing
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     3
begin
e81ebb37aa83 updated to repository version; added a section about timing
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     4
167
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
     5
section {* Measuring Time\label{rec:timing} *} 
154
e81ebb37aa83 updated to repository version; added a section about timing
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     6
e81ebb37aa83 updated to repository version; added a section about timing
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     7
text {*
e81ebb37aa83 updated to repository version; added a section about timing
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     8
 {\bf Problem:}
e81ebb37aa83 updated to repository version; added a section about timing
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     9
  You want to measure the running time of a tactic or function.\smallskip
e81ebb37aa83 updated to repository version; added a section about timing
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    10
e81ebb37aa83 updated to repository version; added a section about timing
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    11
  {\bf Solution:} Time can be measured using the function 
e81ebb37aa83 updated to repository version; added a section about timing
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    12
  @{ML start_timing} and @{ML end_timing}.\smallskip
e81ebb37aa83 updated to repository version; added a section about timing
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    13
168
009ca4807baa polished somewhat the recipes and solutions
Christian Urban <urbanc@in.tum.de>
parents: 167
diff changeset
    14
  Suppose you defined the Ackermann function inside Isabelle. 
154
e81ebb37aa83 updated to repository version; added a section about timing
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    15
*}
e81ebb37aa83 updated to repository version; added a section about timing
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    16
155
Christian Urban <urbanc@in.tum.de>
parents: 154
diff changeset
    17
fun 
168
009ca4807baa polished somewhat the recipes and solutions
Christian Urban <urbanc@in.tum.de>
parents: 167
diff changeset
    18
 ackermann:: "(nat \<times> nat) \<Rightarrow> nat"
155
Christian Urban <urbanc@in.tum.de>
parents: 154
diff changeset
    19
where
Christian Urban <urbanc@in.tum.de>
parents: 154
diff changeset
    20
    "ackermann (0, n) = n + 1"
Christian Urban <urbanc@in.tum.de>
parents: 154
diff changeset
    21
  | "ackermann (m, 0) = ackermann (m - 1, 1)"
Christian Urban <urbanc@in.tum.de>
parents: 154
diff changeset
    22
  | "ackermann (m, n) = ackermann (m - 1, ackermann (m, n - 1))"
Christian Urban <urbanc@in.tum.de>
parents: 154
diff changeset
    23
167
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    24
text {* 
168
009ca4807baa polished somewhat the recipes and solutions
Christian Urban <urbanc@in.tum.de>
parents: 167
diff changeset
    25
  You can measure how long the simplifier takes to verify a datapoint
175
7c09bd3227c5 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 168
diff changeset
    26
  of this function. The timing of a tactic can be done using the following 
7c09bd3227c5 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 168
diff changeset
    27
  wrapper function:
167
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    28
*}
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    29
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    30
ML{*fun timing_wrapper tac st =
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    31
let 
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    32
  val t_start = start_timing ();
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    33
  val res = tac st;
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    34
  val t_end = end_timing t_start;
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    35
in
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    36
  (warning (#message t_end); res)
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    37
end*}
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    38
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    39
text {*
175
7c09bd3227c5 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 168
diff changeset
    40
  Note that this function, in addition to a tactic, also takes a state @{text
7c09bd3227c5 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 168
diff changeset
    41
  "st"} as argument and applies this state to the tactic. The reason is that
7c09bd3227c5 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 168
diff changeset
    42
  tactics are lazy functions and you need to force them to run, otherwise the
7c09bd3227c5 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 168
diff changeset
    43
  timing will be meaningless.  The time between start and finish of the tactic
7c09bd3227c5 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 168
diff changeset
    44
  will be calculated as the end time minus the start time.  An example of the
7c09bd3227c5 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 168
diff changeset
    45
  wrapper is the proof
7c09bd3227c5 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 168
diff changeset
    46
168
009ca4807baa polished somewhat the recipes and solutions
Christian Urban <urbanc@in.tum.de>
parents: 167
diff changeset
    47
167
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    48
*}
154
e81ebb37aa83 updated to repository version; added a section about timing
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    49
155
Christian Urban <urbanc@in.tum.de>
parents: 154
diff changeset
    50
lemma "ackermann (3, 4) = 125"
Christian Urban <urbanc@in.tum.de>
parents: 154
diff changeset
    51
apply(tactic {* 
167
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    52
  timing_wrapper (simp_tac (@{simpset} addsimps @{thms "nat_number"}) 1) *})
155
Christian Urban <urbanc@in.tum.de>
parents: 154
diff changeset
    53
done
154
e81ebb37aa83 updated to repository version; added a section about timing
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    54
167
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    55
text {*
168
009ca4807baa polished somewhat the recipes and solutions
Christian Urban <urbanc@in.tum.de>
parents: 167
diff changeset
    56
  where it returns something on the scale of 3 seconds. We choose to return
009ca4807baa polished somewhat the recipes and solutions
Christian Urban <urbanc@in.tum.de>
parents: 167
diff changeset
    57
  this information as a string, but the timing information is also accessible
009ca4807baa polished somewhat the recipes and solutions
Christian Urban <urbanc@in.tum.de>
parents: 167
diff changeset
    58
  in number format.
167
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    59
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    60
  \begin{readmore}
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    61
  Basic functions regarding timing are defined in @{ML_file 
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    62
  "Pure/ML-Systems/polyml_common.ML"} (for the PolyML compiler). Some more
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    63
  advanced functions are defined in @{ML_file "Pure/General/output.ML"}.
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    64
  \end{readmore}
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    65
*}
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    66
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    67
3e30ea95c7aa added temporarily some timing test about conversions and simprocs
Christian Urban <urbanc@in.tum.de>
parents: 157
diff changeset
    68
154
e81ebb37aa83 updated to repository version; added a section about timing
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    69
end