# HG changeset patch # User Cezary Kaliszyk # Date 1269438591 -3600 # Node ID 9e31248a1b8c7110a401f13194134a3bab5ff5ea # Parent 68c8666453f721c58f54a75b94b8516a1272b6a7# Parent a0ca7d9f678197392ef7c58c1441c01d8aecec79 avoiding for atom. diff -r a0ca7d9f6781 -r 9e31248a1b8c Nominal/ExCoreHaskell.thy --- a/Nominal/ExCoreHaskell.thy Wed Mar 24 12:53:39 2010 +0100 +++ b/Nominal/ExCoreHaskell.thy Wed Mar 24 14:49:51 2010 +0100 @@ -88,8 +88,87 @@ lemmas fv_supp=tkind_ckind_ty_ty_lst_co_co_lst_trm_assoc_lst_pat_vt_lst_tvtk_lst_tvck_lst.supp(1-9,11,13,15) lemmas supp=tkind_ckind_ty_ty_lst_co_co_lst_trm_assoc_lst_pat_vt_lst_tvtk_lst_tvck_lst.fv[simplified fv_supp] +lemma + assumes a01: "\b. P1 b KStar" + and a02: "\tkind1 tkind2 b. \\c. P1 c tkind1; \c. P1 c tkind2\ \ P1 b (KFun tkind1 tkind2)" + and a03: "\ty1 ty2 b. \\c. P3 c ty1; \c. P3 c ty2\ \ P2 b (CKEq ty1 ty2)" + and a04: "\tvar b. P3 b (TVar tvar)" + and a05: "\char b. P3 b (TC char)" + and a06: "\ty1 ty2 b. \\c. P3 c ty1; \c. P3 c ty2\ \ P3 b (TApp ty1 ty2)" + and a07: "\char ty_lst b. \\c. P4 c ty_lst\ \ P3 b (TFun char ty_lst)" + and a08: "\tvar tkind ty b. \\c. P1 c tkind; \c. P3 c ty; atom tvar \ b\ + \ P3 b (TAll tvar tkind ty)" + and a09: "\ty1 ty2 ty3 b. \\c. P3 c ty1; \c. P3 c ty2; \c. P3 c ty3\ \ P3 b (TEq ty1 ty2 ty3)" + and a10: "\b. P4 b TsNil" + and a11: "\ty ty_lst b. \\c. P3 c ty; \c. P4 c ty_lst\ \ P4 b (TsCons ty ty_lst)" + and a12: "\char b. P5 b (CC char)" + and a13: "\co1 co2 b. \\c. P5 c co1; \c. P5 c co2\ \ P5 b (CApp co1 co2)" + and a14: "\char co_lst b. \\c. P6 c co_lst\ \ P5 b (CFun char co_lst)" + and a15: "\tvar ckind co b. \\c. P2 c ckind; \c. P5 c co; atom tvar \ b\ + \ P5 b (CAll tvar ckind co)" + and a16: "\co1 co2 co3 b. \\c. P5 c co1; \c. P5 c co2; \c. P5 c co3\ \ P5 b (CEq co1 co2 co3)" + and a17: "\co b. \\c. P5 c co\ \ P5 b (CSym co)" + and a18: "\co1 co2 b. \\c. P5 c co1; \c. P5 c co2\ \ P5 b (CCir co1 co2)" + and a19: "\co b. \\c. P5 c co\ \ P5 b (CLeft co)" + and a20: "\co b. \\c. P5 c co\ \ P5 b (CRight co)" + and a21: "\co b. \\c. P5 c co\ \ P5 b (CSim co)" + and a22: "\co b. \\c. P5 c co\ \ P5 b (CRightc co)" + and a23: "\co b. \\c. P5 c co\ \ P5 b (CLeftc co)" + and a24: "\co1 co2 b. \\c. P5 c co1; \c. P5 c co2\ \ P5 b (CCoe co1 co2)" + and a25: "\b. P6 b CsNil" + and a26: "\co co_lst b. \\c. P5 c co; \c. P6 c co_lst\ \ P6 b (CsCons co co_lst)" + and a27: "\var b. P7 b (Var var)" + and a28: "\char b. P7 b (C char)" + and a29: "\tvar tkind trm b. \\c. P1 c tkind; \c. P7 c trm; atom tvar \ b\ + \ P7 b (LAMT tvar tkind trm)" + and a30: "\tvar ckind trm b. \\c. P2 c ckind; \c. P7 c trm; atom tvar \ b\ + \ P7 b (LAMC tvar ckind trm)" + and a31: "\trm ty b. \\c. P7 c trm; \c. P3 c ty\ \ P7 b (APP trm ty)" + and a32: "\var ty trm b. \\c. P3 c ty; \c. P7 c trm; atom var \ b\ \ P7 b (Lam var ty trm)" + and a33: "\trm1 trm2 b. \\c. P7 c trm1; \c. P7 c trm2\ \ P7 b (App trm1 trm2)" + and a34: "\var ty trm1 trm2 b. \\c. P3 c ty; \c. P7 c trm1; \c. P7 c trm2; atom var \ b\ + \ P7 b (Let var ty trm1 trm2)" + and a35: "\trm assoc_lst b. \\c. P7 c trm; \c. P8 c assoc_lst\ \ P7 b (Case trm assoc_lst)" + and a36: "\trm ty b. \\c. P7 c trm; \c. P3 c ty\ \ P7 b (Cast trm ty)" + and a37: "\b. P8 b ANil" + and a38: "\pat trm assoc_lst b. \\c. P9 c pat; \c. P7 c trm; \c. P8 c assoc_lst; bv(pat) \* b\ + \ P8 b (ACons pat trm assoc_lst)" + and a39: "\char tvtk_lst tvck_lst vt_lst b. \\c. P11 c tvtk_lst; \c. P12 c tvck_lst; \c. P10 c vt_lst\ + \ P9 b (K char tvtk_lst tvck_lst vt_lst)" + and a40: "\b. P10 b VTNil" + and a41: "\var ty vt_lst b. \\c. P3 c ty; \c. P10 c vt_lst\ \ P10 b (VTCons var ty vt_lst)" + and a42: "\b. P11 b TVTKNil" + and a43: "\tvar tkind tvtk_lst b. \\c. P1 c tkind; \c. P11 c tvtk_lst\ + \ P11 b (TVTKCons tvar tkind tvtk_lst)" + and a44: "\b. P12 b TVCKNil" + and a45: "\tvar ckind tvck_lst b. \\c. P2 c ckind; \c. P12 c tvck_lst\ + \ P12 b (TVCKCons tvar ckind tvck_lst)" + shows "P1 (a :: 'a :: pt) tkind \ + P2 (b :: 'b :: pt) ckind \ + P3 (c :: 'c :: pt) ty \ + P4 (d :: 'd :: pt) ty_lst \ + P5 (e :: 'e :: pt) co \ + P6 (f :: 'f :: pt) co_lst \ + P7 (g :: 'g :: pt) trm \ + P8 (h :: 'h :: pt) assoc_lst \ + P9 (i :: 'i :: pt) pat \ + P10 (j :: 'j :: pt) vt_lst \ + P11 (k :: 'k :: pt) tvtk_lst \ + P12 (l :: 'l :: pt) tvck_lst" +proof - + have a: "(\p a. P1 a (p \ tkind)) \ (\p b. P2 b (p \ ckind)) \ (\p c. P3 c (p \ ty)) \ (\p d. P4 d (p \ ty_lst)) \ (\p e. P5 e (p \ co)) \ (\p f. P6 f (p \ co_lst)) \ (\p g. P7 g (p \ trm)) \ (\p h. P8 h (p \ assoc_lst)) \ (\p i. P9 i (p \ pat)) \ (\p j. P10 j (p \ vt_lst)) \ (\p k. P11 k (p \ tvtk_lst)) \ (\p l. P12 l (p \ tvck_lst))" + apply (rule tkind_ckind_ty_ty_lst_co_co_lst_trm_assoc_lst_pat_vt_lst_tvtk_lst_tvck_lst.induct) + apply (tactic {* ALLGOALS (REPEAT o rtac allI) *}) + apply (tactic {* ALLGOALS (TRY o SOLVED' (simp_tac @{simpset} THEN_ALL_NEW resolve_tac @{thms assms} THEN_ALL_NEW asm_full_simp_tac @{simpset})) *}) + sorry + have g1: "P1 a (0 \ tkind)" using a[THEN conjunct1] by blast + have g2: "P2 b (0 \ ckind)" using a[THEN conjunct2,THEN conjunct1] by blast + have g3: "P3 c (0 \ ty) \ + P4 d (0 \ ty_lst) \ P5 e (0 \ co) \ P6 f (0 \ co_lst) \ + P7 g (0 \ trm) \ P8 h (0 \ assoc_lst) \ P9 i (0 \ pat) \ + P10 j (0 \ vt_lst) \ P11 k (0 \ tvtk_lst) \ P12 l (0 \ tvck_lst)" using a by blast + show ?thesis using g1 g2 g3 by simp +qed end - - diff -r a0ca7d9f6781 -r 9e31248a1b8c Nominal/Nominal2_Supp.thy --- a/Nominal/Nominal2_Supp.thy Wed Mar 24 12:53:39 2010 +0100 +++ b/Nominal/Nominal2_Supp.thy Wed Mar 24 14:49:51 2010 +0100 @@ -483,4 +483,19 @@ apply(auto simp add: fresh_star_def fresh_def) done +lemma at_set_avoiding2_atom: + assumes "finite (supp c)" "finite (supp x)" + and b: "xa \ x" + shows "\p. (p \ xa) \ c \ supp x \* p" +proof - + have a: "{xa} \* x" unfolding fresh_star_def by (simp add: b) + obtain p where p1: "(p \ {xa}) \* c" and p2: "supp x \* p" + using at_set_avoiding2[of "{xa}" "c" "x"] assms a by blast + have c: "(p \ xa) \ c" using p1 + unfolding fresh_star_def Ball_def + by (erule_tac x="p \ xa" in allE) (simp add: eqvts) + hence "p \ xa \ c \ supp x \* p" using p2 by blast + then show ?thesis by blast +qed + end