| 28447 |      1 | %
 | 
|  |      2 | \begin{isabellebody}%
 | 
|  |      3 | \def\isabellecontext{Further}%
 | 
|  |      4 | %
 | 
|  |      5 | \isadelimtheory
 | 
|  |      6 | %
 | 
|  |      7 | \endisadelimtheory
 | 
|  |      8 | %
 | 
|  |      9 | \isatagtheory
 | 
|  |     10 | \isacommand{theory}\isamarkupfalse%
 | 
|  |     11 | \ Further\isanewline
 | 
|  |     12 | \isakeyword{imports}\ Setup\isanewline
 | 
|  |     13 | \isakeyword{begin}%
 | 
|  |     14 | \endisatagtheory
 | 
|  |     15 | {\isafoldtheory}%
 | 
|  |     16 | %
 | 
|  |     17 | \isadelimtheory
 | 
|  |     18 | %
 | 
|  |     19 | \endisadelimtheory
 | 
|  |     20 | %
 | 
|  |     21 | \isamarkupsection{Further issues \label{sec:further}%
 | 
|  |     22 | }
 | 
|  |     23 | \isamarkuptrue%
 | 
|  |     24 | %
 | 
|  |     25 | \isamarkupsubsection{Further reading%
 | 
|  |     26 | }
 | 
|  |     27 | \isamarkuptrue%
 | 
|  |     28 | %
 | 
|  |     29 | \begin{isamarkuptext}%
 | 
| 34155 |     30 | To dive deeper into the issue of code generation, you should visit
 | 
|  |     31 |   the Isabelle/Isar Reference Manual \cite{isabelle-isar-ref}, which
 | 
| 28593 |     32 |   contains exhaustive syntax diagrams.%
 | 
| 28447 |     33 | \end{isamarkuptext}%
 | 
|  |     34 | \isamarkuptrue%
 | 
|  |     35 | %
 | 
|  |     36 | \isamarkupsubsection{Modules%
 | 
|  |     37 | }
 | 
|  |     38 | \isamarkuptrue%
 | 
|  |     39 | %
 | 
|  |     40 | \begin{isamarkuptext}%
 | 
|  |     41 | When invoking the \hyperlink{command.export-code}{\mbox{\isa{\isacommand{export{\isacharunderscore}code}}}} command it is possible to leave
 | 
|  |     42 |   out the \hyperlink{keyword.module-name}{\mbox{\isa{\isakeyword{module{\isacharunderscore}name}}}} part;  then code is distributed over
 | 
|  |     43 |   different modules, where the module name space roughly is induced
 | 
| 28635 |     44 |   by the \isa{Isabelle} theory name space.
 | 
| 28447 |     45 | 
 | 
|  |     46 |   Then sometimes the awkward situation occurs that dependencies between
 | 
|  |     47 |   definitions introduce cyclic dependencies between modules, which in the
 | 
|  |     48 |   \isa{Haskell} world leaves you to the mercy of the \isa{Haskell} implementation
 | 
|  |     49 |   you are using,  while for \isa{SML}/\isa{OCaml} code generation is not possible.
 | 
|  |     50 | 
 | 
|  |     51 |   A solution is to declare module names explicitly.
 | 
|  |     52 |   Let use assume the three cyclically dependent
 | 
|  |     53 |   modules are named \emph{A}, \emph{B} and \emph{C}.
 | 
|  |     54 |   Then, by stating%
 | 
|  |     55 | \end{isamarkuptext}%
 | 
|  |     56 | \isamarkuptrue%
 | 
| 28593 |     57 | %
 | 
|  |     58 | \isadelimquote
 | 
|  |     59 | %
 | 
|  |     60 | \endisadelimquote
 | 
|  |     61 | %
 | 
|  |     62 | \isatagquote
 | 
| 28447 |     63 | \isacommand{code{\isacharunderscore}modulename}\isamarkupfalse%
 | 
|  |     64 | \ SML\isanewline
 | 
|  |     65 | \ \ A\ ABC\isanewline
 | 
|  |     66 | \ \ B\ ABC\isanewline
 | 
|  |     67 | \ \ C\ ABC%
 | 
| 28593 |     68 | \endisatagquote
 | 
|  |     69 | {\isafoldquote}%
 | 
|  |     70 | %
 | 
|  |     71 | \isadelimquote
 | 
|  |     72 | %
 | 
|  |     73 | \endisadelimquote
 | 
|  |     74 | %
 | 
| 28447 |     75 | \begin{isamarkuptext}%
 | 
| 34155 |     76 | \noindent
 | 
|  |     77 |   we explicitly map all those modules on \emph{ABC},
 | 
| 28447 |     78 |   resulting in an ad-hoc merge of this three modules
 | 
|  |     79 |   at serialisation time.%
 | 
|  |     80 | \end{isamarkuptext}%
 | 
|  |     81 | \isamarkuptrue%
 | 
|  |     82 | %
 | 
|  |     83 | \isamarkupsubsection{Evaluation oracle%
 | 
|  |     84 | }
 | 
|  |     85 | \isamarkuptrue%
 | 
|  |     86 | %
 | 
| 28593 |     87 | \begin{isamarkuptext}%
 | 
|  |     88 | Code generation may also be used to \emph{evaluate} expressions
 | 
|  |     89 |   (using \isa{SML} as target language of course).
 | 
| 34155 |     90 |   For instance, the \hyperlink{command.value}{\mbox{\isa{\isacommand{value}}}} reduces an expression to a
 | 
| 28593 |     91 |   normal form with respect to the underlying code equations:%
 | 
|  |     92 | \end{isamarkuptext}%
 | 
|  |     93 | \isamarkuptrue%
 | 
|  |     94 | %
 | 
|  |     95 | \isadelimquote
 | 
|  |     96 | %
 | 
|  |     97 | \endisadelimquote
 | 
|  |     98 | %
 | 
|  |     99 | \isatagquote
 | 
|  |    100 | \isacommand{value}\isamarkupfalse%
 | 
|  |    101 | \ {\isachardoublequoteopen}{\isadigit{4}}{\isadigit{2}}\ {\isacharslash}\ {\isacharparenleft}{\isadigit{1}}{\isadigit{2}}\ {\isacharcolon}{\isacharcolon}\ rat{\isacharparenright}{\isachardoublequoteclose}%
 | 
|  |    102 | \endisatagquote
 | 
|  |    103 | {\isafoldquote}%
 | 
|  |    104 | %
 | 
|  |    105 | \isadelimquote
 | 
|  |    106 | %
 | 
|  |    107 | \endisadelimquote
 | 
|  |    108 | %
 | 
|  |    109 | \begin{isamarkuptext}%
 | 
|  |    110 | \noindent will display \isa{{\isadigit{7}}\ {\isacharslash}\ {\isadigit{2}}}.
 | 
|  |    111 | 
 | 
|  |    112 |   The \hyperlink{method.eval}{\mbox{\isa{eval}}} method tries to reduce a goal by code generation to \isa{True}
 | 
|  |    113 |   and solves it in that case, but fails otherwise:%
 | 
|  |    114 | \end{isamarkuptext}%
 | 
|  |    115 | \isamarkuptrue%
 | 
|  |    116 | %
 | 
|  |    117 | \isadelimquote
 | 
|  |    118 | %
 | 
|  |    119 | \endisadelimquote
 | 
|  |    120 | %
 | 
|  |    121 | \isatagquote
 | 
|  |    122 | \isacommand{lemma}\isamarkupfalse%
 | 
|  |    123 | \ {\isachardoublequoteopen}{\isadigit{4}}{\isadigit{2}}\ {\isacharslash}\ {\isacharparenleft}{\isadigit{1}}{\isadigit{2}}\ {\isacharcolon}{\isacharcolon}\ rat{\isacharparenright}\ {\isacharequal}\ {\isadigit{7}}\ {\isacharslash}\ {\isadigit{2}}{\isachardoublequoteclose}\isanewline
 | 
|  |    124 | \ \ \isacommand{by}\isamarkupfalse%
 | 
|  |    125 | \ eval%
 | 
|  |    126 | \endisatagquote
 | 
|  |    127 | {\isafoldquote}%
 | 
|  |    128 | %
 | 
|  |    129 | \isadelimquote
 | 
|  |    130 | %
 | 
|  |    131 | \endisadelimquote
 | 
|  |    132 | %
 | 
|  |    133 | \begin{isamarkuptext}%
 | 
|  |    134 | \noindent The soundness of the \hyperlink{method.eval}{\mbox{\isa{eval}}} method depends crucially 
 | 
|  |    135 |   on the correctness of the code generator;  this is one of the reasons
 | 
| 31050 |    136 |   why you should not use adaptation (see \secref{sec:adaptation}) frivolously.%
 | 
| 28593 |    137 | \end{isamarkuptext}%
 | 
|  |    138 | \isamarkuptrue%
 | 
|  |    139 | %
 | 
| 28447 |    140 | \isamarkupsubsection{Code antiquotation%
 | 
|  |    141 | }
 | 
|  |    142 | \isamarkuptrue%
 | 
|  |    143 | %
 | 
| 28593 |    144 | \begin{isamarkuptext}%
 | 
|  |    145 | In scenarios involving techniques like reflection it is quite common
 | 
|  |    146 |   that code generated from a theory forms the basis for implementing
 | 
|  |    147 |   a proof procedure in \isa{SML}.  To facilitate interfacing of generated code
 | 
|  |    148 |   with system code, the code generator provides a \isa{code} antiquotation:%
 | 
|  |    149 | \end{isamarkuptext}%
 | 
| 28447 |    150 | \isamarkuptrue%
 | 
|  |    151 | %
 | 
| 28593 |    152 | \isadelimquote
 | 
|  |    153 | %
 | 
|  |    154 | \endisadelimquote
 | 
|  |    155 | %
 | 
|  |    156 | \isatagquote
 | 
|  |    157 | \isacommand{datatype}\isamarkupfalse%
 | 
| 30880 |    158 | \ form\ {\isacharequal}\ T\ {\isacharbar}\ F\ {\isacharbar}\ And\ form\ form\ {\isacharbar}\ Or\ form\ form\ %
 | 
| 30227 |    159 | \endisatagquote
 | 
|  |    160 | {\isafoldquote}%
 | 
|  |    161 | %
 | 
|  |    162 | \isadelimquote
 | 
|  |    163 | %
 | 
|  |    164 | \endisadelimquote
 | 
|  |    165 | %
 | 
|  |    166 | \isadelimquotett
 | 
| 30880 |    167 | \ %
 | 
| 30227 |    168 | \endisadelimquotett
 | 
|  |    169 | %
 | 
|  |    170 | \isatagquotett
 | 
| 28593 |    171 | \isacommand{ML}\isamarkupfalse%
 | 
|  |    172 | \ {\isacharverbatimopen}\isanewline
 | 
|  |    173 | \ \ fun\ eval{\isacharunderscore}form\ %
 | 
|  |    174 | \isaantiq
 | 
|  |    175 | code\ T%
 | 
|  |    176 | \endisaantiq
 | 
|  |    177 | \ {\isacharequal}\ true\isanewline
 | 
|  |    178 | \ \ \ \ {\isacharbar}\ eval{\isacharunderscore}form\ %
 | 
|  |    179 | \isaantiq
 | 
|  |    180 | code\ F%
 | 
|  |    181 | \endisaantiq
 | 
|  |    182 | \ {\isacharequal}\ false\isanewline
 | 
|  |    183 | \ \ \ \ {\isacharbar}\ eval{\isacharunderscore}form\ {\isacharparenleft}%
 | 
|  |    184 | \isaantiq
 | 
|  |    185 | code\ And%
 | 
|  |    186 | \endisaantiq
 | 
|  |    187 | \ {\isacharparenleft}p{\isacharcomma}\ q{\isacharparenright}{\isacharparenright}\ {\isacharequal}\isanewline
 | 
|  |    188 | \ \ \ \ \ \ \ \ eval{\isacharunderscore}form\ p\ andalso\ eval{\isacharunderscore}form\ q\isanewline
 | 
|  |    189 | \ \ \ \ {\isacharbar}\ eval{\isacharunderscore}form\ {\isacharparenleft}%
 | 
|  |    190 | \isaantiq
 | 
|  |    191 | code\ Or%
 | 
|  |    192 | \endisaantiq
 | 
|  |    193 | \ {\isacharparenleft}p{\isacharcomma}\ q{\isacharparenright}{\isacharparenright}\ {\isacharequal}\isanewline
 | 
|  |    194 | \ \ \ \ \ \ \ \ eval{\isacharunderscore}form\ p\ orelse\ eval{\isacharunderscore}form\ q{\isacharsemicolon}\isanewline
 | 
|  |    195 | {\isacharverbatimclose}%
 | 
| 30227 |    196 | \endisatagquotett
 | 
|  |    197 | {\isafoldquotett}%
 | 
| 28593 |    198 | %
 | 
| 30227 |    199 | \isadelimquotett
 | 
| 28593 |    200 | %
 | 
| 30227 |    201 | \endisadelimquotett
 | 
| 28593 |    202 | %
 | 
| 28447 |    203 | \begin{isamarkuptext}%
 | 
| 28593 |    204 | \noindent \isa{code} takes as argument the name of a constant;  after the
 | 
|  |    205 |   whole \isa{SML} is read, the necessary code is generated transparently
 | 
|  |    206 |   and the corresponding constant names are inserted.  This technique also
 | 
|  |    207 |   allows to use pattern matching on constructors stemming from compiled
 | 
|  |    208 |   \isa{datatypes}.
 | 
|  |    209 | 
 | 
| 29798 |    210 |   For a less simplistic example, theory \hyperlink{theory.Ferrack}{\mbox{\isa{Ferrack}}} is
 | 
| 28593 |    211 |   a good reference.%
 | 
| 28447 |    212 | \end{isamarkuptext}%
 | 
|  |    213 | \isamarkuptrue%
 | 
|  |    214 | %
 | 
|  |    215 | \isamarkupsubsection{Imperative data structures%
 | 
|  |    216 | }
 | 
|  |    217 | \isamarkuptrue%
 | 
|  |    218 | %
 | 
| 28593 |    219 | \begin{isamarkuptext}%
 | 
|  |    220 | If you consider imperative data structures as inevitable for a specific
 | 
|  |    221 |   application, you should consider
 | 
|  |    222 |   \emph{Imperative Functional Programming with Isabelle/HOL}
 | 
| 34155 |    223 |   \cite{bulwahn-et-al:2008:imperative};
 | 
| 28593 |    224 |   the framework described there is available in theory \hyperlink{theory.Imperative-HOL}{\mbox{\isa{Imperative{\isacharunderscore}HOL}}}.%
 | 
|  |    225 | \end{isamarkuptext}%
 | 
|  |    226 | \isamarkuptrue%
 | 
|  |    227 | %
 | 
| 28447 |    228 | \isadelimtheory
 | 
|  |    229 | %
 | 
|  |    230 | \endisadelimtheory
 | 
|  |    231 | %
 | 
|  |    232 | \isatagtheory
 | 
|  |    233 | \isacommand{end}\isamarkupfalse%
 | 
|  |    234 | %
 | 
|  |    235 | \endisatagtheory
 | 
|  |    236 | {\isafoldtheory}%
 | 
|  |    237 | %
 | 
|  |    238 | \isadelimtheory
 | 
|  |    239 | %
 | 
|  |    240 | \endisadelimtheory
 | 
|  |    241 | \isanewline
 | 
|  |    242 | \end{isabellebody}%
 | 
|  |    243 | %%% Local Variables:
 | 
|  |    244 | %%% mode: latex
 | 
|  |    245 | %%% TeX-master: "root"
 | 
|  |    246 | %%% End:
 |