author | zhangx |
Sun, 17 Jan 2016 22:18:35 +0800 | |
changeset 79 | 8067efcb43da |
parent 77 | d37703e0c5c4 |
child 80 | 17305a85493d |
permissions | -rw-r--r-- |
73 | 1 |
theory CpsG |
2 |
imports PIPDefs |
|
3 |
begin |
|
4 |
||
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
5 |
lemma Max_f_mono: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
6 |
assumes seq: "A \<subseteq> B" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
7 |
and np: "A \<noteq> {}" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
8 |
and fnt: "finite B" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
9 |
shows "Max (f ` A) \<le> Max (f ` B)" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
10 |
proof(rule Max_mono) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
11 |
from seq show "f ` A \<subseteq> f ` B" by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
12 |
next |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
13 |
from np show "f ` A \<noteq> {}" by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
14 |
next |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
15 |
from fnt and seq show "finite (f ` B)" by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
16 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
17 |
|
73 | 18 |
|
19 |
locale valid_trace = |
|
20 |
fixes s |
|
21 |
assumes vt : "vt s" |
|
22 |
||
23 |
locale valid_trace_e = valid_trace + |
|
24 |
fixes e |
|
25 |
assumes vt_e: "vt (e#s)" |
|
26 |
begin |
|
27 |
||
28 |
lemma pip_e: "PIP s e" |
|
29 |
using vt_e by (cases, simp) |
|
30 |
||
31 |
end |
|
32 |
||
79 | 33 |
locale valid_trace_create = valid_trace_e + |
34 |
fixes th prio |
|
35 |
assumes is_create: "e = Create th prio" |
|
36 |
||
37 |
locale valid_trace_exit = valid_trace_e + |
|
38 |
fixes th |
|
39 |
assumes is_exit: "e = Exit th" |
|
40 |
||
41 |
locale valid_trace_p = valid_trace_e + |
|
42 |
fixes th cs |
|
43 |
assumes is_p: "e = P th cs" |
|
44 |
||
45 |
locale valid_trace_v = valid_trace_e + |
|
46 |
fixes th cs |
|
47 |
assumes is_v: "e = V th cs" |
|
48 |
begin |
|
49 |
definition "rest = tl (wq s cs)" |
|
50 |
definition "wq' = (SOME q. distinct q \<and> set q = set rest)" |
|
51 |
end |
|
52 |
||
53 |
locale valid_trace_v_n = valid_trace_v + |
|
54 |
assumes rest_nnl: "rest \<noteq> []" |
|
55 |
||
56 |
locale valid_trace_v_e = valid_trace_v + |
|
57 |
assumes rest_nil: "rest = []" |
|
58 |
||
59 |
locale valid_trace_set= valid_trace_e + |
|
60 |
fixes th prio |
|
61 |
assumes is_set: "e = Set th prio" |
|
62 |
||
63 |
context valid_trace |
|
64 |
begin |
|
65 |
||
66 |
lemma ind [consumes 0, case_names Nil Cons, induct type]: |
|
67 |
assumes "PP []" |
|
68 |
and "(\<And>s e. valid_trace_e s e \<Longrightarrow> |
|
69 |
PP s \<Longrightarrow> PIP s e \<Longrightarrow> PP (e # s))" |
|
70 |
shows "PP s" |
|
71 |
proof(induct rule:vt.induct[OF vt, case_names Init Step]) |
|
72 |
case Init |
|
73 |
from assms(1) show ?case . |
|
74 |
next |
|
75 |
case (Step s e) |
|
76 |
show ?case |
|
77 |
proof(rule assms(2)) |
|
78 |
show "valid_trace_e s e" using Step by (unfold_locales, auto) |
|
79 |
next |
|
80 |
show "PP s" using Step by simp |
|
81 |
next |
|
82 |
show "PIP s e" using Step by simp |
|
83 |
qed |
|
84 |
qed |
|
85 |
||
86 |
lemma vt_moment: "\<And> t. vt (moment t s)" |
|
87 |
proof(induct rule:ind) |
|
88 |
case Nil |
|
89 |
thus ?case by (simp add:vt_nil) |
|
90 |
next |
|
91 |
case (Cons s e t) |
|
92 |
show ?case |
|
93 |
proof(cases "t \<ge> length (e#s)") |
|
94 |
case True |
|
95 |
from True have "moment t (e#s) = e#s" by simp |
|
96 |
thus ?thesis using Cons |
|
97 |
by (simp add:valid_trace_def valid_trace_e_def, auto) |
|
98 |
next |
|
99 |
case False |
|
100 |
from Cons have "vt (moment t s)" by simp |
|
101 |
moreover have "moment t (e#s) = moment t s" |
|
102 |
proof - |
|
103 |
from False have "t \<le> length s" by simp |
|
104 |
from moment_app [OF this, of "[e]"] |
|
105 |
show ?thesis by simp |
|
106 |
qed |
|
107 |
ultimately show ?thesis by simp |
|
108 |
qed |
|
109 |
qed |
|
110 |
||
111 |
lemma finite_threads: |
|
112 |
shows "finite (threads s)" |
|
113 |
using vt by (induct) (auto elim: step.cases) |
|
114 |
||
115 |
end |
|
116 |
||
117 |
lemma cp_eq_cpreced: "cp s th = cpreced (wq s) s th" |
|
118 |
unfolding cp_def wq_def |
|
119 |
apply(induct s rule: schs.induct) |
|
120 |
apply(simp add: Let_def cpreced_initial) |
|
121 |
apply(simp add: Let_def) |
|
122 |
apply(simp add: Let_def) |
|
123 |
apply(simp add: Let_def) |
|
124 |
apply(subst (2) schs.simps) |
|
125 |
apply(simp add: Let_def) |
|
126 |
apply(subst (2) schs.simps) |
|
127 |
apply(simp add: Let_def) |
|
128 |
done |
|
129 |
||
130 |
lemma RAG_target_th: "(Th th, x) \<in> RAG (s::state) \<Longrightarrow> \<exists> cs. x = Cs cs" |
|
131 |
by (unfold s_RAG_def, auto) |
|
132 |
||
133 |
locale valid_moment = valid_trace + |
|
134 |
fixes i :: nat |
|
135 |
||
136 |
sublocale valid_moment < vat_moment: valid_trace "(moment i s)" |
|
137 |
by (unfold_locales, insert vt_moment, auto) |
|
138 |
||
139 |
lemma waiting_eq: "waiting s th cs = waiting (wq s) th cs" |
|
140 |
by (unfold s_waiting_def cs_waiting_def wq_def, auto) |
|
141 |
||
142 |
lemma holding_eq: "holding (s::state) th cs = holding (wq s) th cs" |
|
143 |
by (unfold s_holding_def wq_def cs_holding_def, simp) |
|
144 |
||
73 | 145 |
lemma runing_ready: |
146 |
shows "runing s \<subseteq> readys s" |
|
147 |
unfolding runing_def readys_def |
|
148 |
by auto |
|
149 |
||
150 |
lemma readys_threads: |
|
151 |
shows "readys s \<subseteq> threads s" |
|
152 |
unfolding readys_def |
|
153 |
by auto |
|
154 |
||
155 |
lemma wq_v_neq [simp]: |
|
156 |
"cs \<noteq> cs' \<Longrightarrow> wq (V thread cs#s) cs' = wq s cs'" |
|
157 |
by (auto simp:wq_def Let_def cp_def split:list.splits) |
|
158 |
||
159 |
lemma runing_head: |
|
160 |
assumes "th \<in> runing s" |
|
161 |
and "th \<in> set (wq_fun (schs s) cs)" |
|
162 |
shows "th = hd (wq_fun (schs s) cs)" |
|
163 |
using assms |
|
164 |
by (simp add:runing_def readys_def s_waiting_def wq_def) |
|
165 |
||
166 |
context valid_trace |
|
167 |
begin |
|
168 |
||
79 | 169 |
lemma runing_wqE: |
170 |
assumes "th \<in> runing s" |
|
171 |
and "th \<in> set (wq s cs)" |
|
172 |
obtains rest where "wq s cs = th#rest" |
|
173 |
proof - |
|
174 |
from assms(2) obtain th' rest where eq_wq: "wq s cs = th'#rest" |
|
175 |
by (meson list.set_cases) |
|
176 |
have "th' = th" |
|
177 |
proof(rule ccontr) |
|
178 |
assume "th' \<noteq> th" |
|
179 |
hence "th \<noteq> hd (wq s cs)" using eq_wq by auto |
|
180 |
with assms(2) |
|
181 |
have "waiting s th cs" |
|
182 |
by (unfold s_waiting_def, fold wq_def, auto) |
|
183 |
with assms show False |
|
184 |
by (unfold runing_def readys_def, auto) |
|
185 |
qed |
|
186 |
with eq_wq that show ?thesis by metis |
|
187 |
qed |
|
188 |
||
189 |
end |
|
190 |
||
191 |
context valid_trace_create |
|
192 |
begin |
|
193 |
||
194 |
lemma wq_neq_simp [simp]: |
|
195 |
shows "wq (e#s) cs' = wq s cs'" |
|
196 |
using assms unfolding is_create wq_def |
|
197 |
by (auto simp:Let_def) |
|
198 |
||
199 |
lemma wq_distinct_kept: |
|
200 |
assumes "distinct (wq s cs')" |
|
201 |
shows "distinct (wq (e#s) cs')" |
|
202 |
using assms by simp |
|
203 |
end |
|
204 |
||
205 |
context valid_trace_exit |
|
206 |
begin |
|
207 |
||
208 |
lemma wq_neq_simp [simp]: |
|
209 |
shows "wq (e#s) cs' = wq s cs'" |
|
210 |
using assms unfolding is_exit wq_def |
|
211 |
by (auto simp:Let_def) |
|
212 |
||
213 |
lemma wq_distinct_kept: |
|
214 |
assumes "distinct (wq s cs')" |
|
215 |
shows "distinct (wq (e#s) cs')" |
|
216 |
using assms by simp |
|
217 |
end |
|
218 |
||
219 |
context valid_trace_p |
|
220 |
begin |
|
221 |
||
222 |
lemma wq_neq_simp [simp]: |
|
223 |
assumes "cs' \<noteq> cs" |
|
224 |
shows "wq (e#s) cs' = wq s cs'" |
|
225 |
using assms unfolding is_p wq_def |
|
226 |
by (auto simp:Let_def) |
|
227 |
||
228 |
lemma runing_th_s: |
|
229 |
shows "th \<in> runing s" |
|
230 |
proof - |
|
231 |
from pip_e[unfolded is_p] |
|
232 |
show ?thesis by (cases, simp) |
|
233 |
qed |
|
234 |
||
235 |
lemma th_not_waiting: |
|
236 |
"\<not> waiting s th c" |
|
237 |
proof - |
|
238 |
have "th \<in> readys s" |
|
239 |
using runing_ready runing_th_s by blast |
|
240 |
thus ?thesis |
|
241 |
by (unfold readys_def, auto) |
|
242 |
qed |
|
243 |
||
244 |
lemma waiting_neq_th: |
|
245 |
assumes "waiting s t c" |
|
246 |
shows "t \<noteq> th" |
|
247 |
using assms using th_not_waiting by blast |
|
248 |
||
249 |
lemma th_not_in_wq: |
|
250 |
shows "th \<notin> set (wq s cs)" |
|
251 |
proof |
|
252 |
assume otherwise: "th \<in> set (wq s cs)" |
|
253 |
from runing_wqE[OF runing_th_s this] |
|
254 |
obtain rest where eq_wq: "wq s cs = th#rest" by blast |
|
255 |
with otherwise |
|
256 |
have "holding s th cs" |
|
257 |
by (unfold s_holding_def, fold wq_def, simp) |
|
258 |
hence cs_th_RAG: "(Cs cs, Th th) \<in> RAG s" |
|
259 |
by (unfold s_RAG_def, fold holding_eq, auto) |
|
260 |
from pip_e[unfolded is_p] |
|
261 |
show False |
|
262 |
proof(cases) |
|
263 |
case (thread_P) |
|
264 |
with cs_th_RAG show ?thesis by auto |
|
265 |
qed |
|
266 |
qed |
|
267 |
||
268 |
lemma wq_es_cs: |
|
269 |
"wq (e#s) cs = wq s cs @ [th]" |
|
270 |
by (unfold is_p wq_def, auto simp:Let_def) |
|
271 |
||
272 |
lemma wq_distinct_kept: |
|
273 |
assumes "distinct (wq s cs')" |
|
274 |
shows "distinct (wq (e#s) cs')" |
|
275 |
proof(cases "cs' = cs") |
|
276 |
case True |
|
277 |
show ?thesis using True assms th_not_in_wq |
|
278 |
by (unfold True wq_es_cs, auto) |
|
279 |
qed (insert assms, simp) |
|
280 |
||
281 |
end |
|
282 |
||
283 |
context valid_trace_v |
|
284 |
begin |
|
285 |
||
286 |
lemma wq_neq_simp [simp]: |
|
287 |
assumes "cs' \<noteq> cs" |
|
288 |
shows "wq (e#s) cs' = wq s cs'" |
|
289 |
using assms unfolding is_v wq_def |
|
290 |
by (auto simp:Let_def) |
|
291 |
||
292 |
lemma runing_th_s: |
|
293 |
shows "th \<in> runing s" |
|
294 |
proof - |
|
295 |
from pip_e[unfolded is_v] |
|
296 |
show ?thesis by (cases, simp) |
|
297 |
qed |
|
298 |
||
299 |
lemma th_not_waiting: |
|
300 |
"\<not> waiting s th c" |
|
301 |
proof - |
|
302 |
have "th \<in> readys s" |
|
303 |
using runing_ready runing_th_s by blast |
|
304 |
thus ?thesis |
|
305 |
by (unfold readys_def, auto) |
|
306 |
qed |
|
307 |
||
308 |
lemma waiting_neq_th: |
|
309 |
assumes "waiting s t c" |
|
310 |
shows "t \<noteq> th" |
|
311 |
using assms using th_not_waiting by blast |
|
312 |
||
313 |
lemma wq_s_cs: |
|
314 |
"wq s cs = th#rest" |
|
315 |
proof - |
|
316 |
from pip_e[unfolded is_v] |
|
317 |
show ?thesis |
|
318 |
proof(cases) |
|
319 |
case (thread_V) |
|
320 |
from this(2) show ?thesis |
|
321 |
by (unfold rest_def s_holding_def, fold wq_def, |
|
322 |
metis empty_iff list.collapse list.set(1)) |
|
323 |
qed |
|
324 |
qed |
|
325 |
||
326 |
lemma wq_es_cs: |
|
327 |
"wq (e#s) cs = wq'" |
|
328 |
using wq_s_cs[unfolded wq_def] |
|
329 |
by (auto simp:Let_def wq_def rest_def wq'_def is_v, simp) |
|
330 |
||
331 |
lemma wq_distinct_kept: |
|
332 |
assumes "distinct (wq s cs')" |
|
333 |
shows "distinct (wq (e#s) cs')" |
|
334 |
proof(cases "cs' = cs") |
|
335 |
case True |
|
336 |
show ?thesis |
|
337 |
proof(unfold True wq_es_cs wq'_def, rule someI2) |
|
338 |
show "distinct rest \<and> set rest = set rest" |
|
339 |
using assms[unfolded True wq_s_cs] by auto |
|
340 |
qed simp |
|
341 |
qed (insert assms, simp) |
|
342 |
||
343 |
end |
|
344 |
||
345 |
context valid_trace_set |
|
346 |
begin |
|
347 |
||
348 |
lemma wq_neq_simp [simp]: |
|
349 |
shows "wq (e#s) cs' = wq s cs'" |
|
350 |
using assms unfolding is_set wq_def |
|
351 |
by (auto simp:Let_def) |
|
352 |
||
353 |
lemma wq_distinct_kept: |
|
354 |
assumes "distinct (wq s cs')" |
|
355 |
shows "distinct (wq (e#s) cs')" |
|
356 |
using assms by simp |
|
357 |
end |
|
358 |
||
359 |
context valid_trace |
|
360 |
begin |
|
361 |
||
73 | 362 |
lemma actor_inv: |
363 |
assumes "PIP s e" |
|
364 |
and "\<not> isCreate e" |
|
365 |
shows "actor e \<in> runing s" |
|
366 |
using assms |
|
367 |
by (induct, auto) |
|
368 |
||
369 |
lemma isP_E: |
|
370 |
assumes "isP e" |
|
371 |
obtains cs where "e = P (actor e) cs" |
|
372 |
using assms by (cases e, auto) |
|
373 |
||
374 |
lemma isV_E: |
|
375 |
assumes "isV e" |
|
376 |
obtains cs where "e = V (actor e) cs" |
|
377 |
using assms by (cases e, auto) |
|
378 |
||
379 |
lemma wq_distinct: "distinct (wq s cs)" |
|
380 |
proof(induct rule:ind) |
|
381 |
case (Cons s e) |
|
79 | 382 |
interpret vt_e: valid_trace_e s e using Cons by simp |
73 | 383 |
show ?case |
79 | 384 |
proof(cases e) |
385 |
case (Create th prio) |
|
386 |
interpret vt_create: valid_trace_create s e th prio |
|
387 |
using Create by (unfold_locales, simp) |
|
388 |
show ?thesis using Cons by (simp add: vt_create.wq_distinct_kept) |
|
389 |
next |
|
390 |
case (Exit th) |
|
391 |
interpret vt_exit: valid_trace_exit s e th |
|
392 |
using Exit by (unfold_locales, simp) |
|
393 |
show ?thesis using Cons by (simp add: vt_exit.wq_distinct_kept) |
|
73 | 394 |
next |
79 | 395 |
case (P th cs) |
396 |
interpret vt_p: valid_trace_p s e th cs using P by (unfold_locales, simp) |
|
397 |
show ?thesis using Cons by (simp add: vt_p.wq_distinct_kept) |
|
398 |
next |
|
399 |
case (V th cs) |
|
400 |
interpret vt_v: valid_trace_v s e th cs using V by (unfold_locales, simp) |
|
401 |
show ?thesis using Cons by (simp add: vt_v.wq_distinct_kept) |
|
402 |
next |
|
403 |
case (Set th prio) |
|
404 |
interpret vt_set: valid_trace_set s e th prio |
|
405 |
using Set by (unfold_locales, simp) |
|
406 |
show ?thesis using Cons by (simp add: vt_set.wq_distinct_kept) |
|
407 |
qed |
|
73 | 408 |
qed (unfold wq_def Let_def, simp) |
409 |
||
410 |
end |
|
411 |
||
412 |
context valid_trace_e |
|
413 |
begin |
|
414 |
||
415 |
text {* |
|
416 |
The following lemma shows that only the @{text "P"} |
|
417 |
operation can add new thread into waiting queues. |
|
418 |
Such kind of lemmas are very obvious, but need to be checked formally. |
|
419 |
This is a kind of confirmation that our modelling is correct. |
|
420 |
*} |
|
421 |
||
422 |
lemma wq_in_inv: |
|
423 |
assumes s_ni: "thread \<notin> set (wq s cs)" |
|
424 |
and s_i: "thread \<in> set (wq (e#s) cs)" |
|
425 |
shows "e = P thread cs" |
|
426 |
proof(cases e) |
|
427 |
-- {* This is the only non-trivial case: *} |
|
428 |
case (V th cs1) |
|
429 |
have False |
|
430 |
proof(cases "cs1 = cs") |
|
431 |
case True |
|
432 |
show ?thesis |
|
433 |
proof(cases "(wq s cs1)") |
|
434 |
case (Cons w_hd w_tl) |
|
435 |
have "set (wq (e#s) cs) \<subseteq> set (wq s cs)" |
|
436 |
proof - |
|
437 |
have "(wq (e#s) cs) = (SOME q. distinct q \<and> set q = set w_tl)" |
|
438 |
using Cons V by (auto simp:wq_def Let_def True split:if_splits) |
|
439 |
moreover have "set ... \<subseteq> set (wq s cs)" |
|
440 |
proof(rule someI2) |
|
441 |
show "distinct w_tl \<and> set w_tl = set w_tl" |
|
442 |
by (metis distinct.simps(2) local.Cons wq_distinct) |
|
443 |
qed (insert Cons True, auto) |
|
444 |
ultimately show ?thesis by simp |
|
445 |
qed |
|
446 |
with assms show ?thesis by auto |
|
447 |
qed (insert assms V True, auto simp:wq_def Let_def split:if_splits) |
|
448 |
qed (insert assms V, auto simp:wq_def Let_def split:if_splits) |
|
449 |
thus ?thesis by auto |
|
450 |
qed (insert assms, auto simp:wq_def Let_def split:if_splits) |
|
451 |
||
452 |
lemma wq_out_inv: |
|
453 |
assumes s_in: "thread \<in> set (wq s cs)" |
|
454 |
and s_hd: "thread = hd (wq s cs)" |
|
455 |
and s_i: "thread \<noteq> hd (wq (e#s) cs)" |
|
456 |
shows "e = V thread cs" |
|
457 |
proof(cases e) |
|
458 |
-- {* There are only two non-trivial cases: *} |
|
459 |
case (V th cs1) |
|
460 |
show ?thesis |
|
461 |
proof(cases "cs1 = cs") |
|
462 |
case True |
|
463 |
have "PIP s (V th cs)" using pip_e[unfolded V[unfolded True]] . |
|
464 |
thus ?thesis |
|
465 |
proof(cases) |
|
466 |
case (thread_V) |
|
467 |
moreover have "th = thread" using thread_V(2) s_hd |
|
468 |
by (unfold s_holding_def wq_def, simp) |
|
469 |
ultimately show ?thesis using V True by simp |
|
470 |
qed |
|
471 |
qed (insert assms V, auto simp:wq_def Let_def split:if_splits) |
|
472 |
next |
|
473 |
case (P th cs1) |
|
474 |
show ?thesis |
|
475 |
proof(cases "cs1 = cs") |
|
476 |
case True |
|
477 |
with P have "wq (e#s) cs = wq_fun (schs s) cs @ [th]" |
|
478 |
by (auto simp:wq_def Let_def split:if_splits) |
|
479 |
with s_i s_hd s_in have False |
|
480 |
by (metis empty_iff hd_append2 list.set(1) wq_def) |
|
481 |
thus ?thesis by simp |
|
482 |
qed (insert assms P, auto simp:wq_def Let_def split:if_splits) |
|
483 |
qed (insert assms, auto simp:wq_def Let_def split:if_splits) |
|
484 |
||
485 |
end |
|
486 |
||
487 |
||
488 |
context valid_trace |
|
489 |
begin |
|
490 |
||
491 |
||
492 |
text {* (* ddd *) |
|
493 |
The nature of the work is like this: since it starts from a very simple and basic |
|
494 |
model, even intuitively very `basic` and `obvious` properties need to derived from scratch. |
|
495 |
For instance, the fact |
|
496 |
that one thread can not be blocked by two critical resources at the same time |
|
497 |
is obvious, because only running threads can make new requests, if one is waiting for |
|
498 |
a critical resource and get blocked, it can not make another resource request and get |
|
499 |
blocked the second time (because it is not running). |
|
500 |
||
501 |
To derive this fact, one needs to prove by contraction and |
|
502 |
reason about time (or @{text "moement"}). The reasoning is based on a generic theorem |
|
503 |
named @{text "p_split"}, which is about status changing along the time axis. It says if |
|
504 |
a condition @{text "Q"} is @{text "True"} at a state @{text "s"}, |
|
505 |
but it was @{text "False"} at the very beginning, then there must exits a moment @{text "t"} |
|
506 |
in the history of @{text "s"} (notice that @{text "s"} itself is essentially the history |
|
507 |
of events leading to it), such that @{text "Q"} switched |
|
508 |
from being @{text "False"} to @{text "True"} and kept being @{text "True"} |
|
509 |
till the last moment of @{text "s"}. |
|
510 |
||
511 |
Suppose a thread @{text "th"} is blocked |
|
512 |
on @{text "cs1"} and @{text "cs2"} in some state @{text "s"}, |
|
513 |
since no thread is blocked at the very beginning, by applying |
|
514 |
@{text "p_split"} to these two blocking facts, there exist |
|
515 |
two moments @{text "t1"} and @{text "t2"} in @{text "s"}, such that |
|
516 |
@{text "th"} got blocked on @{text "cs1"} and @{text "cs2"} |
|
517 |
and kept on blocked on them respectively ever since. |
|
518 |
||
519 |
Without lost of generality, we assume @{text "t1"} is earlier than @{text "t2"}. |
|
520 |
However, since @{text "th"} was blocked ever since memonent @{text "t1"}, so it was still |
|
521 |
in blocked state at moment @{text "t2"} and could not |
|
522 |
make any request and get blocked the second time: Contradiction. |
|
523 |
*} |
|
524 |
||
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
525 |
lemma waiting_unique_pre: (* ddd *) |
73 | 526 |
assumes h11: "thread \<in> set (wq s cs1)" |
527 |
and h12: "thread \<noteq> hd (wq s cs1)" |
|
528 |
assumes h21: "thread \<in> set (wq s cs2)" |
|
529 |
and h22: "thread \<noteq> hd (wq s cs2)" |
|
530 |
and neq12: "cs1 \<noteq> cs2" |
|
531 |
shows "False" |
|
532 |
proof - |
|
533 |
let "?Q" = "\<lambda> cs s. thread \<in> set (wq s cs) \<and> thread \<noteq> hd (wq s cs)" |
|
534 |
from h11 and h12 have q1: "?Q cs1 s" by simp |
|
535 |
from h21 and h22 have q2: "?Q cs2 s" by simp |
|
536 |
have nq1: "\<not> ?Q cs1 []" by (simp add:wq_def) |
|
537 |
have nq2: "\<not> ?Q cs2 []" by (simp add:wq_def) |
|
538 |
from p_split [of "?Q cs1", OF q1 nq1] |
|
539 |
obtain t1 where lt1: "t1 < length s" |
|
540 |
and np1: "\<not> ?Q cs1 (moment t1 s)" |
|
541 |
and nn1: "(\<forall>i'>t1. ?Q cs1 (moment i' s))" by auto |
|
542 |
from p_split [of "?Q cs2", OF q2 nq2] |
|
543 |
obtain t2 where lt2: "t2 < length s" |
|
544 |
and np2: "\<not> ?Q cs2 (moment t2 s)" |
|
545 |
and nn2: "(\<forall>i'>t2. ?Q cs2 (moment i' s))" by auto |
|
546 |
{ fix s cs |
|
547 |
assume q: "?Q cs s" |
|
548 |
have "thread \<notin> runing s" |
|
549 |
proof |
|
550 |
assume "thread \<in> runing s" |
|
551 |
hence " \<forall>cs. \<not> (thread \<in> set (wq_fun (schs s) cs) \<and> |
|
552 |
thread \<noteq> hd (wq_fun (schs s) cs))" |
|
553 |
by (unfold runing_def s_waiting_def readys_def, auto) |
|
554 |
from this[rule_format, of cs] q |
|
555 |
show False by (simp add: wq_def) |
|
556 |
qed |
|
557 |
} note q_not_runing = this |
|
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
558 |
{ fix t1 t2 cs1 cs2 |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
559 |
assume lt1: "t1 < length s" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
560 |
and np1: "\<not> ?Q cs1 (moment t1 s)" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
561 |
and nn1: "(\<forall>i'>t1. ?Q cs1 (moment i' s))" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
562 |
and lt2: "t2 < length s" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
563 |
and np2: "\<not> ?Q cs2 (moment t2 s)" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
564 |
and nn2: "(\<forall>i'>t2. ?Q cs2 (moment i' s))" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
565 |
and lt12: "t1 < t2" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
566 |
let ?t3 = "Suc t2" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
567 |
from lt2 have le_t3: "?t3 \<le> length s" by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
568 |
from moment_plus [OF this] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
569 |
obtain e where eq_m: "moment ?t3 s = e#moment t2 s" by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
570 |
have "t2 < ?t3" by simp |
73 | 571 |
from nn2 [rule_format, OF this] and eq_m |
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
572 |
have h1: "thread \<in> set (wq (e#moment t2 s) cs2)" and |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
573 |
h2: "thread \<noteq> hd (wq (e#moment t2 s) cs2)" by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
574 |
have "vt (e#moment t2 s)" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
575 |
proof - |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
576 |
from vt_moment |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
577 |
have "vt (moment ?t3 s)" . |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
578 |
with eq_m show ?thesis by simp |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
579 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
580 |
then interpret vt_e: valid_trace_e "moment t2 s" "e" |
73 | 581 |
by (unfold_locales, auto, cases, simp) |
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
582 |
have ?thesis |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
583 |
proof - |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
584 |
have "thread \<in> runing (moment t2 s)" |
73 | 585 |
proof(cases "thread \<in> set (wq (moment t2 s) cs2)") |
586 |
case True |
|
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
587 |
have "e = V thread cs2" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
588 |
proof - |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
589 |
have eq_th: "thread = hd (wq (moment t2 s) cs2)" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
590 |
using True and np2 by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
591 |
from vt_e.wq_out_inv[OF True this h2] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
592 |
show ?thesis . |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
593 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
594 |
thus ?thesis using vt_e.actor_inv[OF vt_e.pip_e] by auto |
73 | 595 |
next |
596 |
case False |
|
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
597 |
have "e = P thread cs2" using vt_e.wq_in_inv[OF False h1] . |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
598 |
with vt_e.actor_inv[OF vt_e.pip_e] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
599 |
show ?thesis by auto |
73 | 600 |
qed |
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
601 |
moreover have "thread \<notin> runing (moment t2 s)" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
602 |
by (rule q_not_runing[OF nn1[rule_format, OF lt12]]) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
603 |
ultimately show ?thesis by simp |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
604 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
605 |
} note lt_case = this |
73 | 606 |
show ?thesis |
607 |
proof - |
|
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
608 |
{ assume "t1 < t2" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
609 |
from lt_case[OF lt1 np1 nn1 lt2 np2 nn2 this] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
610 |
have ?thesis . |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
611 |
} moreover { |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
612 |
assume "t2 < t1" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
613 |
from lt_case[OF lt2 np2 nn2 lt1 np1 nn1 this] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
614 |
have ?thesis . |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
615 |
} moreover { |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
616 |
assume eq_12: "t1 = t2" |
73 | 617 |
let ?t3 = "Suc t2" |
618 |
from lt2 have le_t3: "?t3 \<le> length s" by auto |
|
619 |
from moment_plus [OF this] |
|
620 |
obtain e where eq_m: "moment ?t3 s = e#moment t2 s" by auto |
|
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
621 |
have lt_2: "t2 < ?t3" by simp |
73 | 622 |
from nn2 [rule_format, OF this] and eq_m |
623 |
have h1: "thread \<in> set (wq (e#moment t2 s) cs2)" and |
|
624 |
h2: "thread \<noteq> hd (wq (e#moment t2 s) cs2)" by auto |
|
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
625 |
from nn1[rule_format, OF lt_2[folded eq_12]] eq_m[folded eq_12] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
626 |
have g1: "thread \<in> set (wq (e#moment t1 s) cs1)" and |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
627 |
g2: "thread \<noteq> hd (wq (e#moment t1 s) cs1)" by auto |
73 | 628 |
have "vt (e#moment t2 s)" |
629 |
proof - |
|
630 |
from vt_moment |
|
631 |
have "vt (moment ?t3 s)" . |
|
632 |
with eq_m show ?thesis by simp |
|
633 |
qed |
|
634 |
then interpret vt_e: valid_trace_e "moment t2 s" "e" |
|
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
635 |
by (unfold_locales, auto, cases, simp) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
636 |
have "e = V thread cs2 \<or> e = P thread cs2" |
73 | 637 |
proof(cases "thread \<in> set (wq (moment t2 s) cs2)") |
638 |
case True |
|
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
639 |
have "e = V thread cs2" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
640 |
proof - |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
641 |
have eq_th: "thread = hd (wq (moment t2 s) cs2)" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
642 |
using True and np2 by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
643 |
from vt_e.wq_out_inv[OF True this h2] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
644 |
show ?thesis . |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
645 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
646 |
thus ?thesis by auto |
73 | 647 |
next |
648 |
case False |
|
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
649 |
have "e = P thread cs2" using vt_e.wq_in_inv[OF False h1] . |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
650 |
thus ?thesis by auto |
73 | 651 |
qed |
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
652 |
moreover have "e = V thread cs1 \<or> e = P thread cs1" |
73 | 653 |
proof(cases "thread \<in> set (wq (moment t1 s) cs1)") |
654 |
case True |
|
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
655 |
have eq_th: "thread = hd (wq (moment t1 s) cs1)" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
656 |
using True and np1 by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
657 |
from vt_e.wq_out_inv[folded eq_12, OF True this g2] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
658 |
have "e = V thread cs1" . |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
659 |
thus ?thesis by auto |
73 | 660 |
next |
661 |
case False |
|
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
662 |
have "e = P thread cs1" using vt_e.wq_in_inv[folded eq_12, OF False g1] . |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
663 |
thus ?thesis by auto |
73 | 664 |
qed |
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
665 |
ultimately have ?thesis using neq12 by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
666 |
} ultimately show ?thesis using nat_neq_iff by blast |
73 | 667 |
qed |
668 |
qed |
|
669 |
||
670 |
text {* |
|
671 |
This lemma is a simple corrolary of @{text "waiting_unique_pre"}. |
|
672 |
*} |
|
673 |
||
674 |
lemma waiting_unique: |
|
675 |
assumes "waiting s th cs1" |
|
676 |
and "waiting s th cs2" |
|
677 |
shows "cs1 = cs2" |
|
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
678 |
using waiting_unique_pre assms |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
679 |
unfolding wq_def s_waiting_def |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
680 |
by auto |
73 | 681 |
|
682 |
end |
|
683 |
||
684 |
(* not used *) |
|
685 |
text {* |
|
686 |
Every thread can only be blocked on one critical resource, |
|
687 |
symmetrically, every critical resource can only be held by one thread. |
|
688 |
This fact is much more easier according to our definition. |
|
689 |
*} |
|
690 |
lemma held_unique: |
|
691 |
assumes "holding (s::event list) th1 cs" |
|
692 |
and "holding s th2 cs" |
|
693 |
shows "th1 = th2" |
|
694 |
by (insert assms, unfold s_holding_def, auto) |
|
695 |
||
696 |
lemma last_set_lt: "th \<in> threads s \<Longrightarrow> last_set th s < length s" |
|
697 |
apply (induct s, auto) |
|
698 |
by (case_tac a, auto split:if_splits) |
|
699 |
||
700 |
lemma last_set_unique: |
|
701 |
"\<lbrakk>last_set th1 s = last_set th2 s; th1 \<in> threads s; th2 \<in> threads s\<rbrakk> |
|
702 |
\<Longrightarrow> th1 = th2" |
|
703 |
apply (induct s, auto) |
|
704 |
by (case_tac a, auto split:if_splits dest:last_set_lt) |
|
705 |
||
706 |
lemma preced_unique : |
|
707 |
assumes pcd_eq: "preced th1 s = preced th2 s" |
|
708 |
and th_in1: "th1 \<in> threads s" |
|
709 |
and th_in2: " th2 \<in> threads s" |
|
710 |
shows "th1 = th2" |
|
711 |
proof - |
|
712 |
from pcd_eq have "last_set th1 s = last_set th2 s" by (simp add:preced_def) |
|
713 |
from last_set_unique [OF this th_in1 th_in2] |
|
714 |
show ?thesis . |
|
715 |
qed |
|
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
716 |
|
73 | 717 |
lemma preced_linorder: |
718 |
assumes neq_12: "th1 \<noteq> th2" |
|
719 |
and th_in1: "th1 \<in> threads s" |
|
720 |
and th_in2: " th2 \<in> threads s" |
|
721 |
shows "preced th1 s < preced th2 s \<or> preced th1 s > preced th2 s" |
|
722 |
proof - |
|
723 |
from preced_unique [OF _ th_in1 th_in2] and neq_12 |
|
724 |
have "preced th1 s \<noteq> preced th2 s" by auto |
|
725 |
thus ?thesis by auto |
|
726 |
qed |
|
727 |
||
728 |
text {* |
|
729 |
The following three lemmas show that @{text "RAG"} does not change |
|
730 |
by the happening of @{text "Set"}, @{text "Create"} and @{text "Exit"} |
|
731 |
events, respectively. |
|
732 |
*} |
|
733 |
||
734 |
lemma RAG_set_unchanged: "(RAG (Set th prio # s)) = RAG s" |
|
735 |
apply (unfold s_RAG_def s_waiting_def wq_def) |
|
736 |
by (simp add:Let_def) |
|
737 |
||
738 |
lemma RAG_create_unchanged: "(RAG (Create th prio # s)) = RAG s" |
|
739 |
apply (unfold s_RAG_def s_waiting_def wq_def) |
|
740 |
by (simp add:Let_def) |
|
741 |
||
742 |
lemma RAG_exit_unchanged: "(RAG (Exit th # s)) = RAG s" |
|
743 |
apply (unfold s_RAG_def s_waiting_def wq_def) |
|
744 |
by (simp add:Let_def) |
|
745 |
||
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
746 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
747 |
context valid_trace_v |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
748 |
begin |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
749 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
750 |
lemma distinct_rest: "distinct rest" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
751 |
by (simp add: distinct_tl rest_def wq_distinct) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
752 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
753 |
lemma holding_cs_eq_th: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
754 |
assumes "holding s t cs" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
755 |
shows "t = th" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
756 |
proof - |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
757 |
from pip_e[unfolded is_v] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
758 |
show ?thesis |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
759 |
proof(cases) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
760 |
case (thread_V) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
761 |
from held_unique[OF this(2) assms] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
762 |
show ?thesis by simp |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
763 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
764 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
765 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
766 |
lemma distinct_wq': "distinct wq'" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
767 |
by (metis (mono_tags, lifting) distinct_rest some_eq_ex wq'_def) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
768 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
769 |
lemma th'_in_inv: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
770 |
assumes "th' \<in> set wq'" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
771 |
shows "th' \<in> set rest" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
772 |
using assms |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
773 |
by (metis (mono_tags, lifting) distinct.simps(2) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
774 |
rest_def some_eq_ex wq'_def wq_distinct wq_s_cs) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
775 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
776 |
lemma neq_t_th: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
777 |
assumes "waiting (e#s) t c" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
778 |
shows "t \<noteq> th" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
779 |
proof |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
780 |
assume otherwise: "t = th" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
781 |
show False |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
782 |
proof(cases "c = cs") |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
783 |
case True |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
784 |
have "t \<in> set wq'" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
785 |
using assms[unfolded True s_waiting_def, folded wq_def, unfolded wq_es_cs] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
786 |
by simp |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
787 |
from th'_in_inv[OF this] have "t \<in> set rest" . |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
788 |
with wq_s_cs[folded otherwise] wq_distinct[of cs] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
789 |
show ?thesis by simp |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
790 |
next |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
791 |
case False |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
792 |
have "wq (e#s) c = wq s c" using False |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
793 |
by (unfold is_v, simp) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
794 |
hence "waiting s t c" using assms |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
795 |
by (simp add: cs_waiting_def waiting_eq) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
796 |
hence "t \<notin> readys s" by (unfold readys_def, auto) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
797 |
hence "t \<notin> runing s" using runing_ready by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
798 |
with runing_th_s[folded otherwise] show ?thesis by auto |
73 | 799 |
qed |
800 |
qed |
|
801 |
||
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
802 |
lemma waiting_esI1: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
803 |
assumes "waiting s t c" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
804 |
and "c \<noteq> cs" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
805 |
shows "waiting (e#s) t c" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
806 |
proof - |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
807 |
have "wq (e#s) c = wq s c" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
808 |
using assms(2) is_v by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
809 |
with assms(1) show ?thesis |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
810 |
using cs_waiting_def waiting_eq by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
811 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
812 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
813 |
lemma holding_esI2: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
814 |
assumes "c \<noteq> cs" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
815 |
and "holding s t c" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
816 |
shows "holding (e#s) t c" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
817 |
proof - |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
818 |
from assms(1) have "wq (e#s) c = wq s c" using is_v by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
819 |
from assms(2)[unfolded s_holding_def, folded wq_def, |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
820 |
folded this, unfolded wq_def, folded s_holding_def] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
821 |
show ?thesis . |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
822 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
823 |
|
79 | 824 |
lemma holding_esI1: |
825 |
assumes "holding s t c" |
|
826 |
and "t \<noteq> th" |
|
827 |
shows "holding (e#s) t c" |
|
828 |
proof - |
|
829 |
have "c \<noteq> cs" using assms using holding_cs_eq_th by blast |
|
830 |
from holding_esI2[OF this assms(1)] |
|
831 |
show ?thesis . |
|
832 |
qed |
|
833 |
||
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
834 |
end |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
835 |
|
79 | 836 |
context valid_trace_v_n |
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
837 |
begin |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
838 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
839 |
lemma neq_wq': "wq' \<noteq> []" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
840 |
proof (unfold wq'_def, rule someI2) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
841 |
show "distinct rest \<and> set rest = set rest" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
842 |
by (simp add: distinct_rest) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
843 |
next |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
844 |
fix x |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
845 |
assume " distinct x \<and> set x = set rest" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
846 |
thus "x \<noteq> []" using rest_nnl by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
847 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
848 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
849 |
definition "taker = hd wq'" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
850 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
851 |
definition "rest' = tl wq'" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
852 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
853 |
lemma eq_wq': "wq' = taker # rest'" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
854 |
by (simp add: neq_wq' rest'_def taker_def) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
855 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
856 |
lemma next_th_taker: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
857 |
shows "next_th s th cs taker" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
858 |
using rest_nnl taker_def wq'_def wq_s_cs |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
859 |
by (auto simp:next_th_def) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
860 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
861 |
lemma taker_unique: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
862 |
assumes "next_th s th cs taker'" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
863 |
shows "taker' = taker" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
864 |
proof - |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
865 |
from assms |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
866 |
obtain rest' where |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
867 |
h: "wq s cs = th # rest'" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
868 |
"taker' = hd (SOME q. distinct q \<and> set q = set rest')" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
869 |
by (unfold next_th_def, auto) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
870 |
with wq_s_cs have "rest' = rest" by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
871 |
thus ?thesis using h(2) taker_def wq'_def by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
872 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
873 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
874 |
lemma waiting_set_eq: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
875 |
"{(Th th', Cs cs) |th'. next_th s th cs th'} = {(Th taker, Cs cs)}" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
876 |
by (smt all_not_in_conv bot.extremum insertI1 insert_subset |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
877 |
mem_Collect_eq next_th_taker subsetI subset_antisym taker_def taker_unique) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
878 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
879 |
lemma holding_set_eq: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
880 |
"{(Cs cs, Th th') |th'. next_th s th cs th'} = {(Cs cs, Th taker)}" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
881 |
using next_th_taker taker_def waiting_set_eq |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
882 |
by fastforce |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
883 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
884 |
lemma holding_taker: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
885 |
shows "holding (e#s) taker cs" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
886 |
by (unfold s_holding_def, fold wq_def, unfold wq_es_cs, |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
887 |
auto simp:neq_wq' taker_def) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
888 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
889 |
lemma waiting_esI2: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
890 |
assumes "waiting s t cs" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
891 |
and "t \<noteq> taker" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
892 |
shows "waiting (e#s) t cs" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
893 |
proof - |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
894 |
have "t \<in> set wq'" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
895 |
proof(unfold wq'_def, rule someI2) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
896 |
show "distinct rest \<and> set rest = set rest" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
897 |
by (simp add: distinct_rest) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
898 |
next |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
899 |
fix x |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
900 |
assume "distinct x \<and> set x = set rest" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
901 |
moreover have "t \<in> set rest" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
902 |
using assms(1) cs_waiting_def waiting_eq wq_s_cs by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
903 |
ultimately show "t \<in> set x" by simp |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
904 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
905 |
moreover have "t \<noteq> hd wq'" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
906 |
using assms(2) taker_def by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
907 |
ultimately show ?thesis |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
908 |
by (unfold s_waiting_def, fold wq_def, unfold wq_es_cs, simp) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
909 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
910 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
911 |
lemma waiting_esE: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
912 |
assumes "waiting (e#s) t c" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
913 |
obtains "c \<noteq> cs" "waiting s t c" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
914 |
| "c = cs" "t \<noteq> taker" "waiting s t cs" "t \<in> set rest'" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
915 |
proof(cases "c = cs") |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
916 |
case False |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
917 |
hence "wq (e#s) c = wq s c" using is_v by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
918 |
with assms have "waiting s t c" using cs_waiting_def waiting_eq by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
919 |
from that(1)[OF False this] show ?thesis . |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
920 |
next |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
921 |
case True |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
922 |
from assms[unfolded s_waiting_def True, folded wq_def, unfolded wq_es_cs] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
923 |
have "t \<noteq> hd wq'" "t \<in> set wq'" by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
924 |
hence "t \<noteq> taker" by (simp add: taker_def) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
925 |
moreover hence "t \<noteq> th" using assms neq_t_th by blast |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
926 |
moreover have "t \<in> set rest" by (simp add: `t \<in> set wq'` th'_in_inv) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
927 |
ultimately have "waiting s t cs" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
928 |
by (metis cs_waiting_def list.distinct(2) list.sel(1) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
929 |
list.set_sel(2) rest_def waiting_eq wq_s_cs) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
930 |
show ?thesis using that(2) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
931 |
using True `t \<in> set wq'` `t \<noteq> taker` `waiting s t cs` eq_wq' by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
932 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
933 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
934 |
lemma holding_esI1: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
935 |
assumes "c = cs" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
936 |
and "t = taker" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
937 |
shows "holding (e#s) t c" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
938 |
by (unfold assms, simp add: holding_taker) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
939 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
940 |
lemma holding_esE: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
941 |
assumes "holding (e#s) t c" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
942 |
obtains "c = cs" "t = taker" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
943 |
| "c \<noteq> cs" "holding s t c" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
944 |
proof(cases "c = cs") |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
945 |
case True |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
946 |
from assms[unfolded True, unfolded s_holding_def, |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
947 |
folded wq_def, unfolded wq_es_cs] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
948 |
have "t = taker" by (simp add: taker_def) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
949 |
from that(1)[OF True this] show ?thesis . |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
950 |
next |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
951 |
case False |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
952 |
hence "wq (e#s) c = wq s c" using is_v by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
953 |
from assms[unfolded s_holding_def, folded wq_def, |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
954 |
unfolded this, unfolded wq_def, folded s_holding_def] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
955 |
have "holding s t c" . |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
956 |
from that(2)[OF False this] show ?thesis . |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
957 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
958 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
959 |
end |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
960 |
|
79 | 961 |
|
962 |
context valid_trace_v_e |
|
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
963 |
begin |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
964 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
965 |
lemma nil_wq': "wq' = []" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
966 |
proof (unfold wq'_def, rule someI2) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
967 |
show "distinct rest \<and> set rest = set rest" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
968 |
by (simp add: distinct_rest) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
969 |
next |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
970 |
fix x |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
971 |
assume " distinct x \<and> set x = set rest" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
972 |
thus "x = []" using rest_nil by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
973 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
974 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
975 |
lemma no_taker: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
976 |
assumes "next_th s th cs taker" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
977 |
shows "False" |
73 | 978 |
proof - |
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
979 |
from assms[unfolded next_th_def] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
980 |
obtain rest' where "wq s cs = th # rest'" "rest' \<noteq> []" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
981 |
by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
982 |
thus ?thesis using rest_def rest_nil by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
983 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
984 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
985 |
lemma waiting_set_eq: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
986 |
"{(Th th', Cs cs) |th'. next_th s th cs th'} = {}" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
987 |
using no_taker by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
988 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
989 |
lemma holding_set_eq: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
990 |
"{(Cs cs, Th th') |th'. next_th s th cs th'} = {}" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
991 |
using no_taker by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
992 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
993 |
lemma no_holding: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
994 |
assumes "holding (e#s) taker cs" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
995 |
shows False |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
996 |
proof - |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
997 |
from wq_es_cs[unfolded nil_wq'] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
998 |
have " wq (e # s) cs = []" . |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
999 |
from assms[unfolded s_holding_def, folded wq_def, unfolded this] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1000 |
show ?thesis by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1001 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1002 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1003 |
lemma no_waiting: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1004 |
assumes "waiting (e#s) t cs" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1005 |
shows False |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1006 |
proof - |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1007 |
from wq_es_cs[unfolded nil_wq'] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1008 |
have " wq (e # s) cs = []" . |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1009 |
from assms[unfolded s_waiting_def, folded wq_def, unfolded this] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1010 |
show ?thesis by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1011 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1012 |
|
79 | 1013 |
lemma waiting_esI2: |
1014 |
assumes "waiting s t c" |
|
1015 |
shows "waiting (e#s) t c" |
|
1016 |
proof - |
|
1017 |
have "c \<noteq> cs" using assms |
|
1018 |
using cs_waiting_def rest_nil waiting_eq wq_s_cs by auto |
|
1019 |
from waiting_esI1[OF assms this] |
|
1020 |
show ?thesis . |
|
1021 |
qed |
|
1022 |
||
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1023 |
lemma waiting_esE: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1024 |
assumes "waiting (e#s) t c" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1025 |
obtains "c \<noteq> cs" "waiting s t c" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1026 |
proof(cases "c = cs") |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1027 |
case False |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1028 |
hence "wq (e#s) c = wq s c" using is_v by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1029 |
with assms have "waiting s t c" using cs_waiting_def waiting_eq by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1030 |
from that(1)[OF False this] show ?thesis . |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1031 |
next |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1032 |
case True |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1033 |
from no_waiting[OF assms[unfolded True]] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1034 |
show ?thesis by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1035 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1036 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1037 |
lemma holding_esE: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1038 |
assumes "holding (e#s) t c" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1039 |
obtains "c \<noteq> cs" "holding s t c" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1040 |
proof(cases "c = cs") |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1041 |
case True |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1042 |
from no_holding[OF assms[unfolded True]] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1043 |
show ?thesis by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1044 |
next |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1045 |
case False |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1046 |
hence "wq (e#s) c = wq s c" using is_v by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1047 |
from assms[unfolded s_holding_def, folded wq_def, |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1048 |
unfolded this, unfolded wq_def, folded s_holding_def] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1049 |
have "holding s t c" . |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1050 |
from that[OF False this] show ?thesis . |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1051 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1052 |
|
79 | 1053 |
end |
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1054 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1055 |
lemma rel_eqI: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1056 |
assumes "\<And> x y. (x,y) \<in> A \<Longrightarrow> (x,y) \<in> B" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1057 |
and "\<And> x y. (x,y) \<in> B \<Longrightarrow> (x, y) \<in> A" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1058 |
shows "A = B" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1059 |
using assms by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1060 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1061 |
lemma in_RAG_E: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1062 |
assumes "(n1, n2) \<in> RAG (s::state)" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1063 |
obtains (waiting) th cs where "n1 = Th th" "n2 = Cs cs" "waiting s th cs" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1064 |
| (holding) th cs where "n1 = Cs cs" "n2 = Th th" "holding s th cs" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1065 |
using assms[unfolded s_RAG_def, folded waiting_eq holding_eq] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1066 |
by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1067 |
|
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1068 |
context valid_trace_v |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1069 |
begin |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1070 |
|
79 | 1071 |
lemma RAG_es: |
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1072 |
"RAG (e # s) = |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1073 |
RAG s - {(Cs cs, Th th)} - |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1074 |
{(Th th', Cs cs) |th'. next_th s th cs th'} \<union> |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1075 |
{(Cs cs, Th th') |th'. next_th s th cs th'}" (is "?L = ?R") |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1076 |
proof(rule rel_eqI) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1077 |
fix n1 n2 |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1078 |
assume "(n1, n2) \<in> ?L" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1079 |
thus "(n1, n2) \<in> ?R" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1080 |
proof(cases rule:in_RAG_E) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1081 |
case (waiting th' cs') |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1082 |
show ?thesis |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1083 |
proof(cases "rest = []") |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1084 |
case False |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1085 |
interpret h_n: valid_trace_v_n s e th cs |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1086 |
by (unfold_locales, insert False, simp) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1087 |
from waiting(3) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1088 |
show ?thesis |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1089 |
proof(cases rule:h_n.waiting_esE) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1090 |
case 1 |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1091 |
with waiting(1,2) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1092 |
show ?thesis |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1093 |
by (unfold h_n.waiting_set_eq h_n.holding_set_eq s_RAG_def, |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1094 |
fold waiting_eq, auto) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1095 |
next |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1096 |
case 2 |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1097 |
with waiting(1,2) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1098 |
show ?thesis |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1099 |
by (unfold h_n.waiting_set_eq h_n.holding_set_eq s_RAG_def, |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1100 |
fold waiting_eq, auto) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1101 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1102 |
next |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1103 |
case True |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1104 |
interpret h_e: valid_trace_v_e s e th cs |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1105 |
by (unfold_locales, insert True, simp) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1106 |
from waiting(3) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1107 |
show ?thesis |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1108 |
proof(cases rule:h_e.waiting_esE) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1109 |
case 1 |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1110 |
with waiting(1,2) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1111 |
show ?thesis |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1112 |
by (unfold h_e.waiting_set_eq h_e.holding_set_eq s_RAG_def, |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1113 |
fold waiting_eq, auto) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1114 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1115 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1116 |
next |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1117 |
case (holding th' cs') |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1118 |
show ?thesis |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1119 |
proof(cases "rest = []") |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1120 |
case False |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1121 |
interpret h_n: valid_trace_v_n s e th cs |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1122 |
by (unfold_locales, insert False, simp) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1123 |
from holding(3) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1124 |
show ?thesis |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1125 |
proof(cases rule:h_n.holding_esE) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1126 |
case 1 |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1127 |
with holding(1,2) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1128 |
show ?thesis |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1129 |
by (unfold h_n.waiting_set_eq h_n.holding_set_eq s_RAG_def, |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1130 |
fold waiting_eq, auto) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1131 |
next |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1132 |
case 2 |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1133 |
with holding(1,2) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1134 |
show ?thesis |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1135 |
by (unfold h_n.waiting_set_eq h_n.holding_set_eq s_RAG_def, |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1136 |
fold holding_eq, auto) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1137 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1138 |
next |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1139 |
case True |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1140 |
interpret h_e: valid_trace_v_e s e th cs |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1141 |
by (unfold_locales, insert True, simp) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1142 |
from holding(3) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1143 |
show ?thesis |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1144 |
proof(cases rule:h_e.holding_esE) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1145 |
case 1 |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1146 |
with holding(1,2) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1147 |
show ?thesis |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1148 |
by (unfold h_e.waiting_set_eq h_e.holding_set_eq s_RAG_def, |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1149 |
fold holding_eq, auto) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1150 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1151 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1152 |
qed |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1153 |
next |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1154 |
fix n1 n2 |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1155 |
assume h: "(n1, n2) \<in> ?R" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1156 |
show "(n1, n2) \<in> ?L" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1157 |
proof(cases "rest = []") |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1158 |
case False |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1159 |
interpret h_n: valid_trace_v_n s e th cs |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1160 |
by (unfold_locales, insert False, simp) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1161 |
from h[unfolded h_n.waiting_set_eq h_n.holding_set_eq] |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1162 |
have "((n1, n2) \<in> RAG s \<and> (n1 \<noteq> Cs cs \<or> n2 \<noteq> Th th) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1163 |
\<and> (n1 \<noteq> Th h_n.taker \<or> n2 \<noteq> Cs cs)) \<or> |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1164 |
(n2 = Th h_n.taker \<and> n1 = Cs cs)" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1165 |
by auto |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1166 |
thus ?thesis |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1167 |
proof |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1168 |
assume "n2 = Th h_n.taker \<and> n1 = Cs cs" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1169 |
with h_n.holding_taker |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1170 |
show ?thesis |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1171 |
by (unfold s_RAG_def, fold holding_eq, auto) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1172 |
next |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1173 |
assume h: "(n1, n2) \<in> RAG s \<and> |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1174 |
(n1 \<noteq> Cs cs \<or> n2 \<noteq> Th th) \<and> (n1 \<noteq> Th h_n.taker \<or> n2 \<noteq> Cs cs)" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1175 |
hence "(n1, n2) \<in> RAG s" by simp |
73 | 1176 |
thus ?thesis |
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1177 |
proof(cases rule:in_RAG_E) |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1178 |
case (waiting th' cs') |
79 | 1179 |
from h and this(1,2) |
1180 |
have "th' \<noteq> h_n.taker \<or> cs' \<noteq> cs" by auto |
|
1181 |
hence "waiting (e#s) th' cs'" |
|
1182 |
proof |
|
1183 |
assume "cs' \<noteq> cs" |
|
1184 |
from waiting_esI1[OF waiting(3) this] |
|
1185 |
show ?thesis . |
|
1186 |
next |
|
1187 |
assume neq_th': "th' \<noteq> h_n.taker" |
|
1188 |
show ?thesis |
|
1189 |
proof(cases "cs' = cs") |
|
1190 |
case False |
|
1191 |
from waiting_esI1[OF waiting(3) this] |
|
1192 |
show ?thesis . |
|
1193 |
next |
|
1194 |
case True |
|
1195 |
from h_n.waiting_esI2[OF waiting(3)[unfolded True] neq_th', folded True] |
|
1196 |
show ?thesis . |
|
1197 |
qed |
|
1198 |
qed |
|
1199 |
thus ?thesis using waiting(1,2) |
|
1200 |
by (unfold s_RAG_def, fold waiting_eq, auto) |
|
1201 |
next |
|
1202 |
case (holding th' cs') |
|
1203 |
from h this(1,2) |
|
1204 |
have "cs' \<noteq> cs \<or> th' \<noteq> th" by auto |
|
1205 |
hence "holding (e#s) th' cs'" |
|
1206 |
proof |
|
1207 |
assume "cs' \<noteq> cs" |
|
1208 |
from holding_esI2[OF this holding(3)] |
|
1209 |
show ?thesis . |
|
1210 |
next |
|
1211 |
assume "th' \<noteq> th" |
|
1212 |
from holding_esI1[OF holding(3) this] |
|
1213 |
show ?thesis . |
|
1214 |
qed |
|
1215 |
thus ?thesis using holding(1,2) |
|
1216 |
by (unfold s_RAG_def, fold holding_eq, auto) |
|
73 | 1217 |
qed |
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1218 |
qed |
79 | 1219 |
next |
1220 |
case True |
|
1221 |
interpret h_e: valid_trace_v_e s e th cs |
|
1222 |
by (unfold_locales, insert True, simp) |
|
1223 |
from h[unfolded h_e.waiting_set_eq h_e.holding_set_eq] |
|
1224 |
have h_s: "(n1, n2) \<in> RAG s" "(n1, n2) \<noteq> (Cs cs, Th th)" |
|
1225 |
by auto |
|
1226 |
from h_s(1) |
|
1227 |
show ?thesis |
|
1228 |
proof(cases rule:in_RAG_E) |
|
1229 |
case (waiting th' cs') |
|
1230 |
from h_e.waiting_esI2[OF this(3)] |
|
1231 |
show ?thesis using waiting(1,2) |
|
1232 |
by (unfold s_RAG_def, fold waiting_eq, auto) |
|
1233 |
next |
|
1234 |
case (holding th' cs') |
|
1235 |
with h_s(2) |
|
1236 |
have "cs' \<noteq> cs \<or> th' \<noteq> th" by auto |
|
1237 |
thus ?thesis |
|
1238 |
proof |
|
1239 |
assume neq_cs: "cs' \<noteq> cs" |
|
1240 |
from holding_esI2[OF this holding(3)] |
|
1241 |
show ?thesis using holding(1,2) |
|
1242 |
by (unfold s_RAG_def, fold holding_eq, auto) |
|
1243 |
next |
|
1244 |
assume "th' \<noteq> th" |
|
1245 |
from holding_esI1[OF holding(3) this] |
|
1246 |
show ?thesis using holding(1,2) |
|
1247 |
by (unfold s_RAG_def, fold holding_eq, auto) |
|
1248 |
qed |
|
1249 |
qed |
|
1250 |
qed |
|
73 | 1251 |
qed |
1252 |
||
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1253 |
end |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1254 |
|
79 | 1255 |
lemma step_RAG_v: |
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1256 |
assumes vt: |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1257 |
"vt (V th cs#s)" |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1258 |
shows " |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1259 |
RAG (V th cs # s) = |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1260 |
RAG s - {(Cs cs, Th th)} - |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1261 |
{(Th th', Cs cs) |th'. next_th s th cs th'} \<union> |
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1262 |
{(Cs cs, Th th') |th'. next_th s th cs th'}" (is "?L = ?R") |
79 | 1263 |
proof - |
1264 |
interpret vt_v: valid_trace_v s "V th cs" |
|
1265 |
using assms step_back_vt by (unfold_locales, auto) |
|
1266 |
show ?thesis using vt_v.RAG_es . |
|
1267 |
qed |
|
1268 |
||
1269 |
lemma (in valid_trace_create) |
|
1270 |
th_not_in_threads: "th \<notin> threads s" |
|
1271 |
proof - |
|
1272 |
from pip_e[unfolded is_create] |
|
1273 |
show ?thesis by (cases, simp) |
|
73 | 1274 |
qed |
1275 |
||
79 | 1276 |
lemma (in valid_trace_create) |
1277 |
threads_es [simp]: "threads (e#s) = threads s \<union> {th}" |
|
1278 |
by (unfold is_create, simp) |
|
73 | 1279 |
|
79 | 1280 |
lemma (in valid_trace_exit) |
1281 |
threads_es [simp]: "threads (e#s) = threads s - {th}" |
|
1282 |
by (unfold is_exit, simp) |
|
73 | 1283 |
|
79 | 1284 |
lemma (in valid_trace_p) |
1285 |
threads_es [simp]: "threads (e#s) = threads s" |
|
1286 |
by (unfold is_p, simp) |
|
73 | 1287 |
|
79 | 1288 |
lemma (in valid_trace_v) |
1289 |
threads_es [simp]: "threads (e#s) = threads s" |
|
1290 |
by (unfold is_v, simp) |
|
73 | 1291 |
|
79 | 1292 |
lemma (in valid_trace_v) |
1293 |
th_not_in_rest[simp]: "th \<notin> set rest" |
|
1294 |
proof |
|
1295 |
assume otherwise: "th \<in> set rest" |
|
1296 |
have "distinct (wq s cs)" by (simp add: wq_distinct) |
|
1297 |
from this[unfolded wq_s_cs] and otherwise |
|
1298 |
show False by auto |
|
1299 |
qed |
|
1300 |
||
1301 |
lemma (in valid_trace_v) |
|
1302 |
set_wq_es_cs [simp]: "set (wq (e#s) cs) = set (wq s cs) - {th}" |
|
1303 |
proof(unfold wq_es_cs wq'_def, rule someI2) |
|
1304 |
show "distinct rest \<and> set rest = set rest" |
|
1305 |
by (simp add: distinct_rest) |
|
1306 |
next |
|
1307 |
fix x |
|
1308 |
assume "distinct x \<and> set x = set rest" |
|
1309 |
thus "set x = set (wq s cs) - {th}" |
|
1310 |
by (unfold wq_s_cs, simp) |
|
73 | 1311 |
qed |
1312 |
||
79 | 1313 |
lemma (in valid_trace_exit) |
1314 |
th_not_in_wq: "th \<notin> set (wq s cs)" |
|
73 | 1315 |
proof - |
79 | 1316 |
from pip_e[unfolded is_exit] |
1317 |
show ?thesis |
|
1318 |
by (cases, unfold holdents_def s_holding_def, fold wq_def, |
|
1319 |
auto elim!:runing_wqE) |
|
73 | 1320 |
qed |
1321 |
||
79 | 1322 |
lemma (in valid_trace) wq_threads: |
1323 |
assumes "th \<in> set (wq s cs)" |
|
73 | 1324 |
shows "th \<in> threads s" |
79 | 1325 |
using assms |
1326 |
proof(induct rule:ind) |
|
1327 |
case (Nil) |
|
1328 |
thus ?case by (auto simp:wq_def) |
|
1329 |
next |
|
1330 |
case (Cons s e) |
|
1331 |
interpret vt_e: valid_trace_e s e using Cons by simp |
|
1332 |
show ?case |
|
1333 |
proof(cases e) |
|
1334 |
case (Create th' prio') |
|
1335 |
interpret vt: valid_trace_create s e th' prio' |
|
1336 |
using Create by (unfold_locales, simp) |
|
1337 |
show ?thesis |
|
1338 |
using Cons.hyps(2) Cons.prems by auto |
|
1339 |
next |
|
1340 |
case (Exit th') |
|
1341 |
interpret vt: valid_trace_exit s e th' |
|
1342 |
using Exit by (unfold_locales, simp) |
|
1343 |
show ?thesis |
|
1344 |
using Cons.hyps(2) Cons.prems vt.th_not_in_wq by auto |
|
1345 |
next |
|
1346 |
case (P th' cs') |
|
1347 |
interpret vt: valid_trace_p s e th' cs' |
|
1348 |
using P by (unfold_locales, simp) |
|
1349 |
show ?thesis |
|
1350 |
using Cons.hyps(2) Cons.prems readys_threads |
|
1351 |
runing_ready vt.is_p vt.runing_th_s vt_e.wq_in_inv |
|
1352 |
by fastforce |
|
1353 |
next |
|
1354 |
case (V th' cs') |
|
1355 |
interpret vt: valid_trace_v s e th' cs' |
|
1356 |
using V by (unfold_locales, simp) |
|
1357 |
show ?thesis using Cons |
|
1358 |
using vt.is_v vt.threads_es vt_e.wq_in_inv by blast |
|
1359 |
next |
|
1360 |
case (Set th' prio) |
|
1361 |
interpret vt: valid_trace_set s e th' prio |
|
1362 |
using Set by (unfold_locales, simp) |
|
1363 |
show ?thesis using Cons.hyps(2) Cons.prems vt.is_set |
|
73 | 1364 |
by (auto simp:wq_def Let_def) |
1365 |
qed |
|
79 | 1366 |
qed |
73 | 1367 |
|
1368 |
context valid_trace |
|
57
f1b39d77db00
Added generic theory "RTree.thy"
xingyuan zhang <xingyuanzhang@126.com>
parents:
diff
changeset
|
1369 |
begin |
f1b39d77db00
Added generic theory "RTree.thy"
xingyuan zhang <xingyuanzhang@126.com>
parents:
diff
changeset
|
1370 |
|
79 | 1371 |
lemma dm_RAG_threads: |
73 | 1372 |
assumes in_dom: "(Th th) \<in> Domain (RAG s)" |
1373 |
shows "th \<in> threads s" |
|
1374 |
proof - |
|
1375 |
from in_dom obtain n where "(Th th, n) \<in> RAG s" by auto |
|
1376 |
moreover from RAG_target_th[OF this] obtain cs where "n = Cs cs" by auto |
|
1377 |
ultimately have "(Th th, Cs cs) \<in> RAG s" by simp |
|
1378 |
hence "th \<in> set (wq s cs)" |
|
1379 |
by (unfold s_RAG_def, auto simp:cs_waiting_def) |
|
1380 |
from wq_threads [OF this] show ?thesis . |
|
1381 |
qed |
|
1382 |
||
79 | 1383 |
lemma cp_le: |
73 | 1384 |
assumes th_in: "th \<in> threads s" |
1385 |
shows "cp s th \<le> Max ((\<lambda> th. (preced th s)) ` threads s)" |
|
1386 |
proof(unfold cp_eq_cpreced cpreced_def cs_dependants_def) |
|
1387 |
show "Max ((\<lambda>th. preced th s) ` ({th} \<union> {th'. (Th th', Th th) \<in> (RAG (wq s))\<^sup>+})) |
|
1388 |
\<le> Max ((\<lambda>th. preced th s) ` threads s)" |
|
1389 |
(is "Max (?f ` ?A) \<le> Max (?f ` ?B)") |
|
1390 |
proof(rule Max_f_mono) |
|
1391 |
show "{th} \<union> {th'. (Th th', Th th) \<in> (RAG (wq s))\<^sup>+} \<noteq> {}" by simp |
|
1392 |
next |
|
1393 |
from finite_threads |
|
1394 |
show "finite (threads s)" . |
|
1395 |
next |
|
1396 |
from th_in |
|
1397 |
show "{th} \<union> {th'. (Th th', Th th) \<in> (RAG (wq s))\<^sup>+} \<subseteq> threads s" |
|
1398 |
apply (auto simp:Domain_def) |
|
1399 |
apply (rule_tac dm_RAG_threads) |
|
1400 |
apply (unfold trancl_domain [of "RAG s", symmetric]) |
|
1401 |
by (unfold cs_RAG_def s_RAG_def, auto simp:Domain_def) |
|
1402 |
qed |
|
1403 |
qed |
|
1404 |
||
1405 |
lemma max_cp_eq: |
|
1406 |
shows "Max ((cp s) ` threads s) = Max ((\<lambda> th. (preced th s)) ` threads s)" |
|
1407 |
(is "?l = ?r") |
|
1408 |
proof(cases "threads s = {}") |
|
1409 |
case True |
|
1410 |
thus ?thesis by auto |
|
1411 |
next |
|
1412 |
case False |
|
1413 |
have "?l \<in> ((cp s) ` threads s)" |
|
1414 |
proof(rule Max_in) |
|
1415 |
from finite_threads |
|
1416 |
show "finite (cp s ` threads s)" by auto |
|
1417 |
next |
|
1418 |
from False show "cp s ` threads s \<noteq> {}" by auto |
|
1419 |
qed |
|
1420 |
then obtain th |
|
1421 |
where th_in: "th \<in> threads s" and eq_l: "?l = cp s th" by auto |
|
1422 |
have "\<dots> \<le> ?r" by (rule cp_le[OF th_in]) |
|
1423 |
moreover have "?r \<le> cp s th" (is "Max (?f ` ?A) \<le> cp s th") |
|
1424 |
proof - |
|
1425 |
have "?r \<in> (?f ` ?A)" |
|
1426 |
proof(rule Max_in) |
|
1427 |
from finite_threads |
|
1428 |
show " finite ((\<lambda>th. preced th s) ` threads s)" by auto |
|
1429 |
next |
|
1430 |
from False show " (\<lambda>th. preced th s) ` threads s \<noteq> {}" by auto |
|
1431 |
qed |
|
1432 |
then obtain th' where |
|
1433 |
th_in': "th' \<in> ?A " and eq_r: "?r = ?f th'" by auto |
|
1434 |
from le_cp [of th'] eq_r |
|
1435 |
have "?r \<le> cp s th'" by auto |
|
1436 |
moreover have "\<dots> \<le> cp s th" |
|
1437 |
proof(fold eq_l) |
|
1438 |
show " cp s th' \<le> Max (cp s ` threads s)" |
|
1439 |
proof(rule Max_ge) |
|
1440 |
from th_in' show "cp s th' \<in> cp s ` threads s" |
|
1441 |
by auto |
|
1442 |
next |
|
1443 |
from finite_threads |
|
1444 |
show "finite (cp s ` threads s)" by auto |
|
1445 |
qed |
|
1446 |
qed |
|
1447 |
ultimately show ?thesis by auto |
|
1448 |
qed |
|
1449 |
ultimately show ?thesis using eq_l by auto |
|
1450 |
qed |
|
1451 |
||
79 | 1452 |
lemma max_cp_eq_the_preced: |
1453 |
shows "Max ((cp s) ` threads s) = Max (the_preced s ` threads s)" |
|
1454 |
using max_cp_eq using the_preced_def by presburger |
|
63 | 1455 |
|
1456 |
end |
|
1457 |
||
79 | 1458 |
lemma preced_v [simp]: "preced th' (V th cs#s) = preced th' s" |
1459 |
by (unfold preced_def, simp) |
|
58 | 1460 |
|
79 | 1461 |
lemma (in valid_trace_v) |
1462 |
preced_es: "preced th (e#s) = preced th s" |
|
1463 |
by (unfold is_v preced_def, simp) |
|
58 | 1464 |
|
79 | 1465 |
lemma the_preced_v[simp]: "the_preced (V th cs#s) = the_preced s" |
1466 |
proof |
|
1467 |
fix th' |
|
1468 |
show "the_preced (V th cs # s) th' = the_preced s th'" |
|
1469 |
by (unfold the_preced_def preced_def, simp) |
|
61 | 1470 |
qed |
1471 |
||
79 | 1472 |
lemma (in valid_trace_v) |
1473 |
the_preced_es: "the_preced (e#s) = the_preced s" |
|
1474 |
by (unfold is_v preced_def, simp) |
|
63 | 1475 |
|
79 | 1476 |
context valid_trace_p |
58 | 1477 |
begin |
1478 |
||
79 | 1479 |
lemma not_holding_es_th_cs: "\<not> holding s th cs" |
62 | 1480 |
proof |
79 | 1481 |
assume otherwise: "holding s th cs" |
1482 |
from pip_e[unfolded is_p] |
|
1483 |
show False |
|
1484 |
proof(cases) |
|
1485 |
case (thread_P) |
|
1486 |
moreover have "(Cs cs, Th th) \<in> RAG s" |
|
1487 |
using otherwise cs_holding_def |
|
1488 |
holding_eq th_not_in_wq by auto |
|
1489 |
ultimately show ?thesis by auto |
|
58 | 1490 |
qed |
1491 |
qed |
|
1492 |
||
1493 |
end |
|
1494 |
||
79 | 1495 |
locale valid_trace_p_h = valid_trace_p + |
1496 |
assumes we: "wq s cs = []" |
|
58 | 1497 |
|
79 | 1498 |
locale valid_trace_p_w = valid_trace_p + |
1499 |
assumes we: "wq s cs \<noteq> []" |
|
63 | 1500 |
begin |
1501 |
||
79 | 1502 |
definition "holder = hd (wq s cs)" |
1503 |
definition "waiters = tl (wq s cs)" |
|
1504 |
definition "waiters' = waiters @ [th]" |
|
57
f1b39d77db00
Added generic theory "RTree.thy"
xingyuan zhang <xingyuanzhang@126.com>
parents:
diff
changeset
|
1505 |
|
79 | 1506 |
lemma wq_s_cs: "wq s cs = holder#waiters" |
1507 |
by (simp add: holder_def waiters_def we) |
|
1508 |
||
1509 |
lemma wq_es_cs': "wq (e#s) cs = holder#waiters@[th]" |
|
1510 |
by (simp add: wq_es_cs wq_s_cs) |
|
1511 |
||
1512 |
lemma waiting_es_th_cs: "waiting (e#s) th cs" |
|
1513 |
using cs_waiting_def th_not_in_wq waiting_eq wq_es_cs' wq_s_cs by auto |
|
1514 |
||
1515 |
lemma RAG_edge: "(Th th, Cs cs) \<in> RAG (e#s)" |
|
1516 |
by (unfold s_RAG_def, fold waiting_eq, insert waiting_es_th_cs, auto) |
|
63 | 1517 |
|
1518 |
end |
|
58 | 1519 |
|
79 | 1520 |
context valid_trace_p_h |
1521 |
begin |
|
1522 |
||
1523 |
lemma wq_es_cs': "wq (e#s) cs = [th]" |
|
1524 |
using wq_es_cs[unfolded we] by simp |
|
1525 |
||
1526 |
lemma holding_es_th_cs: |
|
1527 |
shows "holding (e#s) th cs" |
|
1528 |
proof - |
|
1529 |
from wq_es_cs' |
|
1530 |
have "th \<in> set (wq (e#s) cs)" "th = hd (wq (e#s) cs)" by auto |
|
1531 |
thus ?thesis using cs_holding_def holding_eq by blast |
|
1532 |
qed |
|
1533 |
||
1534 |
lemma RAG_edge: "(Cs cs, Th th) \<in> RAG (e#s)" |
|
1535 |
by (unfold s_RAG_def, fold holding_eq, insert holding_es_th_cs, auto) |
|
1536 |
||
1537 |
lemma waiting_esE: |
|
1538 |
assumes "waiting (e#s) th' cs'" |
|
1539 |
obtains "waiting s th' cs'" |
|
1540 |
using assms |
|
1541 |
by (metis cs_waiting_def event.distinct(15) is_p list.sel(1) |
|
1542 |
set_ConsD waiting_eq we wq_es_cs' wq_neq_simp wq_out_inv) |
|
1543 |
||
1544 |
lemma holding_esE: |
|
1545 |
assumes "holding (e#s) th' cs'" |
|
1546 |
obtains "cs' \<noteq> cs" "holding s th' cs'" |
|
1547 |
| "cs' = cs" "th' = th" |
|
1548 |
proof(cases "cs' = cs") |
|
1549 |
case True |
|
1550 |
from held_unique[OF holding_es_th_cs assms[unfolded True]] |
|
1551 |
have "th' = th" by simp |
|
1552 |
from that(2)[OF True this] show ?thesis . |
|
1553 |
next |
|
1554 |
case False |
|
1555 |
have "holding s th' cs'" using assms |
|
1556 |
using False cs_holding_def holding_eq by auto |
|
1557 |
from that(1)[OF False this] show ?thesis . |
|
1558 |
qed |
|
57
f1b39d77db00
Added generic theory "RTree.thy"
xingyuan zhang <xingyuanzhang@126.com>
parents:
diff
changeset
|
1559 |
|
79 | 1560 |
lemma waiting_kept: |
1561 |
assumes "waiting s th' cs'" |
|
1562 |
shows "waiting (e#s) th' cs'" |
|
1563 |
using assms |
|
1564 |
by (metis cs_waiting_def list.sel(1) list.set_intros(2) |
|
1565 |
th_not_in_wq waiting_eq we wq_es_cs' wq_neq_simp) |
|
1566 |
||
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1567 |
|
79 | 1568 |
lemma RAG_es: "RAG (e # s) = RAG s \<union> {(Cs cs, Th th)}" (is "?L = ?R") |
1569 |
proof(rule rel_eqI) |
|
1570 |
fix n1 n2 |
|
1571 |
assume "(n1, n2) \<in> ?L" |
|
1572 |
thus "(n1, n2) \<in> ?R" |
|
1573 |
proof(cases rule:in_RAG_E) |
|
1574 |
case (waiting th' cs') |
|
1575 |
from this(3) |
|
1576 |
show ?thesis |
|
1577 |
proof(cases rule:waiting_esE) |
|
1578 |
case 1 |
|
1579 |
thus ?thesis using waiting(1,2) |
|
1580 |
by (unfold s_RAG_def, fold waiting_eq, auto) |
|
1581 |
qed |
|
1582 |
next |
|
1583 |
case (holding th' cs') |
|
1584 |
from this(3) |
|
1585 |
show ?thesis |
|
1586 |
proof(cases rule:holding_esE) |
|
1587 |
case 1 |
|
1588 |
with holding(1,2) |
|
1589 |
show ?thesis by (unfold s_RAG_def, fold holding_eq, auto) |
|
1590 |
next |
|
1591 |
case 2 |
|
1592 |
with holding(1,2) show ?thesis by auto |
|
1593 |
qed |
|
1594 |
qed |
|
1595 |
next |
|
1596 |
fix n1 n2 |
|
1597 |
assume "(n1, n2) \<in> ?R" |
|
1598 |
hence "(n1, n2) \<in> RAG s \<or> (n1 = Cs cs \<and> n2 = Th th)" by auto |
|
1599 |
thus "(n1, n2) \<in> ?L" |
|
1600 |
proof |
|
1601 |
assume "(n1, n2) \<in> RAG s" |
|
1602 |
thus ?thesis |
|
1603 |
proof(cases rule:in_RAG_E) |
|
1604 |
case (waiting th' cs') |
|
1605 |
find_theorems waiting e s |
|
1606 |
qed |
|
1607 |
qed |
|
1608 |
qed |
|
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1609 |
|
57
f1b39d77db00
Added generic theory "RTree.thy"
xingyuan zhang <xingyuanzhang@126.com>
parents:
diff
changeset
|
1610 |
end |
77
d37703e0c5c4
CpsG.thy updated. It is a copy of PIPBasics.thy under drastic improvement.
zhangx
parents:
73
diff
changeset
|
1611 |
|
79 | 1612 |
|
1613 |
||
1614 |
lemma "RAG (e # s) = (if (wq s cs = []) then RAG s \<union> {(Cs cs, Th th)} |
|
1615 |
else RAG s \<union> {(Th th, Cs cs)})" |
|
1616 |
proof(cases "wq s cs = []") |
|
1617 |
case True |
|
1618 |
from wq_es_cs[unfolded this] |
|
1619 |
have "th \<in> set (wq (e#s) cs)" "th = hd (wq (e#s) cs)" by auto |
|
1620 |
hence "holding (e#s) th cs" |
|
1621 |
using cs_holding_def holding_eq by blast |
|
1622 |
thus |
|
1623 |
qed |
|
1624 |
end |
|
1625 |
||
1626 |
text {* |
|
1627 |
The following @{text "step_RAG_p"} lemma charaterizes how @{text "RAG"} is changed |
|
1628 |
with the happening of @{text "P"}-events: |
|
1629 |
*} |
|
1630 |
lemma step_RAG_p: |
|
1631 |
"vt (P th cs#s) \<Longrightarrow> |
|
1632 |
RAG (P th cs # s) = (if (wq s cs = []) then RAG s \<union> {(Cs cs, Th th)} |
|
1633 |
else RAG s \<union> {(Th th, Cs cs)})" |
|
1634 |
apply(simp only: s_RAG_def wq_def) |
|
1635 |
apply (auto split:list.splits prod.splits simp:Let_def wq_def cs_waiting_def cs_holding_def) |
|
1636 |
apply(case_tac "csa = cs", auto) |
|
1637 |
apply(fold wq_def) |
|
1638 |
apply(drule_tac step_back_step) |
|
1639 |
apply(ind_cases " step s (P (hd (wq s cs)) cs)") |
|
1640 |
apply(simp add:s_RAG_def wq_def cs_holding_def) |
|
1641 |
apply(auto) |
|
1642 |
done |
|
1643 |
||
1644 |
||
1645 |
||
1646 |
end |