src/HOL/Tools/Meson/meson_tactic.ML
author blanchet
Wed, 15 Dec 2010 18:10:32 +0100
changeset 41171 043f8dc3b51f
parent 39948 317010af8972
child 42793 88bee9f6eec7
permissions -rw-r--r--
facilitate debugging
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
39948
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
     1
(*  Title:      HOL/Tools/Meson/meson_tactic.ML
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
     2
    Author:     Jia Meng, Cambridge University Computer Laboratory and NICTA
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
     3
    Author:     Jasmin Blanchette, TU Muenchen
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
     4
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
     5
The "meson" proof method for HOL.
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
     6
*)
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
     7
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
     8
signature MESON_TACTIC =
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
     9
sig
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
    10
  val meson_general_tac : Proof.context -> thm list -> int -> tactic
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
    11
  val setup: theory -> theory
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
    12
end;
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
    13
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
    14
structure Meson_Tactic : MESON_TACTIC =
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
    15
struct
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
    16
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
    17
open Meson_Clausify
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
    18
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
    19
fun meson_general_tac ctxt ths =
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
    20
  let val ctxt = Classical.put_claset HOL_cs ctxt in
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
    21
    Meson.meson_tac ctxt (maps (snd o cnf_axiom ctxt false 0) ths)
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
    22
  end
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
    23
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
    24
val setup =
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
    25
  Method.setup @{binding meson} (Attrib.thms >> (fn ths => fn ctxt =>
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
    26
     SIMPLE_METHOD' (CHANGED_PROP o meson_general_tac ctxt ths)))
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
    27
     "MESON resolution proof procedure"
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
    28
317010af8972 factor out "Meson_Tactic" from "Meson_Clausify"
blanchet
parents:
diff changeset
    29
end;