--- a/Quot/Examples/FSet.thy Wed Dec 09 06:21:09 2009 +0100
+++ b/Quot/Examples/FSet.thy Wed Dec 09 15:11:49 2009 +0100
@@ -373,10 +373,10 @@
apply (lifting ttt)
done
+
lemma ttt2: "(\<lambda>e. ((op @) x ((op #) e []))) = (\<lambda>e. ((op #) e x))"
sorry
-(* PROBLEM *)
lemma "(\<lambda>e. (FUNION x (INSERT e EMPTY))) = (\<lambda>e. (INSERT e x))"
apply(lifting ttt2)
apply(regularize)
@@ -389,6 +389,7 @@
lemma ttt3: "(\<lambda>x. ((op @) x ((op #) e []))) = (\<lambda>x. ((op #) e x))"
sorry
+
lemma "(\<lambda>x. (FUNION x (INSERT e EMPTY))) = (\<lambda>x. (INSERT e x))"
(* apply (tactic {* procedure_tac @{context} @{thm ttt3} 1 *}) *)
sorry
@@ -396,9 +397,10 @@
lemma hard: "(\<lambda>P. \<lambda>Q. P (Q (x::'a list))) = (\<lambda>P. \<lambda>Q. Q (P (x::'a list)))"
sorry
-(* PROBLEM *)
lemma hard_lift: "(\<lambda>P. \<lambda>Q. P (Q (x::'a fset))) = (\<lambda>P. \<lambda>Q. Q (P (x::'a fset)))"
apply(lifting hard)
+apply(regularize)
+apply(auto)
sorry
end
--- a/Quot/QuotMain.thy Wed Dec 09 06:21:09 2009 +0100
+++ b/Quot/QuotMain.thy Wed Dec 09 15:11:49 2009 +0100
@@ -1038,32 +1038,39 @@
(* 4. Test for refl *)
ML {*
-fun fun_map_conv xs ctxt ctrm =
+fun fun_map_simple_conv xs ctxt ctrm =
case (term_of ctrm) of
((Const (@{const_name "fun_map"}, _) $ _ $ _) $ h $ _) =>
- (Conv.binop_conv (fun_map_conv xs ctxt) then_conv
- (if (member (op=) xs h)
- then Conv.all_conv
- else Conv.rewr_conv @{thm fun_map.simps[THEN eq_reflection]})) ctrm
- | _ $ _ => Conv.comb_conv (fun_map_conv xs ctxt) ctrm
+ if (member (op=) xs h)
+ then Conv.all_conv ctrm
+ else Conv.rewr_conv @{thm fun_map.simps[THEN eq_reflection]} ctrm
+ | _ => Conv.all_conv ctrm
+
+fun fun_map_conv xs ctxt ctrm =
+ case (term_of ctrm) of
+ _ $ _ => (Conv.comb_conv (fun_map_conv xs ctxt) then_conv
+ fun_map_simple_conv xs ctxt) ctrm
| Abs _ => Conv.abs_conv (fn (x, ctxt) => fun_map_conv ((term_of x)::xs) ctxt) ctxt ctrm
| _ => Conv.all_conv ctrm
fun fun_map_tac ctxt = CONVERSION (fun_map_conv [] ctxt)
*}
+
+
ML {*
fun clean_tac lthy =
let
val thy = ProofContext.theory_of lthy;
val defs = map (Thm.varifyT o symmetric o #def) (qconsts_dest thy)
(* FIXME: why is the Thm.varifyT needed: example where it fails is LamEx *)
+
val thms1 = defs @ (prs_rules_get lthy) @ @{thms babs_prs all_prs ex_prs}
- val thms2 = @{thms Quotient_abs_rep Quotient_rel_rep} @ (id_simps_get lthy)
+ val thms2 = @{thms Quotient_abs_rep Quotient_rel_rep} @ (id_simps_get lthy)
fun simps thms = (mk_minimal_ss lthy) addsimps thms addSolver quotient_solver
in
EVERY' [simp_tac (simps thms1),
- TRY o REPEAT_ALL_NEW (CHANGED o (fun_map_tac lthy)),
+ fun_map_tac lthy,
lambda_prs_tac lthy,
simp_tac (simps thms2),
TRY o rtac refl]