ProgTutorial/Advanced.thy
author Christian Urban <urbanc@in.tum.de>
Sat, 12 Nov 2011 11:45:39 +0000 (2011-11-12)
changeset 496 80eb66aefc66
parent 495 f3f24874e8be
child 497 76c632c05949
permissions -rw-r--r--
tuned
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
395
2c392f61f400 spilt the Essential's chapter
Christian Urban <urbanc@in.tum.de>
parents: 394
diff changeset
     1
theory Advanced
441
Christian Urban <urbanc@in.tum.de>
parents: 414
diff changeset
     2
imports Base First_Steps
318
efb5fff99c96 split up the first-steps section into two chapters
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     3
begin
efb5fff99c96 split up the first-steps section into two chapters
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     4
346
0fea8b7a14a1 tuned the ML-output mechanism; tuned slightly the text
Christian Urban <urbanc@in.tum.de>
parents: 345
diff changeset
     5
(*<*)
0fea8b7a14a1 tuned the ML-output mechanism; tuned slightly the text
Christian Urban <urbanc@in.tum.de>
parents: 345
diff changeset
     6
setup{*
0fea8b7a14a1 tuned the ML-output mechanism; tuned slightly the text
Christian Urban <urbanc@in.tum.de>
parents: 345
diff changeset
     7
open_file_with_prelude 
395
2c392f61f400 spilt the Essential's chapter
Christian Urban <urbanc@in.tum.de>
parents: 394
diff changeset
     8
  "Advanced_Code.thy"
441
Christian Urban <urbanc@in.tum.de>
parents: 414
diff changeset
     9
  ["theory Advanced", "imports Base First_Steps", "begin"]
346
0fea8b7a14a1 tuned the ML-output mechanism; tuned slightly the text
Christian Urban <urbanc@in.tum.de>
parents: 345
diff changeset
    10
*}
0fea8b7a14a1 tuned the ML-output mechanism; tuned slightly the text
Christian Urban <urbanc@in.tum.de>
parents: 345
diff changeset
    11
(*>*)
0fea8b7a14a1 tuned the ML-output mechanism; tuned slightly the text
Christian Urban <urbanc@in.tum.de>
parents: 345
diff changeset
    12
0fea8b7a14a1 tuned the ML-output mechanism; tuned slightly the text
Christian Urban <urbanc@in.tum.de>
parents: 345
diff changeset
    13
414
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
    14
chapter {* Advanced Isabelle\label{chp:advanced} *}
381
97518188ef0e added more to the unification section
Christian Urban <urbanc@in.tum.de>
parents: 380
diff changeset
    15
97518188ef0e added more to the unification section
Christian Urban <urbanc@in.tum.de>
parents: 380
diff changeset
    16
text {*
410
Christian Urban <urbanc@in.tum.de>
parents: 408
diff changeset
    17
   \begin{flushright}
Christian Urban <urbanc@in.tum.de>
parents: 408
diff changeset
    18
  {\em All things are difficult before they are easy.} \\[1ex]
Christian Urban <urbanc@in.tum.de>
parents: 408
diff changeset
    19
  proverb
Christian Urban <urbanc@in.tum.de>
parents: 408
diff changeset
    20
  \end{flushright}
Christian Urban <urbanc@in.tum.de>
parents: 408
diff changeset
    21
Christian Urban <urbanc@in.tum.de>
parents: 408
diff changeset
    22
  \medskip
400
Christian Urban <urbanc@in.tum.de>
parents: 396
diff changeset
    23
  While terms, types and theorems are the most basic data structures in
Christian Urban <urbanc@in.tum.de>
parents: 396
diff changeset
    24
  Isabelle, there are a number of layers built on top of them. Most of these
408
Christian Urban <urbanc@in.tum.de>
parents: 401
diff changeset
    25
  layers are concerned with storing and manipulating data. Handling them
487
1c4250bc6258 more on theories
Christian Urban <urbanc@in.tum.de>
parents: 486
diff changeset
    26
  properly is an essential skill for programming on the ML-level of Isabelle. 
1c4250bc6258 more on theories
Christian Urban <urbanc@in.tum.de>
parents: 486
diff changeset
    27
  The most basic layer are theories. They contain global data and
408
Christian Urban <urbanc@in.tum.de>
parents: 401
diff changeset
    28
  can be seen as the ``long-term memory'' of Isabelle. There is usually only
Christian Urban <urbanc@in.tum.de>
parents: 401
diff changeset
    29
  one theory active at each moment. Proof contexts and local theories, on the
400
Christian Urban <urbanc@in.tum.de>
parents: 396
diff changeset
    30
  other hand, store local data for a task at hand. They act like the
408
Christian Urban <urbanc@in.tum.de>
parents: 401
diff changeset
    31
  ``short-term memory'' and there can be many of them that are active in
Christian Urban <urbanc@in.tum.de>
parents: 401
diff changeset
    32
  parallel.
318
efb5fff99c96 split up the first-steps section into two chapters
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    33
*}
efb5fff99c96 split up the first-steps section into two chapters
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    34
486
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
    35
section {* Theories and Setups\label{sec:theories} *}
358
9cf3bc448210 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 356
diff changeset
    36
9cf3bc448210 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 356
diff changeset
    37
text {*
492
Christian Urban <urbanc@in.tum.de>
parents: 491
diff changeset
    38
  Theories, as said above, are the most basic layer of abstraction in
Christian Urban <urbanc@in.tum.de>
parents: 491
diff changeset
    39
  Isabelle. They record information about definitions, syntax declarations, axioms,
488
780100cd4060 more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 487
diff changeset
    40
  theorems and much more.  For example, if a definition is made, it
780100cd4060 more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 487
diff changeset
    41
  must be stored in a theory in order to be usable later on. Similar
780100cd4060 more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 487
diff changeset
    42
  with proofs: once a proof is finished, the proved theorem needs to
780100cd4060 more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 487
diff changeset
    43
  be stored in the theorem database of the theory in order to be
491
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
    44
  usable. All relevant data of a theory can be queried with the
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
    45
  Isabelle command \isacommand{print\_theory}.
358
9cf3bc448210 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 356
diff changeset
    46
9cf3bc448210 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 356
diff changeset
    47
  \begin{isabelle}
9cf3bc448210 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 356
diff changeset
    48
  \isacommand{print\_theory}\\
9cf3bc448210 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 356
diff changeset
    49
  @{text "> names: Pure Code_Generator HOL \<dots>"}\\
9cf3bc448210 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 356
diff changeset
    50
  @{text "> classes: Inf < type \<dots>"}\\
9cf3bc448210 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 356
diff changeset
    51
  @{text "> default sort: type"}\\
9cf3bc448210 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 356
diff changeset
    52
  @{text "> syntactic types: #prop \<dots>"}\\
9cf3bc448210 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 356
diff changeset
    53
  @{text "> logical types: 'a \<times> 'b \<dots>"}\\
9cf3bc448210 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 356
diff changeset
    54
  @{text "> type arities: * :: (random, random) random \<dots>"}\\
9cf3bc448210 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 356
diff changeset
    55
  @{text "> logical constants: == :: 'a \<Rightarrow> 'a \<Rightarrow> prop \<dots>"}\\
9cf3bc448210 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 356
diff changeset
    56
  @{text "> abbreviations: \<dots>"}\\
9cf3bc448210 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 356
diff changeset
    57
  @{text "> axioms: \<dots>"}\\
9cf3bc448210 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 356
diff changeset
    58
  @{text "> oracles: \<dots>"}\\
9cf3bc448210 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 356
diff changeset
    59
  @{text "> definitions: \<dots>"}\\
9cf3bc448210 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 356
diff changeset
    60
  @{text "> theorems: \<dots>"}
9cf3bc448210 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 356
diff changeset
    61
  \end{isabelle}
9cf3bc448210 some polishing
Christian Urban <urbanc@in.tum.de>
parents: 356
diff changeset
    62
487
1c4250bc6258 more on theories
Christian Urban <urbanc@in.tum.de>
parents: 486
diff changeset
    63
  Functions acting on theories often end with the suffix @{text "_global"},
1c4250bc6258 more on theories
Christian Urban <urbanc@in.tum.de>
parents: 486
diff changeset
    64
  for example the function @{ML read_term_global in Syntax} in the structure
1c4250bc6258 more on theories
Christian Urban <urbanc@in.tum.de>
parents: 486
diff changeset
    65
  @{ML_struct Syntax}. The reason is to set them syntactically apart from
491
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
    66
  functions acting on contexts or local theories, which will be discussed in
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
    67
  the next sections. There is a tendency amongst Isabelle developers to prefer
487
1c4250bc6258 more on theories
Christian Urban <urbanc@in.tum.de>
parents: 486
diff changeset
    68
  ``non-global'' operations, because they have some advantages, as we will also
490
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
    69
  discuss later. However, some basic understanding of theories is still necessary
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
    70
  for effective Isabelle programming.
487
1c4250bc6258 more on theories
Christian Urban <urbanc@in.tum.de>
parents: 486
diff changeset
    71
491
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
    72
  An important Isabelle command with theories is \isacommand{setup}. In the
492
Christian Urban <urbanc@in.tum.de>
parents: 491
diff changeset
    73
  previous chapters we used it already to make a theorem attribute known
Christian Urban <urbanc@in.tum.de>
parents: 491
diff changeset
    74
  to Isabelle and to register a theorem under a name. What happens behind the
490
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
    75
  scenes is that \isacommand{setup} expects a function of type @{ML_type
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
    76
  "theory -> theory"}: the input theory is the current theory and the output
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
    77
  the theory where the attribute has been registered or the theorem has been
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
    78
  stored.  This is a fundamental principle in Isabelle. A similar situation
491
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
    79
  arises with declaring a constant, which can be done on the ML-level with 
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
    80
  function @{ML_ind declare_const in Sign} from the structure @{ML_struct
490
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
    81
  Sign}. To see how \isacommand{setup} works, consider the following code:
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
    82
348
Christian Urban <urbanc@in.tum.de>
parents: 347
diff changeset
    83
*}  
Christian Urban <urbanc@in.tum.de>
parents: 347
diff changeset
    84
485
f3536f0b47a9 added section about testboard
Christian Urban <urbanc@in.tum.de>
parents: 484
diff changeset
    85
ML{*let
f3536f0b47a9 added section about testboard
Christian Urban <urbanc@in.tum.de>
parents: 484
diff changeset
    86
  val thy = @{theory}
f3536f0b47a9 added section about testboard
Christian Urban <urbanc@in.tum.de>
parents: 484
diff changeset
    87
  val bar_const = ((@{binding "BAR"}, @{typ "nat"}), NoSyn)
f3536f0b47a9 added section about testboard
Christian Urban <urbanc@in.tum.de>
parents: 484
diff changeset
    88
in 
f3536f0b47a9 added section about testboard
Christian Urban <urbanc@in.tum.de>
parents: 484
diff changeset
    89
  Sign.declare_const @{context} bar_const thy  
f3536f0b47a9 added section about testboard
Christian Urban <urbanc@in.tum.de>
parents: 484
diff changeset
    90
end*}
348
Christian Urban <urbanc@in.tum.de>
parents: 347
diff changeset
    91
Christian Urban <urbanc@in.tum.de>
parents: 347
diff changeset
    92
text {*
488
780100cd4060 more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 487
diff changeset
    93
  If you simply run this code\footnote{Recall that ML-code needs to be enclosed in
486
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
    94
  \isacommand{ML}~@{text "\<verbopen> \<dots> \<verbclose>"}.} with the
491
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
    95
  intention of declaring a constant @{text "BAR"} having type @{typ nat}, then 
488
780100cd4060 more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 487
diff changeset
    96
  indeed you obtain a theory as result. But if you query the
486
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
    97
  constant on the Isabelle level using the command \isacommand{term}
348
Christian Urban <urbanc@in.tum.de>
parents: 347
diff changeset
    98
Christian Urban <urbanc@in.tum.de>
parents: 347
diff changeset
    99
  \begin{isabelle}
485
f3536f0b47a9 added section about testboard
Christian Urban <urbanc@in.tum.de>
parents: 484
diff changeset
   100
  \isacommand{term}~@{text BAR}\\
348
Christian Urban <urbanc@in.tum.de>
parents: 347
diff changeset
   101
  @{text "> \"BAR\" :: \"'a\""}
Christian Urban <urbanc@in.tum.de>
parents: 347
diff changeset
   102
  \end{isabelle}
Christian Urban <urbanc@in.tum.de>
parents: 347
diff changeset
   103
495
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   104
  you can see that you do \emph{not} obtain the expected constant of type @{typ nat}, but a free 
484
490fe9483c0d more material
Christian Urban <urbanc@in.tum.de>
parents: 481
diff changeset
   105
  variable (printed in blue) of polymorphic type. The problem is that the 
490fe9483c0d more material
Christian Urban <urbanc@in.tum.de>
parents: 481
diff changeset
   106
  ML-expression above did not ``register'' the declaration with the current theory. 
490fe9483c0d more material
Christian Urban <urbanc@in.tum.de>
parents: 481
diff changeset
   107
  This is what the command \isacommand{setup} is for. The constant is properly 
490fe9483c0d more material
Christian Urban <urbanc@in.tum.de>
parents: 481
diff changeset
   108
  declared with
348
Christian Urban <urbanc@in.tum.de>
parents: 347
diff changeset
   109
*}
Christian Urban <urbanc@in.tum.de>
parents: 347
diff changeset
   110
486
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   111
setup %gray {* fn thy => 
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   112
let
485
f3536f0b47a9 added section about testboard
Christian Urban <urbanc@in.tum.de>
parents: 484
diff changeset
   113
  val bar_const = ((@{binding "BAR"}, @{typ "nat"}), NoSyn)
486
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   114
  val (_, thy') = Sign.declare_const @{context} bar_const thy
485
f3536f0b47a9 added section about testboard
Christian Urban <urbanc@in.tum.de>
parents: 484
diff changeset
   115
in 
486
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   116
  thy'
485
f3536f0b47a9 added section about testboard
Christian Urban <urbanc@in.tum.de>
parents: 484
diff changeset
   117
end *}
348
Christian Urban <urbanc@in.tum.de>
parents: 347
diff changeset
   118
Christian Urban <urbanc@in.tum.de>
parents: 347
diff changeset
   119
text {* 
486
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   120
  where the declaration is actually applied to the current theory and
348
Christian Urban <urbanc@in.tum.de>
parents: 347
diff changeset
   121
  
Christian Urban <urbanc@in.tum.de>
parents: 347
diff changeset
   122
  \begin{isabelle}
Christian Urban <urbanc@in.tum.de>
parents: 347
diff changeset
   123
  \isacommand{term}~@{text [quotes] "BAR"}\\
Christian Urban <urbanc@in.tum.de>
parents: 347
diff changeset
   124
  @{text "> \"BAR\" :: \"nat\""}
Christian Urban <urbanc@in.tum.de>
parents: 347
diff changeset
   125
  \end{isabelle}
Christian Urban <urbanc@in.tum.de>
parents: 347
diff changeset
   126
492
Christian Urban <urbanc@in.tum.de>
parents: 491
diff changeset
   127
  now returns a (black) constant with the type @{typ nat}, as expected.
348
Christian Urban <urbanc@in.tum.de>
parents: 347
diff changeset
   128
491
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
   129
  In a sense, \isacommand{setup} can be seen as a transaction that
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
   130
  takes the current theory @{text thy}, applies an operation, and
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
   131
  produces a new current theory @{text thy'}. This means that we have
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
   132
  to be careful to apply operations always to the most current theory,
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
   133
  not to a \emph{stale} one. Consider again the function inside the
486
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   134
  \isacommand{setup}-command:
485
f3536f0b47a9 added section about testboard
Christian Urban <urbanc@in.tum.de>
parents: 484
diff changeset
   135
486
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   136
  \begin{isabelle}
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   137
  \begin{graybox}
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   138
  \isacommand{setup}~@{text "\<verbopen>"} @{ML
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   139
"fn thy => 
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   140
let
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   141
  val bar_const = ((@{binding \"BAR\"}, @{typ \"nat\"}), NoSyn)
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   142
  val (_, thy') = Sign.declare_const @{context} bar_const thy
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   143
in
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   144
  thy
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   145
end"}~@{text "\<verbclose>"}\isanewline
495
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   146
  @{text "> ERROR: \"Stale theory encountered\""}
486
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   147
  \end{graybox}
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   148
  \end{isabelle}
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   149
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   150
  This time we erroneously return the original theory @{text thy}, instead of
488
780100cd4060 more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 487
diff changeset
   151
  the modified one @{text thy'}. Such buggy code will always result into 
780100cd4060 more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 487
diff changeset
   152
  a runtime error message about stale theories.
486
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   153
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   154
  However, sometimes it does make sense to work with two theories at the same
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   155
  time, especially in the context of parsing and typing. In the code below we
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   156
  use in Line 3 the function @{ML_ind copy in Theory} from the structure
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   157
  @{ML_struct Theory} for obtaining a new theory that contains the same
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   158
  data, but is unrelated to the existing theory.
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   159
*}
485
f3536f0b47a9 added section about testboard
Christian Urban <urbanc@in.tum.de>
parents: 484
diff changeset
   160
486
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   161
setup %graylinenos {* fn thy => 
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   162
let
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   163
  val tmp_thy = Theory.copy thy
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   164
  val foo_const = ((@{binding "FOO"}, @{typ "nat => nat"}), NoSyn)
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   165
  val (_, tmp_thy') = Sign.declare_const @{context} foo_const tmp_thy
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   166
  val trm1 = Syntax.read_term_global tmp_thy' "FOO baz"
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   167
  val trm2 = Syntax.read_term_global thy "FOO baz"
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   168
  val _ = writeln (@{make_string} trm1 ^ "\n" ^ @{make_string} trm2)
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   169
in
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   170
  thy
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   171
end *}
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   172
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   173
text {*
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   174
  That means we can make changes to the theory @{text tmp_thy} without
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   175
  affecting the current theory @{text thy}. In this case we declare in @{text
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   176
  "tmp_thy"} the constant @{text FOO} (Lines 4 and 5). The point of this code
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   177
  is that we next, in Lines 6 and 7, parse a string to become a term (both
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   178
  times the string is @{text [quotes] "FOO baz"}). But since we parse the string
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   179
  once in the context of the theory @{text tmp_thy'} in which @{text FOO} is
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   180
  declared to be a constant of type @{typ "nat \<Rightarrow>nat"} and once in the context 
488
780100cd4060 more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 487
diff changeset
   181
  of @{text thy} where it is not, we obtain two different terms, namely 
486
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   182
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   183
  \begin{isabelle}
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   184
  \begin{graybox}
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   185
  @{text "> Const (\"Advanced.FOO\", \"nat \<Rightarrow> nat\") $ Free (\"baz\", \"nat\")"}\isanewline
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   186
  @{text "> Free (\"FOO\", \"'a \<Rightarrow> 'b\") $ Free (\"baz\", \"'a\")"}
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   187
  \end{graybox}
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   188
  \end{isabelle}
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   189
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   190
  There are two reasons for parsing a term in a temporary theory. One is to
488
780100cd4060 more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 487
diff changeset
   191
  obtain fully qualified names for constants and the other is appropriate type 
780100cd4060 more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 487
diff changeset
   192
  inference. This is relevant in situations where definitions are made later, 
780100cd4060 more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 487
diff changeset
   193
  but parsing and type inference has to take already proceed as if the definitions 
780100cd4060 more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 487
diff changeset
   194
  were already made.
348
Christian Urban <urbanc@in.tum.de>
parents: 347
diff changeset
   195
*}
318
efb5fff99c96 split up the first-steps section into two chapters
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   196
495
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   197
section {* Contexts *}
341
62dea749d5ed more work on theorem section
Christian Urban <urbanc@in.tum.de>
parents: 340
diff changeset
   198
486
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   199
text {*
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   200
  Contexts are arguably more important than theories, even though they only 
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   201
  contain ``short-term memory data''. The reason is that a vast number of
490
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
   202
  functions in Isabelle depend in one way or another on contexts. Even such
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
   203
  mundane operations like printing out a term make essential use of contexts.
494
Christian Urban <urbanc@in.tum.de>
parents: 493
diff changeset
   204
  For this consider the following contrived proof-snippet whose purpose is to 
490
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
   205
  fix two variables:
486
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   206
*}
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   207
488
780100cd4060 more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 487
diff changeset
   208
lemma "True"
780100cd4060 more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 487
diff changeset
   209
proof -
491
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
   210
  txt_raw {*\mbox{}\\[-7mm]*} 
492
Christian Urban <urbanc@in.tum.de>
parents: 491
diff changeset
   211
  ML_prf {* Variable.dest_fixes @{context} *} 
491
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
   212
  txt_raw {*\mbox{}\\[-7mm]\mbox{}*}
492
Christian Urban <urbanc@in.tum.de>
parents: 491
diff changeset
   213
 fix x y  
491
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
   214
  txt_raw {*\mbox{}\\[-7mm]*}
488
780100cd4060 more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 487
diff changeset
   215
  ML_prf {* Variable.dest_fixes @{context} *} 
491
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
   216
  txt_raw {*\mbox{}\\[-7mm] \ldots*}(*<*)oops(*>*)
488
780100cd4060 more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 487
diff changeset
   217
490
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
   218
text {*
496
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   219
  The interesting point is that we injected ML-code before and after
490
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
   220
  the variables are fixed. For this remember that ML-code inside a proof
494
Christian Urban <urbanc@in.tum.de>
parents: 493
diff changeset
   221
  needs to be enclosed inside \isacommand{ML\_prf}~@{text "\<verbopen> \<dots> \<verbclose>"},
490
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
   222
  not \isacommand{ML}~@{text "\<verbopen> \<dots> \<verbclose>"}. The function 
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
   223
  @{ML_ind dest_fixes in Variable} from the structure @{ML_struct Variable} takes 
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
   224
  a context and returns all its currently fixed variable (names). That 
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
   225
  means a context has a dataslot containing information about fixed variables.
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
   226
  The ML-antiquotation @{text "@{context}"} points to the context that is
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
   227
  active at that point of the theory. Consequently, in the first call to 
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
   228
  @{ML dest_fixes in Variable} this dataslot is  empty; in the second it is 
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
   229
  filled with @{text x} and @{text y}. What is interesting is that contexts
494
Christian Urban <urbanc@in.tum.de>
parents: 493
diff changeset
   230
  can be stacked. For this consider the following proof fragment:
490
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
   231
*}
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
   232
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
   233
lemma "True"
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
   234
proof -
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
   235
  fix x y
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
   236
  { fix z w
491
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
   237
  txt_raw {*\mbox{}\\[-7mm]*}
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
   238
  ML_prf {* Variable.dest_fixes @{context} *} 
492
Christian Urban <urbanc@in.tum.de>
parents: 491
diff changeset
   239
  txt_raw {*\mbox{}\\[-7mm]\mbox{}*}
Christian Urban <urbanc@in.tum.de>
parents: 491
diff changeset
   240
 }
491
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
   241
  txt_raw {*\mbox{}\\[-7mm]*}
490
Christian Urban <urbanc@in.tum.de>
parents: 488
diff changeset
   242
  ML_prf {* Variable.dest_fixes @{context} *} 
491
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
   243
  txt_raw {*\mbox{}\\[-7mm] \ldots*}(*<*)oops(*>*)
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
   244
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
   245
text {*
495
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   246
  Here the first time we call @{ML dest_fixes in Variable} we have four fixes variables;
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   247
  the second time we get only the fixes variables @{text x} and @{text y} as answer, since
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   248
  @{text z} and @{text w} are not anymore in the scope of the context. 
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   249
  This means the curly-braces act on the Isabelle level as opening and closing statements 
496
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   250
  for a context. The above proof fragment corresponds roughly to the following ML-code
491
Christian Urban <urbanc@in.tum.de>
parents: 490
diff changeset
   251
*}
488
780100cd4060 more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 487
diff changeset
   252
492
Christian Urban <urbanc@in.tum.de>
parents: 491
diff changeset
   253
ML{*val ctxt0 = @{context};
Christian Urban <urbanc@in.tum.de>
parents: 491
diff changeset
   254
val ([x, y], ctxt1) = Variable.add_fixes ["x", "y"] ctxt0;
Christian Urban <urbanc@in.tum.de>
parents: 491
diff changeset
   255
val ([z, w], ctxt2) = Variable.add_fixes ["z", "w"] ctxt1*}
Christian Urban <urbanc@in.tum.de>
parents: 491
diff changeset
   256
Christian Urban <urbanc@in.tum.de>
parents: 491
diff changeset
   257
text {*
494
Christian Urban <urbanc@in.tum.de>
parents: 493
diff changeset
   258
  where the function @{ML_ind add_fixes in Variable} fixes a list of variables
Christian Urban <urbanc@in.tum.de>
parents: 493
diff changeset
   259
  specified by strings. Let us come back to the point about printing terms. Consider
495
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   260
  printing out the term \mbox{@{text "(x, y, z, w)"}} using our function @{ML_ind pretty_term}.
496
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   261
  This function takes a term and a context as argument. Notice how the printing
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   262
  of the term changes with which context is used.
492
Christian Urban <urbanc@in.tum.de>
parents: 491
diff changeset
   263
495
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   264
  \begin{isabelle}
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   265
  \begin{graybox}
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   266
  @{ML "let
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   267
  val trm = @{term \"(x, y, z, w)\"}
493
Christian Urban <urbanc@in.tum.de>
parents: 492
diff changeset
   268
in
Christian Urban <urbanc@in.tum.de>
parents: 492
diff changeset
   269
  pwriteln (Pretty.chunks 
Christian Urban <urbanc@in.tum.de>
parents: 492
diff changeset
   270
    [ pretty_term ctxt0 trm,
Christian Urban <urbanc@in.tum.de>
parents: 492
diff changeset
   271
      pretty_term ctxt1 trm,
Christian Urban <urbanc@in.tum.de>
parents: 492
diff changeset
   272
      pretty_term ctxt2 trm ])
495
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   273
end"}\\
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   274
  \setlength{\fboxsep}{0mm}
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   275
  @{text ">"}~@{text "("}\colorbox{gray!5}{\raisebox{0mm}[3mm][1mm]{@{text x}}}@{text ","}~%
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   276
  \colorbox{gray!5}{\raisebox{0mm}[3mm][1mm]{@{text y}}}@{text ","}~%
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   277
  \colorbox{gray!5}{\raisebox{0mm}[3mm][1mm]{@{text z}}}@{text ","}~%
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   278
  \colorbox{gray!5}{\raisebox{0mm}[3mm][1mm]{@{text w}}}@{text ")"}\\
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   279
  @{text ">"}~@{text "("}\colorbox{gray!20}{\raisebox{0mm}[3mm][1mm]{@{text x}}}@{text ","}~%
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   280
  \colorbox{gray!20}{\raisebox{0mm}[3mm][1mm]{@{text y}}}@{text ","}~%
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   281
  \colorbox{gray!5}{\raisebox{0mm}[3mm][1mm]{@{text z}}}@{text ","}~%
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   282
  \colorbox{gray!5}{\raisebox{0mm}[3mm][1mm]{@{text w}}}@{text ")"}\\
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   283
  @{text ">"}~@{text "("}\colorbox{gray!20}{\raisebox{0mm}[3mm][1mm]{@{text x}}}@{text ","}~%
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   284
  \colorbox{gray!20}{\raisebox{0mm}[3mm][1mm]{@{text y}}}@{text ","}~%
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   285
  \colorbox{gray!20}{\raisebox{0mm}[3mm][1mm]{@{text z}}}@{text ","}~%
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   286
  \colorbox{gray!20}{\raisebox{0mm}[3mm][1mm]{@{text w}}}@{text ")"}
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   287
  \end{graybox}
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   288
  \end{isabelle}
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   289
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   290
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   291
  The term we are printing is in all three cases the same---a tuple containing
496
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   292
  four free variables. As you can see, however, in case of @{ML "ctxt0"} all
495
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   293
  variables are highlighted indicating a problem, while in case of @{ML
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   294
  "ctxt1"} @{text x} and @{text y} are printed as normal (blue) free
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   295
  variables, but not @{text z} and @{text w}. In the last case all variables
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   296
  are printed as expected. The point of this example is that the context
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   297
  contains the information which variables are fixed, and designates all other
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   298
  free variables as being alien or faulty.  While this seems like a minor
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   299
  detail, the concept of making the context aware of fixed variables is
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   300
  actually quite useful. For example it prevents us from fixing a variable
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   301
  twice
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   302
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   303
  @{ML_response_fake [gray, display]
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   304
  "@{context}
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   305
|> Variable.add_fixes [\"x\", \"x\"]" 
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   306
  "ERROR: Duplicate fixed variable(s): \"x\""}
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   307
496
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   308
  More importantly it also allows us to easily create fresh free variables avoiding any 
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   309
  clashes with fixed variables. In Line~3 below we fix the variable @{text x} in the context
495
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   310
  @{text ctxt1}. Next we want to create two fresh variables of type @{typ nat}
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   311
  as variants of the string @{text [quotes] "x"}.
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   312
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   313
  @{ML_response_fake [display, gray, linenos]
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   314
  "let
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   315
  val ctxt0 = @{context}
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   316
  val (_, ctxt1) = Variable.add_fixes [\"x\"] ctxt0
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   317
  val frees = replicate 2 (\"x\", @{typ nat})
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   318
in
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   319
  (Variable.variant_frees ctxt0 [] frees,
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   320
   Variable.variant_frees ctxt1 [] frees)
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   321
end"
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   322
  "([(\"x\", \"nat\"), (\"xa\", \"nat\")], 
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   323
 [(\"xa\", \"nat\"), (\"xb\", \"nat\")])"}
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   324
496
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   325
  As you can see, if we create the fresh variables with the context @{text ctxt0},
495
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   326
  then we obtain @{text "x"} and @{text "xa"}; but in @{text ctxt1} we obtain @{text "xa"}
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   327
  and @{text "xb"} avoiding @{text x}, which was fixed in this context.
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   328
496
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   329
  Often one has the problem that given some terms, create fresh variables
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   330
  avoiding any variable occurring in those terms. For this you can use the
495
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   331
  function @{ML_ind declare_term in Variable} from the structure @{ML_struct Variable}.
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   332
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   333
  @{ML_response_fake [gray, display]
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   334
  "let
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   335
  val ctxt1 = Variable.declare_term @{term \"(x, xa)\"} @{context}
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   336
  val frees = replicate 2 (\"x\", @{typ nat})
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   337
in
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   338
  Variable.variant_frees ctxt1 [] frees
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   339
end"
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   340
  "[(\"xb\", \"nat\"), (\"xc\", \"nat\")]"}
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   341
496
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   342
  The result is @{text xb} and @{text xc} for the names of the fresh
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   343
  variables. Note that @{ML_ind declare_term in Variable} does not fix the
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   344
  variables; it just makes them ``known'' to the context. This is helpful when
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   345
  parsing terms using the function @{ML_ind read_term in Syntax} from the
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   346
  structure @{ML_struct Syntax}. Consider the following code:
495
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   347
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   348
  @{ML_response_fake [gray, display]
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   349
  "let
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   350
  val ctxt0 = @{context}
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   351
  val ctxt1 = Variable.declare_term @{term \"x::nat\"} ctxt0
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   352
in
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   353
  (Syntax.read_term ctxt0 \"x\", 
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   354
   Syntax.read_term ctxt1 \"x\") 
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   355
end"
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   356
  "(Free (\"x\", \"'a\"), Free (\"x\", \"nat\"))"}
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   357
  
496
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   358
  Parsing the string in the context @{text "ctxt0"} results in a free variable 
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   359
  with a default polymorphic type, but in case of @{text "ctxt1"} we obtain a
495
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   360
  free variable of type @{typ nat} as previously declared. Which
496
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   361
  type the parsed term receives depends upon the last declaration that
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   362
  is made, as the next example illustrates.
495
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   363
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   364
  @{ML_response_fake [gray, display]
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   365
  "let
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   366
  val ctxt1 = Variable.declare_term @{term \"x::nat\"} @{context}
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   367
  val ctxt2 = Variable.declare_term @{term \"x::int\"} ctxt1
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   368
in
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   369
  (Syntax.read_term ctxt1 \"x\", 
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   370
   Syntax.read_term ctxt2 \"x\") 
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   371
end"
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   372
  "(Free (\"x\", \"nat\"), Free (\"x\", \"int\"))"}
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   373
496
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   374
  The most useful feature of contexts is that one can export, for example,
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   375
  terms between contexts.
495
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   376
*}
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   377
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   378
ML {*
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   379
let
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   380
  val ctxt0 = @{context}
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   381
  val (_, ctxt1) = Variable.add_fixes ["x", "y", "z"] ctxt0 
496
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   382
  val foo_trm = @{term "P x y z"}
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   383
in
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   384
  singleton (Variable.export_terms ctxt1 ctxt0) foo_trm
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   385
  |> pretty_term ctxt1
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   386
  |> pwriteln
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   387
end
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   388
*}
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   389
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   390
ML {*
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   391
let
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   392
  val thy = @{theory}
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   393
  val ctxt0 = @{context}
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   394
  val (_, ctxt1) = Variable.add_fixes ["x", "y", "z"] ctxt0 
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   395
  val foo_thm = Skip_Proof.make_thm thy @{prop "P x y z"}
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   396
in
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   397
  singleton (Proof_Context.export ctxt1 ctxt0) foo_thm
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   398
end
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   399
*}
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   400
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   401
ML {*
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   402
let
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   403
  val thy = @{theory}
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   404
  val ctxt0 = @{context}
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   405
  val (_, ctxt1) = Variable.add_fixes ["x", "y", "z"] ctxt0 
Christian Urban <urbanc@in.tum.de>
parents: 495
diff changeset
   406
  val foo_thm = Skip_Proof.make_thm thy @{prop "P x y z"}
495
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   407
in
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   408
  singleton (Proof_Context.export ctxt1 ctxt0) foo_thm
493
Christian Urban <urbanc@in.tum.de>
parents: 492
diff changeset
   409
end
Christian Urban <urbanc@in.tum.de>
parents: 492
diff changeset
   410
*}
Christian Urban <urbanc@in.tum.de>
parents: 492
diff changeset
   411
495
f3f24874e8be more on contexts
Christian Urban <urbanc@in.tum.de>
parents: 494
diff changeset
   412
text {*
493
Christian Urban <urbanc@in.tum.de>
parents: 492
diff changeset
   413
Christian Urban <urbanc@in.tum.de>
parents: 492
diff changeset
   414
*}
Christian Urban <urbanc@in.tum.de>
parents: 492
diff changeset
   415
492
Christian Urban <urbanc@in.tum.de>
parents: 491
diff changeset
   416
486
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   417
(*
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   418
ML{*Proof_Context.debug := true*}
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   419
ML{*Proof_Context.verbose := true*}
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   420
*)
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   421
487
1c4250bc6258 more on theories
Christian Urban <urbanc@in.tum.de>
parents: 486
diff changeset
   422
(*
486
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   423
lemma "True"
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   424
proof -
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   425
  { -- "\<And>x. _"
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   426
    fix x
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   427
    have "B x" sorry
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   428
    thm this
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   429
  }
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   430
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   431
  thm this
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   432
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   433
  { -- "A \<Longrightarrow> _"
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   434
    assume A
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   435
    have B sorry
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   436
    thm this
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   437
  }
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   438
   
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   439
  thm this
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   440
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   441
  { -- "\<And>x. x = _ \<Longrightarrow> _"
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   442
    def x \<equiv> a
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   443
    have "B x" sorry
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   444
  }
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   445
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   446
  thm this
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   447
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   448
oops
487
1c4250bc6258 more on theories
Christian Urban <urbanc@in.tum.de>
parents: 486
diff changeset
   449
*)
413
95461cf6fd07 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 410
diff changeset
   450
341
62dea749d5ed more work on theorem section
Christian Urban <urbanc@in.tum.de>
parents: 340
diff changeset
   451
section {* Local Theories (TBD) *}
62dea749d5ed more work on theorem section
Christian Urban <urbanc@in.tum.de>
parents: 340
diff changeset
   452
394
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   453
text {*
400
Christian Urban <urbanc@in.tum.de>
parents: 396
diff changeset
   454
  In contrast to an ordinary theory, which simply consists of a type
Christian Urban <urbanc@in.tum.de>
parents: 396
diff changeset
   455
  signature, as well as tables for constants, axioms and theorems, a local
Christian Urban <urbanc@in.tum.de>
parents: 396
diff changeset
   456
  theory contains additional context information, such as locally fixed
Christian Urban <urbanc@in.tum.de>
parents: 396
diff changeset
   457
  variables and local assumptions that may be used by the package. The type
Christian Urban <urbanc@in.tum.de>
parents: 396
diff changeset
   458
  @{ML_type local_theory} is identical to the type of \emph{proof contexts}
Christian Urban <urbanc@in.tum.de>
parents: 396
diff changeset
   459
  @{ML_type "Proof.context"}, although not every proof context constitutes a
Christian Urban <urbanc@in.tum.de>
parents: 396
diff changeset
   460
  valid local theory.
Christian Urban <urbanc@in.tum.de>
parents: 396
diff changeset
   461
Christian Urban <urbanc@in.tum.de>
parents: 396
diff changeset
   462
  @{ML "Context.>> o Context.map_theory"}
394
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   463
  @{ML_ind "Local_Theory.declaration"}
486
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   464
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   465
   A similar command is \isacommand{local\_setup}, which expects a function
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   466
  of type @{ML_type "local_theory -> local_theory"}. Later on we will also
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   467
  use the commands \isacommand{method\_setup} for installing methods in the
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   468
  current theory and \isacommand{simproc\_setup} for adding new simprocs to
45cfd2ece7bd a section about theories and setups
Christian Urban <urbanc@in.tum.de>
parents: 485
diff changeset
   469
  the current simpset.
394
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   470
*}
318
efb5fff99c96 split up the first-steps section into two chapters
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   471
336
a12bb28fe2bd polished on the pretty printing section
Christian Urban <urbanc@in.tum.de>
parents: 335
diff changeset
   472
394
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   473
section {* Morphisms (TBD) *}
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   474
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   475
text {*
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   476
  Morphisms are arbitrary transformations over terms, types, theorems and bindings.
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   477
  They can be constructed using the function @{ML_ind morphism in Morphism},
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   478
  which expects a record with functions of type
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   479
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   480
  \begin{isabelle}
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   481
  \begin{tabular}{rl}
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   482
  @{text "binding:"} & @{text "binding -> binding"}\\
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   483
  @{text "typ:"}     & @{text "typ -> typ"}\\
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   484
  @{text "term:"}    & @{text "term -> term"}\\
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   485
  @{text "fact:"}    & @{text "thm list -> thm list"}
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   486
  \end{tabular}
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   487
  \end{isabelle}
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   488
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   489
  The simplest morphism is the  @{ML_ind identity in Morphism}-morphism defined as
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   490
*}
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   491
481
32323727af96 updated
Christian Urban <urbanc@in.tum.de>
parents: 475
diff changeset
   492
ML{*val identity = Morphism.morphism {binding = [], typ = [], term = [], fact = []}*}
394
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   493
  
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   494
text {*
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   495
  Morphisms can be composed with the function @{ML_ind "$>" in Morphism}
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   496
*}
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   497
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   498
ML{*fun trm_phi (Free (x, T)) = Var ((x, 0), T) 
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   499
  | trm_phi (Abs (x, T, t)) = Abs (x, T, trm_phi t)
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   500
  | trm_phi (t $ s) = (trm_phi t) $ (trm_phi s)
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   501
  | trm_phi t = t*}
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   502
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   503
ML{*val phi = Morphism.term_morphism trm_phi*}
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   504
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   505
ML{*Morphism.term phi @{term "P x y"}*}
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   506
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   507
text {*
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   508
  @{ML_ind term_morphism in Morphism}
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   509
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   510
  @{ML_ind term in Morphism},
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   511
  @{ML_ind thm in Morphism}
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   512
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   513
  \begin{readmore}
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   514
  Morphisms are implemented in the file @{ML_file "Pure/morphism.ML"}.
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   515
  \end{readmore}
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   516
*}
318
efb5fff99c96 split up the first-steps section into two chapters
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   517
efb5fff99c96 split up the first-steps section into two chapters
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   518
section {* Misc (TBD) *}
efb5fff99c96 split up the first-steps section into two chapters
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   519
efb5fff99c96 split up the first-steps section into two chapters
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   520
ML {*Datatype.get_info @{theory} "List.list"*}
efb5fff99c96 split up the first-steps section into two chapters
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   521
319
6bce4acf7f2a added file for producing a keyword file
Christian Urban <urbanc@in.tum.de>
parents: 318
diff changeset
   522
text {* 
6bce4acf7f2a added file for producing a keyword file
Christian Urban <urbanc@in.tum.de>
parents: 318
diff changeset
   523
FIXME: association lists:
6bce4acf7f2a added file for producing a keyword file
Christian Urban <urbanc@in.tum.de>
parents: 318
diff changeset
   524
@{ML_file "Pure/General/alist.ML"}
6bce4acf7f2a added file for producing a keyword file
Christian Urban <urbanc@in.tum.de>
parents: 318
diff changeset
   525
6bce4acf7f2a added file for producing a keyword file
Christian Urban <urbanc@in.tum.de>
parents: 318
diff changeset
   526
FIXME: calling the ML-compiler
6bce4acf7f2a added file for producing a keyword file
Christian Urban <urbanc@in.tum.de>
parents: 318
diff changeset
   527
6bce4acf7f2a added file for producing a keyword file
Christian Urban <urbanc@in.tum.de>
parents: 318
diff changeset
   528
*}
6bce4acf7f2a added file for producing a keyword file
Christian Urban <urbanc@in.tum.de>
parents: 318
diff changeset
   529
414
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   530
section {* What Is In an Isabelle Name? (TBD) *}
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   531
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   532
text {*
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   533
  On the ML-level of Isabelle, you often have to work with qualified names.
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   534
  These are strings with some additional information, such as positional
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   535
  information and qualifiers. Such qualified names can be generated with the
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   536
  antiquotation @{text "@{binding \<dots>}"}. For example
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   537
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   538
  @{ML_response [display,gray]
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   539
  "@{binding \"name\"}"
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   540
  "name"}
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   541
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   542
  An example where a qualified name is needed is the function 
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   543
  @{ML_ind define in Local_Theory}.  This function is used below to define 
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   544
  the constant @{term "TrueConj"} as the conjunction @{term "True \<and> True"}.
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   545
*}
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   546
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   547
local_setup %gray {* 
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   548
  Local_Theory.define ((@{binding "TrueConj"}, NoSyn), 
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   549
      (Attrib.empty_binding, @{term "True \<and> True"})) #> snd *}
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   550
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   551
text {* 
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   552
  Now querying the definition you obtain:
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   553
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   554
  \begin{isabelle}
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   555
  \isacommand{thm}~@{text "TrueConj_def"}\\
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   556
  @{text "> "}~@{thm TrueConj_def}
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   557
  \end{isabelle}
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   558
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   559
  \begin{readmore}
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   560
  The basic operations on bindings are implemented in 
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   561
  @{ML_file "Pure/General/binding.ML"}.
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   562
  \end{readmore}
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   563
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   564
  \footnote{\bf FIXME give a better example why bindings are important}
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   565
  \footnote{\bf FIXME give a pointer to \isacommand{local\_setup}; if not, then explain
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   566
  why @{ML snd} is needed.}
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   567
  \footnote{\bf FIXME: There should probably a separate section on binding, long-names
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   568
  and sign.}
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   569
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   570
*}
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   571
318
efb5fff99c96 split up the first-steps section into two chapters
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   572
360
Christian Urban <urbanc@in.tum.de>
parents: 359
diff changeset
   573
ML {* Sign.intern_type @{theory} "list" *}
Christian Urban <urbanc@in.tum.de>
parents: 359
diff changeset
   574
ML {* Sign.intern_const @{theory} "prod_fun" *}
Christian Urban <urbanc@in.tum.de>
parents: 359
diff changeset
   575
414
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   576
text {*
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   577
  \footnote{\bf FIXME: Explain the following better; maybe put in a separate
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   578
  section and link with the comment in the antiquotation section.}
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   579
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   580
  Occasionally you have to calculate what the ``base'' name of a given
462
1d1e795bc3ad updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 441
diff changeset
   581
  constant is. For this you can use the function @{ML_ind  Long_Name.base_name}. For example:
414
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   582
462
1d1e795bc3ad updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 441
diff changeset
   583
  @{ML_response [display,gray] "Long_Name.base_name \"List.list.Nil\"" "\"Nil\""}
414
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   584
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   585
  \begin{readmore}
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   586
  Functions about naming are implemented in @{ML_file "Pure/General/name_space.ML"};
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   587
  functions about signatures in @{ML_file "Pure/sign.ML"}.
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   588
  \end{readmore}
5fc2fb34c323 polished
Christian Urban <urbanc@in.tum.de>
parents: 413
diff changeset
   589
*}
387
5dcee4d751ad completed the unification section
Christian Urban <urbanc@in.tum.de>
parents: 386
diff changeset
   590
5dcee4d751ad completed the unification section
Christian Urban <urbanc@in.tum.de>
parents: 386
diff changeset
   591
text {* 
5dcee4d751ad completed the unification section
Christian Urban <urbanc@in.tum.de>
parents: 386
diff changeset
   592
  @{ML_ind "Binding.name_of"} returns the string without markup
394
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   593
0019ebf76e10 updated to new Isabelle
Christian Urban <urbanc@in.tum.de>
parents: 393
diff changeset
   594
  @{ML_ind "Binding.conceal"} 
387
5dcee4d751ad completed the unification section
Christian Urban <urbanc@in.tum.de>
parents: 386
diff changeset
   595
*}
5dcee4d751ad completed the unification section
Christian Urban <urbanc@in.tum.de>
parents: 386
diff changeset
   596
388
0b337dedc306 added Skip_Proof.mk_thm and some pointers about concurrency
Christian Urban <urbanc@in.tum.de>
parents: 387
diff changeset
   597
section {* Concurrency (TBD) *}
0b337dedc306 added Skip_Proof.mk_thm and some pointers about concurrency
Christian Urban <urbanc@in.tum.de>
parents: 387
diff changeset
   598
0b337dedc306 added Skip_Proof.mk_thm and some pointers about concurrency
Christian Urban <urbanc@in.tum.de>
parents: 387
diff changeset
   599
text {*
0b337dedc306 added Skip_Proof.mk_thm and some pointers about concurrency
Christian Urban <urbanc@in.tum.de>
parents: 387
diff changeset
   600
  @{ML_ind prove_future in Goal}
0b337dedc306 added Skip_Proof.mk_thm and some pointers about concurrency
Christian Urban <urbanc@in.tum.de>
parents: 387
diff changeset
   601
  @{ML_ind future_result in Goal}
0b337dedc306 added Skip_Proof.mk_thm and some pointers about concurrency
Christian Urban <urbanc@in.tum.de>
parents: 387
diff changeset
   602
  @{ML_ind fork_pri in Future}
0b337dedc306 added Skip_Proof.mk_thm and some pointers about concurrency
Christian Urban <urbanc@in.tum.de>
parents: 387
diff changeset
   603
*}
387
5dcee4d751ad completed the unification section
Christian Urban <urbanc@in.tum.de>
parents: 386
diff changeset
   604
396
Christian Urban <urbanc@in.tum.de>
parents: 395
diff changeset
   605
section {* Parse and Print Translations (TBD) *}
Christian Urban <urbanc@in.tum.de>
parents: 395
diff changeset
   606
349
9e374cd891e1 updated to Isabelle changes
Christian Urban <urbanc@in.tum.de>
parents: 348
diff changeset
   607
section {* Summary *}
9e374cd891e1 updated to Isabelle changes
Christian Urban <urbanc@in.tum.de>
parents: 348
diff changeset
   608
9e374cd891e1 updated to Isabelle changes
Christian Urban <urbanc@in.tum.de>
parents: 348
diff changeset
   609
text {*
395
2c392f61f400 spilt the Essential's chapter
Christian Urban <urbanc@in.tum.de>
parents: 394
diff changeset
   610
  TBD
349
9e374cd891e1 updated to Isabelle changes
Christian Urban <urbanc@in.tum.de>
parents: 348
diff changeset
   611
*}
318
efb5fff99c96 split up the first-steps section into two chapters
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   612
efb5fff99c96 split up the first-steps section into two chapters
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   613
end