src/HOL/Tools/Sledgehammer/sledgehammer_isar_minimize.ML
author blanchet
Mon, 03 Feb 2014 10:14:18 +0100
changeset 55264 43473497fb65
parent 55263 4d63fffcde8d
child 55265 bd9f033b9896
permissions -rw-r--r--
centralize preplaying
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
55202
824c48a539c9 renamed many Sledgehammer ML files to clarify structure
blanchet
parents: 54828
diff changeset
     1
(*  Title:      HOL/Tools/Sledgehammer/sledgehammer_isar_minimize.ML
54712
cbebe2cf77f1 more work on Z3 Isar proofs
blanchet
parents: 54700
diff changeset
     2
    Author:     Steffen Juilf Smolka, TU Muenchen
52611
831f7479c74f minimize dependencies (used facts) of Isar proof steps; remove unreferenced steps
smolkas
parents:
diff changeset
     3
    Author:     Jasmin Blanchette, TU Muenchen
831f7479c74f minimize dependencies (used facts) of Isar proof steps; remove unreferenced steps
smolkas
parents:
diff changeset
     4
831f7479c74f minimize dependencies (used facts) of Isar proof steps; remove unreferenced steps
smolkas
parents:
diff changeset
     5
Minimize dependencies (used facts) of Isar proof steps.
831f7479c74f minimize dependencies (used facts) of Isar proof steps; remove unreferenced steps
smolkas
parents:
diff changeset
     6
*)
831f7479c74f minimize dependencies (used facts) of Isar proof steps; remove unreferenced steps
smolkas
parents:
diff changeset
     7
55202
824c48a539c9 renamed many Sledgehammer ML files to clarify structure
blanchet
parents: 54828
diff changeset
     8
signature SLEDGEHAMMER_ISAR_MINIMIZE =
52611
831f7479c74f minimize dependencies (used facts) of Isar proof steps; remove unreferenced steps
smolkas
parents:
diff changeset
     9
sig
55202
824c48a539c9 renamed many Sledgehammer ML files to clarify structure
blanchet
parents: 54828
diff changeset
    10
  type isar_step = Sledgehammer_Isar_Proof.isar_step
824c48a539c9 renamed many Sledgehammer ML files to clarify structure
blanchet
parents: 54828
diff changeset
    11
  type isar_proof = Sledgehammer_Isar_Proof.isar_proof
55213
dcb36a2540bc tuned ML function names
blanchet
parents: 55212
diff changeset
    12
  type isar_preplay_data = Sledgehammer_Isar_Preplay.isar_preplay_data
54712
cbebe2cf77f1 more work on Z3 Isar proofs
blanchet
parents: 54700
diff changeset
    13
55260
ada3ae6458d4 more data structure rationalization
blanchet
parents: 55259
diff changeset
    14
  val minimize_isar_step_dependencies : Proof.context -> isar_preplay_data Unsynchronized.ref ->
ada3ae6458d4 more data structure rationalization
blanchet
parents: 55259
diff changeset
    15
    isar_step -> isar_step
55213
dcb36a2540bc tuned ML function names
blanchet
parents: 55212
diff changeset
    16
  val postprocess_isar_proof_remove_unreferenced_steps : (isar_step -> isar_step) -> isar_proof ->
dcb36a2540bc tuned ML function names
blanchet
parents: 55212
diff changeset
    17
    isar_proof
54504
blanchet
parents: 53764
diff changeset
    18
end;
52611
831f7479c74f minimize dependencies (used facts) of Isar proof steps; remove unreferenced steps
smolkas
parents:
diff changeset
    19
55202
824c48a539c9 renamed many Sledgehammer ML files to clarify structure
blanchet
parents: 54828
diff changeset
    20
structure Sledgehammer_Isar_Minimize : SLEDGEHAMMER_ISAR_MINIMIZE =
52611
831f7479c74f minimize dependencies (used facts) of Isar proof steps; remove unreferenced steps
smolkas
parents:
diff changeset
    21
struct
831f7479c74f minimize dependencies (used facts) of Isar proof steps; remove unreferenced steps
smolkas
parents:
diff changeset
    22
54828
b2271ad695db don't do 'isar_try0' if preplaying is off
blanchet
parents: 54827
diff changeset
    23
open Sledgehammer_Reconstructor
55202
824c48a539c9 renamed many Sledgehammer ML files to clarify structure
blanchet
parents: 54828
diff changeset
    24
open Sledgehammer_Isar_Proof
824c48a539c9 renamed many Sledgehammer ML files to clarify structure
blanchet
parents: 54828
diff changeset
    25
open Sledgehammer_Isar_Preplay
52611
831f7479c74f minimize dependencies (used facts) of Isar proof steps; remove unreferenced steps
smolkas
parents:
diff changeset
    26
54712
cbebe2cf77f1 more work on Z3 Isar proofs
blanchet
parents: 54700
diff changeset
    27
val slack = seconds 0.1
52611
831f7479c74f minimize dependencies (used facts) of Isar proof steps; remove unreferenced steps
smolkas
parents:
diff changeset
    28
55260
ada3ae6458d4 more data structure rationalization
blanchet
parents: 55259
diff changeset
    29
fun minimize_isar_step_dependencies _ _ (step as Let _) = step
ada3ae6458d4 more data structure rationalization
blanchet
parents: 55259
diff changeset
    30
  | minimize_isar_step_dependencies ctxt preplay_data
55244
12e1a5d8ee48 simplified data structure -- eliminated distinction between 'first-class' and 'second-class' proof methods
blanchet
parents: 55243
diff changeset
    31
      (step as Prove (qs, xs, l, t, subproofs, ((lfs, gfs), meths as meth :: _))) =
55260
ada3ae6458d4 more data structure rationalization
blanchet
parents: 55259
diff changeset
    32
    (case Lazy.force (preplay_outcome_of_isar_step (!preplay_data) l meth) of
54828
b2271ad695db don't do 'isar_try0' if preplaying is off
blanchet
parents: 54827
diff changeset
    33
      Played time =>
54712
cbebe2cf77f1 more work on Z3 Isar proofs
blanchet
parents: 54700
diff changeset
    34
      let
55244
12e1a5d8ee48 simplified data structure -- eliminated distinction between 'first-class' and 'second-class' proof methods
blanchet
parents: 55243
diff changeset
    35
        fun mk_step_lfs_gfs lfs gfs = Prove (qs, xs, l, t, subproofs, ((lfs, gfs), meths))
52611
831f7479c74f minimize dependencies (used facts) of Isar proof steps; remove unreferenced steps
smolkas
parents:
diff changeset
    36
54712
cbebe2cf77f1 more work on Z3 Isar proofs
blanchet
parents: 54700
diff changeset
    37
        fun minimize_facts _ time min_facts [] = (time, min_facts)
cbebe2cf77f1 more work on Z3 Isar proofs
blanchet
parents: 54700
diff changeset
    38
          | minimize_facts mk_step time min_facts (f :: facts) =
55258
8cc42c1f9bb5 more data structure rationalization
blanchet
parents: 55255
diff changeset
    39
            (case preplay_isar_step ctxt (Time.+ (time, slack)) meth
8cc42c1f9bb5 more data structure rationalization
blanchet
parents: 55255
diff changeset
    40
                (mk_step (min_facts @ facts)) of
54828
b2271ad695db don't do 'isar_try0' if preplaying is off
blanchet
parents: 54827
diff changeset
    41
              Played time => minimize_facts mk_step time min_facts facts
54827
14e2c7616209 more data structure refactoring
blanchet
parents: 54826
diff changeset
    42
            | _ => minimize_facts mk_step time (f :: min_facts) facts)
52611
831f7479c74f minimize dependencies (used facts) of Isar proof steps; remove unreferenced steps
smolkas
parents:
diff changeset
    43
55263
blanchet
parents: 55260
diff changeset
    44
        val (time, min_lfs) = minimize_facts (fn lfs => mk_step_lfs_gfs lfs gfs) time [] lfs
54712
cbebe2cf77f1 more work on Z3 Isar proofs
blanchet
parents: 54700
diff changeset
    45
        val (time, min_gfs) = minimize_facts (mk_step_lfs_gfs min_lfs) time [] gfs
55264
43473497fb65 centralize preplaying
blanchet
parents: 55263
diff changeset
    46
43473497fb65 centralize preplaying
blanchet
parents: 55263
diff changeset
    47
        val step' = mk_step_lfs_gfs min_lfs min_gfs
54712
cbebe2cf77f1 more work on Z3 Isar proofs
blanchet
parents: 54700
diff changeset
    48
      in
55264
43473497fb65 centralize preplaying
blanchet
parents: 55263
diff changeset
    49
        set_preplay_outcomes_of_isar_step ctxt time preplay_data step'
43473497fb65 centralize preplaying
blanchet
parents: 55263
diff changeset
    50
          [(meth, Lazy.value (Played time))];
43473497fb65 centralize preplaying
blanchet
parents: 55263
diff changeset
    51
        step'
54826
79745ba60a5a data structure rationalization
blanchet
parents: 54813
diff changeset
    52
      end
79745ba60a5a data structure rationalization
blanchet
parents: 54813
diff changeset
    53
    | _ => step (* don't touch steps that time out or fail *))
52611
831f7479c74f minimize dependencies (used facts) of Isar proof steps; remove unreferenced steps
smolkas
parents:
diff changeset
    54
55213
dcb36a2540bc tuned ML function names
blanchet
parents: 55212
diff changeset
    55
fun postprocess_isar_proof_remove_unreferenced_steps postproc_step =
52611
831f7479c74f minimize dependencies (used facts) of Isar proof steps; remove unreferenced steps
smolkas
parents:
diff changeset
    56
  let
55259
blanchet
parents: 55258
diff changeset
    57
    fun process_proof (Proof (fix, assms, steps)) =
blanchet
parents: 55258
diff changeset
    58
      let val (refed, steps) = process_steps steps in
52611
831f7479c74f minimize dependencies (used facts) of Isar proof steps; remove unreferenced steps
smolkas
parents:
diff changeset
    59
        (refed, Proof (fix, assms, steps))
831f7479c74f minimize dependencies (used facts) of Isar proof steps; remove unreferenced steps
smolkas
parents:
diff changeset
    60
      end
55259
blanchet
parents: 55258
diff changeset
    61
    and process_steps [] = ([], [])
blanchet
parents: 55258
diff changeset
    62
      | process_steps steps =
55212
blanchet
parents: 55202
diff changeset
    63
        (* the last step is always implicitly referenced *)
55259
blanchet
parents: 55258
diff changeset
    64
        let val (steps, (refed, concl)) = split_last steps ||> process_referenced_step in
blanchet
parents: 55258
diff changeset
    65
          fold_rev process_step steps (refed, [concl])
54754
6b0ca7f79e93 robustness in degenerate case + tuning
blanchet
parents: 54712
diff changeset
    66
        end
55259
blanchet
parents: 55258
diff changeset
    67
    and process_step step (refed, accu) =
55223
3c593bad6b31 generalized preplaying infrastructure to store various results for various methods
blanchet
parents: 55221
diff changeset
    68
      (case label_of_isar_step step of
52611
831f7479c74f minimize dependencies (used facts) of Isar proof steps; remove unreferenced steps
smolkas
parents:
diff changeset
    69
        NONE => (refed, step :: accu)
831f7479c74f minimize dependencies (used facts) of Isar proof steps; remove unreferenced steps
smolkas
parents:
diff changeset
    70
      | SOME l =>
54813
blanchet
parents: 54754
diff changeset
    71
        if Ord_List.member label_ord refed l then
55259
blanchet
parents: 55258
diff changeset
    72
          process_referenced_step step
54813
blanchet
parents: 54754
diff changeset
    73
          |>> Ord_List.union label_ord refed
blanchet
parents: 54754
diff changeset
    74
          ||> (fn x => x :: accu)
blanchet
parents: 54754
diff changeset
    75
        else
blanchet
parents: 54754
diff changeset
    76
          (refed, accu))
55259
blanchet
parents: 55258
diff changeset
    77
    and process_referenced_step step = step |> postproc_step |> process_referenced_step_subproofs
blanchet
parents: 55258
diff changeset
    78
    and process_referenced_step_subproofs (Prove (qs, xs, l, t, subproofs, ((lfs, gfs), m))) =
blanchet
parents: 55258
diff changeset
    79
      let
blanchet
parents: 55258
diff changeset
    80
        val (refed, subproofs) =
blanchet
parents: 55258
diff changeset
    81
          map process_proof subproofs
blanchet
parents: 55258
diff changeset
    82
          |> split_list
blanchet
parents: 55258
diff changeset
    83
          |>> Ord_List.unions label_ord
blanchet
parents: 55258
diff changeset
    84
          |>> fold (Ord_List.insert label_ord) lfs
blanchet
parents: 55258
diff changeset
    85
        val step = Prove (qs, xs, l, t, subproofs, ((lfs, gfs), m))
blanchet
parents: 55258
diff changeset
    86
      in
blanchet
parents: 55258
diff changeset
    87
        (refed, step)
blanchet
parents: 55258
diff changeset
    88
      end
52611
831f7479c74f minimize dependencies (used facts) of Isar proof steps; remove unreferenced steps
smolkas
parents:
diff changeset
    89
  in
55259
blanchet
parents: 55258
diff changeset
    90
    snd o process_proof
52611
831f7479c74f minimize dependencies (used facts) of Isar proof steps; remove unreferenced steps
smolkas
parents:
diff changeset
    91
  end
831f7479c74f minimize dependencies (used facts) of Isar proof steps; remove unreferenced steps
smolkas
parents:
diff changeset
    92
54504
blanchet
parents: 53764
diff changeset
    93
end;