| author | Cezary Kaliszyk <kaliszyk@in.tum.de> |
| Tue, 15 Jun 2010 09:12:54 +0200 | |
| changeset 2266 | dcffc2f132c9 |
| parent 2177 | 9b566c5dc1f5 |
| child 2301 | 8732ff59068b |
| permissions | -rw-r--r-- |
|
1596
c69d9fb16785
Move Ex1 and Ex2 out of Test
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
1 |
theory Ex2 |
|
2026
7f504136149b
Another example where only alpha_eqvt fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1773
diff
changeset
|
2 |
imports "../NewParser" |
|
1596
c69d9fb16785
Move Ex1 and Ex2 out of Test
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
3 |
begin |
|
c69d9fb16785
Move Ex1 and Ex2 out of Test
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
4 |
|
|
c69d9fb16785
Move Ex1 and Ex2 out of Test
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
5 |
text {* example 2 *}
|
|
c69d9fb16785
Move Ex1 and Ex2 out of Test
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
6 |
|
|
c69d9fb16785
Move Ex1 and Ex2 out of Test
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
7 |
atom_decl name |
|
c69d9fb16785
Move Ex1 and Ex2 out of Test
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
8 |
|
|
2026
7f504136149b
Another example where only alpha_eqvt fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1773
diff
changeset
|
9 |
nominal_datatype trm = |
|
1596
c69d9fb16785
Move Ex1 and Ex2 out of Test
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
10 |
Var "name" |
|
2026
7f504136149b
Another example where only alpha_eqvt fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1773
diff
changeset
|
11 |
| App "trm" "trm" |
|
7f504136149b
Another example where only alpha_eqvt fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1773
diff
changeset
|
12 |
| Lam x::"name" t::"trm" bind_set x in t |
|
2177
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
13 |
| Let p::"pat" "trm" t::"trm" bind "f p" in t |
|
2026
7f504136149b
Another example where only alpha_eqvt fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1773
diff
changeset
|
14 |
and pat = |
|
1596
c69d9fb16785
Move Ex1 and Ex2 out of Test
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
15 |
PN |
|
c69d9fb16785
Move Ex1 and Ex2 out of Test
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
16 |
| PS "name" |
|
c69d9fb16785
Move Ex1 and Ex2 out of Test
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
17 |
| PD "name" "name" |
|
c69d9fb16785
Move Ex1 and Ex2 out of Test
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
18 |
binder |
|
2177
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
19 |
f::"pat \<Rightarrow> atom list" |
|
1596
c69d9fb16785
Move Ex1 and Ex2 out of Test
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
20 |
where |
|
2177
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
21 |
"f PN = []" |
|
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
22 |
| "f (PS x) = [atom x]" |
|
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
23 |
| "f (PD x y) = [atom x, atom y]" |
|
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
24 |
|
|
2026
7f504136149b
Another example where only alpha_eqvt fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1773
diff
changeset
|
25 |
thm trm_pat.bn |
|
7f504136149b
Another example where only alpha_eqvt fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1773
diff
changeset
|
26 |
thm trm_pat.perm |
|
7f504136149b
Another example where only alpha_eqvt fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1773
diff
changeset
|
27 |
thm trm_pat.induct |
|
7f504136149b
Another example where only alpha_eqvt fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1773
diff
changeset
|
28 |
thm trm_pat.distinct |
|
7f504136149b
Another example where only alpha_eqvt fails.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
1773
diff
changeset
|
29 |
thm trm_pat.fv[simplified trm_pat.supp(1-2)] |
|
1596
c69d9fb16785
Move Ex1 and Ex2 out of Test
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
30 |
|
|
2177
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
31 |
lemma lets_overlap1: |
|
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
32 |
"atom a \<noteq> atom b \<Longrightarrow> Let (PD a a) x y \<noteq> Let (PD a b) x y" |
|
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
33 |
by (simp add: trm_pat.eq_iff alphas) |
|
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
34 |
|
|
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
35 |
lemma lets_overlap2: |
|
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
36 |
"atom a \<notin> supp y \<Longrightarrow> atom b \<notin> supp y \<Longrightarrow> Let (PD a a) x y = Let (PD b b) x y" |
|
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
37 |
apply (simp add: trm_pat.eq_iff alphas trm_pat.supp) |
|
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
38 |
apply (rule_tac x="(a\<leftrightarrow>b)" in exI) |
|
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
39 |
apply (simp add: eqvts) |
|
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
40 |
apply (rule conjI) |
|
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
41 |
prefer 2 |
|
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
42 |
apply (rule Nominal2_Supp.supp_perm_eq) |
|
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
43 |
apply (unfold fresh_star_def) |
|
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
44 |
apply (unfold fresh_def) |
|
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
45 |
apply (unfold flip_def) |
|
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
46 |
apply (simp_all add: supp_swap) |
|
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
47 |
apply auto |
|
9b566c5dc1f5
overlapping deep binders proof
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
2120
diff
changeset
|
48 |
done |
|
2082
0854af516f14
cleaned up a bit the examples; added equivariance to all examples
Christian Urban <urbanc@in.tum.de>
parents:
2030
diff
changeset
|
49 |
|
|
1596
c69d9fb16785
Move Ex1 and Ex2 out of Test
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
50 |
end |
|
c69d9fb16785
Move Ex1 and Ex2 out of Test
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
51 |
|
|
c69d9fb16785
Move Ex1 and Ex2 out of Test
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
52 |
|
|
c69d9fb16785
Move Ex1 and Ex2 out of Test
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents:
diff
changeset
|
53 |