Quot/QuotMain.thy
changeset 734 ac2ed047988d
parent 730 66f44de8bf5b
child 735 214b8c35b244
--- a/Quot/QuotMain.thy	Sat Dec 12 13:54:01 2009 +0100
+++ b/Quot/QuotMain.thy	Sat Dec 12 15:07:59 2009 +0100
@@ -399,7 +399,7 @@
 
 ML {*
 fun quotient_tac ctxt =
-  REPEAT_ALL_NEW (FIRST'
+  DETERM o REPEAT_ALL_NEW (FIRST'
     [rtac @{thm identity_quotient},
      resolve_tac (quotient_rules_get ctxt)])
 
@@ -407,6 +407,17 @@
 val quotient_solver = Simplifier.mk_solver' "Quotient goal solver" quotient_solver_tac
 *}
 
+ML {*
+fun solve_quotient_assums ctxt thm =
+let 
+  val goal = hd (Drule.strip_imp_prems (cprop_of thm)) 
+in
+  thm OF [Goal.prove_internal [] goal (fn _ => quotient_tac ctxt 1)]
+end
+handle _ => error "solve_quotient_assums failed. Maybe a quotient_thm is missing"
+*}
+
+
 (* 0. preliminary simplification step according to *)
 thm ball_reg_eqv bex_reg_eqv babs_reg_eqv (* the latter of no use *)
     ball_reg_eqv_range bex_reg_eqv_range
@@ -530,15 +541,7 @@
 
 section {* Injection Tactic *}
 
-ML {*
-fun solve_quotient_assums ctxt thm =
-let 
-  val goal = hd (Drule.strip_imp_prems (cprop_of thm)) 
-in
-  thm OF [Goal.prove_internal [] goal (fn _ => quotient_tac ctxt 1)]
-end
-handle _ => error "solve_quotient_assums failed. Maybe a quotient_thm is missing"
-*}
+
 
 definition
   "QUOT_TRUE x \<equiv> True"
@@ -646,49 +649,57 @@
 val bare_concl = HOLogic.dest_Trueprop o Logic.strip_assums_concl
 *}
 
+thm apply_rsp
+
 ML {*
 val apply_rsp_tac =
   Subgoal.FOCUS (fn {concl, asms, context,...} =>
     case ((HOLogic.dest_Trueprop (term_of concl))) of
-      ((R2 $ (f $ x) $ (g $ y))) =>
+      (R2 $ (f $ x) $ (g $ y)) =>
         (let
-          val (asmf, asma) = find_qt_asm (map term_of asms);
-        in
-          if (fastype_of asmf) = (fastype_of f) then no_tac else let
-            val ty_a = fastype_of x;
-            val ty_b = fastype_of asma;
-            val ty_c = range_type (type_of f);
-            val thy = ProofContext.theory_of context;
-            val ty_inst = map (SOME o (ctyp_of thy)) [ty_a, ty_b, ty_c];
-            val thm = Drule.instantiate' ty_inst [] @{thm apply_rsp}
-            val te = solve_quotient_assums context thm
-            val t_inst = map (SOME o (cterm_of thy)) [R2, f, g, x, y];
-            val thm = Drule.instantiate' [] t_inst te
-          in
-            compose_tac (false, thm, 2) 1
-          end
-        end
+           val (asmf, asma) = find_qt_asm (map term_of asms);
+         in
+           if (fastype_of asmf) = (fastype_of f) (* why is this test necessary *)
+           then no_tac 
+           else 
+             let
+               val ty_a = fastype_of x;
+               val ty_b = fastype_of asma;
+               val ty_c = range_type (type_of f); (* why type_of, not fast_type? *)
+               val thy = ProofContext.theory_of context;
+               val ty_inst = map (SOME o (ctyp_of thy)) [ty_a, ty_b, ty_c];
+               val thm = Drule.instantiate' ty_inst [] @{thm apply_rsp}
+               val te = solve_quotient_assums context thm
+               val t_inst = map (SOME o (cterm_of thy)) [R2, f, g, x, y]; 
+                                                      (* why not instantiate terms 3 lines earlier *)
+               val thm = Drule.instantiate' [] t_inst te
+             in
+               compose_tac (false, thm, 2) 1
+             end
+         end
         handle ERROR "find_qt_asm: no pair" => no_tac)
     | _ => no_tac)
 *}
 
 ML {*
 fun equals_rsp_tac R ctxt =
-  let
-    val ty = domain_type (fastype_of R);
-    val thy = ProofContext.theory_of ctxt
-    val thm = Drule.instantiate' 
-                 [SOME (ctyp_of thy ty)] [SOME (cterm_of thy R)] @{thm equals_rsp}
-  in
-    rtac thm THEN' quotient_tac ctxt
-  end
-  handle THM _  => K no_tac  
-       | TYPE _ => K no_tac    
-       | TERM _ => K no_tac
+let
+  val ty = domain_type (fastype_of R);
+  val thy = ProofContext.theory_of ctxt
+  val thm = Drule.instantiate' 
+               [SOME (ctyp_of thy ty)] [SOME (cterm_of thy R)] @{thm equals_rsp}
+in
+  rtac thm THEN' quotient_tac ctxt
+end
+handle THM _  => K no_tac  
+     | TYPE _ => K no_tac    
+     | TERM _ => K no_tac
 *}
 
+thm rep_abs_rsp
+
 ML {*
-fun rep_abs_rsp_tac ctxt =
+fun rep_abs_rsp_tac ctxt = 
   SUBGOAL (fn (goal, i) =>
     case (bare_concl goal) of 
       (rel $ _ $ (rep $ (abs $ _))) =>
@@ -698,11 +709,10 @@
            val ty_inst = map (SOME o (ctyp_of thy)) [ty_a, ty_b];
            val t_inst = map (SOME o (cterm_of thy)) [rel, abs, rep];
            val thm = Drule.instantiate' ty_inst t_inst @{thm rep_abs_rsp}
-           val te = solve_quotient_assums ctxt thm
          in
-           rtac te i
+           (rtac thm THEN' quotient_tac ctxt) i
          end
-         handle _ => no_tac)
+         handle _ => no_tac) (* what is the catch for ? *)
     | _ => no_tac)
 *}