ProgTutorial/General.thy
changeset 337 a456a21f608a
parent 336 a12bb28fe2bd
child 338 3bc732c9f7ff
--- a/ProgTutorial/General.thy	Thu Oct 08 21:49:11 2009 +0200
+++ b/ProgTutorial/General.thy	Fri Oct 09 10:34:38 2009 +0200
@@ -745,24 +745,34 @@
 
 text {*
   The corresponding ML-code is as follows:
+*}
 
-@{ML_response_fake [display,gray]
-"let
-  val assm1 = @{cprop \"\<And>(x::nat). P x \<Longrightarrow> Q x\"}
-  val assm2 = @{cprop \"(P::nat\<Rightarrow>bool) t\"}
+ML{*val my_thm = let
+  val assm1 = @{cprop "\<And>(x::nat). P x \<Longrightarrow> Q x"}
+  val assm2 = @{cprop "(P::nat \<Rightarrow> bool) t"}
 
   val Pt_implies_Qt = 
         assume assm1
-        |> forall_elim @{cterm \"t::nat\"};
+        |> forall_elim @{cterm "t::nat"}
   
-  val Qt = implies_elim Pt_implies_Qt (assume assm2);
+  val Qt = implies_elim Pt_implies_Qt (assume assm2)
 in
   Qt 
   |> implies_intr assm2
   |> implies_intr assm1
-end" "\<lbrakk>\<And>x. P x \<Longrightarrow> Q x; P t\<rbrakk> \<Longrightarrow> Q t"}
+end*}
+
+text {* 
+  If we print out the value of @{ML my_thm} then we see only the 
+  final statement of the theorem.
 
-  This code-snippet constructs the following proof:
+  @{ML_response_fake [display, gray]
+  "string_of_thm @{context} my_thm 
+ |> tracing"
+  "\<lbrakk>\<And>x. P x \<Longrightarrow> Q x; P t\<rbrakk> \<Longrightarrow> Q t"}
+
+  However, internally the code-snippet constructs the following 
+  proof.
 
   \[
   \infer[(@{text "\<Longrightarrow>"}$-$intro)]{\vdash @{prop "(\<And>x. P x \<Longrightarrow> Q x) \<Longrightarrow> P t \<Longrightarrow> Q t"}}
@@ -777,14 +787,33 @@
     }
   \]
 
-  However, while we obtained a theorem as result, this theorem is not
+  While we obtained a theorem as result, this theorem is not
   yet stored in Isabelle's theorem database. So it cannot be referenced later
-  on. How to store theorems will be explained in Section~\ref{sec:storing}.
+  on. One way to store it is 
+*}
+
+local_setup %gray{*
+  LocalTheory.note Thm.theoremK
+     ((@{binding "my_thm"}, []), [my_thm]) #> snd *}
+
+text {*
+  Now it can be referenced with the \isacommand{thm}-command on the user-level 
+  of Isabelle
+
+  \begin{isabelle}
+  \isacommand{thm}~@{text "my_thm"}\isanewline
+   @{text ">"}~@{prop "\<lbrakk>\<And>x. P x \<Longrightarrow> Q x; P t\<rbrakk> \<Longrightarrow> Q t"}
+  \end{isabelle}
+
+  or with the @{text "@{thm \<dots>}"}-antiquotation on the ML-level. Note that the
+  theorem does not have the meta-variables that would be present if we stated
+  this theorem on the user-level.
+
 
   \begin{readmore}
   For the functions @{text "assume"}, @{text "forall_elim"} etc 
   see \isccite{sec:thms}. The basic functions for theorems are defined in
-  @{ML_file "Pure/thm.ML"}. 
+  @{ML_file "Pure/thm.ML"}, @{ML_file "Pure/more_thm.ML"} and @{ML_file "Pure/drule.ML"}. 
   \end{readmore}
 
   (FIXME: handy functions working on theorems, like @{ML_ind  rulify in ObjectLogic} and so on)