author | paulson |
Tue, 05 Sep 2000 10:16:03 +0200 | |
changeset 9841 | ca3173f87b5c |
parent 9248 | e1dee89de037 |
child 9969 | 4753185f1dd2 |
permissions | -rw-r--r-- |
9169 | 1 |
(* Title: HOLCF/Ssum0.ML |
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
2 |
ID: $Id$ |
1461 | 3 |
Author: Franz Regensburger |
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
4 |
Copyright 1993 Technische Universitaet Muenchen |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
5 |
|
9169 | 6 |
Strict sum with typedef |
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
7 |
*) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
8 |
|
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
9 |
(* ------------------------------------------------------------------------ *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
10 |
(* A non-emptyness result for Sssum *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
11 |
(* ------------------------------------------------------------------------ *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
12 |
|
9248
e1dee89de037
massive tidy-up: goal -> Goal, remove use of prems, etc.
paulson
parents:
9245
diff
changeset
|
13 |
Goalw [Ssum_def] "Sinl_Rep(a):Ssum"; |
9245 | 14 |
by (rtac CollectI 1); |
15 |
by (rtac disjI1 1); |
|
16 |
by (rtac exI 1); |
|
17 |
by (rtac refl 1); |
|
18 |
qed "SsumIl"; |
|
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
19 |
|
9248
e1dee89de037
massive tidy-up: goal -> Goal, remove use of prems, etc.
paulson
parents:
9245
diff
changeset
|
20 |
Goalw [Ssum_def] "Sinr_Rep(a):Ssum"; |
9245 | 21 |
by (rtac CollectI 1); |
22 |
by (rtac disjI2 1); |
|
23 |
by (rtac exI 1); |
|
24 |
by (rtac refl 1); |
|
25 |
qed "SsumIr"; |
|
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
26 |
|
9169 | 27 |
Goal "inj_on Abs_Ssum Ssum"; |
28 |
by (rtac inj_on_inverseI 1); |
|
29 |
by (etac Abs_Ssum_inverse 1); |
|
30 |
qed "inj_on_Abs_Ssum"; |
|
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
31 |
|
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
32 |
(* ------------------------------------------------------------------------ *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
33 |
(* Strictness of Sinr_Rep, Sinl_Rep and Isinl, Isinr *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
34 |
(* ------------------------------------------------------------------------ *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
35 |
|
9248
e1dee89de037
massive tidy-up: goal -> Goal, remove use of prems, etc.
paulson
parents:
9245
diff
changeset
|
36 |
Goalw [Sinr_Rep_def,Sinl_Rep_def] |
9245 | 37 |
"Sinl_Rep(UU) = Sinr_Rep(UU)"; |
38 |
by (rtac ext 1); |
|
39 |
by (rtac ext 1); |
|
40 |
by (rtac ext 1); |
|
41 |
by (fast_tac HOL_cs 1); |
|
42 |
qed "strict_SinlSinr_Rep"; |
|
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
43 |
|
9248
e1dee89de037
massive tidy-up: goal -> Goal, remove use of prems, etc.
paulson
parents:
9245
diff
changeset
|
44 |
Goalw [Isinl_def,Isinr_def] |
9245 | 45 |
"Isinl(UU) = Isinr(UU)"; |
46 |
by (rtac (strict_SinlSinr_Rep RS arg_cong) 1); |
|
47 |
qed "strict_IsinlIsinr"; |
|
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
48 |
|
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
49 |
|
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
50 |
(* ------------------------------------------------------------------------ *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
51 |
(* distinctness of Sinl_Rep, Sinr_Rep and Isinl, Isinr *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
52 |
(* ------------------------------------------------------------------------ *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
53 |
|
9248
e1dee89de037
massive tidy-up: goal -> Goal, remove use of prems, etc.
paulson
parents:
9245
diff
changeset
|
54 |
Goalw [Sinl_Rep_def,Sinr_Rep_def] |
9245 | 55 |
"(Sinl_Rep(a) = Sinr_Rep(b)) ==> a=UU & b=UU"; |
9248
e1dee89de037
massive tidy-up: goal -> Goal, remove use of prems, etc.
paulson
parents:
9245
diff
changeset
|
56 |
by (blast_tac (claset() addSDs [fun_cong]) 1); |
9245 | 57 |
qed "noteq_SinlSinr_Rep"; |
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
58 |
|
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
59 |
|
9248
e1dee89de037
massive tidy-up: goal -> Goal, remove use of prems, etc.
paulson
parents:
9245
diff
changeset
|
60 |
Goalw [Isinl_def,Isinr_def] |
9245 | 61 |
"Isinl(a)=Isinr(b) ==> a=UU & b=UU"; |
62 |
by (rtac noteq_SinlSinr_Rep 1); |
|
63 |
by (etac (inj_on_Abs_Ssum RS inj_onD) 1); |
|
64 |
by (rtac SsumIl 1); |
|
65 |
by (rtac SsumIr 1); |
|
66 |
qed "noteq_IsinlIsinr"; |
|
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
67 |
|
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
68 |
|
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
69 |
|
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
70 |
(* ------------------------------------------------------------------------ *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
71 |
(* injectivity of Sinl_Rep, Sinr_Rep and Isinl, Isinr *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
72 |
(* ------------------------------------------------------------------------ *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
73 |
|
9248
e1dee89de037
massive tidy-up: goal -> Goal, remove use of prems, etc.
paulson
parents:
9245
diff
changeset
|
74 |
Goalw [Sinl_Rep_def] "(Sinl_Rep(a) = Sinl_Rep(UU)) ==> a=UU"; |
e1dee89de037
massive tidy-up: goal -> Goal, remove use of prems, etc.
paulson
parents:
9245
diff
changeset
|
75 |
by (blast_tac (claset() addSDs [fun_cong]) 1); |
9245 | 76 |
qed "inject_Sinl_Rep1"; |
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
77 |
|
9248
e1dee89de037
massive tidy-up: goal -> Goal, remove use of prems, etc.
paulson
parents:
9245
diff
changeset
|
78 |
Goalw [Sinr_Rep_def] "(Sinr_Rep(b) = Sinr_Rep(UU)) ==> b=UU"; |
e1dee89de037
massive tidy-up: goal -> Goal, remove use of prems, etc.
paulson
parents:
9245
diff
changeset
|
79 |
by (blast_tac (claset() addSDs [fun_cong]) 1); |
9245 | 80 |
qed "inject_Sinr_Rep1"; |
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
81 |
|
9248
e1dee89de037
massive tidy-up: goal -> Goal, remove use of prems, etc.
paulson
parents:
9245
diff
changeset
|
82 |
Goalw [Sinl_Rep_def] |
9245 | 83 |
"[| a1~=UU ; a2~=UU ; Sinl_Rep(a1)=Sinl_Rep(a2) |] ==> a1=a2"; |
9248
e1dee89de037
massive tidy-up: goal -> Goal, remove use of prems, etc.
paulson
parents:
9245
diff
changeset
|
84 |
by (blast_tac (claset() addSDs [fun_cong]) 1); |
9245 | 85 |
qed "inject_Sinl_Rep2"; |
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
86 |
|
9248
e1dee89de037
massive tidy-up: goal -> Goal, remove use of prems, etc.
paulson
parents:
9245
diff
changeset
|
87 |
Goalw [Sinr_Rep_def] |
9245 | 88 |
"[|b1~=UU ; b2~=UU ; Sinr_Rep(b1)=Sinr_Rep(b2) |] ==> b1=b2"; |
9248
e1dee89de037
massive tidy-up: goal -> Goal, remove use of prems, etc.
paulson
parents:
9245
diff
changeset
|
89 |
by (blast_tac (claset() addSDs [fun_cong]) 1); |
9245 | 90 |
qed "inject_Sinr_Rep2"; |
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
91 |
|
9169 | 92 |
Goal "Sinl_Rep(a1)=Sinl_Rep(a2) ==> a1=a2"; |
93 |
by (case_tac "a1=UU" 1); |
|
94 |
by (hyp_subst_tac 1); |
|
95 |
by (rtac (inject_Sinl_Rep1 RS sym) 1); |
|
96 |
by (etac sym 1); |
|
97 |
by (case_tac "a2=UU" 1); |
|
98 |
by (hyp_subst_tac 1); |
|
99 |
by (etac inject_Sinl_Rep1 1); |
|
100 |
by (etac inject_Sinl_Rep2 1); |
|
101 |
by (atac 1); |
|
102 |
by (atac 1); |
|
103 |
qed "inject_Sinl_Rep"; |
|
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
104 |
|
9169 | 105 |
Goal "Sinr_Rep(b1)=Sinr_Rep(b2) ==> b1=b2"; |
106 |
by (case_tac "b1=UU" 1); |
|
107 |
by (hyp_subst_tac 1); |
|
108 |
by (rtac (inject_Sinr_Rep1 RS sym) 1); |
|
109 |
by (etac sym 1); |
|
110 |
by (case_tac "b2=UU" 1); |
|
111 |
by (hyp_subst_tac 1); |
|
112 |
by (etac inject_Sinr_Rep1 1); |
|
113 |
by (etac inject_Sinr_Rep2 1); |
|
114 |
by (atac 1); |
|
115 |
by (atac 1); |
|
116 |
qed "inject_Sinr_Rep"; |
|
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
117 |
|
9248
e1dee89de037
massive tidy-up: goal -> Goal, remove use of prems, etc.
paulson
parents:
9245
diff
changeset
|
118 |
Goalw [Isinl_def] "Isinl(a1)=Isinl(a2)==> a1=a2"; |
9245 | 119 |
by (rtac inject_Sinl_Rep 1); |
120 |
by (etac (inj_on_Abs_Ssum RS inj_onD) 1); |
|
121 |
by (rtac SsumIl 1); |
|
122 |
by (rtac SsumIl 1); |
|
123 |
qed "inject_Isinl"; |
|
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
124 |
|
9248
e1dee89de037
massive tidy-up: goal -> Goal, remove use of prems, etc.
paulson
parents:
9245
diff
changeset
|
125 |
Goalw [Isinr_def] "Isinr(b1)=Isinr(b2) ==> b1=b2"; |
9245 | 126 |
by (rtac inject_Sinr_Rep 1); |
127 |
by (etac (inj_on_Abs_Ssum RS inj_onD) 1); |
|
128 |
by (rtac SsumIr 1); |
|
129 |
by (rtac SsumIr 1); |
|
130 |
qed "inject_Isinr"; |
|
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
131 |
|
9169 | 132 |
Goal "a1~=a2 ==> Isinl(a1) ~= Isinl(a2)"; |
133 |
by (rtac contrapos 1); |
|
134 |
by (etac inject_Isinl 2); |
|
135 |
by (atac 1); |
|
136 |
qed "inject_Isinl_rev"; |
|
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
137 |
|
9169 | 138 |
Goal "b1~=b2 ==> Isinr(b1) ~= Isinr(b2)"; |
139 |
by (rtac contrapos 1); |
|
140 |
by (etac inject_Isinr 2); |
|
141 |
by (atac 1); |
|
142 |
qed "inject_Isinr_rev"; |
|
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
143 |
|
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
144 |
(* ------------------------------------------------------------------------ *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
145 |
(* Exhaustion of the strict sum ++ *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
146 |
(* choice of the bottom representation is arbitrary *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
147 |
(* ------------------------------------------------------------------------ *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
148 |
|
9248
e1dee89de037
massive tidy-up: goal -> Goal, remove use of prems, etc.
paulson
parents:
9245
diff
changeset
|
149 |
Goalw [Isinl_def,Isinr_def] |
9245 | 150 |
"z=Isinl(UU) | (? a. z=Isinl(a) & a~=UU) | (? b. z=Isinr(b) & b~=UU)"; |
151 |
by (rtac (rewrite_rule [Ssum_def] Rep_Ssum RS CollectE) 1); |
|
152 |
by (etac disjE 1); |
|
153 |
by (etac exE 1); |
|
154 |
by (case_tac "z= Abs_Ssum(Sinl_Rep(UU))" 1); |
|
155 |
by (etac disjI1 1); |
|
156 |
by (rtac disjI2 1); |
|
157 |
by (rtac disjI1 1); |
|
158 |
by (rtac exI 1); |
|
159 |
by (rtac conjI 1); |
|
160 |
by (rtac (Rep_Ssum_inverse RS sym RS trans) 1); |
|
161 |
by (etac arg_cong 1); |
|
162 |
by (res_inst_tac [("Q","Sinl_Rep(a)=Sinl_Rep(UU)")] contrapos 1); |
|
163 |
by (etac arg_cong 2); |
|
164 |
by (etac contrapos 1); |
|
165 |
by (rtac (Rep_Ssum_inverse RS sym RS trans) 1); |
|
166 |
by (rtac trans 1); |
|
167 |
by (etac arg_cong 1); |
|
168 |
by (etac arg_cong 1); |
|
169 |
by (etac exE 1); |
|
170 |
by (case_tac "z= Abs_Ssum(Sinl_Rep(UU))" 1); |
|
171 |
by (etac disjI1 1); |
|
172 |
by (rtac disjI2 1); |
|
173 |
by (rtac disjI2 1); |
|
174 |
by (rtac exI 1); |
|
175 |
by (rtac conjI 1); |
|
176 |
by (rtac (Rep_Ssum_inverse RS sym RS trans) 1); |
|
177 |
by (etac arg_cong 1); |
|
178 |
by (res_inst_tac [("Q","Sinr_Rep(b)=Sinl_Rep(UU)")] contrapos 1); |
|
179 |
by (hyp_subst_tac 2); |
|
180 |
by (rtac (strict_SinlSinr_Rep RS sym) 2); |
|
181 |
by (etac contrapos 1); |
|
182 |
by (rtac (Rep_Ssum_inverse RS sym RS trans) 1); |
|
183 |
by (rtac trans 1); |
|
184 |
by (etac arg_cong 1); |
|
185 |
by (etac arg_cong 1); |
|
186 |
qed "Exh_Ssum"; |
|
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
187 |
|
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
188 |
(* ------------------------------------------------------------------------ *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
189 |
(* elimination rules for the strict sum ++ *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
190 |
(* ------------------------------------------------------------------------ *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
191 |
|
9169 | 192 |
val prems = Goal |
1461 | 193 |
"[|p=Isinl(UU) ==> Q ;\ |
194 |
\ !!x.[|p=Isinl(x); x~=UU |] ==> Q;\ |
|
9169 | 195 |
\ !!y.[|p=Isinr(y); y~=UU |] ==> Q|] ==> Q"; |
196 |
by (rtac (Exh_Ssum RS disjE) 1); |
|
197 |
by (etac disjE 2); |
|
198 |
by (eresolve_tac prems 1); |
|
199 |
by (etac exE 1); |
|
200 |
by (etac conjE 1); |
|
201 |
by (eresolve_tac prems 1); |
|
202 |
by (atac 1); |
|
203 |
by (etac exE 1); |
|
204 |
by (etac conjE 1); |
|
205 |
by (eresolve_tac prems 1); |
|
206 |
by (atac 1); |
|
207 |
qed "IssumE"; |
|
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
208 |
|
9169 | 209 |
val prems = Goal |
210 |
"[| !!x. [| p = Isinl(x) |] ==> Q; !!y. [| p = Isinr(y) |] ==> Q |] ==>Q"; |
|
211 |
by (rtac IssumE 1); |
|
212 |
by (eresolve_tac prems 1); |
|
213 |
by (eresolve_tac prems 1); |
|
214 |
by (eresolve_tac prems 1); |
|
215 |
qed "IssumE2"; |
|
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
216 |
|
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
217 |
|
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
218 |
|
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
219 |
|
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
220 |
(* ------------------------------------------------------------------------ *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
221 |
(* rewrites for Iwhen *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
222 |
(* ------------------------------------------------------------------------ *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
223 |
|
9248
e1dee89de037
massive tidy-up: goal -> Goal, remove use of prems, etc.
paulson
parents:
9245
diff
changeset
|
224 |
Goalw [Iwhen_def] |
9245 | 225 |
"Iwhen f g (Isinl UU) = UU"; |
226 |
by (rtac select_equality 1); |
|
227 |
by (rtac conjI 1); |
|
228 |
by (fast_tac HOL_cs 1); |
|
229 |
by (rtac conjI 1); |
|
230 |
by (strip_tac 1); |
|
231 |
by (res_inst_tac [("P","a=UU")] notE 1); |
|
232 |
by (fast_tac HOL_cs 1); |
|
233 |
by (rtac inject_Isinl 1); |
|
234 |
by (rtac sym 1); |
|
235 |
by (fast_tac HOL_cs 1); |
|
236 |
by (strip_tac 1); |
|
237 |
by (res_inst_tac [("P","b=UU")] notE 1); |
|
238 |
by (fast_tac HOL_cs 1); |
|
239 |
by (rtac inject_Isinr 1); |
|
240 |
by (rtac sym 1); |
|
241 |
by (rtac (strict_IsinlIsinr RS subst) 1); |
|
242 |
by (fast_tac HOL_cs 1); |
|
243 |
by (fast_tac HOL_cs 1); |
|
244 |
qed "Iwhen1"; |
|
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
245 |
|
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
246 |
|
9248
e1dee89de037
massive tidy-up: goal -> Goal, remove use of prems, etc.
paulson
parents:
9245
diff
changeset
|
247 |
Goalw [Iwhen_def] |
9245 | 248 |
"x~=UU ==> Iwhen f g (Isinl x) = f`x"; |
249 |
by (rtac select_equality 1); |
|
250 |
by (fast_tac HOL_cs 2); |
|
251 |
by (rtac conjI 1); |
|
252 |
by (strip_tac 1); |
|
253 |
by (res_inst_tac [("P","x=UU")] notE 1); |
|
254 |
by (atac 1); |
|
255 |
by (rtac inject_Isinl 1); |
|
256 |
by (atac 1); |
|
257 |
by (rtac conjI 1); |
|
258 |
by (strip_tac 1); |
|
259 |
by (rtac cfun_arg_cong 1); |
|
260 |
by (rtac inject_Isinl 1); |
|
261 |
by (fast_tac HOL_cs 1); |
|
262 |
by (strip_tac 1); |
|
263 |
by (res_inst_tac [("P","Isinl(x) = Isinr(b)")] notE 1); |
|
264 |
by (fast_tac HOL_cs 2); |
|
265 |
by (rtac contrapos 1); |
|
266 |
by (etac noteq_IsinlIsinr 2); |
|
267 |
by (fast_tac HOL_cs 1); |
|
268 |
qed "Iwhen2"; |
|
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
269 |
|
9248
e1dee89de037
massive tidy-up: goal -> Goal, remove use of prems, etc.
paulson
parents:
9245
diff
changeset
|
270 |
Goalw [Iwhen_def] |
9245 | 271 |
"y~=UU ==> Iwhen f g (Isinr y) = g`y"; |
272 |
by (rtac select_equality 1); |
|
273 |
by (fast_tac HOL_cs 2); |
|
274 |
by (rtac conjI 1); |
|
275 |
by (strip_tac 1); |
|
276 |
by (res_inst_tac [("P","y=UU")] notE 1); |
|
277 |
by (atac 1); |
|
278 |
by (rtac inject_Isinr 1); |
|
279 |
by (rtac (strict_IsinlIsinr RS subst) 1); |
|
280 |
by (atac 1); |
|
281 |
by (rtac conjI 1); |
|
282 |
by (strip_tac 1); |
|
283 |
by (res_inst_tac [("P","Isinr(y) = Isinl(a)")] notE 1); |
|
284 |
by (fast_tac HOL_cs 2); |
|
285 |
by (rtac contrapos 1); |
|
286 |
by (etac (sym RS noteq_IsinlIsinr) 2); |
|
287 |
by (fast_tac HOL_cs 1); |
|
288 |
by (strip_tac 1); |
|
289 |
by (rtac cfun_arg_cong 1); |
|
290 |
by (rtac inject_Isinr 1); |
|
291 |
by (fast_tac HOL_cs 1); |
|
292 |
qed "Iwhen3"; |
|
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
293 |
|
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
294 |
(* ------------------------------------------------------------------------ *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
295 |
(* instantiate the simplifier *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
296 |
(* ------------------------------------------------------------------------ *) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
297 |
|
8161 | 298 |
val Ssum0_ss = (simpset_of Cfun3.thy) delsimps [range_composition] addsimps |
1277
caef3601c0b2
corrected some errors that occurred after introduction of local simpsets
regensbu
parents:
1274
diff
changeset
|
299 |
[(strict_IsinlIsinr RS sym),Iwhen1,Iwhen2,Iwhen3]; |
caef3601c0b2
corrected some errors that occurred after introduction of local simpsets
regensbu
parents:
1274
diff
changeset
|
300 |
|
9248
e1dee89de037
massive tidy-up: goal -> Goal, remove use of prems, etc.
paulson
parents:
9245
diff
changeset
|
301 |
Addsimps [strict_IsinlIsinr RS sym, Iwhen1, Iwhen2, Iwhen3]; |