author | wenzelm |
Fri, 09 Oct 2020 12:01:35 +0200 | |
changeset 72408 | 2daa5f549687 |
parent 71568 | 1005c50b2750 |
child 76213 | e44d86131648 |
permissions | -rw-r--r-- |
13503 | 1 |
(* Title: ZF/Constructible/DPow_absolute.thy |
2 |
Author: Lawrence C Paulson, Cambridge University Computer Laboratory |
|
3 |
*) |
|
4 |
||
60770 | 5 |
section \<open>Absoluteness for the Definable Powerset Function\<close> |
13503 | 6 |
|
7 |
||
16417 | 8 |
theory DPow_absolute imports Satisfies_absolute begin |
13503 | 9 |
|
10 |
||
60770 | 11 |
subsection\<open>Preliminary Internalizations\<close> |
13503 | 12 |
|
69593 | 13 |
subsubsection\<open>The Operator \<^term>\<open>is_formula_rec\<close>\<close> |
13503 | 14 |
|
69593 | 15 |
text\<open>The three arguments of \<^term>\<open>p\<close> are always 2, 1, 0. It is buried |
60770 | 16 |
within 11 quantifiers!!\<close> |
13503 | 17 |
|
18 |
(* is_formula_rec :: "[i=>o, [i,i,i]=>o, i, i] => o" |
|
19 |
"is_formula_rec(M,MH,p,z) == |
|
20 |
\<exists>dp[M]. \<exists>i[M]. \<exists>f[M]. finite_ordinal(M,dp) & is_depth(M,p,dp) & |
|
21 |
2 1 0 |
|
22 |
successor(M,dp,i) & fun_apply(M,f,p,z) & is_transrec(M,MH,i,f)" |
|
23 |
*) |
|
24 |
||
21404
eb85850d3eb7
more robust syntax for definition/abbreviation/notation;
wenzelm
parents:
21233
diff
changeset
|
25 |
definition |
eb85850d3eb7
more robust syntax for definition/abbreviation/notation;
wenzelm
parents:
21233
diff
changeset
|
26 |
formula_rec_fm :: "[i, i, i]=>i" where |
13503 | 27 |
"formula_rec_fm(mh,p,z) == |
28 |
Exists(Exists(Exists( |
|
29 |
And(finite_ordinal_fm(2), |
|
30 |
And(depth_fm(p#+3,2), |
|
31 |
And(succ_fm(2,1), |
|
32 |
And(fun_apply_fm(0,p#+3,z#+3), is_transrec_fm(mh,1,0))))))))" |
|
33 |
||
34 |
lemma is_formula_rec_type [TC]: |
|
35 |
"[| p \<in> formula; x \<in> nat; z \<in> nat |] |
|
36 |
==> formula_rec_fm(p,x,z) \<in> formula" |
|
37 |
by (simp add: formula_rec_fm_def) |
|
38 |
||
39 |
lemma sats_formula_rec_fm: |
|
40 |
assumes MH_iff_sats: |
|
41 |
"!!a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10. |
|
42 |
[|a0\<in>A; a1\<in>A; a2\<in>A; a3\<in>A; a4\<in>A; a5\<in>A; a6\<in>A; a7\<in>A; a8\<in>A; a9\<in>A; a10\<in>A|] |
|
46823 | 43 |
==> MH(a2, a1, a0) \<longleftrightarrow> |
13503 | 44 |
sats(A, p, Cons(a0,Cons(a1,Cons(a2,Cons(a3, |
45 |
Cons(a4,Cons(a5,Cons(a6,Cons(a7, |
|
46 |
Cons(a8,Cons(a9,Cons(a10,env))))))))))))" |
|
47 |
shows |
|
48 |
"[|x \<in> nat; z \<in> nat; env \<in> list(A)|] |
|
46823 | 49 |
==> sats(A, formula_rec_fm(p,x,z), env) \<longleftrightarrow> |
13807
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
50 |
is_formula_rec(##A, MH, nth(x,env), nth(z,env))" |
13503 | 51 |
by (simp add: formula_rec_fm_def sats_is_transrec_fm is_formula_rec_def |
52 |
MH_iff_sats [THEN iff_sym]) |
|
53 |
||
54 |
lemma formula_rec_iff_sats: |
|
55 |
assumes MH_iff_sats: |
|
56 |
"!!a0 a1 a2 a3 a4 a5 a6 a7 a8 a9 a10. |
|
57 |
[|a0\<in>A; a1\<in>A; a2\<in>A; a3\<in>A; a4\<in>A; a5\<in>A; a6\<in>A; a7\<in>A; a8\<in>A; a9\<in>A; a10\<in>A|] |
|
46823 | 58 |
==> MH(a2, a1, a0) \<longleftrightarrow> |
13503 | 59 |
sats(A, p, Cons(a0,Cons(a1,Cons(a2,Cons(a3, |
60 |
Cons(a4,Cons(a5,Cons(a6,Cons(a7, |
|
61 |
Cons(a8,Cons(a9,Cons(a10,env))))))))))))" |
|
62 |
shows |
|
63 |
"[|nth(i,env) = x; nth(k,env) = z; |
|
64 |
i \<in> nat; k \<in> nat; env \<in> list(A)|] |
|
46823 | 65 |
==> is_formula_rec(##A, MH, x, z) \<longleftrightarrow> sats(A, formula_rec_fm(p,i,k), env)" |
13503 | 66 |
by (simp add: sats_formula_rec_fm [OF MH_iff_sats]) |
67 |
||
68 |
theorem formula_rec_reflection: |
|
69 |
assumes MH_reflection: |
|
70 |
"!!f' f g h. REFLECTS[\<lambda>x. MH(L, f'(x), f(x), g(x), h(x)), |
|
13807
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
71 |
\<lambda>i x. MH(##Lset(i), f'(x), f(x), g(x), h(x))]" |
13503 | 72 |
shows "REFLECTS[\<lambda>x. is_formula_rec(L, MH(L,x), f(x), h(x)), |
13807
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
73 |
\<lambda>i x. is_formula_rec(##Lset(i), MH(##Lset(i),x), f(x), h(x))]" |
13655
95b95cdb4704
Tidying up. New primitives is_iterates and is_iterates_fm.
paulson
parents:
13634
diff
changeset
|
74 |
apply (simp (no_asm_use) only: is_formula_rec_def) |
13503 | 75 |
apply (intro FOL_reflections function_reflections fun_plus_reflections |
76 |
depth_reflection is_transrec_reflection MH_reflection) |
|
77 |
done |
|
78 |
||
79 |
||
69593 | 80 |
subsubsection\<open>The Operator \<^term>\<open>is_satisfies\<close>\<close> |
13503 | 81 |
|
82 |
(* is_satisfies(M,A,p,z) == is_formula_rec (M, satisfies_MH(M,A), p, z) *) |
|
21404
eb85850d3eb7
more robust syntax for definition/abbreviation/notation;
wenzelm
parents:
21233
diff
changeset
|
83 |
definition |
eb85850d3eb7
more robust syntax for definition/abbreviation/notation;
wenzelm
parents:
21233
diff
changeset
|
84 |
satisfies_fm :: "[i,i,i]=>i" where |
13503 | 85 |
"satisfies_fm(x) == formula_rec_fm (satisfies_MH_fm(x#+5#+6, 2, 1, 0))" |
86 |
||
87 |
lemma is_satisfies_type [TC]: |
|
88 |
"[| x \<in> nat; y \<in> nat; z \<in> nat |] ==> satisfies_fm(x,y,z) \<in> formula" |
|
89 |
by (simp add: satisfies_fm_def) |
|
90 |
||
91 |
lemma sats_satisfies_fm [simp]: |
|
92 |
"[| x \<in> nat; y \<in> nat; z \<in> nat; env \<in> list(A)|] |
|
46823 | 93 |
==> sats(A, satisfies_fm(x,y,z), env) \<longleftrightarrow> |
13807
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
94 |
is_satisfies(##A, nth(x,env), nth(y,env), nth(z,env))" |
71417
89d05db6dd1f
Simplified, generalised version of Constructible due to E. Gunther, M. Pagano and P. Sánchez Terraf
paulson <lp15@cam.ac.uk>
parents:
69593
diff
changeset
|
95 |
by (simp add: satisfies_fm_def is_satisfies_def sats_formula_rec_fm) |
13503 | 96 |
|
97 |
lemma satisfies_iff_sats: |
|
98 |
"[| nth(i,env) = x; nth(j,env) = y; nth(k,env) = z; |
|
99 |
i \<in> nat; j \<in> nat; k \<in> nat; env \<in> list(A)|] |
|
46823 | 100 |
==> is_satisfies(##A, x, y, z) \<longleftrightarrow> sats(A, satisfies_fm(i,j,k), env)" |
71417
89d05db6dd1f
Simplified, generalised version of Constructible due to E. Gunther, M. Pagano and P. Sánchez Terraf
paulson <lp15@cam.ac.uk>
parents:
69593
diff
changeset
|
101 |
by (simp) |
13503 | 102 |
|
103 |
theorem satisfies_reflection: |
|
104 |
"REFLECTS[\<lambda>x. is_satisfies(L,f(x),g(x),h(x)), |
|
13807
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
105 |
\<lambda>i x. is_satisfies(##Lset(i),f(x),g(x),h(x))]" |
13655
95b95cdb4704
Tidying up. New primitives is_iterates and is_iterates_fm.
paulson
parents:
13634
diff
changeset
|
106 |
apply (simp only: is_satisfies_def) |
13503 | 107 |
apply (intro formula_rec_reflection satisfies_MH_reflection) |
108 |
done |
|
109 |
||
110 |
||
69593 | 111 |
subsection \<open>Relativization of the Operator \<^term>\<open>DPow'\<close>\<close> |
13503 | 112 |
|
113 |
lemma DPow'_eq: |
|
13692 | 114 |
"DPow'(A) = {z . ep \<in> list(A) * formula, |
115 |
\<exists>env \<in> list(A). \<exists>p \<in> formula. |
|
116 |
ep = <env,p> & z = {x\<in>A. sats(A, p, Cons(x,env))}}" |
|
117 |
by (simp add: DPow'_def, blast) |
|
13503 | 118 |
|
119 |
||
69593 | 120 |
text\<open>Relativize the use of \<^term>\<open>sats\<close> within \<^term>\<open>DPow'\<close> |
60770 | 121 |
(the comprehension).\<close> |
21233 | 122 |
definition |
21404
eb85850d3eb7
more robust syntax for definition/abbreviation/notation;
wenzelm
parents:
21233
diff
changeset
|
123 |
is_DPow_sats :: "[i=>o,i,i,i,i] => o" where |
13692 | 124 |
"is_DPow_sats(M,A,env,p,x) == |
13503 | 125 |
\<forall>n1[M]. \<forall>e[M]. \<forall>sp[M]. |
46823 | 126 |
is_satisfies(M,A,p,sp) \<longrightarrow> is_Cons(M,x,env,e) \<longrightarrow> |
127 |
fun_apply(M, sp, e, n1) \<longrightarrow> number1(M, n1)" |
|
13503 | 128 |
|
13692 | 129 |
lemma (in M_satisfies) DPow_sats_abs: |
13503 | 130 |
"[| M(A); env \<in> list(A); p \<in> formula; M(x) |] |
46823 | 131 |
==> is_DPow_sats(M,A,env,p,x) \<longleftrightarrow> sats(A, p, Cons(x,env))" |
13503 | 132 |
apply (subgoal_tac "M(env)") |
13692 | 133 |
apply (simp add: is_DPow_sats_def satisfies_closed satisfies_abs) |
13503 | 134 |
apply (blast dest: transM) |
135 |
done |
|
136 |
||
13692 | 137 |
lemma (in M_satisfies) Collect_DPow_sats_abs: |
13503 | 138 |
"[| M(A); env \<in> list(A); p \<in> formula |] |
13692 | 139 |
==> Collect(A, is_DPow_sats(M,A,env,p)) = |
13503 | 140 |
{x \<in> A. sats(A, p, Cons(x,env))}" |
13692 | 141 |
by (simp add: DPow_sats_abs transM [of _ A]) |
13503 | 142 |
|
143 |
||
69593 | 144 |
subsubsection\<open>The Operator \<^term>\<open>is_DPow_sats\<close>, Internalized\<close> |
13503 | 145 |
|
13692 | 146 |
(* is_DPow_sats(M,A,env,p,x) == |
13503 | 147 |
\<forall>n1[M]. \<forall>e[M]. \<forall>sp[M]. |
46823 | 148 |
is_satisfies(M,A,p,sp) \<longrightarrow> is_Cons(M,x,env,e) \<longrightarrow> |
149 |
fun_apply(M, sp, e, n1) \<longrightarrow> number1(M, n1) *) |
|
13503 | 150 |
|
21404
eb85850d3eb7
more robust syntax for definition/abbreviation/notation;
wenzelm
parents:
21233
diff
changeset
|
151 |
definition |
eb85850d3eb7
more robust syntax for definition/abbreviation/notation;
wenzelm
parents:
21233
diff
changeset
|
152 |
DPow_sats_fm :: "[i,i,i,i]=>i" where |
eb85850d3eb7
more robust syntax for definition/abbreviation/notation;
wenzelm
parents:
21233
diff
changeset
|
153 |
"DPow_sats_fm(A,env,p,x) == |
13503 | 154 |
Forall(Forall(Forall( |
155 |
Implies(satisfies_fm(A#+3,p#+3,0), |
|
156 |
Implies(Cons_fm(x#+3,env#+3,1), |
|
157 |
Implies(fun_apply_fm(0,1,2), number1_fm(2)))))))" |
|
158 |
||
13692 | 159 |
lemma is_DPow_sats_type [TC]: |
13503 | 160 |
"[| A \<in> nat; x \<in> nat; y \<in> nat; z \<in> nat |] |
13692 | 161 |
==> DPow_sats_fm(A,x,y,z) \<in> formula" |
162 |
by (simp add: DPow_sats_fm_def) |
|
13503 | 163 |
|
13692 | 164 |
lemma sats_DPow_sats_fm [simp]: |
13503 | 165 |
"[| u \<in> nat; x \<in> nat; y \<in> nat; z \<in> nat; env \<in> list(A)|] |
46823 | 166 |
==> sats(A, DPow_sats_fm(u,x,y,z), env) \<longleftrightarrow> |
13807
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
167 |
is_DPow_sats(##A, nth(u,env), nth(x,env), nth(y,env), nth(z,env))" |
13692 | 168 |
by (simp add: DPow_sats_fm_def is_DPow_sats_def) |
13503 | 169 |
|
13692 | 170 |
lemma DPow_sats_iff_sats: |
13503 | 171 |
"[| nth(u,env) = nu; nth(x,env) = nx; nth(y,env) = ny; nth(z,env) = nz; |
172 |
u \<in> nat; x \<in> nat; y \<in> nat; z \<in> nat; env \<in> list(A)|] |
|
46823 | 173 |
==> is_DPow_sats(##A,nu,nx,ny,nz) \<longleftrightarrow> |
13692 | 174 |
sats(A, DPow_sats_fm(u,x,y,z), env)" |
13503 | 175 |
by simp |
176 |
||
13692 | 177 |
theorem DPow_sats_reflection: |
178 |
"REFLECTS[\<lambda>x. is_DPow_sats(L,f(x),g(x),h(x),g'(x)), |
|
13807
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
179 |
\<lambda>i x. is_DPow_sats(##Lset(i),f(x),g(x),h(x),g'(x))]" |
13692 | 180 |
apply (unfold is_DPow_sats_def) |
13503 | 181 |
apply (intro FOL_reflections function_reflections extra_reflections |
182 |
satisfies_reflection) |
|
183 |
done |
|
184 |
||
185 |
||
69593 | 186 |
subsection\<open>A Locale for Relativizing the Operator \<^term>\<open>DPow'\<close>\<close> |
13503 | 187 |
|
188 |
locale M_DPow = M_satisfies + |
|
189 |
assumes sep: |
|
190 |
"[| M(A); env \<in> list(A); p \<in> formula |] |
|
13692 | 191 |
==> separation(M, \<lambda>x. is_DPow_sats(M,A,env,p,x))" |
13503 | 192 |
and rep: |
193 |
"M(A) |
|
194 |
==> strong_replacement (M, |
|
195 |
\<lambda>ep z. \<exists>env[M]. \<exists>p[M]. mem_formula(M,p) & mem_list(M,A,env) & |
|
196 |
pair(M,env,p,ep) & |
|
13692 | 197 |
is_Collect(M, A, \<lambda>x. is_DPow_sats(M,A,env,p,x), z))" |
13503 | 198 |
|
199 |
lemma (in M_DPow) sep': |
|
200 |
"[| M(A); env \<in> list(A); p \<in> formula |] |
|
201 |
==> separation(M, \<lambda>x. sats(A, p, Cons(x,env)))" |
|
13692 | 202 |
by (insert sep [of A env p], simp add: DPow_sats_abs) |
13503 | 203 |
|
204 |
lemma (in M_DPow) rep': |
|
205 |
"M(A) |
|
206 |
==> strong_replacement (M, |
|
207 |
\<lambda>ep z. \<exists>env\<in>list(A). \<exists>p\<in>formula. |
|
13504 | 208 |
ep = <env,p> & z = {x \<in> A . sats(A, p, Cons(x, env))})" |
13692 | 209 |
by (insert rep [of A], simp add: Collect_DPow_sats_abs) |
13503 | 210 |
|
211 |
||
212 |
lemma univalent_pair_eq: |
|
213 |
"univalent (M, A, \<lambda>xy z. \<exists>x\<in>B. \<exists>y\<in>C. xy = \<langle>x,y\<rangle> \<and> z = f(x,y))" |
|
214 |
by (simp add: univalent_def, blast) |
|
215 |
||
216 |
lemma (in M_DPow) DPow'_closed: "M(A) ==> M(DPow'(A))" |
|
217 |
apply (simp add: DPow'_eq) |
|
218 |
apply (fast intro: rep' sep' univalent_pair_eq) |
|
219 |
done |
|
220 |
||
69593 | 221 |
text\<open>Relativization of the Operator \<^term>\<open>DPow'\<close>\<close> |
21233 | 222 |
definition |
21404
eb85850d3eb7
more robust syntax for definition/abbreviation/notation;
wenzelm
parents:
21233
diff
changeset
|
223 |
is_DPow' :: "[i=>o,i,i] => o" where |
13503 | 224 |
"is_DPow'(M,A,Z) == |
46823 | 225 |
\<forall>X[M]. X \<in> Z \<longleftrightarrow> |
13503 | 226 |
subset(M,X,A) & |
227 |
(\<exists>env[M]. \<exists>p[M]. mem_formula(M,p) & mem_list(M,A,env) & |
|
13692 | 228 |
is_Collect(M, A, is_DPow_sats(M,A,env,p), X))" |
13503 | 229 |
|
230 |
lemma (in M_DPow) DPow'_abs: |
|
46823 | 231 |
"[|M(A); M(Z)|] ==> is_DPow'(M,A,Z) \<longleftrightarrow> Z = DPow'(A)" |
13503 | 232 |
apply (rule iffI) |
13692 | 233 |
prefer 2 apply (simp add: is_DPow'_def DPow'_def Collect_DPow_sats_abs) |
13503 | 234 |
apply (rule M_equalityI) |
13692 | 235 |
apply (simp add: is_DPow'_def DPow'_def Collect_DPow_sats_abs, assumption) |
13503 | 236 |
apply (erule DPow'_closed) |
237 |
done |
|
238 |
||
239 |
||
61798 | 240 |
subsection\<open>Instantiating the Locale \<open>M_DPow\<close>\<close> |
13503 | 241 |
|
60770 | 242 |
subsubsection\<open>The Instance of Separation\<close> |
13503 | 243 |
|
244 |
lemma DPow_separation: |
|
245 |
"[| L(A); env \<in> list(A); p \<in> formula |] |
|
13692 | 246 |
==> separation(L, \<lambda>x. is_DPow_sats(L,A,env,p,x))" |
247 |
apply (rule gen_separation_multi [OF DPow_sats_reflection, of "{A,env,p}"], |
|
13687 | 248 |
auto intro: transL) |
249 |
apply (rule_tac env="[A,env,p]" in DPow_LsetI) |
|
13692 | 250 |
apply (rule DPow_sats_iff_sats sep_rules | simp)+ |
13503 | 251 |
done |
252 |
||
253 |
||
254 |
||
60770 | 255 |
subsubsection\<open>The Instance of Replacement\<close> |
13503 | 256 |
|
257 |
lemma DPow_replacement_Reflects: |
|
258 |
"REFLECTS [\<lambda>x. \<exists>u[L]. u \<in> B & |
|
259 |
(\<exists>env[L]. \<exists>p[L]. |
|
260 |
mem_formula(L,p) & mem_list(L,A,env) & pair(L,env,p,u) & |
|
13692 | 261 |
is_Collect (L, A, is_DPow_sats(L,A,env,p), x)), |
13503 | 262 |
\<lambda>i x. \<exists>u \<in> Lset(i). u \<in> B & |
263 |
(\<exists>env \<in> Lset(i). \<exists>p \<in> Lset(i). |
|
13807
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
264 |
mem_formula(##Lset(i),p) & mem_list(##Lset(i),A,env) & |
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
265 |
pair(##Lset(i),env,p,u) & |
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
266 |
is_Collect (##Lset(i), A, is_DPow_sats(##Lset(i),A,env,p), x))]" |
13503 | 267 |
apply (unfold is_Collect_def) |
268 |
apply (intro FOL_reflections function_reflections mem_formula_reflection |
|
13692 | 269 |
mem_list_reflection DPow_sats_reflection) |
13503 | 270 |
done |
271 |
||
272 |
lemma DPow_replacement: |
|
273 |
"L(A) |
|
274 |
==> strong_replacement (L, |
|
275 |
\<lambda>ep z. \<exists>env[L]. \<exists>p[L]. mem_formula(L,p) & mem_list(L,A,env) & |
|
276 |
pair(L,env,p,ep) & |
|
13692 | 277 |
is_Collect(L, A, \<lambda>x. is_DPow_sats(L,A,env,p,x), z))" |
13503 | 278 |
apply (rule strong_replacementI) |
13687 | 279 |
apply (rule_tac u="{A,B}" |
280 |
in gen_separation_multi [OF DPow_replacement_Reflects], |
|
281 |
auto) |
|
13566 | 282 |
apply (unfold is_Collect_def) |
13687 | 283 |
apply (rule_tac env="[A,B]" in DPow_LsetI) |
13503 | 284 |
apply (rule sep_rules mem_formula_iff_sats mem_list_iff_sats |
13692 | 285 |
DPow_sats_iff_sats | simp)+ |
13503 | 286 |
done |
287 |
||
288 |
||
60770 | 289 |
subsubsection\<open>Actually Instantiating the Locale\<close> |
13503 | 290 |
|
291 |
lemma M_DPow_axioms_L: "M_DPow_axioms(L)" |
|
292 |
apply (rule M_DPow_axioms.intro) |
|
293 |
apply (assumption | rule DPow_separation DPow_replacement)+ |
|
294 |
done |
|
295 |
||
71417
89d05db6dd1f
Simplified, generalised version of Constructible due to E. Gunther, M. Pagano and P. Sánchez Terraf
paulson <lp15@cam.ac.uk>
parents:
69593
diff
changeset
|
296 |
theorem M_DPow_L: "M_DPow(L)" |
13503 | 297 |
apply (rule M_DPow.intro) |
19931
fb32b43e7f80
Restructured locales with predicates: import is now an interpretation.
ballarin
parents:
16417
diff
changeset
|
298 |
apply (rule M_satisfies_L) |
13503 | 299 |
apply (rule M_DPow_axioms_L) |
300 |
done |
|
301 |
||
302 |
lemmas DPow'_closed [intro, simp] = M_DPow.DPow'_closed [OF M_DPow_L] |
|
303 |
and DPow'_abs [intro, simp] = M_DPow.DPow'_abs [OF M_DPow_L] |
|
304 |
||
13505 | 305 |
|
69593 | 306 |
subsubsection\<open>The Operator \<^term>\<open>is_Collect\<close>\<close> |
13505 | 307 |
|
69593 | 308 |
text\<open>The formula \<^term>\<open>is_P\<close> has one free variable, 0, and it is |
60770 | 309 |
enclosed within a single quantifier.\<close> |
13505 | 310 |
|
311 |
(* is_Collect :: "[i=>o,i,i=>o,i] => o" |
|
46823 | 312 |
"is_Collect(M,A,P,z) == \<forall>x[M]. x \<in> z \<longleftrightarrow> x \<in> A & P(x)" *) |
13505 | 313 |
|
21404
eb85850d3eb7
more robust syntax for definition/abbreviation/notation;
wenzelm
parents:
21233
diff
changeset
|
314 |
definition |
eb85850d3eb7
more robust syntax for definition/abbreviation/notation;
wenzelm
parents:
21233
diff
changeset
|
315 |
Collect_fm :: "[i, i, i]=>i" where |
13505 | 316 |
"Collect_fm(A,is_P,z) == |
317 |
Forall(Iff(Member(0,succ(z)), |
|
318 |
And(Member(0,succ(A)), is_P)))" |
|
319 |
||
320 |
lemma is_Collect_type [TC]: |
|
321 |
"[| is_P \<in> formula; x \<in> nat; y \<in> nat |] |
|
322 |
==> Collect_fm(x,is_P,y) \<in> formula" |
|
323 |
by (simp add: Collect_fm_def) |
|
324 |
||
325 |
lemma sats_Collect_fm: |
|
326 |
assumes is_P_iff_sats: |
|
46823 | 327 |
"!!a. a \<in> A ==> is_P(a) \<longleftrightarrow> sats(A, p, Cons(a, env))" |
13505 | 328 |
shows |
329 |
"[|x \<in> nat; y \<in> nat; env \<in> list(A)|] |
|
46823 | 330 |
==> sats(A, Collect_fm(x,p,y), env) \<longleftrightarrow> |
13807
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
331 |
is_Collect(##A, nth(x,env), is_P, nth(y,env))" |
13505 | 332 |
by (simp add: Collect_fm_def is_Collect_def is_P_iff_sats [THEN iff_sym]) |
333 |
||
334 |
lemma Collect_iff_sats: |
|
335 |
assumes is_P_iff_sats: |
|
46823 | 336 |
"!!a. a \<in> A ==> is_P(a) \<longleftrightarrow> sats(A, p, Cons(a, env))" |
13505 | 337 |
shows |
338 |
"[| nth(i,env) = x; nth(j,env) = y; |
|
339 |
i \<in> nat; j \<in> nat; env \<in> list(A)|] |
|
46823 | 340 |
==> is_Collect(##A, x, is_P, y) \<longleftrightarrow> sats(A, Collect_fm(i,p,j), env)" |
13505 | 341 |
by (simp add: sats_Collect_fm [OF is_P_iff_sats]) |
342 |
||
343 |
||
69593 | 344 |
text\<open>The second argument of \<^term>\<open>is_P\<close> gives it direct access to \<^term>\<open>x\<close>, |
60770 | 345 |
which is essential for handling free variable references.\<close> |
13505 | 346 |
theorem Collect_reflection: |
347 |
assumes is_P_reflection: |
|
348 |
"!!h f g. REFLECTS[\<lambda>x. is_P(L, f(x), g(x)), |
|
13807
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
349 |
\<lambda>i x. is_P(##Lset(i), f(x), g(x))]" |
13505 | 350 |
shows "REFLECTS[\<lambda>x. is_Collect(L, f(x), is_P(L,x), g(x)), |
13807
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
351 |
\<lambda>i x. is_Collect(##Lset(i), f(x), is_P(##Lset(i), x), g(x))]" |
13655
95b95cdb4704
Tidying up. New primitives is_iterates and is_iterates_fm.
paulson
parents:
13634
diff
changeset
|
352 |
apply (simp (no_asm_use) only: is_Collect_def) |
13505 | 353 |
apply (intro FOL_reflections is_P_reflection) |
354 |
done |
|
355 |
||
356 |
||
69593 | 357 |
subsubsection\<open>The Operator \<^term>\<open>is_Replace\<close>\<close> |
13505 | 358 |
|
69593 | 359 |
text\<open>BEWARE! The formula \<^term>\<open>is_P\<close> has free variables 0, 1 |
60770 | 360 |
and not the usual 1, 0! It is enclosed within two quantifiers.\<close> |
13505 | 361 |
|
362 |
(* is_Replace :: "[i=>o,i,[i,i]=>o,i] => o" |
|
46823 | 363 |
"is_Replace(M,A,P,z) == \<forall>u[M]. u \<in> z \<longleftrightarrow> (\<exists>x[M]. x\<in>A & P(x,u))" *) |
13505 | 364 |
|
21404
eb85850d3eb7
more robust syntax for definition/abbreviation/notation;
wenzelm
parents:
21233
diff
changeset
|
365 |
definition |
eb85850d3eb7
more robust syntax for definition/abbreviation/notation;
wenzelm
parents:
21233
diff
changeset
|
366 |
Replace_fm :: "[i, i, i]=>i" where |
eb85850d3eb7
more robust syntax for definition/abbreviation/notation;
wenzelm
parents:
21233
diff
changeset
|
367 |
"Replace_fm(A,is_P,z) == |
13505 | 368 |
Forall(Iff(Member(0,succ(z)), |
369 |
Exists(And(Member(0,A#+2), is_P))))" |
|
370 |
||
371 |
lemma is_Replace_type [TC]: |
|
372 |
"[| is_P \<in> formula; x \<in> nat; y \<in> nat |] |
|
373 |
==> Replace_fm(x,is_P,y) \<in> formula" |
|
374 |
by (simp add: Replace_fm_def) |
|
375 |
||
376 |
lemma sats_Replace_fm: |
|
377 |
assumes is_P_iff_sats: |
|
378 |
"!!a b. [|a \<in> A; b \<in> A|] |
|
46823 | 379 |
==> is_P(a,b) \<longleftrightarrow> sats(A, p, Cons(a,Cons(b,env)))" |
13505 | 380 |
shows |
381 |
"[|x \<in> nat; y \<in> nat; env \<in> list(A)|] |
|
46823 | 382 |
==> sats(A, Replace_fm(x,p,y), env) \<longleftrightarrow> |
13807
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
383 |
is_Replace(##A, nth(x,env), is_P, nth(y,env))" |
13505 | 384 |
by (simp add: Replace_fm_def is_Replace_def is_P_iff_sats [THEN iff_sym]) |
385 |
||
386 |
lemma Replace_iff_sats: |
|
387 |
assumes is_P_iff_sats: |
|
388 |
"!!a b. [|a \<in> A; b \<in> A|] |
|
46823 | 389 |
==> is_P(a,b) \<longleftrightarrow> sats(A, p, Cons(a,Cons(b,env)))" |
13505 | 390 |
shows |
391 |
"[| nth(i,env) = x; nth(j,env) = y; |
|
392 |
i \<in> nat; j \<in> nat; env \<in> list(A)|] |
|
46823 | 393 |
==> is_Replace(##A, x, is_P, y) \<longleftrightarrow> sats(A, Replace_fm(i,p,j), env)" |
13505 | 394 |
by (simp add: sats_Replace_fm [OF is_P_iff_sats]) |
395 |
||
396 |
||
69593 | 397 |
text\<open>The second argument of \<^term>\<open>is_P\<close> gives it direct access to \<^term>\<open>x\<close>, |
60770 | 398 |
which is essential for handling free variable references.\<close> |
13505 | 399 |
theorem Replace_reflection: |
400 |
assumes is_P_reflection: |
|
401 |
"!!h f g. REFLECTS[\<lambda>x. is_P(L, f(x), g(x), h(x)), |
|
13807
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
402 |
\<lambda>i x. is_P(##Lset(i), f(x), g(x), h(x))]" |
13505 | 403 |
shows "REFLECTS[\<lambda>x. is_Replace(L, f(x), is_P(L,x), g(x)), |
13807
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
404 |
\<lambda>i x. is_Replace(##Lset(i), f(x), is_P(##Lset(i), x), g(x))]" |
13655
95b95cdb4704
Tidying up. New primitives is_iterates and is_iterates_fm.
paulson
parents:
13634
diff
changeset
|
405 |
apply (simp (no_asm_use) only: is_Replace_def) |
13505 | 406 |
apply (intro FOL_reflections is_P_reflection) |
407 |
done |
|
408 |
||
409 |
||
410 |
||
69593 | 411 |
subsubsection\<open>The Operator \<^term>\<open>is_DPow'\<close>, Internalized\<close> |
13505 | 412 |
|
413 |
(* "is_DPow'(M,A,Z) == |
|
46823 | 414 |
\<forall>X[M]. X \<in> Z \<longleftrightarrow> |
13505 | 415 |
subset(M,X,A) & |
416 |
(\<exists>env[M]. \<exists>p[M]. mem_formula(M,p) & mem_list(M,A,env) & |
|
13692 | 417 |
is_Collect(M, A, is_DPow_sats(M,A,env,p), X))" *) |
13505 | 418 |
|
21404
eb85850d3eb7
more robust syntax for definition/abbreviation/notation;
wenzelm
parents:
21233
diff
changeset
|
419 |
definition |
eb85850d3eb7
more robust syntax for definition/abbreviation/notation;
wenzelm
parents:
21233
diff
changeset
|
420 |
DPow'_fm :: "[i,i]=>i" where |
13505 | 421 |
"DPow'_fm(A,Z) == |
422 |
Forall( |
|
423 |
Iff(Member(0,succ(Z)), |
|
424 |
And(subset_fm(0,succ(A)), |
|
425 |
Exists(Exists( |
|
426 |
And(mem_formula_fm(0), |
|
427 |
And(mem_list_fm(A#+3,1), |
|
428 |
Collect_fm(A#+3, |
|
13692 | 429 |
DPow_sats_fm(A#+4, 2, 1, 0), 2))))))))" |
13505 | 430 |
|
431 |
lemma is_DPow'_type [TC]: |
|
432 |
"[| x \<in> nat; y \<in> nat |] ==> DPow'_fm(x,y) \<in> formula" |
|
433 |
by (simp add: DPow'_fm_def) |
|
434 |
||
435 |
lemma sats_DPow'_fm [simp]: |
|
436 |
"[| x \<in> nat; y \<in> nat; env \<in> list(A)|] |
|
46823 | 437 |
==> sats(A, DPow'_fm(x,y), env) \<longleftrightarrow> |
13807
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
438 |
is_DPow'(##A, nth(x,env), nth(y,env))" |
13505 | 439 |
by (simp add: DPow'_fm_def is_DPow'_def sats_subset_fm' sats_Collect_fm) |
440 |
||
441 |
lemma DPow'_iff_sats: |
|
442 |
"[| nth(i,env) = x; nth(j,env) = y; |
|
443 |
i \<in> nat; j \<in> nat; env \<in> list(A)|] |
|
46823 | 444 |
==> is_DPow'(##A, x, y) \<longleftrightarrow> sats(A, DPow'_fm(i,j), env)" |
71417
89d05db6dd1f
Simplified, generalised version of Constructible due to E. Gunther, M. Pagano and P. Sánchez Terraf
paulson <lp15@cam.ac.uk>
parents:
69593
diff
changeset
|
445 |
by (simp) |
13505 | 446 |
|
447 |
theorem DPow'_reflection: |
|
448 |
"REFLECTS[\<lambda>x. is_DPow'(L,f(x),g(x)), |
|
13807
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
449 |
\<lambda>i x. is_DPow'(##Lset(i),f(x),g(x))]" |
13655
95b95cdb4704
Tidying up. New primitives is_iterates and is_iterates_fm.
paulson
parents:
13634
diff
changeset
|
450 |
apply (simp only: is_DPow'_def) |
13505 | 451 |
apply (intro FOL_reflections function_reflections mem_formula_reflection |
13692 | 452 |
mem_list_reflection Collect_reflection DPow_sats_reflection) |
13505 | 453 |
done |
454 |
||
455 |
||
69593 | 456 |
subsection\<open>A Locale for Relativizing the Operator \<^term>\<open>Lset\<close>\<close> |
13505 | 457 |
|
21233 | 458 |
definition |
21404
eb85850d3eb7
more robust syntax for definition/abbreviation/notation;
wenzelm
parents:
21233
diff
changeset
|
459 |
transrec_body :: "[i=>o,i,i,i,i] => o" where |
13505 | 460 |
"transrec_body(M,g,x) == |
461 |
\<lambda>y z. \<exists>gy[M]. y \<in> x & fun_apply(M,g,y,gy) & is_DPow'(M,gy,z)" |
|
462 |
||
463 |
lemma (in M_DPow) transrec_body_abs: |
|
464 |
"[|M(x); M(g); M(z)|] |
|
46823 | 465 |
==> transrec_body(M,g,x,y,z) \<longleftrightarrow> y \<in> x & z = DPow'(g`y)" |
13505 | 466 |
by (simp add: transrec_body_def DPow'_abs transM [of _ x]) |
467 |
||
468 |
locale M_Lset = M_DPow + |
|
469 |
assumes strong_rep: |
|
470 |
"[|M(x); M(g)|] ==> strong_replacement(M, \<lambda>y z. transrec_body(M,g,x,y,z))" |
|
471 |
and transrec_rep: |
|
472 |
"M(i) ==> transrec_replacement(M, \<lambda>x f u. |
|
473 |
\<exists>r[M]. is_Replace(M, x, transrec_body(M,f,x), r) & |
|
474 |
big_union(M, r, u), i)" |
|
475 |
||
476 |
||
477 |
lemma (in M_Lset) strong_rep': |
|
478 |
"[|M(x); M(g)|] |
|
479 |
==> strong_replacement(M, \<lambda>y z. y \<in> x & z = DPow'(g`y))" |
|
480 |
by (insert strong_rep [of x g], simp add: transrec_body_abs) |
|
481 |
||
482 |
lemma (in M_Lset) DPow_apply_closed: |
|
483 |
"[|M(f); M(x); y\<in>x|] ==> M(DPow'(f`y))" |
|
484 |
by (blast intro: DPow'_closed dest: transM) |
|
485 |
||
486 |
lemma (in M_Lset) RepFun_DPow_apply_closed: |
|
487 |
"[|M(f); M(x)|] ==> M({DPow'(f`y). y\<in>x})" |
|
488 |
by (blast intro: DPow_apply_closed RepFun_closed2 strong_rep') |
|
489 |
||
490 |
lemma (in M_Lset) RepFun_DPow_abs: |
|
491 |
"[|M(x); M(f); M(r) |] |
|
46823 | 492 |
==> is_Replace(M, x, \<lambda>y z. transrec_body(M,f,x,y,z), r) \<longleftrightarrow> |
13505 | 493 |
r = {DPow'(f`y). y\<in>x}" |
494 |
apply (simp add: transrec_body_abs RepFun_def) |
|
495 |
apply (rule iff_trans) |
|
496 |
apply (rule Replace_abs) |
|
497 |
apply (simp_all add: DPow_apply_closed strong_rep') |
|
498 |
done |
|
499 |
||
500 |
lemma (in M_Lset) transrec_rep': |
|
501 |
"M(i) ==> transrec_replacement(M, \<lambda>x f u. u = (\<Union>y\<in>x. DPow'(f ` y)), i)" |
|
502 |
apply (insert transrec_rep [of i]) |
|
503 |
apply (simp add: RepFun_DPow_apply_closed RepFun_DPow_abs |
|
504 |
transrec_replacement_def) |
|
505 |
done |
|
506 |
||
507 |
||
69593 | 508 |
text\<open>Relativization of the Operator \<^term>\<open>Lset\<close>\<close> |
13692 | 509 |
|
21233 | 510 |
definition |
21404
eb85850d3eb7
more robust syntax for definition/abbreviation/notation;
wenzelm
parents:
21233
diff
changeset
|
511 |
is_Lset :: "[i=>o, i, i] => o" where |
69593 | 512 |
\<comment> \<open>We can use the term language below because \<^term>\<open>is_Lset\<close> will |
13692 | 513 |
not have to be internalized: it isn't used in any instance of |
60770 | 514 |
separation.\<close> |
13505 | 515 |
"is_Lset(M,a,z) == is_transrec(M, %x f u. u = (\<Union>y\<in>x. DPow'(f`y)), a, z)" |
516 |
||
517 |
lemma (in M_Lset) Lset_abs: |
|
518 |
"[|Ord(i); M(i); M(z)|] |
|
46823 | 519 |
==> is_Lset(M,i,z) \<longleftrightarrow> z = Lset(i)" |
13505 | 520 |
apply (simp add: is_Lset_def Lset_eq_transrec_DPow') |
521 |
apply (rule transrec_abs) |
|
13634 | 522 |
apply (simp_all add: transrec_rep' relation2_def RepFun_DPow_apply_closed) |
13505 | 523 |
done |
524 |
||
525 |
lemma (in M_Lset) Lset_closed: |
|
526 |
"[|Ord(i); M(i)|] ==> M(Lset(i))" |
|
527 |
apply (simp add: Lset_eq_transrec_DPow') |
|
528 |
apply (rule transrec_closed [OF transrec_rep']) |
|
13634 | 529 |
apply (simp_all add: relation2_def RepFun_DPow_apply_closed) |
13505 | 530 |
done |
531 |
||
532 |
||
61798 | 533 |
subsection\<open>Instantiating the Locale \<open>M_Lset\<close>\<close> |
13505 | 534 |
|
60770 | 535 |
subsubsection\<open>The First Instance of Replacement\<close> |
13505 | 536 |
|
537 |
lemma strong_rep_Reflects: |
|
538 |
"REFLECTS [\<lambda>u. \<exists>v[L]. v \<in> B & (\<exists>gy[L]. |
|
539 |
v \<in> x & fun_apply(L,g,v,gy) & is_DPow'(L,gy,u)), |
|
540 |
\<lambda>i u. \<exists>v \<in> Lset(i). v \<in> B & (\<exists>gy \<in> Lset(i). |
|
13807
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
541 |
v \<in> x & fun_apply(##Lset(i),g,v,gy) & is_DPow'(##Lset(i),gy,u))]" |
13505 | 542 |
by (intro FOL_reflections function_reflections DPow'_reflection) |
543 |
||
544 |
lemma strong_rep: |
|
545 |
"[|L(x); L(g)|] ==> strong_replacement(L, \<lambda>y z. transrec_body(L,g,x,y,z))" |
|
546 |
apply (unfold transrec_body_def) |
|
547 |
apply (rule strong_replacementI) |
|
13687 | 548 |
apply (rule_tac u="{x,g,B}" |
549 |
in gen_separation_multi [OF strong_rep_Reflects], auto) |
|
550 |
apply (rule_tac env="[x,g,B]" in DPow_LsetI) |
|
13505 | 551 |
apply (rule sep_rules DPow'_iff_sats | simp)+ |
552 |
done |
|
553 |
||
554 |
||
60770 | 555 |
subsubsection\<open>The Second Instance of Replacement\<close> |
13505 | 556 |
|
557 |
lemma transrec_rep_Reflects: |
|
558 |
"REFLECTS [\<lambda>x. \<exists>v[L]. v \<in> B & |
|
559 |
(\<exists>y[L]. pair(L,v,y,x) & |
|
560 |
is_wfrec (L, \<lambda>x f u. \<exists>r[L]. |
|
561 |
is_Replace (L, x, \<lambda>y z. |
|
562 |
\<exists>gy[L]. y \<in> x & fun_apply(L,f,y,gy) & |
|
563 |
is_DPow'(L,gy,z), r) & big_union(L,r,u), mr, v, y)), |
|
564 |
\<lambda>i x. \<exists>v \<in> Lset(i). v \<in> B & |
|
13807
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
565 |
(\<exists>y \<in> Lset(i). pair(##Lset(i),v,y,x) & |
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
566 |
is_wfrec (##Lset(i), \<lambda>x f u. \<exists>r \<in> Lset(i). |
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
567 |
is_Replace (##Lset(i), x, \<lambda>y z. |
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
568 |
\<exists>gy \<in> Lset(i). y \<in> x & fun_apply(##Lset(i),f,y,gy) & |
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
569 |
is_DPow'(##Lset(i),gy,z), r) & |
a28a8fbc76d4
changed ** to ## to avoid conflict with new comment syntax
paulson
parents:
13692
diff
changeset
|
570 |
big_union(##Lset(i),r,u), mr, v, y))]" |
13655
95b95cdb4704
Tidying up. New primitives is_iterates and is_iterates_fm.
paulson
parents:
13634
diff
changeset
|
571 |
apply (simp only: rex_setclass_is_bex [symmetric]) |
67443
3abf6a722518
standardized towards new-style formal comments: isabelle update_comments;
wenzelm
parents:
61798
diff
changeset
|
572 |
\<comment> \<open>Convert \<open>\<exists>y\<in>Lset(i)\<close> to \<open>\<exists>y[##Lset(i)]\<close> within the body |
69593 | 573 |
of the \<^term>\<open>is_wfrec\<close> application.\<close> |
13505 | 574 |
apply (intro FOL_reflections function_reflections |
575 |
is_wfrec_reflection Replace_reflection DPow'_reflection) |
|
576 |
done |
|
577 |
||
578 |
||
579 |
lemma transrec_rep: |
|
580 |
"[|L(j)|] |
|
581 |
==> transrec_replacement(L, \<lambda>x f u. |
|
582 |
\<exists>r[L]. is_Replace(L, x, transrec_body(L,f,x), r) & |
|
583 |
big_union(L, r, u), j)" |
|
71568
1005c50b2750
prefer strict qualification (default for 'interpretation', see 461ee3e49ad3) as proposed by Pedro Sánchez Terraf;
wenzelm
parents:
71417
diff
changeset
|
584 |
apply (rule L.transrec_replacementI, assumption) |
13566 | 585 |
apply (unfold transrec_body_def) |
13505 | 586 |
apply (rule strong_replacementI) |
13566 | 587 |
apply (rule_tac u="{j,B,Memrel(eclose({j}))}" |
13687 | 588 |
in gen_separation_multi [OF transrec_rep_Reflects], auto) |
589 |
apply (rule_tac env="[j,B,Memrel(eclose({j}))]" in DPow_LsetI) |
|
13505 | 590 |
apply (rule sep_rules is_wfrec_iff_sats Replace_iff_sats DPow'_iff_sats | |
591 |
simp)+ |
|
592 |
done |
|
593 |
||
594 |
||
61798 | 595 |
subsubsection\<open>Actually Instantiating \<open>M_Lset\<close>\<close> |
13505 | 596 |
|
597 |
lemma M_Lset_axioms_L: "M_Lset_axioms(L)" |
|
598 |
apply (rule M_Lset_axioms.intro) |
|
599 |
apply (assumption | rule strong_rep transrec_rep)+ |
|
600 |
done |
|
601 |
||
71417
89d05db6dd1f
Simplified, generalised version of Constructible due to E. Gunther, M. Pagano and P. Sánchez Terraf
paulson <lp15@cam.ac.uk>
parents:
69593
diff
changeset
|
602 |
theorem M_Lset_L: "M_Lset(L)" |
19931
fb32b43e7f80
Restructured locales with predicates: import is now an interpretation.
ballarin
parents:
16417
diff
changeset
|
603 |
apply (rule M_Lset.intro) |
fb32b43e7f80
Restructured locales with predicates: import is now an interpretation.
ballarin
parents:
16417
diff
changeset
|
604 |
apply (rule M_DPow_L) |
fb32b43e7f80
Restructured locales with predicates: import is now an interpretation.
ballarin
parents:
16417
diff
changeset
|
605 |
apply (rule M_Lset_axioms_L) |
fb32b43e7f80
Restructured locales with predicates: import is now an interpretation.
ballarin
parents:
16417
diff
changeset
|
606 |
done |
13505 | 607 |
|
60770 | 608 |
text\<open>Finally: the point of the whole theory!\<close> |
13505 | 609 |
lemmas Lset_closed = M_Lset.Lset_closed [OF M_Lset_L] |
610 |
and Lset_abs = M_Lset.Lset_abs [OF M_Lset_L] |
|
611 |
||
612 |
||
60770 | 613 |
subsection\<open>The Notion of Constructible Set\<close> |
13505 | 614 |
|
21233 | 615 |
definition |
21404
eb85850d3eb7
more robust syntax for definition/abbreviation/notation;
wenzelm
parents:
21233
diff
changeset
|
616 |
constructible :: "[i=>o,i] => o" where |
13505 | 617 |
"constructible(M,x) == |
618 |
\<exists>i[M]. \<exists>Li[M]. ordinal(M,i) & is_Lset(M,i,Li) & x \<in> Li" |
|
619 |
||
620 |
theorem V_equals_L_in_L: |
|
47072 | 621 |
"L(x) \<longleftrightarrow> constructible(L,x)" |
622 |
apply (simp add: constructible_def Lset_abs Lset_closed) |
|
13505 | 623 |
apply (simp add: L_def) |
624 |
apply (blast intro: Ord_in_L) |
|
625 |
done |
|
626 |
||
13503 | 627 |
end |