merged
authorwenzelm
Thu, 17 Jan 2013 15:50:56 +0100
changeset 50947 8757e6aa50eb
parent 50944 03b11adf1f33 (current diff)
parent 50946 8ad3e376f63e (diff)
child 50948 8c742f9de9f5
child 50956 d58dae9079a6
merged
--- a/src/HOL/Multivariate_Analysis/Integration.thy	Thu Jan 17 14:38:12 2013 +0100
+++ b/src/HOL/Multivariate_Analysis/Integration.thy	Thu Jan 17 15:50:56 2013 +0100
@@ -89,7 +89,8 @@
       case True
       show ?thesis
         apply (rule assms[OF Suc(1)[OF True]])
-        using `?r` apply auto
+        using `?r`
+        apply auto
         done
     next
       case False
@@ -241,7 +242,8 @@
           thus ?thesis
             apply (rule_tac x=i in bexI, rule_tac x=x in exI, rule_tac x="min d e" in exI)
             unfolding ab
-            using interval_open_subset_closed[of a b] and e apply fastforce+
+            using interval_open_subset_closed[of a b] and e
+            apply fastforce+
             done
         next
           case False
@@ -285,8 +287,10 @@
                 done
               also have "\<dots> < \<bar>e\<bar> / 2 + \<bar>e\<bar> / 2"
                 apply (rule add_strict_left_mono)
-                using as unfolding mem_ball dist_norm
-                using e apply (auto simp add: field_simps)
+                using as
+                unfolding mem_ball dist_norm
+                using e
+                apply (auto simp add: field_simps)
                 done
               finally show "y\<in>ball x e"
                 unfolding mem_ball dist_norm using e by (auto simp add:field_simps)
@@ -415,7 +419,8 @@
   assumes "{a..b}\<noteq>{}"
   shows "content {a..b} = (\<Prod>i\<in>Basis. b\<bullet>i - a\<bullet>i)"
   apply (rule content_closed_interval)
-  using assms unfolding interval_ne_empty
+  using assms
+  unfolding interval_ne_empty
   apply assumption
   done
 
@@ -533,10 +538,10 @@
     unfolding content_def
     unfolding interval_bounds[OF ab_ne] interval_bounds[OF cd_ne]
     unfolding if_not_P[OF False] if_not_P[OF `{c..d} \<noteq> {}`]
-    apply(rule setprod_mono,rule)
+    apply (rule setprod_mono, rule)
   proof
     fix i :: 'a
-    assume i:"i\<in>Basis"
+    assume i: "i\<in>Basis"
     show "0 \<le> b \<bullet> i - a \<bullet> i" using ab_ne[THEN bspec, OF i] i by auto
     show "b \<bullet> i - a \<bullet> i \<le> d \<bullet> i - c \<bullet> i"
       using assms[unfolded subset_eq mem_interval,rule_format,OF ab_ab(2),of i]
@@ -620,7 +625,10 @@
     assume "s = {{a}}"
     moreover fix k assume "k\<in>s" 
     ultimately have"\<exists>x y. k = {x..y}"
-      apply (rule_tac x=a in exI)+ unfolding interval_sing by auto
+      apply (rule_tac x=a in exI)+
+      unfolding interval_sing
+      apply auto
+      done
   }
   ultimately show ?l unfolding division_of_def interval_sing by auto
 next
@@ -671,9 +679,9 @@
   assumes "content {a..b} = 0" "d division_of {a..b}"
   shows "\<forall>k\<in>d. content k = 0"
   unfolding forall_in_division[OF assms(2)]
-  apply(rule,rule,rule)
-  apply(drule division_ofD(2)[OF assms(2)])
-  apply(drule content_subset) unfolding assms(1)
+  apply (rule,rule,rule)
+  apply (drule division_ofD(2)[OF assms(2)])
+  apply (drule content_subset) unfolding assms(1)
 proof -
   case goal1
   thus ?case using content_pos_le[of a b] by auto
@@ -748,7 +756,9 @@
 lemma elementary_inter:
   assumes "p1 division_of s" "p2 division_of (t::('a::ordered_euclidean_space) set)"
   shows "\<exists>p. p division_of (s \<inter> t)"
-  by (rule, rule division_inter[OF assms])
+  apply rule
+  apply (rule division_inter[OF assms])
+  done
 
 lemma elementary_inters:
   assumes "finite f" "f\<noteq>{}" "\<forall>s\<in>f. \<exists>p. p division_of (s::('a::ordered_euclidean_space) set)"
@@ -775,21 +785,41 @@
 
 lemma division_disjoint_union:
   assumes "p1 division_of s1" "p2 division_of s2" "interior s1 \<inter> interior s2 = {}"
-  shows "(p1 \<union> p2) division_of (s1 \<union> s2)" proof(rule division_ofI) 
+  shows "(p1 \<union> p2) division_of (s1 \<union> s2)"
+proof (rule division_ofI)
   note d1 = division_ofD[OF assms(1)] and d2 = division_ofD[OF assms(2)]
   show "finite (p1 \<union> p2)" using d1(1) d2(1) by auto
   show "\<Union>(p1 \<union> p2) = s1 \<union> s2" using d1(6) d2(6) by auto
-  { fix k1 k2 assume as:"k1 \<in> p1 \<union> p2" "k2 \<in> p1 \<union> p2" "k1 \<noteq> k2" moreover let ?g="interior k1 \<inter> interior k2 = {}"
-  { assume as:"k1\<in>p1" "k2\<in>p2" have ?g using interior_mono[OF d1(2)[OF as(1)]] interior_mono[OF d2(2)[OF as(2)]]
-      using assms(3) by blast } moreover
-  { assume as:"k1\<in>p2" "k2\<in>p1" have ?g using interior_mono[OF d1(2)[OF as(2)]] interior_mono[OF d2(2)[OF as(1)]]
-      using assms(3) by blast} ultimately
-  show ?g using d1(5)[OF _ _ as(3)] and d2(5)[OF _ _ as(3)] by auto }
-  fix k assume k:"k \<in> p1 \<union> p2"  show "k \<subseteq> s1 \<union> s2" using k d1(2) d2(2) by auto
-  show "k \<noteq> {}" using k d1(3) d2(3) by auto show "\<exists>a b. k = {a..b}" using k d1(4) d2(4) by auto qed
+  {
+    fix k1 k2
+    assume as: "k1 \<in> p1 \<union> p2" "k2 \<in> p1 \<union> p2" "k1 \<noteq> k2"
+    moreover
+    let ?g="interior k1 \<inter> interior k2 = {}"
+    {
+      assume as: "k1\<in>p1" "k2\<in>p2"
+      have ?g
+        using interior_mono[OF d1(2)[OF as(1)]] interior_mono[OF d2(2)[OF as(2)]]
+        using assms(3) by blast
+    }
+    moreover
+    {
+      assume as: "k1\<in>p2" "k2\<in>p1"
+      have ?g
+        using interior_mono[OF d1(2)[OF as(2)]] interior_mono[OF d2(2)[OF as(1)]]
+        using assms(3) by blast
+    }
+    ultimately show ?g using d1(5)[OF _ _ as(3)] and d2(5)[OF _ _ as(3)] by auto
+  }
+  fix k
+  assume k: "k \<in> p1 \<union> p2"
+  show "k \<subseteq> s1 \<union> s2" using k d1(2) d2(2) by auto
+  show "k \<noteq> {}" using k d1(3) d2(3) by auto
+  show "\<exists>a b. k = {a..b}" using k d1(4) d2(4) by auto
+qed
 
 lemma partial_division_extend_1:
-  assumes incl: "{c..d} \<subseteq> {a..b::'a::ordered_euclidean_space}" and nonempty: "{c..d} \<noteq> {}"
+  assumes incl: "{c..d} \<subseteq> {a..b::'a::ordered_euclidean_space}"
+    and nonempty: "{c..d} \<noteq> {}"
   obtains p where "p division_of {a..b}" "{c..d} \<in> p"
 proof
   let ?B = "\<lambda>f::'a\<Rightarrow>'a \<times> 'a. {(\<Sum>i\<in>Basis. (fst (f i) \<bullet> i) *\<^sub>R i) .. (\<Sum>i\<in>Basis. (snd (f i) \<bullet> i) *\<^sub>R i)}"
@@ -800,52 +830,61 @@
     by (auto simp add: interval_eq_empty eucl_le[where 'a='a]
              intro!: image_eqI[where x="\<lambda>(i::'a)\<in>Basis. (c, d)"])
 
-  {  fix i :: 'a assume "i \<in> Basis"
+  {
+    fix i :: 'a
+    assume "i \<in> Basis"
     with incl nonempty have "a \<bullet> i \<le> c \<bullet> i" "c \<bullet> i \<le> d \<bullet> i" "d \<bullet> i \<le> b \<bullet> i"
-      unfolding interval_eq_empty subset_interval by (auto simp: not_le) }
+      unfolding interval_eq_empty subset_interval by (auto simp: not_le)
+  }
   note ord = this
 
   show "p division_of {a..b}"
   proof (rule division_ofI)
-    show "finite p"
-      unfolding p_def by (auto intro!: finite_PiE)
-    { fix k assume "k \<in> p"
+    show "finite p" unfolding p_def by (auto intro!: finite_PiE)
+    {
+      fix k
+      assume "k \<in> p"
       then obtain f where f: "f \<in> Basis \<rightarrow>\<^isub>E {(a, c), (c, d), (d, b)}" and k: "k = ?B f"
         by (auto simp: p_def)
       then show "\<exists>a b. k = {a..b}" by auto
       have "k \<subseteq> {a..b} \<and> k \<noteq> {}"
       proof (simp add: k interval_eq_empty subset_interval not_less, safe)
         fix i :: 'a assume i: "i \<in> Basis"
-        moreover with f have "f i = (a, c) \<or> f i = (c, d) \<or> f i = (d, b)"
+        moreover
+        with f have "f i = (a, c) \<or> f i = (c, d) \<or> f i = (d, b)"
           by (auto simp: PiE_iff)
         moreover note ord[of i]
-        ultimately show "a \<bullet> i \<le> fst (f i) \<bullet> i" "snd (f i) \<bullet> i \<le> b \<bullet> i" "fst (f i) \<bullet> i \<le> snd (f i) \<bullet> i"
+        ultimately
+        show "a \<bullet> i \<le> fst (f i) \<bullet> i" "snd (f i) \<bullet> i \<le> b \<bullet> i" "fst (f i) \<bullet> i \<le> snd (f i) \<bullet> i"
           by (auto simp: subset_iff eucl_le[where 'a='a])
       qed
       then show "k \<noteq> {}" "k \<subseteq> {a .. b}" by auto
-      { 
-      fix l assume "l \<in> p"
-      then obtain g where g: "g \<in> Basis \<rightarrow>\<^isub>E {(a, c), (c, d), (d, b)}" and l: "l = ?B g"
-        by (auto simp: p_def)
-      assume "l \<noteq> k"
-      have "\<exists>i\<in>Basis. f i \<noteq> g i"
-      proof (rule ccontr)
-        assume "\<not> (\<exists>i\<in>Basis. f i \<noteq> g i)"
-        with f g have "f = g"
-          by (auto simp: PiE_iff extensional_def intro!: ext)
-        with `l \<noteq> k` show False
-          by (simp add: l k)
-      qed
-      then guess i ..
-      moreover then have "f i = (a, c) \<or> f i = (c, d) \<or> f i = (d, b)"
-          "g i = (a, c) \<or> g i = (c, d) \<or> g i = (d, b)"
-        using f g by (auto simp: PiE_iff)
-      moreover note ord[of i]
-      ultimately show "interior l \<inter> interior k = {}"
-        by (auto simp add: l k interior_closed_interval disjoint_interval intro!: bexI[of _ i]) }
-      note `k \<subseteq> { a.. b}` }
+      {
+        fix l assume "l \<in> p"
+        then obtain g where g: "g \<in> Basis \<rightarrow>\<^isub>E {(a, c), (c, d), (d, b)}" and l: "l = ?B g"
+          by (auto simp: p_def)
+        assume "l \<noteq> k"
+        have "\<exists>i\<in>Basis. f i \<noteq> g i"
+        proof (rule ccontr)
+          assume "\<not> (\<exists>i\<in>Basis. f i \<noteq> g i)"
+          with f g have "f = g"
+            by (auto simp: PiE_iff extensional_def intro!: ext)
+          with `l \<noteq> k` show False
+            by (simp add: l k)
+        qed
+        then guess i .. note * = this
+        moreover from * have "f i = (a, c) \<or> f i = (c, d) \<or> f i = (d, b)"
+            "g i = (a, c) \<or> g i = (c, d) \<or> g i = (d, b)"
+          using f g by (auto simp: PiE_iff)
+        moreover note ord[of i]
+        ultimately show "interior l \<inter> interior k = {}"
+          by (auto simp add: l k interior_closed_interval disjoint_interval intro!: bexI[of _ i])
+      }
+      note `k \<subseteq> { a.. b}`
+    }
     moreover
-    { fix x assume x: "x \<in> {a .. b}"
+    {
+      fix x assume x: "x \<in> {a .. b}"
       have "\<forall>i\<in>Basis. \<exists>l. x \<bullet> i \<in> {fst l \<bullet> i .. snd l \<bullet> i} \<and> l \<in> {(a, c), (c, d), (d, b)}"
       proof
         fix i :: 'a assume "i \<in> Basis"
@@ -868,61 +907,164 @@
   qed
 qed
 
-lemma partial_division_extend_interval: assumes "p division_of (\<Union>p)" "(\<Union>p) \<subseteq> {a..b}"
-  obtains q where "p \<subseteq> q" "q division_of {a..b::'a::ordered_euclidean_space}" proof(cases "p = {}")
-  case True guess q apply(rule elementary_interval[of a b]) .
-  thus ?thesis apply- apply(rule that[of q]) unfolding True by auto next
-  case False note p = division_ofD[OF assms(1)]
-  have *:"\<forall>k\<in>p. \<exists>q. q division_of {a..b} \<and> k\<in>q" proof case goal1
-    guess c using p(4)[OF goal1] .. then guess d .. note "cd" = this
-    have *:"{c..d} \<subseteq> {a..b}" "{c..d} \<noteq> {}" using p(2,3)[OF goal1, unfolded "cd"] using assms(2) by auto
-    guess q apply(rule partial_division_extend_1[OF *]) . thus ?case unfolding "cd" by auto qed
+lemma partial_division_extend_interval:
+  assumes "p division_of (\<Union>p)" "(\<Union>p) \<subseteq> {a..b}"
+  obtains q where "p \<subseteq> q" "q division_of {a..b::'a::ordered_euclidean_space}"
+proof (cases "p = {}")
+  case True
+  guess q apply (rule elementary_interval[of a b]) .
+  thus ?thesis
+    apply -
+    apply (rule that[of q])
+    unfolding True
+    apply auto
+    done
+next
+  case False
+  note p = division_ofD[OF assms(1)]
+  have *: "\<forall>k\<in>p. \<exists>q. q division_of {a..b} \<and> k\<in>q"
+  proof
+    case goal1
+    guess c using p(4)[OF goal1] ..
+    then guess d .. note "cd" = this
+    have *: "{c..d} \<subseteq> {a..b}" "{c..d} \<noteq> {}"
+      using p(2,3)[OF goal1, unfolded "cd"] using assms(2) by auto
+    guess q apply(rule partial_division_extend_1[OF *]) .
+    thus ?case unfolding "cd" by auto
+  qed
   guess q using bchoice[OF *] .. note q = conjunctD2[OF this[rule_format]]
-  have "\<And>x. x\<in>p \<Longrightarrow> \<exists>d. d division_of \<Union>(q x - {x})" apply(rule,rule_tac p="q x" in division_of_subset) proof-
-    fix x assume x:"x\<in>p" show "q x division_of \<Union>q x" apply-apply(rule division_ofI)
-      using division_ofD[OF q(1)[OF x]] by auto show "q x - {x} \<subseteq> q x" by auto qed
-  hence "\<exists>d. d division_of \<Inter> ((\<lambda>i. \<Union>(q i - {i})) ` p)" apply- apply(rule elementary_inters)
-    apply(rule finite_imageI[OF p(1)]) unfolding image_is_empty apply(rule False) by auto
+  have "\<And>x. x\<in>p \<Longrightarrow> \<exists>d. d division_of \<Union>(q x - {x})"
+    apply (rule, rule_tac p="q x" in division_of_subset)
+  proof -
+    fix x
+    assume x: "x\<in>p"
+    show "q x division_of \<Union>q x"
+      apply -
+      apply (rule division_ofI)
+      using division_ofD[OF q(1)[OF x]]
+      apply auto
+      done
+    show "q x - {x} \<subseteq> q x" by auto
+  qed
+  hence "\<exists>d. d division_of \<Inter> ((\<lambda>i. \<Union>(q i - {i})) ` p)"
+    apply -
+    apply (rule elementary_inters)
+    apply (rule finite_imageI[OF p(1)])
+    unfolding image_is_empty
+    apply (rule False)
+    apply auto
+    done
   then guess d .. note d = this
-  show ?thesis apply(rule that[of "d \<union> p"]) proof-
-    have *:"\<And>s f t. s \<noteq> {} \<Longrightarrow> (\<forall>i\<in>s. f i \<union> i = t) \<Longrightarrow> t = \<Inter> (f ` s) \<union> (\<Union>s)" by auto
-    have *:"{a..b} = \<Inter> (\<lambda>i. \<Union>(q i - {i})) ` p \<union> \<Union>p" apply(rule *[OF False]) proof fix i assume i:"i\<in>p"
-      show "\<Union>(q i - {i}) \<union> i = {a..b}" using division_ofD(6)[OF q(1)[OF i]] using q(2)[OF i] by auto qed
-    show "d \<union> p division_of {a..b}" unfolding * apply(rule division_disjoint_union[OF d assms(1)])
-      apply(rule inter_interior_unions_intervals) apply(rule p open_interior ballI)+ proof(assumption,rule)
-      fix k assume k:"k\<in>p" have *:"\<And>u t s. u \<subseteq> s \<Longrightarrow> s \<inter> t = {} \<Longrightarrow> u \<inter> t = {}" by auto
-      show "interior (\<Inter>(\<lambda>i. \<Union>(q i - {i})) ` p) \<inter> interior k = {}" apply(rule *[of _ "interior (\<Union>(q k - {k}))"])
-        defer apply(subst Int_commute) apply(rule inter_interior_unions_intervals) proof- note qk=division_ofD[OF q(1)[OF k]]
-        show "finite (q k - {k})" "open (interior k)"  "\<forall>t\<in>q k - {k}. \<exists>a b. t = {a..b}" using qk by auto
-        show "\<forall>t\<in>q k - {k}. interior k \<inter> interior t = {}" using qk(5) using q(2)[OF k] by auto
-        have *:"\<And>x s. x \<in> s \<Longrightarrow> \<Inter>s \<subseteq> x" by auto show "interior (\<Inter>(\<lambda>i. \<Union>(q i - {i})) ` p) \<subseteq> interior (\<Union>(q k - {k}))"
-          apply(rule interior_mono *)+ using k by auto qed qed qed auto qed
+  show ?thesis
+    apply (rule that[of "d \<union> p"])
+  proof -
+    have *: "\<And>s f t. s \<noteq> {} \<Longrightarrow> (\<forall>i\<in>s. f i \<union> i = t) \<Longrightarrow> t = \<Inter> (f ` s) \<union> (\<Union>s)" by auto
+    have *: "{a..b} = \<Inter> (\<lambda>i. \<Union>(q i - {i})) ` p \<union> \<Union>p"
+      apply (rule *[OF False])
+    proof
+      fix i
+      assume i: "i\<in>p"
+      show "\<Union>(q i - {i}) \<union> i = {a..b}"
+        using division_ofD(6)[OF q(1)[OF i]] using q(2)[OF i] by auto
+    qed
+    show "d \<union> p division_of {a..b}"
+      unfolding *
+      apply (rule division_disjoint_union[OF d assms(1)])
+      apply (rule inter_interior_unions_intervals)
+      apply (rule p open_interior ballI)+
+    proof (assumption, rule)
+      fix k
+      assume k: "k\<in>p"
+      have *: "\<And>u t s. u \<subseteq> s \<Longrightarrow> s \<inter> t = {} \<Longrightarrow> u \<inter> t = {}" by auto
+      show "interior (\<Inter>(\<lambda>i. \<Union>(q i - {i})) ` p) \<inter> interior k = {}"
+        apply (rule *[of _ "interior (\<Union>(q k - {k}))"])
+        defer
+        apply (subst Int_commute)
+        apply (rule inter_interior_unions_intervals)
+      proof -
+        note qk=division_ofD[OF q(1)[OF k]]
+        show "finite (q k - {k})" "open (interior k)"
+          "\<forall>t\<in>q k - {k}. \<exists>a b. t = {a..b}" using qk by auto
+        show "\<forall>t\<in>q k - {k}. interior k \<inter> interior t = {}"
+          using qk(5) using q(2)[OF k] by auto
+        have *: "\<And>x s. x \<in> s \<Longrightarrow> \<Inter>s \<subseteq> x" by auto
+        show "interior (\<Inter>(\<lambda>i. \<Union>(q i - {i})) ` p) \<subseteq> interior (\<Union>(q k - {k}))"
+          apply (rule interior_mono *)+
+          using k by auto
+      qed
+    qed
+  qed auto
+qed
 
 lemma elementary_bounded[dest]: "p division_of s \<Longrightarrow> bounded (s::('a::ordered_euclidean_space) set)"
   unfolding division_of_def by(metis bounded_Union bounded_interval) 
 
 lemma elementary_subset_interval: "p division_of s \<Longrightarrow> \<exists>a b. s \<subseteq> {a..b::'a::ordered_euclidean_space}"
-  by(meson elementary_bounded bounded_subset_closed_interval)
-
-lemma division_union_intervals_exists: assumes "{a..b::'a::ordered_euclidean_space} \<noteq> {}"
-  obtains p where "(insert {a..b} p) division_of ({a..b} \<union> {c..d})" proof(cases "{c..d} = {}")
-  case True show ?thesis apply(rule that[of "{}"]) unfolding True using assms by auto next
-  case False note false=this show ?thesis proof(cases "{a..b} \<inter> {c..d} = {}")
-  have *:"\<And>a b. {a,b} = {a} \<union> {b}" by auto
-  case True show ?thesis apply(rule that[of "{{c..d}}"]) unfolding * apply(rule division_disjoint_union)
-    using false True assms using interior_subset by auto next
-  case False obtain u v where uv:"{a..b} \<inter> {c..d} = {u..v}" unfolding inter_interval by auto
-  have *:"{u..v} \<subseteq> {c..d}" using uv by auto
-  guess p apply(rule partial_division_extend_1[OF * False[unfolded uv]]) . note p=this division_ofD[OF this(1)]
-  have *:"{a..b} \<union> {c..d} = {a..b} \<union> \<Union>(p - {{u..v}})" "\<And>x s. insert x s = {x} \<union> s" using p(8) unfolding uv[THEN sym] by auto
-  show thesis apply(rule that[of "p - {{u..v}}"]) unfolding *(1) apply(subst *(2)) apply(rule division_disjoint_union)
-    apply(rule,rule assms) apply(rule division_of_subset[of p]) apply(rule division_of_union_self[OF p(1)]) defer
-    unfolding interior_inter[THEN sym] proof-
-    have *:"\<And>cd p uv ab. p \<subseteq> cd \<Longrightarrow> ab \<inter> cd = uv \<Longrightarrow> ab \<inter> p = uv \<inter> p" by auto
-    have "interior ({a..b} \<inter> \<Union>(p - {{u..v}})) = interior({u..v} \<inter> \<Union>(p - {{u..v}}))" 
-      apply(rule arg_cong[of _ _ interior]) apply(rule *[OF _ uv]) using p(8) by auto
-    also have "\<dots> = {}" unfolding interior_inter apply(rule inter_interior_unions_intervals) using p(6) p(7)[OF p(2)] p(3) by auto
-    finally show "interior ({a..b} \<inter> \<Union>(p - {{u..v}})) = {}" by assumption qed auto qed qed
+  by (meson elementary_bounded bounded_subset_closed_interval)
+
+lemma division_union_intervals_exists:
+  assumes "{a..b::'a::ordered_euclidean_space} \<noteq> {}"
+  obtains p where "(insert {a..b} p) division_of ({a..b} \<union> {c..d})"
+proof (cases "{c..d} = {}")
+  case True
+  show ?thesis
+    apply (rule that[of "{}"])
+    unfolding True
+    using assms
+    apply auto
+    done
+next
+  case False
+  note false=this
+  show ?thesis
+  proof (cases "{a..b} \<inter> {c..d} = {}")
+    case True
+    have *:"\<And>a b. {a,b} = {a} \<union> {b}" by auto
+    show ?thesis
+      apply (rule that[of "{{c..d}}"])
+      unfolding *
+      apply (rule division_disjoint_union)
+      using false True assms
+      using interior_subset
+      apply auto
+      done
+  next
+    case False
+    obtain u v where uv: "{a..b} \<inter> {c..d} = {u..v}"
+      unfolding inter_interval by auto
+    have *: "{u..v} \<subseteq> {c..d}" using uv by auto
+    guess p apply (rule partial_division_extend_1[OF * False[unfolded uv]]) .
+    note p=this division_ofD[OF this(1)]
+    have *: "{a..b} \<union> {c..d} = {a..b} \<union> \<Union>(p - {{u..v}})" "\<And>x s. insert x s = {x} \<union> s"
+      using p(8) unfolding uv[THEN sym] by auto
+    show ?thesis
+      apply (rule that[of "p - {{u..v}}"])
+      unfolding *(1)
+      apply (subst *(2))
+      apply (rule division_disjoint_union)
+      apply (rule, rule assms)
+      apply (rule division_of_subset[of p])
+      apply (rule division_of_union_self[OF p(1)])
+      defer
+      unfolding interior_inter[THEN sym]
+    proof -
+      have *: "\<And>cd p uv ab. p \<subseteq> cd \<Longrightarrow> ab \<inter> cd = uv \<Longrightarrow> ab \<inter> p = uv \<inter> p" by auto
+      have "interior ({a..b} \<inter> \<Union>(p - {{u..v}})) = interior({u..v} \<inter> \<Union>(p - {{u..v}}))" 
+        apply (rule arg_cong[of _ _ interior])
+        apply (rule *[OF _ uv])
+        using p(8)
+        apply auto
+        done
+      also have "\<dots> = {}"
+        unfolding interior_inter
+        apply (rule inter_interior_unions_intervals)
+        using p(6) p(7)[OF p(2)] p(3)
+        apply auto
+        done
+      finally show "interior ({a..b} \<inter> \<Union>(p - {{u..v}})) = {}" .
+    qed auto
+  qed
+qed
 
 lemma division_of_unions: assumes "finite f"  "\<And>p. p\<in>f \<Longrightarrow> p division_of (\<Union>p)"
   "\<And>k1 k2. \<lbrakk>k1 \<in> \<Union>f; k2 \<in> \<Union>f; k1 \<noteq> k2\<rbrakk> \<Longrightarrow> interior k1 \<inter> interior k2 = {}"
--- a/src/Pure/General/properties.scala	Thu Jan 17 14:38:12 2013 +0100
+++ b/src/Pure/General/properties.scala	Thu Jan 17 15:50:56 2013 +0100
@@ -102,33 +102,5 @@
         case Some((_, value)) => Value.Double.unapply(value)
       }
   }
-
-
-  /* concrete syntax -- similar to ML */
-
-  private val syntax = Outer_Syntax.empty + "," + "(" + ")" + "[" + "]"
-
-  private object Parser extends Parse.Parser
-  {
-    def prop: Parser[Entry] =
-      keyword("(") ~ string ~ keyword(",") ~ string ~ keyword(")") ^^
-      { case _ ~ x ~ _ ~ y ~ _ => (x, y) }
-    def props: Parser[T] =
-      keyword("[") ~> repsep(prop, keyword(",")) <~ keyword("]")
-  }
-
-  def parse(text: java.lang.String): Properties.T =
-  {
-    Parser.parse_all(Parser.props, Token.reader(syntax.scan(text))) match {
-      case Parser.Success(result, _) => result
-      case bad => error(bad.toString)
-    }
-  }
-
-  def parse_lines(prefix: java.lang.String, lines: List[java.lang.String]): List[T] =
-    for (line <- lines; s <- Library.try_unprefix(prefix, line)) yield parse(s)
-
-  def find_parse_line(prefix: java.lang.String, lines: List[java.lang.String]): Option[T] =
-    lines.find(_.startsWith(prefix)).map(line => parse(line.substring(prefix.length)))
 }
 
--- a/src/Pure/Tools/build.scala	Thu Jan 17 14:38:12 2013 +0100
+++ b/src/Pure/Tools/build.scala	Thu Jan 17 15:50:56 2013 +0100
@@ -521,6 +521,37 @@
   }
 
 
+  /* inlined properties -- syntax similar to ML */
+
+  object Props
+  {
+    private val syntax = Outer_Syntax.empty + "," + "(" + ")" + "[" + "]"
+
+    private object Parser extends Parse.Parser
+    {
+      def prop: Parser[Properties.Entry] =
+        keyword("(") ~ string ~ keyword(",") ~ string ~ keyword(")") ^^
+        { case _ ~ x ~ _ ~ y ~ _ => (x, y) }
+      def props: Parser[Properties.T] =
+        keyword("[") ~> repsep(prop, keyword(",")) <~ keyword("]")
+    }
+
+    def parse(text: String): Properties.T =
+    {
+      Parser.parse_all(Parser.props, Token.reader(syntax.scan(text))) match {
+        case Parser.Success(result, _) => result
+        case bad => error(bad.toString)
+      }
+    }
+
+    def parse_lines(prefix: String, lines: List[String]): List[Properties.T] =
+      for (line <- lines; s <- Library.try_unprefix(prefix, line)) yield parse(s)
+
+    def find_parse_line(prefix: String, lines: List[String]): Option[Properties.T] =
+      lines.find(_.startsWith(prefix)).map(line => parse(line.substring(prefix.length)))
+  }
+
+
   /* log files */
 
   private val LOG = Path.explode("log")
@@ -529,13 +560,14 @@
 
   private val SESSION_PARENT_PATH = "\fSession.parent_path = "
 
+
   sealed case class Log_Info(stats: List[Properties.T], timing: Properties.T)
 
   def parse_log(text: String): Log_Info =
   {
     val lines = split_lines(text)
-    val stats = Properties.parse_lines("\fML_statistics = ", lines)
-    val timing = Properties.find_parse_line("\fTiming = ", lines) getOrElse Nil
+    val stats = Props.parse_lines("\fML_statistics = ", lines)
+    val timing = Props.find_parse_line("\fTiming = ", lines) getOrElse Nil
     Log_Info(stats, timing)
   }