src/HOL/SPARK/Manual/Reference.thy
author wenzelm
Sun, 14 Mar 2021 22:55:52 +0100
changeset 73439 cb127ce2c092
parent 72514 d8661799afb2
child 74097 6d7be1227d02
permissions -rw-r--r--
tuned --- following hints by IntelliJ;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
     1
(*<*)
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
     2
theory Reference
72514
d8661799afb2 removed dependency
haftmann
parents: 72488
diff changeset
     3
imports "HOL-SPARK.SPARK"
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
     4
begin
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
     5
72514
d8661799afb2 removed dependency
haftmann
parents: 72488
diff changeset
     6
lemma AND_mod: "x AND (2 ^ n - 1) = x mod 2 ^ n" for x :: int
d8661799afb2 removed dependency
haftmann
parents: 72488
diff changeset
     7
  by (simp flip: mask_eq_exp_minus_1 take_bit_eq_mask take_bit_eq_mod)
d8661799afb2 removed dependency
haftmann
parents: 72488
diff changeset
     8
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
     9
syntax (my_constrain output)
61143
5f898411ce87 eliminated \<Colon> from syntax of constraints;
wenzelm
parents: 59938
diff changeset
    10
  "_constrain" :: "logic => type => logic" ("_ :: _" [4, 0] 3)
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    11
(*>*)
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    12
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
    13
chapter \<open>HOL-\SPARK{} Reference\<close>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    14
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
    15
text \<open>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    16
\label{sec:spark-reference}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    17
This section is intended as a quick reference for the HOL-\SPARK{} verification
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    18
environment. In \secref{sec:spark-commands}, we give a summary of the commands
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    19
provided by the HOL-\SPARK{}, while \secref{sec:spark-types} contains a description
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    20
of how particular types of \SPARK{} and FDL are modelled in Isabelle.
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
    21
\<close>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    22
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
    23
section \<open>Commands\<close>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    24
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
    25
text \<open>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    26
\label{sec:spark-commands}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    27
This section describes the syntax and effect of each of the commands provided
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    28
by HOL-\SPARK{}.
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 66992
diff changeset
    29
\<^rail>\<open>
59938
wenzelm
parents: 58130
diff changeset
    30
  @'spark_open' name ('(' name ')')?
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 66992
diff changeset
    31
\<close>
56798
939e88e79724 Discontinued old spark_open; spark_open_siv is now spark_open
berghofe
parents: 48168
diff changeset
    32
Opens a new \SPARK{} verification environment and loads a \texttt{*.siv} file with VCs.
939e88e79724 Discontinued old spark_open; spark_open_siv is now spark_open
berghofe
parents: 48168
diff changeset
    33
Alternatively, \texttt{*.vcg} files can be loaded using \isa{\isacommand{spark\_open\_vcg}}.
939e88e79724 Discontinued old spark_open; spark_open_siv is now spark_open
berghofe
parents: 48168
diff changeset
    34
The corresponding \texttt{*.fdl} and \texttt{*.rls}
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    35
files must reside in the same directory as the file given as an argument to the command.
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    36
This command also generates records and datatypes for the types specified in the
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    37
\texttt{*.fdl} file, unless they have already been associated with user-defined
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    38
Isabelle types (see below).
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    39
Since the full package name currently cannot be determined from the files generated by the
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    40
\SPARK{} Examiner, the command also allows to specify an optional package prefix in the
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    41
format \texttt{$p_1$\_\_$\ldots$\_\_$p_n$}. When working with projects consisting of several
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    42
packages, this is necessary in order for the verification environment to be able to map proof
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    43
functions and types defined in Isabelle to their \SPARK{} counterparts.
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 66992
diff changeset
    44
\<^rail>\<open>
59938
wenzelm
parents: 58130
diff changeset
    45
  @'spark_proof_functions' ((name '=' term)+)
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 66992
diff changeset
    46
\<close>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    47
Associates a proof function with the given name to a term. The name should be the full name
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    48
of the proof function as it appears in the \texttt{*.fdl} file, including the package prefix.
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    49
This command can be used both inside and outside a verification environment. The latter
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    50
variant is useful for introducing proof functions that are shared by several procedures
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    51
or packages, whereas the former allows the given term to refer to the types generated
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    52
by \isa{\isacommand{spark\_open}} for record or enumeration types specified in the
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    53
\texttt{*.fdl} file.
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 66992
diff changeset
    54
\<^rail>\<open>
59938
wenzelm
parents: 58130
diff changeset
    55
  @'spark_types' ((name '=' type (mapping?))+)
wenzelm
parents: 58130
diff changeset
    56
  ;
62969
9f394a16c557 eliminated "xname" and variants;
wenzelm
parents: 61143
diff changeset
    57
  mapping: '('((name '=' name)+',')')'
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 66992
diff changeset
    58
\<close>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    59
Associates a \SPARK{} type with the given name with an Isabelle type. This command can
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    60
only be used outside a verification environment. The given type must be either a record
46725
d34ec0512dfb Added infrastructure for mapping SPARK field / constructor names
berghofe
parents: 45044
diff changeset
    61
or a datatype, where the names of fields or constructors must either match those of the
d34ec0512dfb Added infrastructure for mapping SPARK field / constructor names
berghofe
parents: 45044
diff changeset
    62
corresponding \SPARK{} types (modulo casing), or a mapping from \SPARK{} to Isabelle
d34ec0512dfb Added infrastructure for mapping SPARK field / constructor names
berghofe
parents: 45044
diff changeset
    63
names has to be provided.
d34ec0512dfb Added infrastructure for mapping SPARK field / constructor names
berghofe
parents: 45044
diff changeset
    64
This command is useful when having to define
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    65
proof functions referring to record or enumeration types that are shared by several
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    66
procedures or packages. First, the types required by the proof functions can be introduced
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    67
using Isabelle's commands for defining records or datatypes. Having introduced the
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    68
types, the proof functions can be defined in Isabelle. Finally, both the proof
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    69
functions and the types can be associated with their \SPARK{} counterparts.
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 66992
diff changeset
    70
\<^rail>\<open>
59938
wenzelm
parents: 58130
diff changeset
    71
  @'spark_status' (('(proved)' | '(unproved)')?)
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 66992
diff changeset
    72
\<close>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    73
Outputs the variables declared in the \texttt{*.fdl} file, the rules declared in
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    74
the \texttt{*.rls} file, and all VCs, together with their status (proved, unproved).
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    75
The output can be restricted to the proved or unproved VCs by giving the corresponding
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    76
option to the command.
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 66992
diff changeset
    77
\<^rail>\<open>
59938
wenzelm
parents: 58130
diff changeset
    78
  @'spark_vc' name
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 66992
diff changeset
    79
\<close>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    80
Initiates the proof of the VC with the given name. Similar to the standard
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    81
\isa{\isacommand{lemma}} or \isa{\isacommand{theorem}} commands, this command
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    82
must be followed by a sequence of proof commands. The command introduces the
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    83
hypotheses \texttt{H1} \dots \texttt{H$n$}, as well as the identifiers
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    84
\texttt{?C1} \dots \texttt{?C$m$} corresponding to the conclusions of the VC.
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 66992
diff changeset
    85
\<^rail>\<open>
59938
wenzelm
parents: 58130
diff changeset
    86
  @'spark_end' '(incomplete)'?
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 66992
diff changeset
    87
\<close>
48168
e825bbf49363 Documented "incomplete" option of spark_end
berghofe
parents: 46725
diff changeset
    88
Closes the current verification environment. Unless the \texttt{incomplete}
e825bbf49363 Documented "incomplete" option of spark_end
berghofe
parents: 46725
diff changeset
    89
option is given, all VCs must have been proved,
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    90
otherwise the command issues an error message. As a side effect, the command
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    91
generates a proof review (\texttt{*.prv}) file to inform POGS of the proved
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    92
VCs.
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
    93
\<close>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    94
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
    95
section \<open>Types\<close>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    96
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
    97
text \<open>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    98
\label{sec:spark-types}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
    99
The main types of FDL are integers, enumeration types, records, and arrays.
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   100
In the following sections, we describe how these types are modelled in
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   101
Isabelle.
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   102
\<close>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   103
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   104
subsection \<open>Integers\<close>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   105
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   106
text \<open>
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 66992
diff changeset
   107
The FDL type \texttt{integer} is modelled by the Isabelle type \<^typ>\<open>int\<close>.
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   108
While the FDL \texttt{mod} operator behaves in the same way as its Isabelle
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   109
counterpart, this is not the case for the \texttt{div} operator. As has already
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   110
been mentioned in \secref{sec:proving-vcs}, the \texttt{div} operator of \SPARK{}
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   111
always truncates towards zero, whereas the \<open>div\<close> operator of Isabelle
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   112
truncates towards minus infinity. Therefore, the FDL \texttt{div} operator is
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   113
mapped to the \<open>sdiv\<close> operator in Isabelle. The characteristic theorems
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   114
of \<open>sdiv\<close>, in particular those describing the relationship with the standard
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   115
\<open>div\<close> operator, are shown in \figref{fig:sdiv-properties}
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   116
\begin{figure}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   117
\begin{center}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   118
\small
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   119
\begin{tabular}{ll}
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   120
\<open>sdiv_def\<close>: & @{thm sdiv_def} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   121
\<open>sdiv_minus_dividend\<close>: & @{thm sdiv_minus_dividend} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   122
\<open>sdiv_minus_divisor\<close>: & @{thm sdiv_minus_divisor} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   123
\<open>sdiv_pos_pos\<close>: & @{thm [mode=no_brackets] sdiv_pos_pos} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   124
\<open>sdiv_pos_neg\<close>: & @{thm [mode=no_brackets] sdiv_pos_neg} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   125
\<open>sdiv_neg_pos\<close>: & @{thm [mode=no_brackets] sdiv_neg_pos} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   126
\<open>sdiv_neg_neg\<close>: & @{thm [mode=no_brackets] sdiv_neg_neg} \\
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   127
\end{tabular}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   128
\end{center}
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   129
\caption{Characteristic properties of \<open>sdiv\<close>}
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   130
\label{fig:sdiv-properties}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   131
\end{figure}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   132
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   133
\begin{figure}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   134
\begin{center}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   135
\small
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   136
\begin{tabular}{ll}
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   137
\<open>AND_lower\<close>: & @{thm [mode=no_brackets] AND_lower} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   138
\<open>OR_lower\<close>: & @{thm [mode=no_brackets] OR_lower} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   139
\<open>XOR_lower\<close>: & @{thm [mode=no_brackets] XOR_lower} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   140
\<open>AND_upper1\<close>: & @{thm [mode=no_brackets] AND_upper1} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   141
\<open>AND_upper2\<close>: & @{thm [mode=no_brackets] AND_upper2} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   142
\<open>OR_upper\<close>: & @{thm [mode=no_brackets] OR_upper} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   143
\<open>XOR_upper\<close>: & @{thm [mode=no_brackets] XOR_upper} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   144
\<open>AND_mod\<close>: & @{thm [mode=no_brackets] AND_mod}
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   145
\end{tabular}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   146
\end{center}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   147
\caption{Characteristic properties of bitwise operators}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   148
\label{fig:bitwise}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   149
\end{figure}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   150
The bitwise logical operators of \SPARK{} and FDL are modelled by the operators
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   151
\<open>AND\<close>, \<open>OR\<close> and \<open>XOR\<close> from Isabelle's \<open>Word\<close> library,
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 66992
diff changeset
   152
all of which have type \<^typ>\<open>int \<Rightarrow> int \<Rightarrow> int\<close>. A list of properties of these
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   153
operators that are useful in proofs about \SPARK{} programs are shown in
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   154
\figref{fig:bitwise}
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   155
\<close>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   156
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   157
subsection \<open>Enumeration types\<close>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   158
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   159
text \<open>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   160
The FDL enumeration type
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   161
\begin{alltt}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   162
type \(t\) = (\(e\sb{1}\), \(e\sb{2}\), \dots, \(e\sb{n}\));
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   163
\end{alltt}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   164
is modelled by the Isabelle datatype
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   165
\begin{isabelle}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   166
\normalsize
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   167
\isacommand{datatype}\ $t$\ =\ $e_1$\ $\mid$\ $e_2$\ $\mid$\ \dots\ $\mid$\ $e_n$
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   168
\end{isabelle}
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 66992
diff changeset
   169
The HOL-\SPARK{} environment defines a type class \<^class>\<open>spark_enum\<close> that captures
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   170
the characteristic properties of all enumeration types. It provides the following
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   171
polymorphic functions and constants for all types \<open>'a\<close> of this type class:
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   172
\begin{flushleft}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   173
@{term_type [mode=my_constrain] pos} \\
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   174
@{term_type [mode=my_constrain] val} \\
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   175
@{term_type [mode=my_constrain] succ} \\
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   176
@{term_type [mode=my_constrain] pred} \\
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   177
@{term_type [mode=my_constrain] first_el} \\
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   178
@{term_type [mode=my_constrain] last_el}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   179
\end{flushleft}
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 66992
diff changeset
   180
In addition, \<^class>\<open>spark_enum\<close> is a subclass of the \<^class>\<open>linorder\<close> type class,
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   181
which allows the comparison operators \<open><\<close> and \<open>\<le>\<close> to be used on
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   182
enumeration types. The polymorphic operations shown above enjoy a number of
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   183
generic properties that hold for all enumeration types. These properties are
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   184
listed in \figref{fig:enum-generic-properties}.
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   185
Moreover, \figref{fig:enum-specific-properties} shows a list of properties
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   186
that are specific to each enumeration type $t$, such as the characteristic
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 66992
diff changeset
   187
equations for \<^term>\<open>val\<close> and \<^term>\<open>pos\<close>.
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   188
\begin{figure}[t]
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   189
\begin{center}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   190
\small
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   191
\begin{tabular}{ll}
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   192
\<open>range_pos\<close>: & @{thm range_pos} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   193
\<open>less_pos\<close>: & @{thm less_pos} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   194
\<open>less_eq_pos\<close>: & @{thm less_eq_pos} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   195
\<open>val_def\<close>: & @{thm val_def} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   196
\<open>succ_def\<close>: & @{thm succ_def} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   197
\<open>pred_def\<close>: & @{thm pred_def} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   198
\<open>first_el_def\<close>: & @{thm first_el_def} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   199
\<open>last_el_def\<close>: & @{thm last_el_def} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   200
\<open>inj_pos\<close>: & @{thm inj_pos} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   201
\<open>val_pos\<close>: & @{thm val_pos} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   202
\<open>pos_val\<close>: & @{thm pos_val} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   203
\<open>first_el_smallest\<close>: & @{thm first_el_smallest} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   204
\<open>last_el_greatest\<close>: & @{thm last_el_greatest} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   205
\<open>pos_succ\<close>: & @{thm pos_succ} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   206
\<open>pos_pred\<close>: & @{thm pos_pred} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   207
\<open>succ_val\<close>: & @{thm succ_val} \\
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   208
\<open>pred_val\<close>: & @{thm pred_val}
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   209
\end{tabular}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   210
\end{center}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   211
\caption{Generic properties of functions on enumeration types}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   212
\label{fig:enum-generic-properties}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   213
\end{figure}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   214
\begin{figure}[t]
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   215
\begin{center}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   216
\small
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   217
\begin{tabular}{ll@ {\hspace{2cm}}ll}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   218
\texttt{$t$\_val}: & \isa{val\ $0$\ =\ $e_1$} & \texttt{$t$\_pos}: & pos\ $e_1$\ =\ $0$ \\
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   219
                   & \isa{val\ $1$\ =\ $e_2$} &                    & pos\ $e_2$\ =\ $1$ \\
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   220
                   & \hspace{1cm}\vdots       &                    & \hspace{1cm}\vdots \\
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   221
                   & \isa{val\ $(n-1)$\ =\ $e_n$} &                & pos\ $e_n$\ =\ $n-1$
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   222
\end{tabular} \\[3ex]
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   223
\begin{tabular}{ll}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   224
\texttt{$t$\_card}: & \isa{card($t$)\ =\ $n$} \\
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   225
\texttt{$t$\_first\_el}: & \isa{first\_el\ =\ $e_1$} \\
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   226
\texttt{$t$\_last\_el}: & \isa{last\_el\ =\ $e_n$}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   227
\end{tabular}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   228
\end{center}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   229
\caption{Type-specific properties of functions on enumeration types}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   230
\label{fig:enum-specific-properties}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   231
\end{figure}
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   232
\<close>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   233
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   234
subsection \<open>Records\<close>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   235
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   236
text \<open>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   237
The FDL record type
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   238
\begin{alltt}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   239
type \(t\) = record
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   240
      \(f\sb{1}\) : \(t\sb{1}\);
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   241
       \(\vdots\)
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   242
      \(f\sb{n}\) : \(t\sb{n}\)
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   243
   end;
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   244
\end{alltt}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   245
is modelled by the Isabelle record type
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   246
\begin{isabelle}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   247
\normalsize
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   248
\isacommand{record}\ t\ = \isanewline
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   249
\ \ $f_1$\ ::\ $t_1$ \isanewline
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   250
\ \ \ \vdots \isanewline
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   251
\ \ $f_n$\ ::\ $t_n$
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   252
\end{isabelle}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   253
Records are constructed using the notation
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   254
\isa{\isasymlparr$f_1$\ =\ $v_1$,\ $\ldots$,\ $f_n$\ =\ $v_n$\isasymrparr},
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   255
a field $f_i$ of a record $r$ is selected using the notation $f_i~r$, and the
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   256
fields $f$ and $f'$ of a record $r$ can be updated using the notation
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   257
\mbox{\isa{$r$\ \isasymlparr$f$\ :=\ $v$,\ $f'$\ :=\ $v'$\isasymrparr}}.
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   258
\<close>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   259
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   260
subsection \<open>Arrays\<close>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   261
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   262
text \<open>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   263
The FDL array type
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   264
\begin{alltt}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   265
type \(t\) = array [\(t\sb{1}\), \(\ldots\), \(t\sb{n}\)] of \(u\);
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   266
\end{alltt}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   267
is modelled by the Isabelle function type $t_1 \times \cdots \times t_n \Rightarrow u$.
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   268
Array updates are written as \isa{$A$($x_1$\ := $y_1$,\ \dots,\ $x_n$\ :=\ $y_n$)}.
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   269
To allow updating an array at a set of indices, HOL-\SPARK{} provides the notation
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   270
\isa{\dots\ [:=]\ \dots}, which can be combined with \isa{\dots\ :=\ \dots} and has
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   271
the properties
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   272
@{thm [display,mode=no_brackets] fun_upds_in fun_upds_notin upds_singleton}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   273
Thus, we can write expressions like
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   274
@{term [display] "(A::int\<Rightarrow>int) ({0..9} [:=] 42, 15 := 99, {20..29} [:=] 0)"}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   275
that would be cumbersome to write using single updates.
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   276
\<close>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   277
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   278
section \<open>User-defined proof functions and types\<close>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   279
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   280
text \<open>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   281
To illustrate the interplay between the commands for introducing user-defined proof
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   282
functions and types mentioned in \secref{sec:spark-commands}, we now discuss a larger
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   283
example involving the definition of proof functions on complex types. Assume we would
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   284
like to define an array type, whose elements are records that themselves contain
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   285
arrays. Moreover, assume we would like to initialize all array elements and record
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   286
fields of type \texttt{Integer} in an array of this type with the value \texttt{0}.
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   287
The specification of package \texttt{Complex\_Types} containing the definition of
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   288
the array type, which we call \texttt{Array\_Type2}, is shown in \figref{fig:complex-types}.
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   289
It also contains the declaration of a proof function \texttt{Initialized} that is used
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   290
to express that the array has been initialized. The two other proof functions
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   291
\texttt{Initialized2} and \texttt{Initialized3} are used to reason about the
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   292
initialization of the inner array. Since the array types and proof functions
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   293
may be used by several packages, such as the one shown in \figref{fig:complex-types-app},
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   294
it is advantageous to define the proof functions in a central theory that can
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   295
be included by other theories containing proofs about packages using \texttt{Complex\_Types}.
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   296
We show this theory in \figref{fig:complex-types-thy}. Since the proof functions
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   297
refer to the enumeration and record types defined in \texttt{Complex\_Types},
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   298
we need to define the Isabelle counterparts of these types using the
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   299
\isa{\isacommand{datatype}} and \isa{\isacommand{record}} commands in order
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   300
to be able to write down the definition of the proof functions. These types are
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   301
linked to the corresponding \SPARK{} types using the \isa{\isacommand{spark\_types}}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   302
command. Note that we have to specify the full name of the \SPARK{} functions
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   303
including the package prefix. Using the logic of Isabelle, we can then define
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   304
functions involving the enumeration and record types introduced above, and link
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   305
them to the corresponding \SPARK{} proof functions. It is important that the
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   306
\isa{\isacommand{definition}} commands are preceeded by the \isa{\isacommand{spark\_types}}
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   307
command, since the definition of \<open>initialized3\<close> uses the \<open>val\<close>
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   308
function for enumeration types that is only available once that \<open>day\<close>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   309
has been declared as a \SPARK{} type.
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   310
\begin{figure}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   311
\lstinputlisting{complex_types.ads}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   312
\caption{Nested array and record types}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   313
\label{fig:complex-types}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   314
\end{figure}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   315
\begin{figure}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   316
\lstinputlisting{complex_types_app.ads}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   317
\lstinputlisting{complex_types_app.adb}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   318
\caption{Application of \texttt{Complex\_Types} package}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   319
\label{fig:complex-types-app}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   320
\end{figure}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   321
\begin{figure}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   322
\input{Complex_Types}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   323
\caption{Theory defining proof functions for complex types}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   324
\label{fig:complex-types-thy}
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   325
\end{figure}
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 62969
diff changeset
   326
\<close>
45044
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   327
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   328
(*<*)
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   329
end
2fae15f8984d Added documentation for HOL-SPARK
berghofe
parents:
diff changeset
   330
(*>*)