author | Christian Urban <urbanc@in.tum.de> |
Mon, 29 Mar 2010 00:30:20 +0200 | |
changeset 1687 | 51bc795b81fd |
parent 1667 | 2922b04d9545 |
child 1688 | 0b2535a72fd0 |
permissions | -rw-r--r-- |
1601 | 1 |
theory ExCoreHaskell |
2 |
imports "Parser" |
|
3 |
begin |
|
4 |
||
5 |
(* core haskell *) |
|
6 |
||
1624
91ab98dd9999
Experiments with Core Haskell support.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1621
diff
changeset
|
7 |
ML {* val _ = recursive := false *} |
1656
c9d3dda79fe3
Removed remaining cheats + some cleaning.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1653
diff
changeset
|
8 |
|
1601 | 9 |
atom_decl var |
10 |
atom_decl tvar |
|
11 |
||
1606
75403378068b
Initial list unfoldings in Core Haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1601
diff
changeset
|
12 |
(* there are types, coercion types and regular types list-data-structure *) |
1609
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
13 |
|
1601 | 14 |
nominal_datatype tkind = |
15 |
KStar |
|
16 |
| KFun "tkind" "tkind" |
|
17 |
and ckind = |
|
18 |
CKEq "ty" "ty" |
|
19 |
and ty = |
|
20 |
TVar "tvar" |
|
1609
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
21 |
| TC "char" |
1601 | 22 |
| TApp "ty" "ty" |
1609
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
23 |
| TFun "char" "ty_lst" |
1601 | 24 |
| TAll tv::"tvar" "tkind" T::"ty" bind tv in T |
25 |
| TEq "ty" "ty" "ty" |
|
1606
75403378068b
Initial list unfoldings in Core Haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1601
diff
changeset
|
26 |
and ty_lst = |
75403378068b
Initial list unfoldings in Core Haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1601
diff
changeset
|
27 |
TsNil |
75403378068b
Initial list unfoldings in Core Haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1601
diff
changeset
|
28 |
| TsCons "ty" "ty_lst" |
1601 | 29 |
and co = |
1609
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
30 |
CC "char" |
1601 | 31 |
| CApp "co" "co" |
1609
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
32 |
| CFun "char" "co_lst" |
1601 | 33 |
| CAll tv::"tvar" "ckind" C::"co" bind tv in C |
34 |
| CEq "co" "co" "co" |
|
35 |
| CSym "co" |
|
1687 | 36 |
| CCir "co" "co" |
37 |
(* At ??? *) |
|
1601 | 38 |
| CLeft "co" |
39 |
| CRight "co" |
|
40 |
| CSim "co" |
|
41 |
| CRightc "co" |
|
42 |
| CLeftc "co" |
|
43 |
| CCoe "co" "co" |
|
1606
75403378068b
Initial list unfoldings in Core Haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1601
diff
changeset
|
44 |
and co_lst = |
75403378068b
Initial list unfoldings in Core Haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1601
diff
changeset
|
45 |
CsNil |
75403378068b
Initial list unfoldings in Core Haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1601
diff
changeset
|
46 |
| CsCons "co" "co_lst" |
1609
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
47 |
and trm = |
1601 | 48 |
Var "var" |
1609
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
49 |
| C "char" |
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
50 |
| LAMT tv::"tvar" "tkind" t::"trm" bind tv in t |
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
51 |
| LAMC tv::"tvar" "ckind" t::"trm" bind tv in t |
1601 | 52 |
| APP "trm" "ty" |
53 |
| Lam v::"var" "ty" t::"trm" bind v in t |
|
54 |
| App "trm" "trm" |
|
55 |
| Let x::"var" "ty" "trm" t::"trm" bind x in t |
|
1609
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
56 |
| Case "trm" "assoc_lst" |
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
57 |
| Cast "trm" "ty" --"ty is supposed to be a coercion type only" |
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
58 |
and assoc_lst = |
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
59 |
ANil |
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
60 |
| ACons p::"pat" t::"trm" "assoc_lst" bind "bv p" in t |
1601 | 61 |
and pat = |
1609
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
62 |
K "char" "tvtk_lst" "tvck_lst" "vt_lst" |
1621
a40dbea68d0b
Core Haskell experiments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1615
diff
changeset
|
63 |
and vt_lst = |
a40dbea68d0b
Core Haskell experiments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1615
diff
changeset
|
64 |
VTNil |
a40dbea68d0b
Core Haskell experiments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1615
diff
changeset
|
65 |
| VTCons "var" "ty" "vt_lst" |
1609
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
66 |
and tvtk_lst = |
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
67 |
TVTKNil |
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
68 |
| TVTKCons "tvar" "tkind" "tvtk_lst" |
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
69 |
and tvck_lst = |
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
70 |
TVCKNil |
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
71 |
| TVCKCons "tvar" "ckind" "tvck_lst" |
1601 | 72 |
binder |
1609
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
73 |
bv :: "pat \<Rightarrow> atom set" |
1621
a40dbea68d0b
Core Haskell experiments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1615
diff
changeset
|
74 |
and bv_vt :: "vt_lst \<Rightarrow> atom set" |
1609
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
75 |
and bv_tvtk :: "tvtk_lst \<Rightarrow> atom set" |
1621
a40dbea68d0b
Core Haskell experiments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1615
diff
changeset
|
76 |
and bv_tvck :: "tvck_lst \<Rightarrow> atom set" |
1601 | 77 |
where |
1621
a40dbea68d0b
Core Haskell experiments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1615
diff
changeset
|
78 |
"bv (K s tvts tvcs vs) = (bv_tvtk tvts) \<union> (bv_tvck tvcs) \<union> (bv_vt vs)" |
a40dbea68d0b
Core Haskell experiments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1615
diff
changeset
|
79 |
| "bv_vt VTNil = {}" |
1609
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
80 |
| "bv_vt (VTCons v k t) = {atom v} \<union> bv_vt t" |
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
81 |
| "bv_tvtk TVTKNil = {}" |
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
82 |
| "bv_tvtk (TVTKCons v k t) = {atom v} \<union> bv_tvtk t" |
c9bc3b61046c
Modification to Core Haskell to make it accepted with an empty binding function.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1606
diff
changeset
|
83 |
| "bv_tvck TVCKNil = {}" |
1621
a40dbea68d0b
Core Haskell experiments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1615
diff
changeset
|
84 |
| "bv_tvck (TVCKCons v k t) = {atom v} \<union> bv_tvck t" |
a40dbea68d0b
Core Haskell experiments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1615
diff
changeset
|
85 |
|
1626
0d7d0b8adca5
Showed support of Core Haskell
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1624
diff
changeset
|
86 |
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) |
0d7d0b8adca5
Showed support of Core Haskell
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1624
diff
changeset
|
87 |
lemmas supp=tkind_ckind_ty_ty_lst_co_co_lst_trm_assoc_lst_pat_vt_lst_tvtk_lst_tvck_lst.fv[simplified fv_supp] |
1634
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
88 |
lemmas perm=tkind_ckind_ty_ty_lst_co_co_lst_trm_assoc_lst_pat_vt_lst_tvtk_lst_tvck_lst.perm |
1635
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
89 |
lemmas eq_iff=tkind_ckind_ty_ty_lst_co_co_lst_trm_assoc_lst_pat_vt_lst_tvtk_lst_tvck_lst.eq_iff |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
90 |
lemmas inducts=tkind_ckind_ty_ty_lst_co_co_lst_trm_assoc_lst_pat_vt_lst_tvtk_lst_tvck_lst.inducts |
1634
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
91 |
|
1647
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
92 |
lemmas alpha_inducts=alpha_tkind_raw_alpha_ckind_raw_alpha_ty_raw_alpha_ty_lst_raw_alpha_co_raw_alpha_co_lst_raw_alpha_trm_raw_alpha_assoc_lst_raw_alpha_pat_raw_alpha_vt_lst_raw_alpha_tvtk_lst_raw_alpha_tvck_lst_raw_alpha_bv_raw_alpha_bv_vt_raw_alpha_bv_tvtk_raw_alpha_bv_tvck_raw.inducts |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
93 |
lemmas alpha_intros=alpha_tkind_raw_alpha_ckind_raw_alpha_ty_raw_alpha_ty_lst_raw_alpha_co_raw_alpha_co_lst_raw_alpha_trm_raw_alpha_assoc_lst_raw_alpha_pat_raw_alpha_vt_lst_raw_alpha_tvtk_lst_raw_alpha_tvck_lst_raw_alpha_bv_raw_alpha_bv_vt_raw_alpha_bv_tvtk_raw_alpha_bv_tvck_raw.intros |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
94 |
|
1634
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
95 |
lemma fresh_star_minus_perm: "as \<sharp>* - p = as \<sharp>* (p :: perm)" |
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
96 |
unfolding fresh_star_def Ball_def |
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
97 |
by auto (simp_all add: fresh_minus_perm) |
1615
0ea578c6dae3
Parsing bn functions that call other bn functions and transmitting this information to fv/alpha.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1609
diff
changeset
|
98 |
|
1647
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
99 |
primrec permute_bv_vt_raw |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
100 |
where "permute_bv_vt_raw p VTNil_raw = VTNil_raw" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
101 |
| "permute_bv_vt_raw p (VTCons_raw v t l) = VTCons_raw (p \<bullet> v) t (permute_bv_vt_raw p l)" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
102 |
primrec permute_bv_tvck_raw |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
103 |
where "permute_bv_tvck_raw p TVCKNil_raw = TVCKNil_raw" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
104 |
| "permute_bv_tvck_raw p (TVCKCons_raw v t l) = TVCKCons_raw (p \<bullet> v) t (permute_bv_tvck_raw p l)" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
105 |
primrec permute_bv_tvtk_raw |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
106 |
where "permute_bv_tvtk_raw p TVTKNil_raw = TVTKNil_raw" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
107 |
| "permute_bv_tvtk_raw p (TVTKCons_raw v t l) = TVTKCons_raw (p \<bullet> v) t (permute_bv_tvtk_raw p l)" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
108 |
primrec permute_bv_raw |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
109 |
where "permute_bv_raw p (K_raw c l1 l2 l3) = |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
110 |
K_raw c (permute_bv_tvtk_raw p l1) (permute_bv_tvck_raw p l2) (permute_bv_vt_raw p l3)" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
111 |
|
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
112 |
quotient_definition "permute_bv_vt :: perm \<Rightarrow> vt_lst \<Rightarrow> vt_lst" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
113 |
is "permute_bv_vt_raw" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
114 |
quotient_definition "permute_bv_tvck :: perm \<Rightarrow> tvck_lst \<Rightarrow> tvck_lst" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
115 |
is "permute_bv_tvck_raw" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
116 |
quotient_definition "permute_bv_tvtk :: perm \<Rightarrow> tvtk_lst \<Rightarrow> tvtk_lst" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
117 |
is "permute_bv_tvtk_raw" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
118 |
quotient_definition "permute_bv :: perm \<Rightarrow> pat \<Rightarrow> pat" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
119 |
is "permute_bv_raw" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
120 |
|
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
121 |
lemma rsp_pre: |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
122 |
"alpha_tvtk_lst_raw d a \<Longrightarrow> alpha_tvtk_lst_raw (permute_bv_tvtk_raw x d) (permute_bv_tvtk_raw x a)" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
123 |
"alpha_tvck_lst_raw e b \<Longrightarrow> alpha_tvck_lst_raw (permute_bv_tvck_raw x e) (permute_bv_tvck_raw x b)" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
124 |
"alpha_vt_lst_raw f c \<Longrightarrow> alpha_vt_lst_raw (permute_bv_vt_raw x f) (permute_bv_vt_raw x c)" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
125 |
apply (erule_tac [!] alpha_inducts) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
126 |
apply simp_all |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
127 |
apply (rule_tac [!] alpha_intros) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
128 |
apply simp_all |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
129 |
done |
1646
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
130 |
|
1647
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
131 |
lemma [quot_respect]: |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
132 |
"(op = ===> alpha_pat_raw ===> alpha_pat_raw) permute_bv_raw permute_bv_raw" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
133 |
"(op = ===> alpha_tvtk_lst_raw ===> alpha_tvtk_lst_raw) permute_bv_tvtk_raw permute_bv_tvtk_raw" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
134 |
"(op = ===> alpha_tvck_lst_raw ===> alpha_tvck_lst_raw) permute_bv_tvck_raw permute_bv_tvck_raw" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
135 |
"(op = ===> alpha_vt_lst_raw ===> alpha_vt_lst_raw) permute_bv_vt_raw permute_bv_vt_raw" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
136 |
apply (simp_all add: rsp_pre) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
137 |
apply clarify |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
138 |
apply (erule_tac alpha_inducts) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
139 |
apply (simp_all) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
140 |
apply (rule alpha_intros) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
141 |
apply (simp_all add: rsp_pre) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
142 |
done |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
143 |
|
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
144 |
lemmas permute_bv[simp] = permute_bv_raw.simps[quot_lifted] |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
145 |
permute_bv_vt_raw.simps[quot_lifted] |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
146 |
permute_bv_tvck_raw.simps[quot_lifted] |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
147 |
permute_bv_tvtk_raw.simps[quot_lifted] |
1646
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
148 |
|
1647
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
149 |
lemma perm_bv1: |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
150 |
"p \<bullet> bv_tvck b = bv_tvck (permute_bv_tvck p b)" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
151 |
"p \<bullet> bv_tvtk c = bv_tvtk (permute_bv_tvtk p c)" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
152 |
"p \<bullet> bv_vt d = bv_vt (permute_bv_vt p d)" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
153 |
apply(induct b rule: inducts(12)) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
154 |
apply(rule TrueI) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
155 |
apply(simp_all add:permute_bv eqvts) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
156 |
apply(induct c rule: inducts(11)) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
157 |
apply(rule TrueI) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
158 |
apply(simp_all add:permute_bv eqvts) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
159 |
apply(induct d rule: inducts(10)) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
160 |
apply(rule TrueI) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
161 |
apply(simp_all add:permute_bv eqvts) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
162 |
done |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
163 |
|
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
164 |
lemma perm_bv2: |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
165 |
"p \<bullet> bv l = bv (permute_bv p l)" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
166 |
apply(induct l rule: inducts(9)) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
167 |
apply(rule TrueI) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
168 |
apply(simp_all add:permute_bv) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
169 |
apply(simp add: perm_bv1[symmetric]) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
170 |
apply(simp add: eqvts) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
171 |
done |
1646
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
172 |
|
1648 | 173 |
lemma alpha_perm_bn1: |
174 |
" alpha_bv_tvtk tvtk_lst (permute_bv_tvtk q tvtk_lst)" |
|
175 |
"alpha_bv_tvck tvck_lst (permute_bv_tvck q tvck_lst)" |
|
176 |
"alpha_bv_vt vt_lst (permute_bv_vt q vt_lst)" |
|
177 |
apply(induct tvtk_lst rule: inducts(11)) |
|
178 |
apply(simp_all add:permute_bv eqvts eq_iff) |
|
179 |
apply(induct tvck_lst rule: inducts(12)) |
|
180 |
apply(simp_all add:permute_bv eqvts eq_iff) |
|
181 |
apply(induct vt_lst rule: inducts(10)) |
|
182 |
apply(simp_all add:permute_bv eqvts eq_iff) |
|
183 |
done |
|
184 |
||
185 |
lemma alpha_perm_bn: |
|
186 |
"alpha_bv pat (permute_bv q pat)" |
|
187 |
apply(induct pat rule: inducts(9)) |
|
188 |
apply(simp_all add:permute_bv eqvts eq_iff alpha_perm_bn1) |
|
189 |
done |
|
190 |
||
1646
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
191 |
lemma ACons_subst: |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
192 |
"supp (Abs (bv pat) trm) \<sharp>* q \<Longrightarrow> (ACons pat trm al) = ACons (permute_bv q pat) (q \<bullet> trm) al" |
1648 | 193 |
apply (simp only: eq_iff) |
194 |
apply (rule_tac x="q" in exI) |
|
195 |
apply (simp add: alphas) |
|
196 |
apply (simp add: perm_bv2[symmetric]) |
|
197 |
apply (simp add: eqvts[symmetric]) |
|
1658 | 198 |
apply (simp add: supp_abs) |
1648 | 199 |
apply (simp add: fv_supp) |
200 |
apply (simp add: alpha_perm_bn) |
|
201 |
apply (rule supp_perm_eq[symmetric]) |
|
202 |
apply (subst supp_finite_atom_set) |
|
203 |
apply (rule finite_Diff) |
|
204 |
apply (simp add: finite_supp) |
|
205 |
apply (assumption) |
|
206 |
done |
|
1646
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
207 |
|
1647
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
208 |
lemma permute_bv_zero1: |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
209 |
"permute_bv_tvck 0 b = b" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
210 |
"permute_bv_tvtk 0 c = c" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
211 |
"permute_bv_vt 0 d = d" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
212 |
apply(induct b rule: inducts(12)) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
213 |
apply(rule TrueI) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
214 |
apply(simp_all add:permute_bv eqvts) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
215 |
apply(induct c rule: inducts(11)) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
216 |
apply(rule TrueI) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
217 |
apply(simp_all add:permute_bv eqvts) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
218 |
apply(induct d rule: inducts(10)) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
219 |
apply(rule TrueI) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
220 |
apply(simp_all add:permute_bv eqvts) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
221 |
done |
1646
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
222 |
|
1647
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
223 |
lemma permute_bv_zero2: |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
224 |
"permute_bv 0 a = a" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
225 |
apply(induct a rule: inducts(9)) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
226 |
apply(rule TrueI) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
227 |
apply(simp_all add:permute_bv eqvts permute_bv_zero1) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
228 |
done |
1646
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
229 |
|
1635
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
230 |
lemma fv_alpha1: "fv_bv_tvtk x \<sharp>* pa \<Longrightarrow> alpha_bv_tvtk (pa \<bullet> x) x" |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
231 |
apply (induct x rule: inducts(11)) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
232 |
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *}) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
233 |
apply (simp_all add: eq_iff fresh_star_union) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
234 |
apply (subst supp_perm_eq) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
235 |
apply (simp_all add: fv_supp) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
236 |
done |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
237 |
|
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
238 |
lemma fv_alpha2: "fv_bv_tvck x \<sharp>* pa \<Longrightarrow> alpha_bv_tvck (pa \<bullet> x) x" |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
239 |
apply (induct x rule: inducts(12)) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
240 |
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *}) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
241 |
apply (simp_all add: eq_iff fresh_star_union) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
242 |
apply (subst supp_perm_eq) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
243 |
apply (simp_all add: fv_supp) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
244 |
done |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
245 |
|
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
246 |
lemma fv_alpha3: "fv_bv_vt x \<sharp>* pa \<Longrightarrow> alpha_bv_vt (pa \<bullet> x) x" |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
247 |
apply (induct x rule: inducts(10)) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
248 |
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *}) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
249 |
apply (simp_all add: eq_iff fresh_star_union) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
250 |
apply (subst supp_perm_eq) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
251 |
apply (simp_all add: fv_supp) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
252 |
done |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
253 |
|
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
254 |
lemma fv_alpha: "fv_bv x \<sharp>* pa \<Longrightarrow> alpha_bv (pa \<bullet> x) x" |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
255 |
apply (induct x rule: inducts(9)) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
256 |
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *}) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
257 |
apply (simp_all add: eq_iff fresh_star_union) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
258 |
apply (simp add: fv_alpha1 fv_alpha2 fv_alpha3) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
259 |
apply (simp add: eqvts) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
260 |
done |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
261 |
|
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
262 |
lemma fin1: "finite (fv_bv_tvtk x)" |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
263 |
apply (induct x rule: inducts(11)) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
264 |
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *}) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
265 |
apply (simp_all add: fv_supp finite_supp) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
266 |
done |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
267 |
|
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
268 |
lemma fin2: "finite (fv_bv_tvck x)" |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
269 |
apply (induct x rule: inducts(12)) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
270 |
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *}) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
271 |
apply (simp_all add: fv_supp finite_supp) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
272 |
done |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
273 |
|
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
274 |
lemma fin3: "finite (fv_bv_vt x)" |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
275 |
apply (induct x rule: inducts(10)) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
276 |
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *}) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
277 |
apply (simp_all add: fv_supp finite_supp) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
278 |
done |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
279 |
|
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
280 |
lemma fin_fv_bv: "finite (fv_bv x)" |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
281 |
apply (induct x rule: inducts(9)) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
282 |
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *}) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
283 |
apply (simp add: fin1 fin2 fin3) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
284 |
done |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
285 |
|
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
286 |
lemma finb1: "finite (bv_tvtk x)" |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
287 |
apply (induct x rule: inducts(11)) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
288 |
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *}) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
289 |
apply (simp_all add: fv_supp finite_supp) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
290 |
done |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
291 |
|
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
292 |
lemma finb2: "finite (bv_tvck x)" |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
293 |
apply (induct x rule: inducts(12)) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
294 |
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *}) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
295 |
apply (simp_all add: fv_supp finite_supp) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
296 |
done |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
297 |
|
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
298 |
lemma finb3: "finite (bv_vt x)" |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
299 |
apply (induct x rule: inducts(10)) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
300 |
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *}) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
301 |
apply (simp_all add: fv_supp finite_supp) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
302 |
done |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
303 |
|
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
304 |
lemma fin_bv: "finite (bv x)" |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
305 |
apply (induct x rule: inducts(9)) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
306 |
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *}) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
307 |
apply (simp add: finb1 finb2 finb3) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
308 |
done |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
309 |
|
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
310 |
lemma "bv x \<sharp>* fv_bv x" |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
311 |
apply (induct x rule: inducts(9)) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
312 |
apply (tactic {* ALLGOALS (TRY o rtac @{thm TrueI}) *}) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
313 |
apply (simp) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
314 |
oops |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
315 |
|
1667 | 316 |
lemma strong_inudction_principle: |
1631
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
317 |
assumes a01: "\<And>b. P1 b KStar" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
318 |
and a02: "\<And>tkind1 tkind2 b. \<lbrakk>\<And>c. P1 c tkind1; \<And>c. P1 c tkind2\<rbrakk> \<Longrightarrow> P1 b (KFun tkind1 tkind2)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
319 |
and a03: "\<And>ty1 ty2 b. \<lbrakk>\<And>c. P3 c ty1; \<And>c. P3 c ty2\<rbrakk> \<Longrightarrow> P2 b (CKEq ty1 ty2)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
320 |
and a04: "\<And>tvar b. P3 b (TVar tvar)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
321 |
and a05: "\<And>char b. P3 b (TC char)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
322 |
and a06: "\<And>ty1 ty2 b. \<lbrakk>\<And>c. P3 c ty1; \<And>c. P3 c ty2\<rbrakk> \<Longrightarrow> P3 b (TApp ty1 ty2)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
323 |
and a07: "\<And>char ty_lst b. \<lbrakk>\<And>c. P4 c ty_lst\<rbrakk> \<Longrightarrow> P3 b (TFun char ty_lst)" |
1632
68c8666453f7
Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1631
diff
changeset
|
324 |
and a08: "\<And>tvar tkind ty b. \<lbrakk>\<And>c. P1 c tkind; \<And>c. P3 c ty; atom tvar \<sharp> b\<rbrakk> |
68c8666453f7
Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1631
diff
changeset
|
325 |
\<Longrightarrow> P3 b (TAll tvar tkind ty)" |
1631
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
326 |
and a09: "\<And>ty1 ty2 ty3 b. \<lbrakk>\<And>c. P3 c ty1; \<And>c. P3 c ty2; \<And>c. P3 c ty3\<rbrakk> \<Longrightarrow> P3 b (TEq ty1 ty2 ty3)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
327 |
and a10: "\<And>b. P4 b TsNil" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
328 |
and a11: "\<And>ty ty_lst b. \<lbrakk>\<And>c. P3 c ty; \<And>c. P4 c ty_lst\<rbrakk> \<Longrightarrow> P4 b (TsCons ty ty_lst)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
329 |
and a12: "\<And>char b. P5 b (CC char)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
330 |
and a13: "\<And>co1 co2 b. \<lbrakk>\<And>c. P5 c co1; \<And>c. P5 c co2\<rbrakk> \<Longrightarrow> P5 b (CApp co1 co2)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
331 |
and a14: "\<And>char co_lst b. \<lbrakk>\<And>c. P6 c co_lst\<rbrakk> \<Longrightarrow> P5 b (CFun char co_lst)" |
1632
68c8666453f7
Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1631
diff
changeset
|
332 |
and a15: "\<And>tvar ckind co b. \<lbrakk>\<And>c. P2 c ckind; \<And>c. P5 c co; atom tvar \<sharp> b\<rbrakk> |
68c8666453f7
Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1631
diff
changeset
|
333 |
\<Longrightarrow> P5 b (CAll tvar ckind co)" |
1631
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
334 |
and a16: "\<And>co1 co2 co3 b. \<lbrakk>\<And>c. P5 c co1; \<And>c. P5 c co2; \<And>c. P5 c co3\<rbrakk> \<Longrightarrow> P5 b (CEq co1 co2 co3)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
335 |
and a17: "\<And>co b. \<lbrakk>\<And>c. P5 c co\<rbrakk> \<Longrightarrow> P5 b (CSym co)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
336 |
and a18: "\<And>co1 co2 b. \<lbrakk>\<And>c. P5 c co1; \<And>c. P5 c co2\<rbrakk> \<Longrightarrow> P5 b (CCir co1 co2)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
337 |
and a19: "\<And>co b. \<lbrakk>\<And>c. P5 c co\<rbrakk> \<Longrightarrow> P5 b (CLeft co)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
338 |
and a20: "\<And>co b. \<lbrakk>\<And>c. P5 c co\<rbrakk> \<Longrightarrow> P5 b (CRight co)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
339 |
and a21: "\<And>co b. \<lbrakk>\<And>c. P5 c co\<rbrakk> \<Longrightarrow> P5 b (CSim co)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
340 |
and a22: "\<And>co b. \<lbrakk>\<And>c. P5 c co\<rbrakk> \<Longrightarrow> P5 b (CRightc co)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
341 |
and a23: "\<And>co b. \<lbrakk>\<And>c. P5 c co\<rbrakk> \<Longrightarrow> P5 b (CLeftc co)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
342 |
and a24: "\<And>co1 co2 b. \<lbrakk>\<And>c. P5 c co1; \<And>c. P5 c co2\<rbrakk> \<Longrightarrow> P5 b (CCoe co1 co2)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
343 |
and a25: "\<And>b. P6 b CsNil" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
344 |
and a26: "\<And>co co_lst b. \<lbrakk>\<And>c. P5 c co; \<And>c. P6 c co_lst\<rbrakk> \<Longrightarrow> P6 b (CsCons co co_lst)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
345 |
and a27: "\<And>var b. P7 b (Var var)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
346 |
and a28: "\<And>char b. P7 b (C char)" |
1632
68c8666453f7
Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1631
diff
changeset
|
347 |
and a29: "\<And>tvar tkind trm b. \<lbrakk>\<And>c. P1 c tkind; \<And>c. P7 c trm; atom tvar \<sharp> b\<rbrakk> |
68c8666453f7
Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1631
diff
changeset
|
348 |
\<Longrightarrow> P7 b (LAMT tvar tkind trm)" |
68c8666453f7
Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1631
diff
changeset
|
349 |
and a30: "\<And>tvar ckind trm b. \<lbrakk>\<And>c. P2 c ckind; \<And>c. P7 c trm; atom tvar \<sharp> b\<rbrakk> |
68c8666453f7
Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1631
diff
changeset
|
350 |
\<Longrightarrow> P7 b (LAMC tvar ckind trm)" |
1631
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
351 |
and a31: "\<And>trm ty b. \<lbrakk>\<And>c. P7 c trm; \<And>c. P3 c ty\<rbrakk> \<Longrightarrow> P7 b (APP trm ty)" |
1632
68c8666453f7
Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1631
diff
changeset
|
352 |
and a32: "\<And>var ty trm b. \<lbrakk>\<And>c. P3 c ty; \<And>c. P7 c trm; atom var \<sharp> b\<rbrakk> \<Longrightarrow> P7 b (Lam var ty trm)" |
1631
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
353 |
and a33: "\<And>trm1 trm2 b. \<lbrakk>\<And>c. P7 c trm1; \<And>c. P7 c trm2\<rbrakk> \<Longrightarrow> P7 b (App trm1 trm2)" |
1632
68c8666453f7
Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1631
diff
changeset
|
354 |
and a34: "\<And>var ty trm1 trm2 b. \<lbrakk>\<And>c. P3 c ty; \<And>c. P7 c trm1; \<And>c. P7 c trm2; atom var \<sharp> b\<rbrakk> |
1631
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
355 |
\<Longrightarrow> P7 b (Let var ty trm1 trm2)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
356 |
and a35: "\<And>trm assoc_lst b. \<lbrakk>\<And>c. P7 c trm; \<And>c. P8 c assoc_lst\<rbrakk> \<Longrightarrow> P7 b (Case trm assoc_lst)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
357 |
and a36: "\<And>trm ty b. \<lbrakk>\<And>c. P7 c trm; \<And>c. P3 c ty\<rbrakk> \<Longrightarrow> P7 b (Cast trm ty)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
358 |
and a37: "\<And>b. P8 b ANil" |
1632
68c8666453f7
Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1631
diff
changeset
|
359 |
and a38: "\<And>pat trm assoc_lst b. \<lbrakk>\<And>c. P9 c pat; \<And>c. P7 c trm; \<And>c. P8 c assoc_lst; bv(pat) \<sharp>* b\<rbrakk> |
1631
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
360 |
\<Longrightarrow> P8 b (ACons pat trm assoc_lst)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
361 |
and a39: "\<And>char tvtk_lst tvck_lst vt_lst b. \<lbrakk>\<And>c. P11 c tvtk_lst; \<And>c. P12 c tvck_lst; \<And>c. P10 c vt_lst\<rbrakk> |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
362 |
\<Longrightarrow> P9 b (K char tvtk_lst tvck_lst vt_lst)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
363 |
and a40: "\<And>b. P10 b VTNil" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
364 |
and a41: "\<And>var ty vt_lst b. \<lbrakk>\<And>c. P3 c ty; \<And>c. P10 c vt_lst\<rbrakk> \<Longrightarrow> P10 b (VTCons var ty vt_lst)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
365 |
and a42: "\<And>b. P11 b TVTKNil" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
366 |
and a43: "\<And>tvar tkind tvtk_lst b. \<lbrakk>\<And>c. P1 c tkind; \<And>c. P11 c tvtk_lst\<rbrakk> |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
367 |
\<Longrightarrow> P11 b (TVTKCons tvar tkind tvtk_lst)" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
368 |
and a44: "\<And>b. P12 b TVCKNil" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
369 |
and a45: "\<And>tvar ckind tvck_lst b. \<lbrakk>\<And>c. P2 c ckind; \<And>c. P12 c tvck_lst\<rbrakk> |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
370 |
\<Longrightarrow> P12 b (TVCKCons tvar ckind tvck_lst)" |
1632
68c8666453f7
Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1631
diff
changeset
|
371 |
shows "P1 (a :: 'a :: pt) tkind \<and> |
1631
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
372 |
P2 (b :: 'b :: pt) ckind \<and> |
1634
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
373 |
P3 (c :: 'c :: {pt,fs}) ty \<and> |
1631
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
374 |
P4 (d :: 'd :: pt) ty_lst \<and> |
1635
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
375 |
P5 (e :: 'e :: {pt,fs}) co \<and> |
1631
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
376 |
P6 (f :: 'f :: pt) co_lst \<and> |
1645
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
377 |
P7 (g :: 'g :: {pt,fs}) trm \<and> |
1635
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
378 |
P8 (h :: 'h :: {pt,fs}) assoc_lst \<and> |
1631
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
379 |
P9 (i :: 'i :: pt) pat \<and> |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
380 |
P10 (j :: 'j :: pt) vt_lst \<and> |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
381 |
P11 (k :: 'k :: pt) tvtk_lst \<and> |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
382 |
P12 (l :: 'l :: pt) tvck_lst" |
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
383 |
proof - |
1647
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
384 |
have a1: "(\<forall>p a. P1 a (p \<bullet> tkind))" and "(\<forall>p b. P2 b (p \<bullet> ckind))" and "(\<forall>p c. P3 c (p \<bullet> ty))" and "(\<forall>p d. P4 d (p \<bullet> ty_lst))" and "(\<forall>p e. P5 e (p \<bullet> co))" and " (\<forall>p f. P6 f (p \<bullet> co_lst))" and "(\<forall>p g. P7 g (p \<bullet> trm))" and "(\<forall>p h. P8 h (p \<bullet> assoc_lst))" and a1:"(\<forall>p q i. P9 i (permute_bv p (q \<bullet> pat)))" and a2:"(\<forall>p q j. P10 j (permute_bv_vt q (p \<bullet> vt_lst)))" and a3:"(\<forall>p q k. P11 k ( permute_bv_tvtk q (p \<bullet> tvtk_lst)))" and a4:"(\<forall>p q l. P12 l (permute_bv_tvck q (p \<bullet> tvck_lst)))" |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
385 |
apply (induct rule: tkind_ckind_ty_ty_lst_co_co_lst_trm_assoc_lst_pat_vt_lst_tvtk_lst_tvck_lst.inducts) |
1632
68c8666453f7
Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1631
diff
changeset
|
386 |
apply (tactic {* ALLGOALS (REPEAT o rtac allI) *}) |
68c8666453f7
Started proving strong induction.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1631
diff
changeset
|
387 |
apply (tactic {* ALLGOALS (TRY o SOLVED' (simp_tac @{simpset} THEN_ALL_NEW resolve_tac @{thms assms} THEN_ALL_NEW asm_full_simp_tac @{simpset})) *}) |
1635
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
388 |
|
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
389 |
(* GOAL1 *) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
390 |
apply(subgoal_tac "\<exists>pa. ((pa \<bullet> (atom (p \<bullet> tvar))) \<sharp> c \<and> |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
391 |
supp (Abs (p \<bullet> {atom tvar}) (p \<bullet> ty)) \<sharp>* pa)") |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
392 |
apply clarify |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
393 |
apply (simp only: perm) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
394 |
apply(rule_tac t="TAll (p \<bullet> tvar) (p \<bullet> tkind) (p \<bullet> ty)" |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
395 |
and s="TAll (pa \<bullet> p \<bullet> tvar) (p \<bullet> tkind) (pa \<bullet> p \<bullet> ty)" in subst) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
396 |
apply (simp only: eq_iff) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
397 |
apply (rule_tac x="-pa" in exI) |
1658 | 398 |
apply (simp add: alphas eqvts eqvts_raw supp_abs fv_supp) |
1635
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
399 |
apply (rule_tac t="supp (pa \<bullet> p \<bullet> ty) - {atom (pa \<bullet> p \<bullet> tvar)}" |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
400 |
and s="pa \<bullet> (p \<bullet> supp ty - {p \<bullet> atom tvar})" in subst) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
401 |
apply (simp add: eqvts) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
402 |
apply (simp add: eqvts[symmetric]) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
403 |
apply (rule conjI) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
404 |
apply (rule supp_perm_eq) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
405 |
apply (simp add: eqvts) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
406 |
apply (subst supp_finite_atom_set) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
407 |
apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
408 |
apply (simp add: eqvts) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
409 |
apply (simp add: eqvts) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
410 |
apply (subst supp_perm_eq) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
411 |
apply (subst supp_finite_atom_set) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
412 |
apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
413 |
apply (simp add: eqvts) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
414 |
apply assumption |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
415 |
apply (simp add: fresh_star_minus_perm) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
416 |
apply (rule a08) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
417 |
apply simp |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
418 |
apply(rotate_tac 1) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
419 |
apply(erule_tac x="(pa + p)" in allE) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
420 |
apply simp |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
421 |
apply (simp add: eqvts eqvts_raw) |
1634
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
422 |
apply (rule at_set_avoiding2_atom) |
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
423 |
apply (simp add: finite_supp) |
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
424 |
apply (simp add: finite_supp) |
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
425 |
apply (simp add: fresh_def) |
1658 | 426 |
apply (simp only: supp_abs eqvts) |
1634
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
427 |
apply blast |
1635
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
428 |
|
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
429 |
(* GOAL2 *) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
430 |
apply(subgoal_tac "\<exists>pa. ((pa \<bullet> (atom (p \<bullet> tvar))) \<sharp> e \<and> |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
431 |
supp (Abs (p \<bullet> {atom tvar}) (p \<bullet> co)) \<sharp>* pa)") |
1634
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
432 |
apply clarify |
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
433 |
apply (simp only: perm) |
1635
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
434 |
apply(rule_tac t="CAll (p \<bullet> tvar) (p \<bullet> ckind) (p \<bullet> co)" |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
435 |
and s="CAll (pa \<bullet> p \<bullet> tvar) (p \<bullet> ckind) (pa \<bullet> p \<bullet> co)" in subst) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
436 |
apply (simp only: eq_iff) |
1634
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
437 |
apply (rule_tac x="-pa" in exI) |
1658 | 438 |
apply (simp add: alphas eqvts eqvts_raw supp_abs fv_supp) |
1635
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
439 |
apply (rule_tac t="supp (pa \<bullet> p \<bullet> co) - {atom (pa \<bullet> p \<bullet> tvar)}" |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
440 |
and s="pa \<bullet> (p \<bullet> supp co - {p \<bullet> atom tvar})" in subst) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
441 |
apply (simp add: eqvts) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
442 |
apply (simp add: eqvts[symmetric]) |
1634
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
443 |
apply (rule conjI) |
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
444 |
apply (rule supp_perm_eq) |
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
445 |
apply (simp add: eqvts) |
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
446 |
apply (subst supp_finite_atom_set) |
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
447 |
apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp) |
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
448 |
apply (simp add: eqvts) |
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
449 |
apply (simp add: eqvts) |
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
450 |
apply (subst supp_perm_eq) |
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
451 |
apply (subst supp_finite_atom_set) |
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
452 |
apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp) |
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
453 |
apply (simp add: eqvts) |
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
454 |
apply assumption |
b6656b707a8d
Solved one of the strong-induction goals.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1632
diff
changeset
|
455 |
apply (simp add: fresh_star_minus_perm) |
1635
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
456 |
apply (rule a15) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
457 |
apply simp |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
458 |
apply(rotate_tac 1) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
459 |
apply(erule_tac x="(pa + p)" in allE) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
460 |
apply simp |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
461 |
apply (simp add: eqvts eqvts_raw) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
462 |
apply (rule at_set_avoiding2_atom) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
463 |
apply (simp add: finite_supp) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
464 |
apply (simp add: finite_supp) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
465 |
apply (simp add: fresh_def) |
1658 | 466 |
apply (simp only: supp_abs eqvts) |
1635
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
467 |
apply blast |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
468 |
|
1645
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
469 |
|
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
470 |
(* GOAL3 a copy-and-paste of Goal2 with consts and variable names changed *) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
471 |
apply(subgoal_tac "\<exists>pa. ((pa \<bullet> (atom (p \<bullet> tvar))) \<sharp> g \<and> |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
472 |
supp (Abs (p \<bullet> {atom tvar}) (p \<bullet> trm)) \<sharp>* pa)") |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
473 |
apply clarify |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
474 |
apply (simp only: perm) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
475 |
apply(rule_tac t="LAMT (p \<bullet> tvar) (p \<bullet> tkind) (p \<bullet> trm)" |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
476 |
and s="LAMT (pa \<bullet> p \<bullet> tvar) (p \<bullet> tkind) (pa \<bullet> p \<bullet> trm)" in subst) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
477 |
apply (simp only: eq_iff) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
478 |
apply (rule_tac x="-pa" in exI) |
1658 | 479 |
apply (simp add: alphas eqvts eqvts_raw supp_abs fv_supp) |
1645
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
480 |
apply (rule_tac t="supp (pa \<bullet> p \<bullet> trm) - {atom (pa \<bullet> p \<bullet> tvar)}" |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
481 |
and s="pa \<bullet> (p \<bullet> supp trm - {p \<bullet> atom tvar})" in subst) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
482 |
apply (simp add: eqvts) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
483 |
apply (simp add: eqvts[symmetric]) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
484 |
apply (rule conjI) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
485 |
apply (rule supp_perm_eq) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
486 |
apply (simp add: eqvts) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
487 |
apply (subst supp_finite_atom_set) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
488 |
apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
489 |
apply (simp add: eqvts) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
490 |
apply (simp add: eqvts) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
491 |
apply (subst supp_perm_eq) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
492 |
apply (subst supp_finite_atom_set) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
493 |
apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
494 |
apply (simp add: eqvts) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
495 |
apply assumption |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
496 |
apply (simp add: fresh_star_minus_perm) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
497 |
apply (rule a29) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
498 |
apply simp |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
499 |
apply(rotate_tac 1) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
500 |
apply(erule_tac x="(pa + p)" in allE) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
501 |
apply simp |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
502 |
apply (simp add: eqvts eqvts_raw) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
503 |
apply (rule at_set_avoiding2_atom) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
504 |
apply (simp add: finite_supp) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
505 |
apply (simp add: finite_supp) |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
506 |
apply (simp add: fresh_def) |
1658 | 507 |
apply (simp only: supp_abs eqvts) |
1645
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
508 |
apply blast |
bde8da26093e
One more copy-and-paste in core-haskell.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1635
diff
changeset
|
509 |
|
1646
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
510 |
(* GOAL4 a copy-and-paste *) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
511 |
apply(subgoal_tac "\<exists>pa. ((pa \<bullet> (atom (p \<bullet> tvar))) \<sharp> g \<and> |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
512 |
supp (Abs (p \<bullet> {atom tvar}) (p \<bullet> trm)) \<sharp>* pa)") |
1635
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
513 |
apply clarify |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
514 |
apply (simp only: perm) |
1646
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
515 |
apply(rule_tac t="LAMC (p \<bullet> tvar) (p \<bullet> ckind) (p \<bullet> trm)" |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
516 |
and s="LAMC (pa \<bullet> p \<bullet> tvar) (p \<bullet> ckind) (pa \<bullet> p \<bullet> trm)" in subst) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
517 |
apply (simp only: eq_iff) |
1635
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
518 |
apply (rule_tac x="-pa" in exI) |
1658 | 519 |
apply (simp add: alphas eqvts eqvts_raw supp_abs fv_supp) |
1646
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
520 |
apply (rule_tac t="supp (pa \<bullet> p \<bullet> trm) - {atom (pa \<bullet> p \<bullet> tvar)}" |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
521 |
and s="pa \<bullet> (p \<bullet> supp trm - {p \<bullet> atom tvar})" in subst) |
1635
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
522 |
apply (simp add: eqvts) |
1646
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
523 |
apply (simp add: eqvts[symmetric]) |
1635
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
524 |
apply (rule conjI) |
1646
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
525 |
apply (rule supp_perm_eq) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
526 |
apply (simp add: eqvts) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
527 |
apply (subst supp_finite_atom_set) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
528 |
apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
529 |
apply (simp add: eqvts) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
530 |
apply (simp add: eqvts) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
531 |
apply (subst supp_perm_eq) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
532 |
apply (subst supp_finite_atom_set) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
533 |
apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
534 |
apply (simp add: eqvts) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
535 |
apply assumption |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
536 |
apply (simp add: fresh_star_minus_perm) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
537 |
apply (rule a30) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
538 |
apply simp |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
539 |
apply(rotate_tac 1) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
540 |
apply(erule_tac x="(pa + p)" in allE) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
541 |
apply simp |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
542 |
apply (simp add: eqvts eqvts_raw) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
543 |
apply (rule at_set_avoiding2_atom) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
544 |
apply (simp add: finite_supp) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
545 |
apply (simp add: finite_supp) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
546 |
apply (simp add: fresh_def) |
1658 | 547 |
apply (simp only: supp_abs eqvts) |
1646
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
548 |
apply blast |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
549 |
|
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
550 |
|
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
551 |
(* GOAL5 a copy-and-paste *) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
552 |
apply(subgoal_tac "\<exists>pa. ((pa \<bullet> (atom (p \<bullet> var))) \<sharp> g \<and> |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
553 |
supp (Abs (p \<bullet> {atom var}) (p \<bullet> trm)) \<sharp>* pa)") |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
554 |
apply clarify |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
555 |
apply (simp only: perm) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
556 |
apply(rule_tac t="Lam (p \<bullet> var) (p \<bullet> ty) (p \<bullet> trm)" |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
557 |
and s="Lam (pa \<bullet> p \<bullet> var) (p \<bullet> ty) (pa \<bullet> p \<bullet> trm)" in subst) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
558 |
apply (simp only: eq_iff) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
559 |
apply (rule_tac x="-pa" in exI) |
1658 | 560 |
apply (simp add: alphas eqvts eqvts_raw supp_abs fv_supp) |
1646
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
561 |
apply (rule_tac t="supp (pa \<bullet> p \<bullet> trm) - {atom (pa \<bullet> p \<bullet> var)}" |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
562 |
and s="pa \<bullet> (p \<bullet> supp trm - {p \<bullet> atom var})" in subst) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
563 |
apply (simp add: eqvts) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
564 |
apply (simp add: eqvts[symmetric]) |
1635
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
565 |
apply (rule conjI) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
566 |
apply (rule supp_perm_eq) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
567 |
apply (simp add: eqvts) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
568 |
apply (subst supp_finite_atom_set) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
569 |
apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
570 |
apply (simp add: eqvts) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
571 |
apply (simp add: eqvts) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
572 |
apply (subst supp_perm_eq) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
573 |
apply (subst supp_finite_atom_set) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
574 |
apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
575 |
apply (simp add: eqvts) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
576 |
apply assumption |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
577 |
apply (simp add: fresh_star_minus_perm) |
1646
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
578 |
apply (rule a32) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
579 |
apply simp |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
580 |
apply(rotate_tac 1) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
581 |
apply(erule_tac x="(pa + p)" in allE) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
582 |
apply simp |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
583 |
apply (simp add: eqvts eqvts_raw) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
584 |
apply (rule at_set_avoiding2_atom) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
585 |
apply (simp add: finite_supp) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
586 |
apply (simp add: finite_supp) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
587 |
apply (simp add: fresh_def) |
1658 | 588 |
apply (simp only: supp_abs eqvts) |
1646
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
589 |
apply blast |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
590 |
|
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
591 |
|
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
592 |
(* GOAL6 a copy-and-paste *) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
593 |
apply(subgoal_tac "\<exists>pa. ((pa \<bullet> (atom (p \<bullet> var))) \<sharp> g \<and> |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
594 |
supp (Abs (p \<bullet> {atom var}) (p \<bullet> trm2)) \<sharp>* pa)") |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
595 |
apply clarify |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
596 |
apply (simp only: perm) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
597 |
apply(rule_tac t="Let (p \<bullet> var) (p \<bullet> ty) (p \<bullet> trm1) (p \<bullet> trm2)" |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
598 |
and s="Let (pa \<bullet> p \<bullet> var) (p \<bullet> ty) (p \<bullet> trm1) (pa \<bullet> p \<bullet> trm2)" in subst) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
599 |
apply (simp only: eq_iff) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
600 |
apply (rule_tac x="-pa" in exI) |
1658 | 601 |
apply (simp add: alphas eqvts eqvts_raw supp_abs fv_supp) |
1646
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
602 |
apply (rule_tac t="supp (pa \<bullet> p \<bullet> trm2) - {atom (pa \<bullet> p \<bullet> var)}" |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
603 |
and s="pa \<bullet> (p \<bullet> supp trm2 - {p \<bullet> atom var})" in subst) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
604 |
apply (simp add: eqvts) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
605 |
apply (simp add: eqvts[symmetric]) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
606 |
apply (rule conjI) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
607 |
apply (rule supp_perm_eq) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
608 |
apply (simp add: eqvts) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
609 |
apply (subst supp_finite_atom_set) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
610 |
apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
611 |
apply (simp add: eqvts) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
612 |
apply (simp add: eqvts) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
613 |
apply (subst supp_perm_eq) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
614 |
apply (subst supp_finite_atom_set) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
615 |
apply (simp add: eqvts[symmetric] finite_eqvt[symmetric] finite_supp) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
616 |
apply (simp add: eqvts) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
617 |
apply assumption |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
618 |
apply (simp add: fresh_star_minus_perm) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
619 |
apply (rule a34) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
620 |
apply simp |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
621 |
apply simp |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
622 |
apply(rotate_tac 2) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
623 |
apply(erule_tac x="(pa + p)" in allE) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
624 |
apply simp |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
625 |
apply (simp add: eqvts eqvts_raw) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
626 |
apply (rule at_set_avoiding2_atom) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
627 |
apply (simp add: finite_supp) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
628 |
apply (simp add: finite_supp) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
629 |
apply (simp add: fresh_def) |
1658 | 630 |
apply (simp only: supp_abs eqvts) |
1646
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
631 |
apply blast |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
632 |
|
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
633 |
(* MAIN ACons Goal *) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
634 |
apply(subgoal_tac "\<exists>pa. ((pa \<bullet> (bv (p \<bullet> pat))) \<sharp>* h \<and> |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
635 |
supp (Abs (p \<bullet> (bv pat)) (p \<bullet> trm)) \<sharp>* pa)") |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
636 |
apply clarify |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
637 |
apply (simp only: perm eqvts) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
638 |
apply (subst ACons_subst) |
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
639 |
apply assumption |
1635
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
640 |
apply (rule a38) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
641 |
apply simp |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
642 |
apply(rotate_tac 1) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
643 |
apply(erule_tac x="(pa + p)" in allE) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
644 |
apply simp |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
645 |
apply simp |
1647
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
646 |
apply (simp add: perm_bv2[symmetric]) |
1635
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
647 |
apply (simp add: eqvts eqvts_raw) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
648 |
apply (rule at_set_avoiding2) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
649 |
apply (simp add: fin_bv) |
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
650 |
apply (simp add: finite_supp) |
1658 | 651 |
apply (simp add: supp_abs) |
1635
8b4595cb5524
Further in the strong induction proof.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1634
diff
changeset
|
652 |
apply (rule finite_Diff) |
1646
733bac87d5bf
Solved all boring subgoals, and looking at properly defning permute_bv
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1645
diff
changeset
|
653 |
apply (simp add: finite_supp) |
1658 | 654 |
apply (simp add: fresh_star_def fresh_def supp_abs eqvts) |
1647
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
655 |
done |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
656 |
then have b: "P1 a (0 \<bullet> tkind)" and "P2 b (0 \<bullet> ckind)" "P3 c (0 \<bullet> ty)" and "P4 d (0 \<bullet> ty_lst)" and "P5 e (0 \<bullet> co)" and "P6 f (0 \<bullet> co_lst)" and "P7 g (0 \<bullet> trm)" and "P8 h (0 \<bullet> assoc_lst)" by (blast+) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
657 |
moreover have "P9 i (permute_bv 0 (0 \<bullet> pat))" and "P10 j (permute_bv_vt 0 (0 \<bullet> vt_lst))" and "P11 k (permute_bv_tvtk 0 (0 \<bullet> tvtk_lst))" and "P12 l (permute_bv_tvck 0 (0 \<bullet> tvck_lst))" using a1 a2 a3 a4 by (blast+) |
032649a694d2
Only ACons_subst left to show.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1646
diff
changeset
|
658 |
ultimately show ?thesis by (simp_all add: permute_bv_zero1 permute_bv_zero2) |
1631
e94bfef17bb8
stating the strong induction; further.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1630
diff
changeset
|
659 |
qed |
1615
0ea578c6dae3
Parsing bn functions that call other bn functions and transmitting this information to fv/alpha.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1609
diff
changeset
|
660 |
|
1601 | 661 |
end |
662 |