moved continuity simproc to Cfun.thy
authorhuffman
Mon, 23 May 2005 23:32:07 +0200
changeset 16055 58186c507750
parent 16054 b8ba6727712f
child 16056 32c3b7188c28
moved continuity simproc to Cfun.thy
src/HOLCF/Cfun.thy
--- a/src/HOLCF/Cfun.thy	Mon May 23 23:24:38 2005 +0200
+++ b/src/HOLCF/Cfun.thy	Mon May 23 23:32:07 2005 +0200
@@ -436,10 +436,31 @@
 
 text {* cont2cont tactic *}
 
-lemmas cont_lemmas1 = cont_const cont_id cont_Rep_CFun2
-                    cont2cont_Rep_CFun cont2cont_LAM
+lemmas cont_lemmas1 =
+  cont_const cont_id cont_Rep_CFun2 cont2cont_Rep_CFun cont2cont_LAM
+
+text {*
+  Continuity simproc by Brian Huffman.
+  Given the term @{term "cont f"}, the procedure tries to
+  construct the theorem @{prop "cont f == True"}. If this
+  theorem cannot be completely solved by the introduction
+  rules, then the procedure returns a conditional rewrite
+  rule with the unsolved subgoals as premises.
+*}
 
-declare cont_lemmas1 [simp]
+ML_setup {*
+local
+  val rules = thms "cont_lemmas1";
+  fun solve_cont sg _ t =
+    let val tr = instantiate' [] [SOME (cterm_of sg t)] Eq_TrueI;
+        val tac = REPEAT_ALL_NEW (resolve_tac rules) 1;
+    in Option.map fst (Seq.pull (tac tr)) end;
+in
+  val cont_proc = Simplifier.simproc (Theory.sign_of (the_context ()))
+        "continuity" ["cont f"] solve_cont;
+end;
+Addsimprocs [cont_proc];
+*}
 
 text {* HINT: @{text cont_tac} is now installed in simplifier in Lift.ML ! *}
 
@@ -455,11 +476,6 @@
 
 declare beta_cfun [simp]
 
-text {* use @{text cont_tac} as autotac. *}
-
-text {* HINT: @{text cont_tac} is now installed in simplifier in Lift.ML ! *}
-(*simpset_ref() := simpset() addsolver (K (DEPTH_SOLVE_1 o cont_tac));*)
-
 text {* some lemmata for functions with flat/chfin domain/range types *}
 
 lemma chfin_Rep_CFunR: "chain (Y::nat => 'a::cpo->'b::chfin)