author | paulson |
Sat, 08 Feb 2003 16:05:33 +0100 | |
changeset 13812 | 91713a1915ee |
parent 13805 | 3786b2fd6808 |
child 13861 | 0c18f31d901a |
permissions | -rw-r--r-- |
4776 | 1 |
(* Title: HOL/UNITY/UNITY |
2 |
ID: $Id$ |
|
3 |
Author: Lawrence C Paulson, Cambridge University Computer Laboratory |
|
4 |
Copyright 1998 University of Cambridge |
|
5 |
||
6 |
The basic UNITY theory (revised version, based upon the "co" operator) |
|
7 |
||
8 |
From Misra, "A Logic for Concurrent Programming", 1994 |
|
9 |
*) |
|
10 |
||
13798 | 11 |
header {*The Basic UNITY Theory*} |
12 |
||
13797 | 13 |
theory UNITY = Main: |
6535 | 14 |
|
15 |
typedef (Program) |
|
10064
1a77667b21ef
added compatibility relation: AllowedActs, Allowed, ok,
paulson
parents:
8948
diff
changeset
|
16 |
'a program = "{(init:: 'a set, acts :: ('a * 'a)set set, |
13805 | 17 |
allowed :: ('a * 'a)set set). Id \<in> acts & Id: allowed}" |
13797 | 18 |
by blast |
6536 | 19 |
|
4776 | 20 |
constdefs |
13797 | 21 |
constrains :: "['a set, 'a set] => 'a program set" (infixl "co" 60) |
13805 | 22 |
"A co B == {F. \<forall>act \<in> Acts F. act``A \<subseteq> B}" |
13797 | 23 |
|
24 |
unless :: "['a set, 'a set] => 'a program set" (infixl "unless" 60) |
|
13805 | 25 |
"A unless B == (A-B) co (A \<union> B)" |
13797 | 26 |
|
27 |
mk_program :: "('a set * ('a * 'a)set set * ('a * 'a)set set) |
|
10064
1a77667b21ef
added compatibility relation: AllowedActs, Allowed, ok,
paulson
parents:
8948
diff
changeset
|
28 |
=> 'a program" |
1a77667b21ef
added compatibility relation: AllowedActs, Allowed, ok,
paulson
parents:
8948
diff
changeset
|
29 |
"mk_program == %(init, acts, allowed). |
1a77667b21ef
added compatibility relation: AllowedActs, Allowed, ok,
paulson
parents:
8948
diff
changeset
|
30 |
Abs_Program (init, insert Id acts, insert Id allowed)" |
6535 | 31 |
|
32 |
Init :: "'a program => 'a set" |
|
10064
1a77667b21ef
added compatibility relation: AllowedActs, Allowed, ok,
paulson
parents:
8948
diff
changeset
|
33 |
"Init F == (%(init, acts, allowed). init) (Rep_Program F)" |
6535 | 34 |
|
35 |
Acts :: "'a program => ('a * 'a)set set" |
|
10064
1a77667b21ef
added compatibility relation: AllowedActs, Allowed, ok,
paulson
parents:
8948
diff
changeset
|
36 |
"Acts F == (%(init, acts, allowed). acts) (Rep_Program F)" |
1a77667b21ef
added compatibility relation: AllowedActs, Allowed, ok,
paulson
parents:
8948
diff
changeset
|
37 |
|
1a77667b21ef
added compatibility relation: AllowedActs, Allowed, ok,
paulson
parents:
8948
diff
changeset
|
38 |
AllowedActs :: "'a program => ('a * 'a)set set" |
1a77667b21ef
added compatibility relation: AllowedActs, Allowed, ok,
paulson
parents:
8948
diff
changeset
|
39 |
"AllowedActs F == (%(init, acts, allowed). allowed) (Rep_Program F)" |
1a77667b21ef
added compatibility relation: AllowedActs, Allowed, ok,
paulson
parents:
8948
diff
changeset
|
40 |
|
1a77667b21ef
added compatibility relation: AllowedActs, Allowed, ok,
paulson
parents:
8948
diff
changeset
|
41 |
Allowed :: "'a program => 'a program set" |
13805 | 42 |
"Allowed F == {G. Acts G \<subseteq> AllowedActs F}" |
4776 | 43 |
|
5648 | 44 |
stable :: "'a set => 'a program set" |
6536 | 45 |
"stable A == A co A" |
4776 | 46 |
|
5648 | 47 |
strongest_rhs :: "['a program, 'a set] => 'a set" |
13805 | 48 |
"strongest_rhs F A == Inter {B. F \<in> A co B}" |
4776 | 49 |
|
5648 | 50 |
invariant :: "'a set => 'a program set" |
13805 | 51 |
"invariant A == {F. Init F \<subseteq> A} \<inter> stable A" |
4776 | 52 |
|
6713 | 53 |
increasing :: "['a => 'b::{order}] => 'a program set" |
13812
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
54 |
--{*Polymorphic in both states and the meaning of @{text "\<le>"}*} |
13805 | 55 |
"increasing f == \<Inter>z. stable {s. z \<le> f s}" |
4776 | 56 |
|
6536 | 57 |
|
13812
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
58 |
text{*Perhaps equalities.ML shouldn't add this in the first place!*} |
13797 | 59 |
declare image_Collect [simp del] |
60 |
||
61 |
(*** The abstract type of programs ***) |
|
62 |
||
63 |
lemmas program_typedef = |
|
64 |
Rep_Program Rep_Program_inverse Abs_Program_inverse |
|
65 |
Program_def Init_def Acts_def AllowedActs_def mk_program_def |
|
66 |
||
13805 | 67 |
lemma Id_in_Acts [iff]: "Id \<in> Acts F" |
13797 | 68 |
apply (cut_tac x = F in Rep_Program) |
69 |
apply (auto simp add: program_typedef) |
|
70 |
done |
|
71 |
||
72 |
lemma insert_Id_Acts [iff]: "insert Id (Acts F) = Acts F" |
|
73 |
by (simp add: insert_absorb Id_in_Acts) |
|
74 |
||
13805 | 75 |
lemma Id_in_AllowedActs [iff]: "Id \<in> AllowedActs F" |
13797 | 76 |
apply (cut_tac x = F in Rep_Program) |
77 |
apply (auto simp add: program_typedef) |
|
78 |
done |
|
79 |
||
80 |
lemma insert_Id_AllowedActs [iff]: "insert Id (AllowedActs F) = AllowedActs F" |
|
81 |
by (simp add: insert_absorb Id_in_AllowedActs) |
|
82 |
||
83 |
(** Inspectors for type "program" **) |
|
84 |
||
85 |
lemma Init_eq [simp]: "Init (mk_program (init,acts,allowed)) = init" |
|
13812
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
86 |
by (simp add: program_typedef) |
13797 | 87 |
|
88 |
lemma Acts_eq [simp]: "Acts (mk_program (init,acts,allowed)) = insert Id acts" |
|
13812
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
89 |
by (simp add: program_typedef) |
13797 | 90 |
|
91 |
lemma AllowedActs_eq [simp]: |
|
92 |
"AllowedActs (mk_program (init,acts,allowed)) = insert Id allowed" |
|
13812
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
93 |
by (simp add: program_typedef) |
13797 | 94 |
|
95 |
(** Equality for UNITY programs **) |
|
96 |
||
97 |
lemma surjective_mk_program [simp]: |
|
98 |
"mk_program (Init F, Acts F, AllowedActs F) = F" |
|
99 |
apply (cut_tac x = F in Rep_Program) |
|
100 |
apply (auto simp add: program_typedef) |
|
101 |
apply (drule_tac f = Abs_Program in arg_cong)+ |
|
102 |
apply (simp add: program_typedef insert_absorb) |
|
103 |
done |
|
104 |
||
105 |
lemma program_equalityI: |
|
106 |
"[| Init F = Init G; Acts F = Acts G; AllowedActs F = AllowedActs G |] |
|
107 |
==> F = G" |
|
108 |
apply (rule_tac t = F in surjective_mk_program [THEN subst]) |
|
109 |
apply (rule_tac t = G in surjective_mk_program [THEN subst], simp) |
|
110 |
done |
|
111 |
||
112 |
lemma program_equalityE: |
|
113 |
"[| F = G; |
|
114 |
[| Init F = Init G; Acts F = Acts G; AllowedActs F = AllowedActs G |] |
|
115 |
==> P |] ==> P" |
|
116 |
by simp |
|
117 |
||
118 |
lemma program_equality_iff: |
|
119 |
"(F=G) = |
|
120 |
(Init F = Init G & Acts F = Acts G &AllowedActs F = AllowedActs G)" |
|
121 |
by (blast intro: program_equalityI program_equalityE) |
|
122 |
||
123 |
||
124 |
(*** co ***) |
|
125 |
||
126 |
lemma constrainsI: |
|
13805 | 127 |
"(!!act s s'. [| act: Acts F; (s,s') \<in> act; s \<in> A |] ==> s': A') |
128 |
==> F \<in> A co A'" |
|
13797 | 129 |
by (simp add: constrains_def, blast) |
130 |
||
131 |
lemma constrainsD: |
|
13805 | 132 |
"[| F \<in> A co A'; act: Acts F; (s,s'): act; s \<in> A |] ==> s': A'" |
13797 | 133 |
by (unfold constrains_def, blast) |
134 |
||
13805 | 135 |
lemma constrains_empty [iff]: "F \<in> {} co B" |
13797 | 136 |
by (unfold constrains_def, blast) |
137 |
||
13805 | 138 |
lemma constrains_empty2 [iff]: "(F \<in> A co {}) = (A={})" |
13797 | 139 |
by (unfold constrains_def, blast) |
140 |
||
13805 | 141 |
lemma constrains_UNIV [iff]: "(F \<in> UNIV co B) = (B = UNIV)" |
13797 | 142 |
by (unfold constrains_def, blast) |
143 |
||
13805 | 144 |
lemma constrains_UNIV2 [iff]: "F \<in> A co UNIV" |
13797 | 145 |
by (unfold constrains_def, blast) |
146 |
||
13812
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
147 |
text{*monotonic in 2nd argument*} |
13797 | 148 |
lemma constrains_weaken_R: |
13805 | 149 |
"[| F \<in> A co A'; A'<=B' |] ==> F \<in> A co B'" |
13797 | 150 |
by (unfold constrains_def, blast) |
151 |
||
13812
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
152 |
text{*anti-monotonic in 1st argument*} |
13797 | 153 |
lemma constrains_weaken_L: |
13805 | 154 |
"[| F \<in> A co A'; B \<subseteq> A |] ==> F \<in> B co A'" |
13797 | 155 |
by (unfold constrains_def, blast) |
156 |
||
157 |
lemma constrains_weaken: |
|
13805 | 158 |
"[| F \<in> A co A'; B \<subseteq> A; A'<=B' |] ==> F \<in> B co B'" |
13797 | 159 |
by (unfold constrains_def, blast) |
160 |
||
161 |
(** Union **) |
|
162 |
||
163 |
lemma constrains_Un: |
|
13805 | 164 |
"[| F \<in> A co A'; F \<in> B co B' |] ==> F \<in> (A \<union> B) co (A' \<union> B')" |
13797 | 165 |
by (unfold constrains_def, blast) |
166 |
||
167 |
lemma constrains_UN: |
|
13805 | 168 |
"(!!i. i \<in> I ==> F \<in> (A i) co (A' i)) |
169 |
==> F \<in> (\<Union>i \<in> I. A i) co (\<Union>i \<in> I. A' i)" |
|
13797 | 170 |
by (unfold constrains_def, blast) |
171 |
||
13805 | 172 |
lemma constrains_Un_distrib: "(A \<union> B) co C = (A co C) \<inter> (B co C)" |
13797 | 173 |
by (unfold constrains_def, blast) |
174 |
||
13805 | 175 |
lemma constrains_UN_distrib: "(\<Union>i \<in> I. A i) co B = (\<Inter>i \<in> I. A i co B)" |
13797 | 176 |
by (unfold constrains_def, blast) |
177 |
||
13805 | 178 |
lemma constrains_Int_distrib: "C co (A \<inter> B) = (C co A) \<inter> (C co B)" |
13797 | 179 |
by (unfold constrains_def, blast) |
180 |
||
13805 | 181 |
lemma constrains_INT_distrib: "A co (\<Inter>i \<in> I. B i) = (\<Inter>i \<in> I. A co B i)" |
13797 | 182 |
by (unfold constrains_def, blast) |
183 |
||
184 |
(** Intersection **) |
|
6536 | 185 |
|
13797 | 186 |
lemma constrains_Int: |
13805 | 187 |
"[| F \<in> A co A'; F \<in> B co B' |] ==> F \<in> (A \<inter> B) co (A' \<inter> B')" |
13797 | 188 |
by (unfold constrains_def, blast) |
189 |
||
190 |
lemma constrains_INT: |
|
13805 | 191 |
"(!!i. i \<in> I ==> F \<in> (A i) co (A' i)) |
192 |
==> F \<in> (\<Inter>i \<in> I. A i) co (\<Inter>i \<in> I. A' i)" |
|
13797 | 193 |
by (unfold constrains_def, blast) |
194 |
||
13805 | 195 |
lemma constrains_imp_subset: "F \<in> A co A' ==> A \<subseteq> A'" |
13797 | 196 |
by (unfold constrains_def, auto) |
197 |
||
13812
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
198 |
text{*The reasoning is by subsets since "co" refers to single actions |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
199 |
only. So this rule isn't that useful.*} |
13797 | 200 |
lemma constrains_trans: |
13805 | 201 |
"[| F \<in> A co B; F \<in> B co C |] ==> F \<in> A co C" |
13797 | 202 |
by (unfold constrains_def, blast) |
203 |
||
204 |
lemma constrains_cancel: |
|
13805 | 205 |
"[| F \<in> A co (A' \<union> B); F \<in> B co B' |] ==> F \<in> A co (A' \<union> B')" |
13797 | 206 |
by (unfold constrains_def, clarify, blast) |
207 |
||
208 |
||
209 |
(*** unless ***) |
|
210 |
||
13805 | 211 |
lemma unlessI: "F \<in> (A-B) co (A \<union> B) ==> F \<in> A unless B" |
13797 | 212 |
by (unfold unless_def, assumption) |
213 |
||
13805 | 214 |
lemma unlessD: "F \<in> A unless B ==> F \<in> (A-B) co (A \<union> B)" |
13797 | 215 |
by (unfold unless_def, assumption) |
216 |
||
217 |
||
218 |
(*** stable ***) |
|
219 |
||
13805 | 220 |
lemma stableI: "F \<in> A co A ==> F \<in> stable A" |
13797 | 221 |
by (unfold stable_def, assumption) |
222 |
||
13805 | 223 |
lemma stableD: "F \<in> stable A ==> F \<in> A co A" |
13797 | 224 |
by (unfold stable_def, assumption) |
225 |
||
226 |
lemma stable_UNIV [simp]: "stable UNIV = UNIV" |
|
227 |
by (unfold stable_def constrains_def, auto) |
|
228 |
||
229 |
(** Union **) |
|
230 |
||
231 |
lemma stable_Un: |
|
13805 | 232 |
"[| F \<in> stable A; F \<in> stable A' |] ==> F \<in> stable (A \<union> A')" |
13797 | 233 |
|
234 |
apply (unfold stable_def) |
|
235 |
apply (blast intro: constrains_Un) |
|
236 |
done |
|
237 |
||
238 |
lemma stable_UN: |
|
13805 | 239 |
"(!!i. i \<in> I ==> F \<in> stable (A i)) ==> F \<in> stable (\<Union>i \<in> I. A i)" |
13797 | 240 |
apply (unfold stable_def) |
241 |
apply (blast intro: constrains_UN) |
|
242 |
done |
|
243 |
||
244 |
(** Intersection **) |
|
245 |
||
246 |
lemma stable_Int: |
|
13805 | 247 |
"[| F \<in> stable A; F \<in> stable A' |] ==> F \<in> stable (A \<inter> A')" |
13797 | 248 |
apply (unfold stable_def) |
249 |
apply (blast intro: constrains_Int) |
|
250 |
done |
|
251 |
||
252 |
lemma stable_INT: |
|
13805 | 253 |
"(!!i. i \<in> I ==> F \<in> stable (A i)) ==> F \<in> stable (\<Inter>i \<in> I. A i)" |
13797 | 254 |
apply (unfold stable_def) |
255 |
apply (blast intro: constrains_INT) |
|
256 |
done |
|
257 |
||
258 |
lemma stable_constrains_Un: |
|
13805 | 259 |
"[| F \<in> stable C; F \<in> A co (C \<union> A') |] ==> F \<in> (C \<union> A) co (C \<union> A')" |
13797 | 260 |
by (unfold stable_def constrains_def, blast) |
261 |
||
262 |
lemma stable_constrains_Int: |
|
13805 | 263 |
"[| F \<in> stable C; F \<in> (C \<inter> A) co A' |] ==> F \<in> (C \<inter> A) co (C \<inter> A')" |
13797 | 264 |
by (unfold stable_def constrains_def, blast) |
265 |
||
13805 | 266 |
(*[| F \<in> stable C; F \<in> (C \<inter> A) co A |] ==> F \<in> stable (C \<inter> A) *) |
13797 | 267 |
lemmas stable_constrains_stable = stable_constrains_Int [THEN stableI, standard] |
268 |
||
269 |
||
270 |
(*** invariant ***) |
|
271 |
||
13805 | 272 |
lemma invariantI: "[| Init F \<subseteq> A; F \<in> stable A |] ==> F \<in> invariant A" |
13797 | 273 |
by (simp add: invariant_def) |
274 |
||
13812
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
275 |
text{*Could also say "invariant A \<inter> invariant B \<subseteq> invariant (A \<inter> B)"*} |
13797 | 276 |
lemma invariant_Int: |
13805 | 277 |
"[| F \<in> invariant A; F \<in> invariant B |] ==> F \<in> invariant (A \<inter> B)" |
13797 | 278 |
by (auto simp add: invariant_def stable_Int) |
279 |
||
280 |
||
281 |
(*** increasing ***) |
|
282 |
||
283 |
lemma increasingD: |
|
13805 | 284 |
"F \<in> increasing f ==> F \<in> stable {s. z \<subseteq> f s}" |
13797 | 285 |
by (unfold increasing_def, blast) |
286 |
||
13805 | 287 |
lemma increasing_constant [iff]: "F \<in> increasing (%s. c)" |
13797 | 288 |
by (unfold increasing_def stable_def, auto) |
289 |
||
290 |
lemma mono_increasing_o: |
|
13805 | 291 |
"mono g ==> increasing f \<subseteq> increasing (g o f)" |
13797 | 292 |
apply (unfold increasing_def stable_def constrains_def, auto) |
293 |
apply (blast intro: monoD order_trans) |
|
294 |
done |
|
295 |
||
13805 | 296 |
(*Holds by the theorem (Suc m \<subseteq> n) = (m < n) *) |
13797 | 297 |
lemma strict_increasingD: |
13805 | 298 |
"!!z::nat. F \<in> increasing f ==> F \<in> stable {s. z < f s}" |
13797 | 299 |
by (simp add: increasing_def Suc_le_eq [symmetric]) |
300 |
||
301 |
||
302 |
(** The Elimination Theorem. The "free" m has become universally quantified! |
|
13805 | 303 |
Should the premise be !!m instead of \<forall>m ? Would make it harder to use |
13797 | 304 |
in forward proof. **) |
305 |
||
306 |
lemma elimination: |
|
13805 | 307 |
"[| \<forall>m \<in> M. F \<in> {s. s x = m} co (B m) |] |
308 |
==> F \<in> {s. s x \<in> M} co (\<Union>m \<in> M. B m)" |
|
13797 | 309 |
by (unfold constrains_def, blast) |
310 |
||
13812
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
311 |
text{*As above, but for the trivial case of a one-variable state, in which the |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
312 |
state is identified with its one variable.*} |
13797 | 313 |
lemma elimination_sing: |
13805 | 314 |
"(\<forall>m \<in> M. F \<in> {m} co (B m)) ==> F \<in> M co (\<Union>m \<in> M. B m)" |
13797 | 315 |
by (unfold constrains_def, blast) |
316 |
||
317 |
||
318 |
||
319 |
(*** Theoretical Results from Section 6 ***) |
|
320 |
||
321 |
lemma constrains_strongest_rhs: |
|
13805 | 322 |
"F \<in> A co (strongest_rhs F A )" |
13797 | 323 |
by (unfold constrains_def strongest_rhs_def, blast) |
324 |
||
325 |
lemma strongest_rhs_is_strongest: |
|
13805 | 326 |
"F \<in> A co B ==> strongest_rhs F A \<subseteq> B" |
13797 | 327 |
by (unfold constrains_def strongest_rhs_def, blast) |
328 |
||
329 |
||
330 |
(** Ad-hoc set-theory rules **) |
|
331 |
||
13805 | 332 |
lemma Un_Diff_Diff [simp]: "A \<union> B - (A - B) = B" |
13797 | 333 |
by blast |
334 |
||
13805 | 335 |
lemma Int_Union_Union: "Union(B) \<inter> A = Union((%C. C \<inter> A)`B)" |
13797 | 336 |
by blast |
337 |
||
338 |
(** Needed for WF reasoning in WFair.ML **) |
|
339 |
||
340 |
lemma Image_less_than [simp]: "less_than `` {k} = greaterThan k" |
|
341 |
by blast |
|
342 |
||
343 |
lemma Image_inverse_less_than [simp]: "less_than^-1 `` {k} = lessThan k" |
|
344 |
by blast |
|
6536 | 345 |
|
13812
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
346 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
347 |
subsection{*Partial versus Total Transitions*} |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
348 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
349 |
constdefs |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
350 |
totalize_act :: "('a * 'a)set => ('a * 'a)set" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
351 |
"totalize_act act == act \<union> diag (-(Domain act))" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
352 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
353 |
totalize :: "'a program => 'a program" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
354 |
"totalize F == mk_program (Init F, |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
355 |
totalize_act ` Acts F, |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
356 |
AllowedActs F)" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
357 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
358 |
mk_total_program :: "('a set * ('a * 'a)set set * ('a * 'a)set set) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
359 |
=> 'a program" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
360 |
"mk_total_program args == totalize (mk_program args)" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
361 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
362 |
all_total :: "'a program => bool" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
363 |
"all_total F == \<forall>act \<in> Acts F. Domain act = UNIV" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
364 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
365 |
lemma insert_Id_image_Acts: "f Id = Id ==> insert Id (f`Acts F) = f ` Acts F" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
366 |
by (blast intro: sym [THEN image_eqI]) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
367 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
368 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
369 |
text{*Basic properties*} |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
370 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
371 |
lemma totalize_act_Id [simp]: "totalize_act Id = Id" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
372 |
by (simp add: totalize_act_def) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
373 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
374 |
lemma Domain_totalize_act [simp]: "Domain (totalize_act act) = UNIV" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
375 |
by (auto simp add: totalize_act_def) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
376 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
377 |
lemma Init_totalize [simp]: "Init (totalize F) = Init F" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
378 |
by (unfold totalize_def, auto) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
379 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
380 |
lemma Acts_totalize [simp]: "Acts (totalize F) = (totalize_act ` Acts F)" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
381 |
by (simp add: totalize_def insert_Id_image_Acts) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
382 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
383 |
lemma AllowedActs_totalize [simp]: "AllowedActs (totalize F) = AllowedActs F" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
384 |
by (simp add: totalize_def) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
385 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
386 |
lemma totalize_constrains_iff [simp]: "(totalize F \<in> A co B) = (F \<in> A co B)" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
387 |
by (simp add: totalize_def totalize_act_def constrains_def, blast) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
388 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
389 |
lemma totalize_stable_iff [simp]: "(totalize F \<in> stable A) = (F \<in> stable A)" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
390 |
by (simp add: stable_def) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
391 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
392 |
lemma totalize_invariant_iff [simp]: |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
393 |
"(totalize F \<in> invariant A) = (F \<in> invariant A)" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
394 |
by (simp add: invariant_def) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
395 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
396 |
lemma all_total_totalize: "all_total (totalize F)" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
397 |
by (simp add: totalize_def all_total_def) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
398 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
399 |
lemma Domain_iff_totalize_act: "(Domain act = UNIV) = (totalize_act act = act)" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
400 |
by (force simp add: totalize_act_def) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
401 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
402 |
lemma all_total_imp_totalize: "all_total F ==> (totalize F = F)" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
403 |
apply (simp add: all_total_def totalize_def) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
404 |
apply (rule program_equalityI) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
405 |
apply (simp_all add: Domain_iff_totalize_act image_def) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
406 |
done |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
407 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
408 |
lemma all_total_iff_totalize: "all_total F = (totalize F = F)" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
409 |
apply (rule iffI) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
410 |
apply (erule all_total_imp_totalize) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
411 |
apply (erule subst) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
412 |
apply (rule all_total_totalize) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
413 |
done |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
414 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
415 |
lemma mk_total_program_constrains_iff [simp]: |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
416 |
"(mk_total_program args \<in> A co B) = (mk_program args \<in> A co B)" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
417 |
by (simp add: mk_total_program_def) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
418 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
419 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
420 |
subsection{*Rules for Lazy Definition Expansion*} |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
421 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
422 |
text{*They avoid expanding the full program, which is a large expression*} |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
423 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
424 |
lemma def_prg_Init: |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
425 |
"F == mk_total_program (init,acts,allowed) ==> Init F = init" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
426 |
by (simp add: mk_total_program_def) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
427 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
428 |
lemma def_prg_Acts: |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
429 |
"F == mk_total_program (init,acts,allowed) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
430 |
==> Acts F = insert Id (totalize_act ` acts)" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
431 |
by (simp add: mk_total_program_def) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
432 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
433 |
lemma def_prg_AllowedActs: |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
434 |
"F == mk_total_program (init,acts,allowed) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
435 |
==> AllowedActs F = insert Id allowed" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
436 |
by (simp add: mk_total_program_def) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
437 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
438 |
text{*An action is expanded if a pair of states is being tested against it*} |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
439 |
lemma def_act_simp: |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
440 |
"act == {(s,s'). P s s'} ==> ((s,s') \<in> act) = P s s'" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
441 |
by (simp add: mk_total_program_def) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
442 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
443 |
text{*A set is expanded only if an element is being tested against it*} |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
444 |
lemma def_set_simp: "A == B ==> (x \<in> A) = (x \<in> B)" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
445 |
by (simp add: mk_total_program_def) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
446 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
447 |
(** Inspectors for type "program" **) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
448 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
449 |
lemma Init_total_eq [simp]: |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
450 |
"Init (mk_total_program (init,acts,allowed)) = init" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
451 |
by (simp add: mk_total_program_def) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
452 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
453 |
lemma Acts_total_eq [simp]: |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
454 |
"Acts(mk_total_program(init,acts,allowed)) = insert Id (totalize_act`acts)" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
455 |
by (simp add: mk_total_program_def) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
456 |
|
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
457 |
lemma AllowedActs_total_eq [simp]: |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
458 |
"AllowedActs (mk_total_program (init,acts,allowed)) = insert Id allowed" |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
459 |
by (auto simp add: mk_total_program_def) |
91713a1915ee
converting HOL/UNITY to use unconditional fairness
paulson
parents:
13805
diff
changeset
|
460 |
|
4776 | 461 |
end |