src/HOL/Boogie/Boogie.thy
author sultana
Tue, 17 Apr 2012 16:14:06 +0100
changeset 47509 6f215c2ebd72
parent 46950 d0181abdbdac
child 48891 c0eafbd55de3
permissions -rw-r--r--
split TPTP_Parser thy -- parser can rely on smaller image, whereas TPTP_Interpret requires HOL;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
33419
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
     1
(*  Title:      HOL/Boogie/Boogie.thy
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
     2
    Author:     Sascha Boehme, TU Muenchen
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
     3
*)
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
     4
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
     5
header {* Integration of the Boogie program verifier *}
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
     6
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
     7
theory Boogie
36899
bcd6fce5bf06 layered SMT setup, adapted SMT clients, added further tests, made Z3 proof abstraction configurable
boehmes
parents: 35105
diff changeset
     8
imports Word
46950
d0181abdbdac declare command keywords via theory header, including strict checking outside Pure;
wenzelm
parents: 45294
diff changeset
     9
keywords
d0181abdbdac declare command keywords via theory header, including strict checking outside Pure;
wenzelm
parents: 45294
diff changeset
    10
  "boogie_open" "boogie_end" :: thy_decl and "boogie_vc" :: thy_goal and "boogie_status" :: diag
33419
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    11
uses
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    12
  ("Tools/boogie_vcs.ML")
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    13
  ("Tools/boogie_loader.ML")
34181
003333ffa543 merged verification condition structure and term representation in one datatype,
boehmes
parents: 34068
diff changeset
    14
  ("Tools/boogie_tactics.ML")
33419
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    15
  ("Tools/boogie_commands.ML")
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    16
begin
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    17
33444
cba964797872 added references to HOL-Boogie papers
boehmes
parents: 33419
diff changeset
    18
text {*
cba964797872 added references to HOL-Boogie papers
boehmes
parents: 33419
diff changeset
    19
HOL-Boogie and its applications are described in:
cba964797872 added references to HOL-Boogie papers
boehmes
parents: 33419
diff changeset
    20
\begin{itemize}
cba964797872 added references to HOL-Boogie papers
boehmes
parents: 33419
diff changeset
    21
cba964797872 added references to HOL-Boogie papers
boehmes
parents: 33419
diff changeset
    22
\item Sascha B"ohme, K. Rustan M. Leino, and Burkhart Wolff.
cba964797872 added references to HOL-Boogie papers
boehmes
parents: 33419
diff changeset
    23
HOL-Boogie --- An Interactive Prover for the Boogie Program-Verifier.
cba964797872 added references to HOL-Boogie papers
boehmes
parents: 33419
diff changeset
    24
Theorem Proving in Higher Order Logics, 2008.
cba964797872 added references to HOL-Boogie papers
boehmes
parents: 33419
diff changeset
    25
cba964797872 added references to HOL-Boogie papers
boehmes
parents: 33419
diff changeset
    26
\item Sascha B"ohme, Micha{\l} Moskal, Wolfram Schulte, and Burkhart Wolff.
cba964797872 added references to HOL-Boogie papers
boehmes
parents: 33419
diff changeset
    27
HOL-Boogie --- An Interactive Prover-Backend for the Verifying C Compiler.
cba964797872 added references to HOL-Boogie papers
boehmes
parents: 33419
diff changeset
    28
Journal of Automated Reasoning, 2009.
cba964797872 added references to HOL-Boogie papers
boehmes
parents: 33419
diff changeset
    29
cba964797872 added references to HOL-Boogie papers
boehmes
parents: 33419
diff changeset
    30
\end{itemize}
cba964797872 added references to HOL-Boogie papers
boehmes
parents: 33419
diff changeset
    31
*}
cba964797872 added references to HOL-Boogie papers
boehmes
parents: 33419
diff changeset
    32
cba964797872 added references to HOL-Boogie papers
boehmes
parents: 33419
diff changeset
    33
34068
a78307d72e58 make assertion labels unique already when loading a verification condition,
boehmes
parents: 33465
diff changeset
    34
33419
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    35
section {* Built-in types and functions of Boogie *}
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    36
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    37
subsection {* Labels *}
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    38
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    39
text {*
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    40
See "Generating error traces from verification-condition counterexamples"
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    41
by Leino e.a. (2004) for a description of Boogie's labelling mechanism and
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    42
semantics.
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    43
*}
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    44
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    45
definition assert_at :: "bool \<Rightarrow> bool \<Rightarrow> bool" where "assert_at l P = P"
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    46
definition block_at :: "bool \<Rightarrow> bool \<Rightarrow> bool" where "block_at l P = P"
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    47
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    48
lemmas labels = assert_at_def block_at_def
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    49
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    50
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    51
subsection {* Integer arithmetics *}
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    52
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    53
text {*
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    54
The operations @{text div} and @{text mod} are built-in in Boogie, but
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    55
without a particular semantics due to different interpretations in
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    56
programming languages. We assume that each application comes with a
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    57
proper axiomatization.
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    58
*}
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    59
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    60
axiomatization
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    61
  boogie_div :: "int \<Rightarrow> int \<Rightarrow> int" (infixl "div'_b" 70) and
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    62
  boogie_mod :: "int \<Rightarrow> int \<Rightarrow> int" (infixl "mod'_b" 70)
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    63
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    64
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    65
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    66
section {* Boogie environment *}
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    67
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    68
text {*
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    69
Proving Boogie-generated verification conditions happens inside
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    70
a Boogie environment:
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    71
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    72
  boogie_open "b2i file without extension"
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    73
  boogie_vc "verification condition 1" ...
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    74
  boogie_vc "verification condition 2" ...
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    75
  boogie_vc "verification condition 3" ...
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    76
  boogie_end
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    77
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    78
See the Boogie examples for more details.
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    79
 
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    80
At most one Boogie environment should occur per theory,
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    81
otherwise unexpected effects may arise.
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    82
*}
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    83
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    84
34068
a78307d72e58 make assertion labels unique already when loading a verification condition,
boehmes
parents: 33465
diff changeset
    85
33419
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    86
section {* Setup *}
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    87
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    88
ML {*
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    89
structure Boogie_Axioms = Named_Thms
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    90
(
45294
3c5d3d286055 tuned Named_Thms: proper binding;
wenzelm
parents: 36899
diff changeset
    91
  val name = @{binding boogie}
33465
boehmes
parents: 33444
diff changeset
    92
  val description =
boehmes
parents: 33444
diff changeset
    93
    "Boogie background axioms loaded along with Boogie verification conditions"
33419
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    94
)
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    95
*}
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    96
setup Boogie_Axioms.setup
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    97
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    98
use "Tools/boogie_vcs.ML"
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
    99
use "Tools/boogie_loader.ML"
34181
003333ffa543 merged verification condition structure and term representation in one datatype,
boehmes
parents: 34068
diff changeset
   100
use "Tools/boogie_tactics.ML"
003333ffa543 merged verification condition structure and term representation in one datatype,
boehmes
parents: 34068
diff changeset
   101
setup Boogie_Tactics.setup
003333ffa543 merged verification condition structure and term representation in one datatype,
boehmes
parents: 34068
diff changeset
   102
33419
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
   103
use "Tools/boogie_commands.ML"
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
   104
setup Boogie_Commands.setup
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
   105
8ae45e87b992 added HOL-Boogie
boehmes
parents:
diff changeset
   106
end