src/HOL/Metis.thy
author blanchet
Thu, 16 Dec 2010 15:12:17 +0100
changeset 41208 1b28c43a7074
parent 41140 9c68004b8c9d
child 42349 721e85fd2db3
permissions -rw-r--r--
make "debug" imply "blocking", since in blocking mode the exceptions flow through and are more instructive
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
39946
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
     1
(*  Title:      HOL/Metis.thy
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
     2
    Author:     Lawrence C. Paulson, Cambridge University Computer Laboratory
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
     3
    Author:     Jia Meng, Cambridge University Computer Laboratory and NICTA
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
     4
    Author:     Jasmin Blanchette, TU Muenchen
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
     5
*)
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
     6
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
     7
header {* Metis Proof Method *}
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
     8
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
     9
theory Metis
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
    10
imports Meson
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
    11
uses "~~/src/Tools/Metis/metis.ML"
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
    12
     ("Tools/Metis/metis_translate.ML")
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
    13
     ("Tools/Metis/metis_reconstruct.ML")
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
    14
     ("Tools/Metis/metis_tactics.ML")
41042
8275f52ac991 load "try" after "Metis" and move "Async_Manager" back to Sledgehammer
blanchet
parents: 39980
diff changeset
    15
     ("Tools/try.ML")
39946
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
    16
begin
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
    17
41140
9c68004b8c9d added Sledgehammer support for higher-order propositional reasoning
blanchet
parents: 41042
diff changeset
    18
definition fFalse :: bool where [no_atp]:
9c68004b8c9d added Sledgehammer support for higher-order propositional reasoning
blanchet
parents: 41042
diff changeset
    19
"fFalse \<longleftrightarrow> False"
39946
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
    20
41140
9c68004b8c9d added Sledgehammer support for higher-order propositional reasoning
blanchet
parents: 41042
diff changeset
    21
definition fTrue :: bool where [no_atp]:
9c68004b8c9d added Sledgehammer support for higher-order propositional reasoning
blanchet
parents: 41042
diff changeset
    22
"fTrue \<longleftrightarrow> True"
9c68004b8c9d added Sledgehammer support for higher-order propositional reasoning
blanchet
parents: 41042
diff changeset
    23
9c68004b8c9d added Sledgehammer support for higher-order propositional reasoning
blanchet
parents: 41042
diff changeset
    24
definition fNot :: "bool \<Rightarrow> bool" where [no_atp]:
9c68004b8c9d added Sledgehammer support for higher-order propositional reasoning
blanchet
parents: 41042
diff changeset
    25
"fNot P \<longleftrightarrow> \<not> P"
39946
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
    26
41140
9c68004b8c9d added Sledgehammer support for higher-order propositional reasoning
blanchet
parents: 41042
diff changeset
    27
definition fconj :: "bool \<Rightarrow> bool \<Rightarrow> bool" where [no_atp]:
9c68004b8c9d added Sledgehammer support for higher-order propositional reasoning
blanchet
parents: 41042
diff changeset
    28
"fconj P Q \<longleftrightarrow> P \<and> Q"
9c68004b8c9d added Sledgehammer support for higher-order propositional reasoning
blanchet
parents: 41042
diff changeset
    29
9c68004b8c9d added Sledgehammer support for higher-order propositional reasoning
blanchet
parents: 41042
diff changeset
    30
definition fdisj :: "bool \<Rightarrow> bool \<Rightarrow> bool" where [no_atp]:
9c68004b8c9d added Sledgehammer support for higher-order propositional reasoning
blanchet
parents: 41042
diff changeset
    31
"fdisj P Q \<longleftrightarrow> P \<or> Q"
39946
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
    32
41140
9c68004b8c9d added Sledgehammer support for higher-order propositional reasoning
blanchet
parents: 41042
diff changeset
    33
definition fimplies :: "bool \<Rightarrow> bool \<Rightarrow> bool" where [no_atp]:
9c68004b8c9d added Sledgehammer support for higher-order propositional reasoning
blanchet
parents: 41042
diff changeset
    34
"fimplies P Q \<longleftrightarrow> (P \<longrightarrow> Q)"
9c68004b8c9d added Sledgehammer support for higher-order propositional reasoning
blanchet
parents: 41042
diff changeset
    35
9c68004b8c9d added Sledgehammer support for higher-order propositional reasoning
blanchet
parents: 41042
diff changeset
    36
definition fequal :: "'a \<Rightarrow> 'a \<Rightarrow> bool" where [no_atp]:
9c68004b8c9d added Sledgehammer support for higher-order propositional reasoning
blanchet
parents: 41042
diff changeset
    37
"fequal x y \<longleftrightarrow> (x = y)"
39946
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
    38
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
    39
use "Tools/Metis/metis_translate.ML"
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
    40
use "Tools/Metis/metis_reconstruct.ML"
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
    41
use "Tools/Metis/metis_tactics.ML"
39980
f175e482dabe "setup" in theory
blanchet
parents: 39955
diff changeset
    42
f175e482dabe "setup" in theory
blanchet
parents: 39955
diff changeset
    43
setup {*
f175e482dabe "setup" in theory
blanchet
parents: 39955
diff changeset
    44
  Metis_Reconstruct.setup
f175e482dabe "setup" in theory
blanchet
parents: 39955
diff changeset
    45
  #> Metis_Tactics.setup
f175e482dabe "setup" in theory
blanchet
parents: 39955
diff changeset
    46
*}
39946
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
    47
41140
9c68004b8c9d added Sledgehammer support for higher-order propositional reasoning
blanchet
parents: 41042
diff changeset
    48
hide_const (open) fFalse fTrue fNot fconj fdisj fimplies fequal
9c68004b8c9d added Sledgehammer support for higher-order propositional reasoning
blanchet
parents: 41042
diff changeset
    49
hide_fact (open) fFalse_def fTrue_def fNot_def fconj_def fdisj_def fimplies_def
9c68004b8c9d added Sledgehammer support for higher-order propositional reasoning
blanchet
parents: 41042
diff changeset
    50
                 fequal_def
39953
aa54f347e5e2 hide uninteresting MESON/Metis constants and facts and remove "meson_" prefix to (now hidden) fact names
blanchet
parents: 39947
diff changeset
    51
41042
8275f52ac991 load "try" after "Metis" and move "Async_Manager" back to Sledgehammer
blanchet
parents: 39980
diff changeset
    52
subsection {* Try *}
8275f52ac991 load "try" after "Metis" and move "Async_Manager" back to Sledgehammer
blanchet
parents: 39980
diff changeset
    53
8275f52ac991 load "try" after "Metis" and move "Async_Manager" back to Sledgehammer
blanchet
parents: 39980
diff changeset
    54
use "Tools/try.ML"
8275f52ac991 load "try" after "Metis" and move "Async_Manager" back to Sledgehammer
blanchet
parents: 39980
diff changeset
    55
8275f52ac991 load "try" after "Metis" and move "Async_Manager" back to Sledgehammer
blanchet
parents: 39980
diff changeset
    56
setup {* Try.setup *}
8275f52ac991 load "try" after "Metis" and move "Async_Manager" back to Sledgehammer
blanchet
parents: 39980
diff changeset
    57
39946
78faa9b31202 move Metis into Plain
blanchet
parents:
diff changeset
    58
end