--- a/Nominal/ExLet.thy Thu Mar 25 07:21:41 2010 +0100
+++ b/Nominal/ExLet.thy Thu Mar 25 08:05:03 2010 +0100
@@ -25,10 +25,82 @@
thm trm_lts.eq_iff
thm trm_lts.bn
thm trm_lts.perm
-thm trm_lts.induct
+thm trm_lts.induct[no_vars]
+thm trm_lts.inducts[no_vars]
thm trm_lts.distinct
thm trm_lts.fv[simplified trm_lts.supp]
+lemma
+ fixes t::trm
+ and l::lts
+ and c::"'a::fs"
+ assumes a1: "\<And>name c. P1 c (Vr name)"
+ and a2: "\<And>trm1 trm2 c. \<lbrakk>\<And>d. P1 d trm1; \<And>d. P1 d trm2\<rbrakk> \<Longrightarrow> P1 c (Ap trm1 trm2)"
+ and a3: "\<And>name trm c. \<lbrakk>atom name \<sharp> c; \<And>d. P1 d trm\<rbrakk> \<Longrightarrow> P1 c (Lm name trm)"
+ and a4: "\<And>lts trm c. \<lbrakk>bn lts \<sharp>* c; \<And>d. P2 d lts; \<And>d. P1 d trm\<rbrakk> \<Longrightarrow> P1 c (Lt lts trm)"
+ and a5: "\<And>c. P2 c Lnil"
+ and a6: "\<And>name trm lts c. \<lbrakk>\<And>d. P1 d trm; \<And>d. P2 d lts\<rbrakk> \<Longrightarrow> P2 c (Lcons name trm lts)"
+ shows "P1 c t" and "P2 c l"
+proof -
+ have "(\<And>(p::perm) (c::'a::fs). P1 c (p \<bullet> t))" and
+ "(\<And>(p::perm) (c::'a::fs). P2 c (p \<bullet> l))"
+ apply(induct rule: trm_lts.inducts)
+ apply(simp)
+ apply(rule a1)
+ apply(simp)
+ apply(rule a2)
+ apply(simp)
+ apply(simp)
+ apply(simp)
+ apply(subgoal_tac "\<exists>q. (q \<bullet> (atom (p \<bullet> name))) \<sharp> c \<and> supp (Lm (p \<bullet> name) (p \<bullet> trm)) \<sharp>* q")
+ apply(erule exE)
+ apply(rule_tac t="Lm (p \<bullet> name) (p \<bullet> trm)"
+ and s="q\<bullet> Lm (p \<bullet> name) (p \<bullet> trm)" in subst)
+ apply(rule supp_perm_eq)
+ apply(simp)
+ apply(simp)
+ apply(rule a3)
+ apply(simp add: atom_eqvt)
+ apply(subst permute_plus[symmetric])
+ apply(blast)
+ apply(rule at_set_avoiding2_atom)
+ apply(simp add: finite_supp)
+ apply(simp add: finite_supp)
+ apply(simp add: fresh_def)
+ apply(simp add: trm_lts.fv[simplified trm_lts.supp])
+ apply(simp)
+ apply(subgoal_tac "\<exists>q. (q \<bullet> bn (p \<bullet> lts)) \<sharp>* c \<and> supp (Lt (p \<bullet> lts) (p \<bullet> trm)) \<sharp>* q")
+ apply(erule exE)
+ apply(rule_tac t="Lt (p \<bullet> lts) (p \<bullet> trm)"
+ and s="q \<bullet> Lt (p \<bullet> lts) (p \<bullet> trm)" in subst)
+ apply(rule supp_perm_eq)
+ apply(simp)
+ apply(simp)
+ apply(rule a4)
+ apply(simp add: eqvts)
+ apply(subst permute_plus[symmetric])
+ apply(blast)
+ apply(subst permute_plus[symmetric])
+ apply(blast)
+ apply(rule at_set_avoiding2)
+ apply(simp add: finite_supp)
+ defer
+ apply(simp add: finite_supp)
+ apply(simp add: finite_supp)
+ apply(simp add: fresh_star_def)
+ apply(simp add: fresh_def)
+ apply(simp add: trm_lts.fv[simplified trm_lts.supp])
+ defer
+ apply(simp)
+ apply(rule a5)
+ apply(simp)
+ apply(rule a6)
+ apply(simp)
+ apply(simp)
+ oops
+
+
+
lemma lets_bla:
"x \<noteq> z \<Longrightarrow> y \<noteq> z \<Longrightarrow> x \<noteq> y \<Longrightarrow>(Lt (Lcons x (Vr y) Lnil) (Vr x)) \<noteq> (Lt (Lcons x (Vr z) Lnil) (Vr x))"
by (simp add: trm_lts.eq_iff)