author | webertj |
Fri, 11 Mar 2005 16:08:21 +0100 | |
changeset 15603 | 27a706e3a53d |
parent 15600 | a59f07556a8d |
child 15930 | 145651bc64a8 |
permissions | -rw-r--r-- |
15600 | 1 |
(* Title: HOLCF/Porder.thy |
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
2 |
ID: $Id$ |
1479 | 3 |
Author: Franz Regensburger |
15562 | 4 |
License: GPL (GNU GENERAL PUBLIC LICENSE) |
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
5 |
|
15576
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
6 |
Definition of class porder (partial order). |
297 | 7 |
Conservative extension of theory Porder0 by constant definitions |
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
8 |
*) |
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
9 |
|
15587
f363e6e080e7
added subsections and text for document generation
huffman
parents:
15577
diff
changeset
|
10 |
header {* Partial orders *} |
15576
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
11 |
|
15577 | 12 |
theory Porder |
13 |
imports Main |
|
14 |
begin |
|
15576
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
15 |
|
15587
f363e6e080e7
added subsections and text for document generation
huffman
parents:
15577
diff
changeset
|
16 |
subsection {* Type class for partial orders *} |
f363e6e080e7
added subsections and text for document generation
huffman
parents:
15577
diff
changeset
|
17 |
|
f363e6e080e7
added subsections and text for document generation
huffman
parents:
15577
diff
changeset
|
18 |
-- {* introduce a (syntactic) class for the constant @{text "<<"} *} |
15576
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
19 |
axclass sq_ord < type |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
20 |
|
15587
f363e6e080e7
added subsections and text for document generation
huffman
parents:
15577
diff
changeset
|
21 |
-- {* characteristic constant @{text "<<"} for po *} |
15576
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
22 |
consts |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
23 |
"<<" :: "['a,'a::sq_ord] => bool" (infixl 55) |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
24 |
|
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
25 |
syntax (xsymbols) |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
26 |
"op <<" :: "['a,'a::sq_ord] => bool" (infixl "\<sqsubseteq>" 55) |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
27 |
|
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
28 |
axclass po < sq_ord |
15587
f363e6e080e7
added subsections and text for document generation
huffman
parents:
15577
diff
changeset
|
29 |
-- {* class axioms: *} |
15576
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
30 |
refl_less [iff]: "x << x" |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
31 |
antisym_less: "[|x << y; y << x |] ==> x = y" |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
32 |
trans_less: "[|x << y; y << z |] ==> x << z" |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
33 |
|
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
34 |
text {* minimal fixes least element *} |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
35 |
|
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
36 |
lemma minimal2UU[OF allI] : "!x::'a::po. uu<<x ==> uu=(@u.!y. u<<y)" |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
37 |
apply (blast intro: someI2 antisym_less) |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
38 |
done |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
39 |
|
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
40 |
text {* the reverse law of anti-symmetry of @{term "op <<"} *} |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
41 |
|
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
42 |
lemma antisym_less_inverse: "(x::'a::po)=y ==> x << y & y << x" |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
43 |
apply blast |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
44 |
done |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
45 |
|
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
46 |
lemma box_less: "[| (a::'a::po) << b; c << a; b << d|] ==> c << d" |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
47 |
apply (erule trans_less) |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
48 |
apply (erule trans_less) |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
49 |
apply assumption |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
50 |
done |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
51 |
|
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
52 |
lemma po_eq_conv: "((x::'a::po)=y) = (x << y & y << x)" |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
53 |
apply (fast elim!: antisym_less_inverse intro!: antisym_less) |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
54 |
done |
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
55 |
|
15587
f363e6e080e7
added subsections and text for document generation
huffman
parents:
15577
diff
changeset
|
56 |
subsection {* Chains and least upper bounds *} |
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
57 |
|
1479 | 58 |
consts |
59 |
"<|" :: "['a set,'a::po] => bool" (infixl 55) |
|
60 |
"<<|" :: "['a set,'a::po] => bool" (infixl 55) |
|
61 |
lub :: "'a set => 'a::po" |
|
4721
c8a8482a8124
renamed is_chain to chain, is_tord to tord, replaced chain_finite by chfin
oheimb
parents:
3842
diff
changeset
|
62 |
tord :: "'a::po set => bool" |
c8a8482a8124
renamed is_chain to chain, is_tord to tord, replaced chain_finite by chfin
oheimb
parents:
3842
diff
changeset
|
63 |
chain :: "(nat=>'a::po) => bool" |
1479 | 64 |
max_in_chain :: "[nat,nat=>'a::po]=>bool" |
65 |
finite_chain :: "(nat=>'a::po)=>bool" |
|
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
66 |
|
2394 | 67 |
syntax |
12338
de0f4a63baa5
renamed class "term" to "type" (actually "HOL.type");
wenzelm
parents:
12114
diff
changeset
|
68 |
"@LUB" :: "('b => 'a) => 'a" (binder "LUB " 10) |
2394 | 69 |
|
70 |
translations |
|
3842 | 71 |
"LUB x. t" == "lub(range(%x. t))" |
2394 | 72 |
|
12114
a8e860c86252
eliminated old "symbols" syntax, use "xsymbols" instead;
wenzelm
parents:
12030
diff
changeset
|
73 |
syntax (xsymbols) |
15562 | 74 |
"LUB " :: "[idts, 'a] => 'a" ("(3\<Squnion>_./ _)"[0,10] 10) |
2394 | 75 |
|
1168
74be52691d62
The curried version of HOLCF is now just called HOLCF. The old
regensbu
parents:
297
diff
changeset
|
76 |
defs |
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
77 |
|
15587
f363e6e080e7
added subsections and text for document generation
huffman
parents:
15577
diff
changeset
|
78 |
-- {* class definitions *} |
15562 | 79 |
is_ub_def: "S <| x == ! y. y:S --> y<<x" |
80 |
is_lub_def: "S <<| x == S <| x & (!u. S <| u --> x << u)" |
|
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
81 |
|
15587
f363e6e080e7
added subsections and text for document generation
huffman
parents:
15577
diff
changeset
|
82 |
-- {* Arbitrary chains are total orders *} |
15562 | 83 |
tord_def: "tord S == !x y. x:S & y:S --> (x<<y | y<<x)" |
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
84 |
|
15587
f363e6e080e7
added subsections and text for document generation
huffman
parents:
15577
diff
changeset
|
85 |
-- {* Here we use countable chains and I prefer to code them as functions! *} |
15562 | 86 |
chain_def: "chain F == !i. F i << F (Suc i)" |
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
87 |
|
15587
f363e6e080e7
added subsections and text for document generation
huffman
parents:
15577
diff
changeset
|
88 |
-- {* finite chains, needed for monotony of continouous functions *} |
15562 | 89 |
max_in_chain_def: "max_in_chain i C == ! j. i <= j --> C(i) = C(j)" |
90 |
finite_chain_def: "finite_chain C == chain(C) & (? i. max_in_chain i C)" |
|
91 |
||
92 |
lub_def: "lub S == (@x. S <<| x)" |
|
93 |
||
15576
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
94 |
text {* lubs are unique *} |
15562 | 95 |
|
96 |
lemma unique_lub: |
|
97 |
"[| S <<| x ; S <<| y |] ==> x=y" |
|
98 |
apply (unfold is_lub_def is_ub_def) |
|
99 |
apply (blast intro: antisym_less) |
|
100 |
done |
|
101 |
||
15576
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
102 |
text {* chains are monotone functions *} |
15562 | 103 |
|
104 |
lemma chain_mono [rule_format]: "chain F ==> x<y --> F x<<F y" |
|
105 |
apply (unfold chain_def) |
|
106 |
apply (induct_tac "y") |
|
107 |
apply auto |
|
108 |
prefer 2 apply (blast intro: trans_less) |
|
109 |
apply (blast elim!: less_SucE) |
|
110 |
done |
|
111 |
||
112 |
lemma chain_mono3: "[| chain F; x <= y |] ==> F x << F y" |
|
113 |
apply (drule le_imp_less_or_eq) |
|
114 |
apply (blast intro: chain_mono) |
|
115 |
done |
|
116 |
||
15576
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
117 |
text {* The range of a chain is a totally ordered *} |
15562 | 118 |
|
119 |
lemma chain_tord: "chain(F) ==> tord(range(F))" |
|
120 |
apply (unfold tord_def) |
|
121 |
apply safe |
|
122 |
apply (rule nat_less_cases) |
|
123 |
apply (fast intro: chain_mono)+ |
|
124 |
done |
|
125 |
||
15576
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
126 |
text {* technical lemmas about @{term lub} and @{term is_lub} *} |
15562 | 127 |
|
128 |
lemmas lub = lub_def [THEN meta_eq_to_obj_eq, standard] |
|
129 |
||
130 |
lemma lubI[OF exI]: "EX x. M <<| x ==> M <<| lub(M)" |
|
131 |
apply (simp add: lub some_eq_ex) |
|
132 |
done |
|
133 |
||
134 |
lemma thelubI: "M <<| l ==> lub(M) = l" |
|
135 |
apply (rule unique_lub) |
|
136 |
apply (subst lub) |
|
137 |
apply (erule someI) |
|
138 |
apply assumption |
|
139 |
done |
|
140 |
||
15576
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
141 |
lemma lub_singleton [simp]: "lub{x} = x" |
15562 | 142 |
apply (simp (no_asm) add: thelubI is_lub_def is_ub_def) |
143 |
done |
|
144 |
||
15576
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
145 |
text {* access to some definition as inference rule *} |
15562 | 146 |
|
147 |
lemma is_lubD1: "S <<| x ==> S <| x" |
|
148 |
apply (unfold is_lub_def) |
|
149 |
apply auto |
|
150 |
done |
|
151 |
||
152 |
lemma is_lub_lub: "[| S <<| x; S <| u |] ==> x << u" |
|
153 |
apply (unfold is_lub_def) |
|
154 |
apply auto |
|
155 |
done |
|
156 |
||
157 |
lemma is_lubI: |
|
158 |
"[| S <| x; !!u. S <| u ==> x << u |] ==> S <<| x" |
|
159 |
apply (unfold is_lub_def) |
|
160 |
apply blast |
|
161 |
done |
|
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
162 |
|
15562 | 163 |
lemma chainE: "chain F ==> F(i) << F(Suc(i))" |
164 |
apply (unfold chain_def) |
|
165 |
apply auto |
|
166 |
done |
|
167 |
||
168 |
lemma chainI: "(!!i. F i << F(Suc i)) ==> chain F" |
|
169 |
apply (unfold chain_def) |
|
170 |
apply blast |
|
171 |
done |
|
172 |
||
173 |
lemma chain_shift: "chain Y ==> chain (%i. Y (i + j))" |
|
174 |
apply (rule chainI) |
|
175 |
apply clarsimp |
|
176 |
apply (erule chainE) |
|
177 |
done |
|
178 |
||
15576
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
179 |
text {* technical lemmas about (least) upper bounds of chains *} |
15562 | 180 |
|
181 |
lemma ub_rangeD: "range S <| x ==> S(i) << x" |
|
182 |
apply (unfold is_ub_def) |
|
183 |
apply blast |
|
184 |
done |
|
185 |
||
186 |
lemma ub_rangeI: "(!!i. S i << x) ==> range S <| x" |
|
187 |
apply (unfold is_ub_def) |
|
188 |
apply blast |
|
189 |
done |
|
190 |
||
191 |
lemmas is_ub_lub = is_lubD1 [THEN ub_rangeD, standard] |
|
15587
f363e6e080e7
added subsections and text for document generation
huffman
parents:
15577
diff
changeset
|
192 |
-- {* @{thm is_ub_lub} *} (* range(?S1) <<| ?x1 ==> ?S1(?x) << ?x1 *) |
15562 | 193 |
|
15576
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
194 |
text {* results about finite chains *} |
15562 | 195 |
|
196 |
lemma lub_finch1: |
|
197 |
"[| chain C; max_in_chain i C|] ==> range C <<| C i" |
|
198 |
apply (unfold max_in_chain_def) |
|
199 |
apply (rule is_lubI) |
|
200 |
apply (rule ub_rangeI) |
|
201 |
apply (rule_tac m = "i" in nat_less_cases) |
|
202 |
apply (rule antisym_less_inverse [THEN conjunct2]) |
|
203 |
apply (erule disjI1 [THEN less_or_eq_imp_le, THEN rev_mp]) |
|
204 |
apply (erule spec) |
|
205 |
apply (rule antisym_less_inverse [THEN conjunct2]) |
|
206 |
apply (erule disjI2 [THEN less_or_eq_imp_le, THEN rev_mp]) |
|
207 |
apply (erule spec) |
|
208 |
apply (erule chain_mono) |
|
209 |
apply assumption |
|
210 |
apply (erule ub_rangeD) |
|
211 |
done |
|
212 |
||
213 |
lemma lub_finch2: |
|
214 |
"finite_chain(C) ==> range(C) <<| C(@ i. max_in_chain i C)" |
|
215 |
apply (unfold finite_chain_def) |
|
216 |
apply (rule lub_finch1) |
|
217 |
prefer 2 apply (best intro: someI) |
|
218 |
apply blast |
|
219 |
done |
|
220 |
||
221 |
lemma bin_chain: "x<<y ==> chain (%i. if i=0 then x else y)" |
|
222 |
apply (rule chainI) |
|
223 |
apply (induct_tac "i") |
|
224 |
apply auto |
|
225 |
done |
|
226 |
||
227 |
lemma bin_chainmax: |
|
228 |
"x<<y ==> max_in_chain (Suc 0) (%i. if (i=0) then x else y)" |
|
229 |
apply (unfold max_in_chain_def le_def) |
|
230 |
apply (rule allI) |
|
231 |
apply (induct_tac "j") |
|
232 |
apply auto |
|
233 |
done |
|
234 |
||
235 |
lemma lub_bin_chain: "x << y ==> range(%i::nat. if (i=0) then x else y) <<| y" |
|
236 |
apply (rule_tac s = "if (Suc 0) = 0 then x else y" in subst , rule_tac [2] lub_finch1) |
|
237 |
apply (erule_tac [2] bin_chain) |
|
238 |
apply (erule_tac [2] bin_chainmax) |
|
239 |
apply (simp (no_asm)) |
|
240 |
done |
|
241 |
||
15576
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
242 |
text {* the maximal element in a chain is its lub *} |
15562 | 243 |
|
244 |
lemma lub_chain_maxelem: "[| Y i = c; ALL i. Y i<<c |] ==> lub(range Y) = c" |
|
245 |
apply (blast dest: ub_rangeD intro: thelubI is_lubI ub_rangeI) |
|
246 |
done |
|
247 |
||
15576
efb95d0d01f7
converted to new-style theories, and combined numbered files
huffman
parents:
15562
diff
changeset
|
248 |
text {* the lub of a constant chain is the constant *} |
15562 | 249 |
|
250 |
lemma lub_const: "range(%x. c) <<| c" |
|
251 |
apply (blast dest: ub_rangeD intro: is_lubI ub_rangeI) |
|
252 |
done |
|
1274 | 253 |
|
243
c22b85994e17
Franz Regensburger's Higher-Order Logic of Computable Functions embedding LCF
nipkow
parents:
diff
changeset
|
254 |
end |
1168
74be52691d62
The curried version of HOLCF is now just called HOLCF. The old
regensbu
parents:
297
diff
changeset
|
255 |
|
74be52691d62
The curried version of HOLCF is now just called HOLCF. The old
regensbu
parents:
297
diff
changeset
|
256 |