src/HOL/Analysis/Brouwer_Fixpoint.thy
author haftmann
Thu, 19 Jun 2025 17:15:40 +0200
changeset 82734 89347c0cc6a3
parent 82323 b022c013b04b
permissions -rw-r--r--
treat map_filter similar to list_all, list_ex, list_ex1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
53674
7ac7b2eaa5e6 tuned proofs;
wenzelm
parents: 53252
diff changeset
     1
(*  Author:     John Harrison
63305
3b6975875633 Urysohn's lemma, Dugundji extension theorem and many other proofs
paulson <lp15@cam.ac.uk>
parents: 63301
diff changeset
     2
    Author:     Robert Himmelmann, TU Muenchen (Translation from HOL light) and LCP
53674
7ac7b2eaa5e6 tuned proofs;
wenzelm
parents: 53252
diff changeset
     3
*)
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
     4
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
     5
(* At the moment this is just Brouwer's fixpoint theorem. The proof is from  *)
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
     6
(* Kuhn: "some combinatorial lemmas in topology", IBM J. v4. (1960) p. 518   *)
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
     7
(* See "http://www.research.ibm.com/journal/rd/045/ibmrd0405K.pdf".          *)
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
     8
(*                                                                           *)
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
     9
(* The script below is quite messy, but at least we avoid formalizing any    *)
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
    10
(* topological machinery; we don't even use barycentric subdivision; this is *)
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
    11
(* the big advantage of Kuhn's proof over the usual Sperner's lemma one.     *)
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
    12
(*                                                                           *)
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
    13
(*              (c) Copyright, John Harrison 1998-2008                       *)
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
    14
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    15
section \<open>Brouwer's Fixed Point Theorem\<close>
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
    16
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
    17
theory Brouwer_Fixpoint
70643
93a7a85de312 Removal of the redundant ancestor Continuous_Extension
paulson <lp15@cam.ac.uk>
parents: 70642
diff changeset
    18
  imports Homeomorphism Derivative
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
    19
begin
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
    20
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    21
subsection \<open>Retractions\<close>
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    22
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    23
lemma retract_of_contractible:
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    24
  assumes "contractible T" "S retract_of T"
78457
e2a5c4117ff0 tidying a few proofs a bit more
paulson <lp15@cam.ac.uk>
parents: 78248
diff changeset
    25
  shows "contractible S"
e2a5c4117ff0 tidying a few proofs a bit more
paulson <lp15@cam.ac.uk>
parents: 78248
diff changeset
    26
  using assms
e2a5c4117ff0 tidying a few proofs a bit more
paulson <lp15@cam.ac.uk>
parents: 78248
diff changeset
    27
  apply (clarsimp simp add: retract_of_def contractible_def retraction_def homotopic_with image_subset_iff_funcset)
e2a5c4117ff0 tidying a few proofs a bit more
paulson <lp15@cam.ac.uk>
parents: 78248
diff changeset
    28
  apply (rule_tac x="r a" in exI)
e2a5c4117ff0 tidying a few proofs a bit more
paulson <lp15@cam.ac.uk>
parents: 78248
diff changeset
    29
  apply (rule_tac x="r \<circ> h" in exI)
e2a5c4117ff0 tidying a few proofs a bit more
paulson <lp15@cam.ac.uk>
parents: 78248
diff changeset
    30
  apply (intro conjI continuous_intros continuous_on_compose)
e2a5c4117ff0 tidying a few proofs a bit more
paulson <lp15@cam.ac.uk>
parents: 78248
diff changeset
    31
      apply (erule continuous_on_subset | force)+
e2a5c4117ff0 tidying a few proofs a bit more
paulson <lp15@cam.ac.uk>
parents: 78248
diff changeset
    32
  done
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    33
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    34
lemma retract_of_path_connected:
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    35
    "\<lbrakk>path_connected T; S retract_of T\<rbrakk> \<Longrightarrow> path_connected S"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    36
  by (metis path_connected_continuous_image retract_of_def retraction)
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    37
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    38
lemma retract_of_simply_connected:
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
    39
  assumes T: "simply_connected T" and "S retract_of T"
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
    40
  shows "simply_connected S"
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
    41
proof -
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
    42
  obtain r where r: "retraction T S r"
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
    43
    using assms by (metis retract_of_def) 
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
    44
  have "S \<subseteq> T"
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
    45
    by (meson \<open>retraction T S r\<close> retraction)
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
    46
  then have "(\<lambda>a. a) \<in> S \<rightarrow> T"
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
    47
    by blast
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
    48
  then show ?thesis
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
    49
    using simply_connected_retraction_gen [OF T]
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
    50
    by (metis (no_types) r retraction retraction_refl)
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
    51
qed
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    52
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    53
lemma retract_of_homotopically_trivial:
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    54
  assumes ts: "T retract_of S"
78457
e2a5c4117ff0 tidying a few proofs a bit more
paulson <lp15@cam.ac.uk>
parents: 78248
diff changeset
    55
      and hom: "\<And>f g. \<lbrakk>continuous_on U f; f \<in> U \<rightarrow> S;
e2a5c4117ff0 tidying a few proofs a bit more
paulson <lp15@cam.ac.uk>
parents: 78248
diff changeset
    56
                       continuous_on U g; g \<in> U \<rightarrow> S\<rbrakk>
69986
f2d327275065 generalised homotopic_with to topologies; homotopic_with_canon is the old version
paulson <lp15@cam.ac.uk>
parents: 69945
diff changeset
    57
                       \<Longrightarrow> homotopic_with_canon (\<lambda>x. True) U S f g"
78457
e2a5c4117ff0 tidying a few proofs a bit more
paulson <lp15@cam.ac.uk>
parents: 78248
diff changeset
    58
      and "continuous_on U f" "f \<in> U \<rightarrow> T"
e2a5c4117ff0 tidying a few proofs a bit more
paulson <lp15@cam.ac.uk>
parents: 78248
diff changeset
    59
      and "continuous_on U g" "g \<in> U \<rightarrow> T"
69986
f2d327275065 generalised homotopic_with to topologies; homotopic_with_canon is the old version
paulson <lp15@cam.ac.uk>
parents: 69945
diff changeset
    60
    shows "homotopic_with_canon (\<lambda>x. True) U T f g"
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    61
proof -
78457
e2a5c4117ff0 tidying a few proofs a bit more
paulson <lp15@cam.ac.uk>
parents: 78248
diff changeset
    62
  obtain r where "r \<in> S \<rightarrow> S" "continuous_on S r" "\<forall>x\<in>S. r (r x) = r x" "T = r ` S"
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    63
    using ts by (auto simp: retract_of_def retraction)
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    64
  then obtain k where "Retracts S r T k"
78457
e2a5c4117ff0 tidying a few proofs a bit more
paulson <lp15@cam.ac.uk>
parents: 78248
diff changeset
    65
    unfolding Retracts_def using continuous_on_id by blast
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    66
  then show ?thesis
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
    67
    by (rule Retracts.homotopically_trivial_retraction_gen) (use assms hom in force)+
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    68
qed
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    69
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    70
lemma retract_of_homotopically_trivial_null:
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    71
  assumes ts: "T retract_of S"
78457
e2a5c4117ff0 tidying a few proofs a bit more
paulson <lp15@cam.ac.uk>
parents: 78248
diff changeset
    72
      and hom: "\<And>f. \<lbrakk>continuous_on U f; f \<in> U \<rightarrow> S\<rbrakk>
69986
f2d327275065 generalised homotopic_with to topologies; homotopic_with_canon is the old version
paulson <lp15@cam.ac.uk>
parents: 69945
diff changeset
    73
                     \<Longrightarrow> \<exists>c. homotopic_with_canon (\<lambda>x. True) U S f (\<lambda>x. c)"
78457
e2a5c4117ff0 tidying a few proofs a bit more
paulson <lp15@cam.ac.uk>
parents: 78248
diff changeset
    74
      and "continuous_on U f" "f \<in> U \<rightarrow> T"
69986
f2d327275065 generalised homotopic_with to topologies; homotopic_with_canon is the old version
paulson <lp15@cam.ac.uk>
parents: 69945
diff changeset
    75
  obtains c where "homotopic_with_canon (\<lambda>x. True) U T f (\<lambda>x. c)"
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    76
proof -
78457
e2a5c4117ff0 tidying a few proofs a bit more
paulson <lp15@cam.ac.uk>
parents: 78248
diff changeset
    77
  obtain r where "r \<in> S \<rightarrow> S" "continuous_on S r" "\<forall>x\<in>S. r (r x) = r x" "T = r ` S"
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    78
    using ts by (auto simp: retract_of_def retraction)
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    79
  then obtain k where "Retracts S r T k"
78457
e2a5c4117ff0 tidying a few proofs a bit more
paulson <lp15@cam.ac.uk>
parents: 78248
diff changeset
    80
    unfolding Retracts_def by fastforce
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    81
  then show ?thesis
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
    82
  proof (rule Retracts.homotopically_trivial_retraction_null_gen)
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
    83
    show "\<And>f. \<lbrakk>continuous_on U f; f \<in> U \<rightarrow> S\<rbrakk>
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
    84
         \<Longrightarrow> \<exists>c. homotopic_with_canon (\<lambda>a. True) U S f (\<lambda>x. c)"
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
    85
      using hom by blast
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
    86
  qed (use assms that in auto)
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    87
qed
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    88
69945
35ba13ac6e5c New abstract topological material
paulson <lp15@cam.ac.uk>
parents: 69922
diff changeset
    89
lemma retraction_openin_vimage_iff:
69922
4a9167f377b0 new material about topology, etc.; also fixes for yesterday's
paulson <lp15@cam.ac.uk>
parents: 69738
diff changeset
    90
  "openin (top_of_set S) (S \<inter> r -` U) \<longleftrightarrow> openin (top_of_set T) U"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
    91
  if "retraction S T r" and "U \<subseteq> T"
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
    92
  by (simp add: retraction_openin_vimage_iff that)
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    93
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    94
lemma retract_of_locally_compact:
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    95
    fixes S :: "'a :: {heine_borel,real_normed_vector} set"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    96
    shows  "\<lbrakk> locally compact S; T retract_of S\<rbrakk> \<Longrightarrow> locally compact T"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    97
  by (metis locally_compact_closedin closedin_retract)
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    98
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
    99
lemma homotopic_into_retract:
82323
b022c013b04b Function space instead of image closure
paulson <lp15@cam.ac.uk>
parents: 80095
diff changeset
   100
  assumes fg: "f \<in> S \<rightarrow> T" "g \<in> S \<rightarrow> T"
b022c013b04b Function space instead of image closure
paulson <lp15@cam.ac.uk>
parents: 80095
diff changeset
   101
  assumes "T retract_of U"
b022c013b04b Function space instead of image closure
paulson <lp15@cam.ac.uk>
parents: 80095
diff changeset
   102
  assumes "homotopic_with_canon (\<lambda>x. True) S U f g"
b022c013b04b Function space instead of image closure
paulson <lp15@cam.ac.uk>
parents: 80095
diff changeset
   103
  shows "homotopic_with_canon (\<lambda>x. True) S T f g"
b022c013b04b Function space instead of image closure
paulson <lp15@cam.ac.uk>
parents: 80095
diff changeset
   104
proof -
b022c013b04b Function space instead of image closure
paulson <lp15@cam.ac.uk>
parents: 80095
diff changeset
   105
  obtain h r where r: "retraction U T r"
b022c013b04b Function space instead of image closure
paulson <lp15@cam.ac.uk>
parents: 80095
diff changeset
   106
     "continuous_on ({0..1::real} \<times> S) h"
b022c013b04b Function space instead of image closure
paulson <lp15@cam.ac.uk>
parents: 80095
diff changeset
   107
      and h: "h \<in> {0..1} \<times> S \<rightarrow> U \<and> (\<forall>x. h (0, x) = f x) \<and> (\<forall>x. h (1, x) = g x)"
b022c013b04b Function space instead of image closure
paulson <lp15@cam.ac.uk>
parents: 80095
diff changeset
   108
    using assms by (auto simp: homotopic_with_def retract_of_def)
b022c013b04b Function space instead of image closure
paulson <lp15@cam.ac.uk>
parents: 80095
diff changeset
   109
  then have "continuous_on ({0..1} \<times> S) (r \<circ> h)"
b022c013b04b Function space instead of image closure
paulson <lp15@cam.ac.uk>
parents: 80095
diff changeset
   110
    by (metis continuous_on_compose continuous_on_subset funcset_image
b022c013b04b Function space instead of image closure
paulson <lp15@cam.ac.uk>
parents: 80095
diff changeset
   111
        retraction_def)
b022c013b04b Function space instead of image closure
paulson <lp15@cam.ac.uk>
parents: 80095
diff changeset
   112
  then show ?thesis
b022c013b04b Function space instead of image closure
paulson <lp15@cam.ac.uk>
parents: 80095
diff changeset
   113
    using r fg h
b022c013b04b Function space instead of image closure
paulson <lp15@cam.ac.uk>
parents: 80095
diff changeset
   114
    apply (simp add: retraction homotopic_with Pi_iff)
b022c013b04b Function space instead of image closure
paulson <lp15@cam.ac.uk>
parents: 80095
diff changeset
   115
    by (smt (verit, best) imageI)
b022c013b04b Function space instead of image closure
paulson <lp15@cam.ac.uk>
parents: 80095
diff changeset
   116
qed
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   117
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   118
lemma retract_of_locally_connected:
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   119
  assumes "locally connected T" "S retract_of T"
69661
a03a63b81f44 tuned proofs
haftmann
parents: 69620
diff changeset
   120
  shows "locally connected S"
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   121
  using assms
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
   122
  by (metis retraction_openin_vimage_iff idempotent_imp_retraction locally_connected_quotient_image retract_ofE)
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   123
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   124
lemma retract_of_locally_path_connected:
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   125
  assumes "locally path_connected T" "S retract_of T"
69661
a03a63b81f44 tuned proofs
haftmann
parents: 69620
diff changeset
   126
  shows "locally path_connected S"
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   127
  using assms
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
   128
  by (metis retraction_openin_vimage_iff idempotent_imp_retraction locally_path_connected_quotient_image retract_ofE)
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   129
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   130
text \<open>A few simple lemmas about deformation retracts\<close>
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   131
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   132
lemma deformation_retract_imp_homotopy_eqv:
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   133
  fixes S :: "'a::euclidean_space set"
69986
f2d327275065 generalised homotopic_with to topologies; homotopic_with_canon is the old version
paulson <lp15@cam.ac.uk>
parents: 69945
diff changeset
   134
  assumes "homotopic_with_canon (\<lambda>x. True) S S id r" and r: "retraction S T r"
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   135
  shows "S homotopy_eqv T"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   136
proof -
69986
f2d327275065 generalised homotopic_with to topologies; homotopic_with_canon is the old version
paulson <lp15@cam.ac.uk>
parents: 69945
diff changeset
   137
  have "homotopic_with_canon (\<lambda>x. True) S S (id \<circ> r) id"
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   138
    by (simp add: assms(1) homotopic_with_symD)
69986
f2d327275065 generalised homotopic_with to topologies; homotopic_with_canon is the old version
paulson <lp15@cam.ac.uk>
parents: 69945
diff changeset
   139
  moreover have "homotopic_with_canon (\<lambda>x. True) T T (r \<circ> id) id"
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   140
    using r unfolding retraction_def
69986
f2d327275065 generalised homotopic_with to topologies; homotopic_with_canon is the old version
paulson <lp15@cam.ac.uk>
parents: 69945
diff changeset
   141
    by (metis eq_id_iff homotopic_with_id2 topspace_euclidean_subtopology)
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   142
  ultimately
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   143
  show ?thesis
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
   144
    unfolding homotopy_equivalent_space_def
82323
b022c013b04b Function space instead of image closure
paulson <lp15@cam.ac.uk>
parents: 80095
diff changeset
   145
    by (meson continuous_map_from_subtopology_mono continuous_map_id
b022c013b04b Function space instead of image closure
paulson <lp15@cam.ac.uk>
parents: 80095
diff changeset
   146
        continuous_map_subtopology_eu r retraction_def)
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   147
qed
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   148
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   149
lemma deformation_retract:
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   150
  fixes S :: "'a::euclidean_space set"
69986
f2d327275065 generalised homotopic_with to topologies; homotopic_with_canon is the old version
paulson <lp15@cam.ac.uk>
parents: 69945
diff changeset
   151
    shows "(\<exists>r. homotopic_with_canon (\<lambda>x. True) S S id r \<and> retraction S T r) \<longleftrightarrow>
78457
e2a5c4117ff0 tidying a few proofs a bit more
paulson <lp15@cam.ac.uk>
parents: 78248
diff changeset
   152
           T retract_of S \<and> (\<exists>f. homotopic_with_canon (\<lambda>x. True) S S id f \<and> f \<in> S \<rightarrow> T)"
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   153
    (is "?lhs = ?rhs")
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   154
proof
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   155
  assume ?lhs
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   156
  then show ?rhs
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   157
    by (auto simp: retract_of_def retraction_def)
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   158
next
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
   159
  assume R: ?rhs
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
   160
  have "\<And>r f. \<lbrakk>T \<subseteq> S; continuous_on S r; homotopic_with_canon (\<lambda>x. True) S S id f;
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
   161
            f \<in> S \<rightarrow> T; r \<in> S \<rightarrow> T; \<forall>x\<in>T. r x = x\<rbrakk>
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
   162
           \<Longrightarrow> homotopic_with_canon (\<lambda>x. True) S S f r"
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
   163
    apply (rule_tac f = "r \<circ> f" and g="r \<circ> id" in homotopic_with_eq)
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
   164
       apply (rule_tac Y=S in homotopic_with_compose_continuous_left)
78457
e2a5c4117ff0 tidying a few proofs a bit more
paulson <lp15@cam.ac.uk>
parents: 78248
diff changeset
   165
         apply (auto simp: homotopic_with_sym Pi_iff)
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   166
    done
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
   167
  with R homotopic_with_trans show ?lhs
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
   168
    unfolding retract_of_def retraction_def by blast
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   169
qed
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   170
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   171
lemma deformation_retract_of_contractible_sing:
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   172
  fixes S :: "'a::euclidean_space set"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   173
  assumes "contractible S" "a \<in> S"
69986
f2d327275065 generalised homotopic_with to topologies; homotopic_with_canon is the old version
paulson <lp15@cam.ac.uk>
parents: 69945
diff changeset
   174
  obtains r where "homotopic_with_canon (\<lambda>x. True) S S id r" "retraction S {a} r"
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   175
proof -
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   176
  have "{a} retract_of S"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   177
    by (simp add: \<open>a \<in> S\<close>)
69986
f2d327275065 generalised homotopic_with to topologies; homotopic_with_canon is the old version
paulson <lp15@cam.ac.uk>
parents: 69945
diff changeset
   178
  moreover have "homotopic_with_canon (\<lambda>x. True) S S id (\<lambda>x. a)"
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   179
      using assms
69738
c558fef62915 moved retracts
nipkow
parents: 69712
diff changeset
   180
      by (auto simp: contractible_def homotopic_into_contractible image_subset_iff)
78457
e2a5c4117ff0 tidying a few proofs a bit more
paulson <lp15@cam.ac.uk>
parents: 78248
diff changeset
   181
  moreover have "(\<lambda>x. a) \<in> S \<rightarrow> {a}"
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   182
    by (simp add: image_subsetI)
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   183
  ultimately show ?thesis
78457
e2a5c4117ff0 tidying a few proofs a bit more
paulson <lp15@cam.ac.uk>
parents: 78248
diff changeset
   184
    by (metis that deformation_retract)
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   185
qed
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   186
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   187
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   188
lemma continuous_on_compact_surface_projection_aux:
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   189
  fixes S :: "'a::t2_space set"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   190
  assumes "compact S" "S \<subseteq> T" "image q T \<subseteq> S"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   191
      and contp: "continuous_on T p"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   192
      and "\<And>x. x \<in> S \<Longrightarrow> q x = x"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   193
      and [simp]: "\<And>x. x \<in> T \<Longrightarrow> q(p x) = q x"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   194
      and "\<And>x. x \<in> T \<Longrightarrow> p(q x) = p x"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   195
    shows "continuous_on T q"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   196
proof -
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   197
  have *: "image p T = image p S"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   198
    using assms by auto (metis imageI subset_iff)
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   199
  have contp': "continuous_on S p"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   200
    by (rule continuous_on_subset [OF contp \<open>S \<subseteq> T\<close>])
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   201
  have "continuous_on (p ` T) q"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   202
    by (simp add: "*" assms(1) assms(2) assms(5) continuous_on_inv contp' rev_subsetD)
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   203
  then have "continuous_on T (q \<circ> p)"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   204
    by (rule continuous_on_compose [OF contp])
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   205
  then show ?thesis
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   206
    by (rule continuous_on_eq [of _ "q \<circ> p"]) (simp add: o_def)
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   207
qed
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   208
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   209
lemma continuous_on_compact_surface_projection:
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   210
  fixes S :: "'a::real_normed_vector set"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   211
  assumes "compact S"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   212
      and S: "S \<subseteq> V - {0}" and "cone V"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   213
      and iff: "\<And>x k. x \<in> V - {0} \<Longrightarrow> 0 < k \<and> (k *\<^sub>R x) \<in> S \<longleftrightarrow> d x = k"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   214
  shows "continuous_on (V - {0}) (\<lambda>x. d x *\<^sub>R x)"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   215
proof (rule continuous_on_compact_surface_projection_aux [OF \<open>compact S\<close> S])
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   216
  show "(\<lambda>x. d x *\<^sub>R x) ` (V - {0}) \<subseteq> S"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   217
    using iff by auto
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   218
  show "continuous_on (V - {0}) (\<lambda>x. inverse(norm x) *\<^sub>R x)"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   219
    by (intro continuous_intros) force
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   220
  show "\<And>x. x \<in> S \<Longrightarrow> d x *\<^sub>R x = x"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   221
    by (metis S zero_less_one local.iff scaleR_one subset_eq)
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   222
  show "d (x /\<^sub>R norm x) *\<^sub>R (x /\<^sub>R norm x) = d x *\<^sub>R x" if "x \<in> V - {0}" for x
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   223
    using iff [of "inverse(norm x) *\<^sub>R x" "norm x * d x", symmetric] iff that \<open>cone V\<close>
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   224
    by (simp add: field_simps cone_def zero_less_mult_iff)
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   225
  show "d x *\<^sub>R x /\<^sub>R norm (d x *\<^sub>R x) = x /\<^sub>R norm x" if "x \<in> V - {0}" for x
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   226
  proof -
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   227
    have "0 < d x"
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   228
      using local.iff that by blast
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   229
    then show ?thesis
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   230
      by simp
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   231
  qed
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   232
qed
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   233
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   234
subsection \<open>Kuhn Simplices\<close>
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   235
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   236
lemma bij_betw_singleton_eq:
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   237
  assumes f: "bij_betw f A B" and g: "bij_betw g A B" and a: "a \<in> A"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   238
  assumes eq: "(\<And>x. x \<in> A \<Longrightarrow> x \<noteq> a \<Longrightarrow> f x = g x)"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   239
  shows "f a = g a"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   240
proof -
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   241
  have "f ` (A - {a}) = g ` (A - {a})"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   242
    by (intro image_cong) (simp_all add: eq)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   243
  then have "B - {f a} = B - {g a}"
69286
nipkow
parents: 68621
diff changeset
   244
    using f g a  by (auto simp: bij_betw_def inj_on_image_set_diff set_eq_iff)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   245
  moreover have "f a \<in> B" "g a \<in> B"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   246
    using f g a by (auto simp: bij_betw_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   247
  ultimately show ?thesis
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   248
    by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   249
qed
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   250
63365
5340fb6633d0 more theorems
haftmann
parents: 63332
diff changeset
   251
lemmas swap_apply1 = swap_apply(1)
5340fb6633d0 more theorems
haftmann
parents: 63332
diff changeset
   252
lemmas swap_apply2 = swap_apply(2)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   253
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   254
lemma pointwise_minimal_pointwise_maximal:
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   255
  fixes s :: "(nat \<Rightarrow> nat) set"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   256
  assumes "finite s"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   257
    and "s \<noteq> {}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   258
    and "\<forall>x\<in>s. \<forall>y\<in>s. x \<le> y \<or> y \<le> x"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   259
  shows "\<exists>a\<in>s. \<forall>x\<in>s. a \<le> x"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   260
    and "\<exists>a\<in>s. \<forall>x\<in>s. x \<le> a"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   261
  using assms
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   262
proof (induct s rule: finite_ne_induct)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   263
  case (insert b s)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   264
  assume *: "\<forall>x\<in>insert b s. \<forall>y\<in>insert b s. x \<le> y \<or> y \<le> x"
63540
f8652d0534fa tuned proofs -- avoid unstructured calculation;
wenzelm
parents: 63497
diff changeset
   265
  then obtain u l where "l \<in> s" "\<forall>b\<in>s. l \<le> b" "u \<in> s" "\<forall>b\<in>s. b \<le> u"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   266
    using insert by auto
63540
f8652d0534fa tuned proofs -- avoid unstructured calculation;
wenzelm
parents: 63497
diff changeset
   267
  with * show "\<exists>a\<in>insert b s. \<forall>x\<in>insert b s. a \<le> x" "\<exists>a\<in>insert b s. \<forall>x\<in>insert b s. x \<le> a"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
   268
    by (metis insert_iff order.trans)+
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   269
qed auto
50526
899c9c4e4a4c Remove the indexed basis from the definition of euclidean spaces and only use the set of Basis vectors
hoelzl
parents: 50514
diff changeset
   270
49555
fb2128470345 tuned proofs;
wenzelm
parents: 49374
diff changeset
   271
lemma kuhn_labelling_lemma:
50526
899c9c4e4a4c Remove the indexed basis from the definition of euclidean spaces and only use the set of Basis vectors
hoelzl
parents: 50514
diff changeset
   272
  fixes P Q :: "'a::euclidean_space \<Rightarrow> bool"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   273
  assumes "\<forall>x. P x \<longrightarrow> P (f x)"
50526
899c9c4e4a4c Remove the indexed basis from the definition of euclidean spaces and only use the set of Basis vectors
hoelzl
parents: 50514
diff changeset
   274
    and "\<forall>x. P x \<longrightarrow> (\<forall>i\<in>Basis. Q i \<longrightarrow> 0 \<le> x\<bullet>i \<and> x\<bullet>i \<le> 1)"
899c9c4e4a4c Remove the indexed basis from the definition of euclidean spaces and only use the set of Basis vectors
hoelzl
parents: 50514
diff changeset
   275
  shows "\<exists>l. (\<forall>x.\<forall>i\<in>Basis. l x i \<le> (1::nat)) \<and>
899c9c4e4a4c Remove the indexed basis from the definition of euclidean spaces and only use the set of Basis vectors
hoelzl
parents: 50514
diff changeset
   276
             (\<forall>x.\<forall>i\<in>Basis. P x \<and> Q i \<and> (x\<bullet>i = 0) \<longrightarrow> (l x i = 0)) \<and>
899c9c4e4a4c Remove the indexed basis from the definition of euclidean spaces and only use the set of Basis vectors
hoelzl
parents: 50514
diff changeset
   277
             (\<forall>x.\<forall>i\<in>Basis. P x \<and> Q i \<and> (x\<bullet>i = 1) \<longrightarrow> (l x i = 1)) \<and>
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   278
             (\<forall>x.\<forall>i\<in>Basis. P x \<and> Q i \<and> (l x i = 0) \<longrightarrow> x\<bullet>i \<le> f x\<bullet>i) \<and>
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   279
             (\<forall>x.\<forall>i\<in>Basis. P x \<and> Q i \<and> (l x i = 1) \<longrightarrow> f x\<bullet>i \<le> x\<bullet>i)"
49374
b08c6312782b tuned proofs;
wenzelm
parents: 44890
diff changeset
   280
proof -
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   281
  { fix x i
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   282
    let ?R = "\<lambda>y. (P x \<and> Q i \<and> x \<bullet> i = 0 \<longrightarrow> y = (0::nat)) \<and>
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   283
        (P x \<and> Q i \<and> x \<bullet> i = 1 \<longrightarrow> y = 1) \<and>
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   284
        (P x \<and> Q i \<and> y = 0 \<longrightarrow> x \<bullet> i \<le> f x \<bullet> i) \<and>
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   285
        (P x \<and> Q i \<and> y = 1 \<longrightarrow> f x \<bullet> i \<le> x \<bullet> i)"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   286
    { assume "P x" "Q i" "i \<in> Basis" with assms have "0 \<le> f x \<bullet> i \<and> f x \<bullet> i \<le> 1" by auto }
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   287
    then have "i \<in> Basis \<Longrightarrow> ?R 0 \<or> ?R 1" by auto }
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   288
  then show ?thesis
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   289
    unfolding all_conj_distrib[symmetric] Ball_def (* FIXME: shouldn't this work by metis? *)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   290
    by (subst choice_iff[symmetric])+ blast
49374
b08c6312782b tuned proofs;
wenzelm
parents: 44890
diff changeset
   291
qed
b08c6312782b tuned proofs;
wenzelm
parents: 44890
diff changeset
   292
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
   293
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   294
subsubsection \<open>The key "counting" observation, somewhat abstracted\<close>
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
   295
53252
4766fbe322b5 tuned proofs;
wenzelm
parents: 53248
diff changeset
   296
lemma kuhn_counting_lemma:
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   297
  fixes bnd compo compo' face S F
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   298
  defines "nF s == card {f\<in>F. face f s \<and> compo' f}"
67443
3abf6a722518 standardized towards new-style formal comments: isabelle update_comments;
wenzelm
parents: 67399
diff changeset
   299
  assumes [simp, intro]: "finite F" \<comment> \<open>faces\<close> and [simp, intro]: "finite S" \<comment> \<open>simplices\<close>
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   300
    and "\<And>f. f \<in> F \<Longrightarrow> bnd f \<Longrightarrow> card {s\<in>S. face f s} = 1"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   301
    and "\<And>f. f \<in> F \<Longrightarrow> \<not> bnd f \<Longrightarrow> card {s\<in>S. face f s} = 2"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   302
    and "\<And>s. s \<in> S \<Longrightarrow> compo s \<Longrightarrow> nF s = 1"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   303
    and "\<And>s. s \<in> S \<Longrightarrow> \<not> compo s \<Longrightarrow> nF s = 0 \<or> nF s = 2"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   304
    and "odd (card {f\<in>F. compo' f \<and> bnd f})"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   305
  shows "odd (card {s\<in>S. compo s})"
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
   306
proof -
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   307
  have "(\<Sum>s | s \<in> S \<and> \<not> compo s. nF s) + (\<Sum>s | s \<in> S \<and> compo s. nF s) = (\<Sum>s\<in>S. nF s)"
64267
b9a1486e79be setsum -> sum
nipkow
parents: 64122
diff changeset
   308
    by (subst sum.union_disjoint[symmetric]) (auto intro!: sum.cong)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   309
  also have "\<dots> = (\<Sum>s\<in>S. card {f \<in> {f\<in>F. compo' f \<and> bnd f}. face f s}) +
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   310
                  (\<Sum>s\<in>S. card {f \<in> {f\<in>F. compo' f \<and> \<not> bnd f}. face f s})"
64267
b9a1486e79be setsum -> sum
nipkow
parents: 64122
diff changeset
   311
    unfolding sum.distrib[symmetric]
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   312
    by (subst card_Un_disjoint[symmetric])
64267
b9a1486e79be setsum -> sum
nipkow
parents: 64122
diff changeset
   313
       (auto simp: nF_def intro!: sum.cong arg_cong[where f=card])
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   314
  also have "\<dots> = 1 * card {f\<in>F. compo' f \<and> bnd f} + 2 * card {f\<in>F. compo' f \<and> \<not> bnd f}"
67399
eab6ce8368fa ran isabelle update_op on all sources
nipkow
parents: 66939
diff changeset
   315
    using assms(4,5) by (fastforce intro!: arg_cong2[where f="(+)"] sum_multicount)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   316
  finally have "odd ((\<Sum>s | s \<in> S \<and> \<not> compo s. nF s) + card {s\<in>S. compo s})"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   317
    using assms(6,8) by simp
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   318
  moreover have "(\<Sum>s | s \<in> S \<and> \<not> compo s. nF s) =
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   319
    (\<Sum>s | s \<in> S \<and> \<not> compo s \<and> nF s = 0. nF s) + (\<Sum>s | s \<in> S \<and> \<not> compo s \<and> nF s = 2. nF s)"
64267
b9a1486e79be setsum -> sum
nipkow
parents: 64122
diff changeset
   320
    using assms(7) by (subst sum.union_disjoint[symmetric]) (fastforce intro!: sum.cong)+
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
   321
  ultimately show ?thesis
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
   322
    by auto
53186
0f4d9df1eaec tuned proofs;
wenzelm
parents: 53185
diff changeset
   323
qed
0f4d9df1eaec tuned proofs;
wenzelm
parents: 53185
diff changeset
   324
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
   325
subsubsection \<open>The odd/even result for faces of complete vertices, generalized\<close>
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   326
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   327
lemma kuhn_complete_lemma:
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   328
  assumes [simp]: "finite simplices"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   329
    and face: "\<And>f s. face f s \<longleftrightarrow> (\<exists>a\<in>s. f = s - {a})"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   330
    and card_s[simp]:  "\<And>s. s \<in> simplices \<Longrightarrow> card s = n + 2"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   331
    and rl_bd: "\<And>s. s \<in> simplices \<Longrightarrow> rl ` s \<subseteq> {..Suc n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   332
    and bnd: "\<And>f s. s \<in> simplices \<Longrightarrow> face f s \<Longrightarrow> bnd f \<Longrightarrow> card {s\<in>simplices. face f s} = 1"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   333
    and nbnd: "\<And>f s. s \<in> simplices \<Longrightarrow> face f s \<Longrightarrow> \<not> bnd f \<Longrightarrow> card {s\<in>simplices. face f s} = 2"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   334
    and odd_card: "odd (card {f. (\<exists>s\<in>simplices. face f s) \<and> rl ` f = {..n} \<and> bnd f})"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   335
  shows "odd (card {s\<in>simplices. (rl ` s = {..Suc n})})"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   336
proof (rule kuhn_counting_lemma)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   337
  have finite_s[simp]: "\<And>s. s \<in> simplices \<Longrightarrow> finite s"
72302
d7d90ed4c74e fixed some remarkably ugly proofs
paulson <lp15@cam.ac.uk>
parents: 71745
diff changeset
   338
    by (metis add_is_0 zero_neq_numeral card.infinite assms(3))
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   339
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   340
  let ?F = "{f. \<exists>s\<in>simplices. face f s}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   341
  have F_eq: "?F = (\<Union>s\<in>simplices. \<Union>a\<in>s. {s - {a}})"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   342
    by (auto simp: face)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   343
  show "finite ?F"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   344
    using \<open>finite simplices\<close> unfolding F_eq by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   345
60421
92d9557fb78c misc tuning;
wenzelm
parents: 60420
diff changeset
   346
  show "card {s \<in> simplices. face f s} = 1" if "f \<in> ?F" "bnd f" for f
60449
229bad93377e renamed "prems" to "that";
wenzelm
parents: 60421
diff changeset
   347
    using bnd that by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   348
60421
92d9557fb78c misc tuning;
wenzelm
parents: 60420
diff changeset
   349
  show "card {s \<in> simplices. face f s} = 2" if "f \<in> ?F" "\<not> bnd f" for f
60449
229bad93377e renamed "prems" to "that";
wenzelm
parents: 60421
diff changeset
   350
    using nbnd that by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   351
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   352
  show "odd (card {f \<in> {f. \<exists>s\<in>simplices. face f s}. rl ` f = {..n} \<and> bnd f})"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   353
    using odd_card by simp
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   354
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   355
  fix s assume s[simp]: "s \<in> simplices"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   356
  let ?S = "{f \<in> {f. \<exists>s\<in>simplices. face f s}. face f s \<and> rl ` f = {..n}}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   357
  have "?S = (\<lambda>a. s - {a}) ` {a\<in>s. rl ` (s - {a}) = {..n}}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   358
    using s by (fastforce simp: face)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   359
  then have card_S: "card ?S = card {a\<in>s. rl ` (s - {a}) = {..n}}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   360
    by (auto intro!: card_image inj_onI)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   361
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   362
  { assume rl: "rl ` s = {..Suc n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   363
    then have inj_rl: "inj_on rl s"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   364
      by (intro eq_card_imp_inj_on) auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   365
    moreover obtain a where "rl a = Suc n" "a \<in> s"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   366
      by (metis atMost_iff image_iff le_Suc_eq rl)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   367
    ultimately have n: "{..n} = rl ` (s - {a})"
69286
nipkow
parents: 68621
diff changeset
   368
      by (auto simp: inj_on_image_set_diff rl)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   369
    have "{a\<in>s. rl ` (s - {a}) = {..n}} = {a}"
69286
nipkow
parents: 68621
diff changeset
   370
      using inj_rl \<open>a \<in> s\<close> by (auto simp: n inj_on_image_eq_iff[OF inj_rl])
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   371
    then show "card ?S = 1"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   372
      unfolding card_S by simp }
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   373
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   374
  { assume rl: "rl ` s \<noteq> {..Suc n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   375
    show "card ?S = 0 \<or> card ?S = 2"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   376
    proof cases
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   377
      assume *: "{..n} \<subseteq> rl ` s"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   378
      with rl rl_bd[OF s] have rl_s: "rl ` s = {..n}"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
   379
        by (auto simp: atMost_Suc subset_insert_iff split: if_split_asm)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   380
      then have "\<not> inj_on rl s"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   381
        by (intro pigeonhole) simp
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   382
      then obtain a b where ab: "a \<in> s" "b \<in> s" "rl a = rl b" "a \<noteq> b"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   383
        by (auto simp: inj_on_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   384
      then have eq: "rl ` (s - {a}) = rl ` s"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   385
        by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   386
      with ab have inj: "inj_on rl (s - {a})"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
   387
        by (intro eq_card_imp_inj_on) (auto simp: rl_s card_Diff_singleton_if)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   388
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   389
      { fix x assume "x \<in> s" "x \<notin> {a, b}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   390
        then have "rl ` s - {rl x} = rl ` ((s - {a}) - {x})"
69286
nipkow
parents: 68621
diff changeset
   391
          by (auto simp: eq inj_on_image_set_diff[OF inj])
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   392
        also have "\<dots> = rl ` (s - {x})"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   393
          using ab \<open>x \<notin> {a, b}\<close> by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   394
        also assume "\<dots> = rl ` s"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   395
        finally have False
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   396
          using \<open>x\<in>s\<close> by auto }
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   397
      moreover
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   398
      { fix x assume "x \<in> {a, b}" with ab have "x \<in> s \<and> rl ` (s - {x}) = rl ` s"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   399
          by (simp add: set_eq_iff image_iff Bex_def) metis }
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   400
      ultimately have "{a\<in>s. rl ` (s - {a}) = {..n}} = {a, b}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   401
        unfolding rl_s[symmetric] by fastforce
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   402
      with \<open>a \<noteq> b\<close> show "card ?S = 0 \<or> card ?S = 2"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   403
        unfolding card_S by simp
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   404
    next
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   405
      assume "\<not> {..n} \<subseteq> rl ` s"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   406
      then have "\<And>x. rl ` (s - {x}) \<noteq> {..n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   407
        by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   408
      then show "card ?S = 0 \<or> card ?S = 2"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   409
        unfolding card_S by simp
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   410
    qed }
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   411
qed fact
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   412
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   413
locale kuhn_simplex =
78475
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   414
  fixes p n and base upd and S :: "(nat \<Rightarrow> nat) set"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   415
  assumes base: "base \<in> {..< n} \<rightarrow> {..< p}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   416
  assumes base_out: "\<And>i. n \<le> i \<Longrightarrow> base i = p"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   417
  assumes upd: "bij_betw upd {..< n} {..< n}"
78475
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   418
  assumes s_pre: "S = (\<lambda>i j. if j \<in> upd`{..< i} then Suc (base j) else base j) ` {.. n}"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   419
begin
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   420
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   421
definition "enum i j = (if j \<in> upd`{..< i} then Suc (base j) else base j)"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   422
78475
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   423
lemma s_eq: "S = enum ` {.. n}"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   424
  unfolding s_pre enum_def[abs_def] ..
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   425
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   426
lemma upd_space: "i < n \<Longrightarrow> upd i < n"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   427
  using upd by (auto dest!: bij_betwE)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   428
78475
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   429
lemma s_space: "S \<subseteq> {..< n} \<rightarrow> {.. p}"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   430
proof -
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   431
  { fix i assume "i \<le> n" then have "enum i \<in> {..< n} \<rightarrow> {.. p}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   432
    proof (induct i)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   433
      case 0 then show ?case
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   434
        using base by (auto simp: Pi_iff less_imp_le enum_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   435
    next
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   436
      case (Suc i) with base show ?case
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   437
        by (auto simp: Pi_iff Suc_le_eq less_imp_le enum_def intro: upd_space)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   438
    qed }
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   439
  then show ?thesis
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   440
    by (auto simp: s_eq)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   441
qed
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   442
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   443
lemma inj_upd: "inj_on upd {..< n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   444
  using upd by (simp add: bij_betw_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   445
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   446
lemma inj_enum: "inj_on enum {.. n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   447
proof -
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   448
  { fix x y :: nat assume "x \<noteq> y" "x \<le> n" "y \<le> n"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   449
    with upd have "upd ` {..< x} \<noteq> upd ` {..< y}"
61609
77b453bd616f Coercion "real" now has type nat => real only and is no longer overloaded. Type class "real_of" is gone. Many duplicate theorems removed.
paulson <lp15@cam.ac.uk>
parents: 61520
diff changeset
   450
      by (subst inj_on_image_eq_iff[where C="{..< n}"]) (auto simp: bij_betw_def)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   451
    then have "enum x \<noteq> enum y"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
   452
      by (auto simp: enum_def fun_eq_iff) }
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   453
  then show ?thesis
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   454
    by (auto simp: inj_on_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   455
qed
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   456
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   457
lemma enum_0: "enum 0 = base"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   458
  by (simp add: enum_def[abs_def])
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   459
78475
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   460
lemma base_in_s: "base \<in> S"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   461
  unfolding s_eq by (subst enum_0[symmetric]) auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   462
78475
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   463
lemma enum_in: "i \<le> n \<Longrightarrow> enum i \<in> S"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   464
  unfolding s_eq by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   465
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   466
lemma one_step:
78475
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   467
  assumes a: "a \<in> S" "j < n"
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   468
  assumes *: "\<And>a'. a' \<in> S \<Longrightarrow> a' \<noteq> a \<Longrightarrow> a' j = p'"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   469
  shows "a j \<noteq> p'"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   470
proof
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   471
  assume "a j = p'"
78475
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   472
  with * a have "\<And>a'. a' \<in> S \<Longrightarrow> a' j = p'"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   473
    by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   474
  then have "\<And>i. i \<le> n \<Longrightarrow> enum i j = p'"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   475
    unfolding s_eq by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   476
  from this[of 0] this[of n] have "j \<notin> upd ` {..< n}"
62390
842917225d56 more canonical names
nipkow
parents: 62061
diff changeset
   477
    by (auto simp: enum_def fun_eq_iff split: if_split_asm)
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   478
  with upd \<open>j < n\<close> show False
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   479
    by (auto simp: bij_betw_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   480
qed
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   481
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   482
lemma upd_inj: "i < n \<Longrightarrow> j < n \<Longrightarrow> upd i = upd j \<longleftrightarrow> i = j"
61520
8f85bb443d33 Cauchy's integral formula, required lemmas, and a bit of reorganisation
paulson <lp15@cam.ac.uk>
parents: 61284
diff changeset
   483
  using upd by (auto simp: bij_betw_def inj_on_eq_iff)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   484
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   485
lemma upd_surj: "upd ` {..< n} = {..< n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   486
  using upd by (auto simp: bij_betw_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   487
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   488
lemma in_upd_image: "A \<subseteq> {..< n} \<Longrightarrow> i < n \<Longrightarrow> upd i \<in> upd ` A \<longleftrightarrow> i \<in> A"
61520
8f85bb443d33 Cauchy's integral formula, required lemmas, and a bit of reorganisation
paulson <lp15@cam.ac.uk>
parents: 61284
diff changeset
   489
  using inj_on_image_mem_iff[of upd "{..< n}"] upd
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   490
  by (auto simp: bij_betw_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   491
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   492
lemma enum_inj: "i \<le> n \<Longrightarrow> j \<le> n \<Longrightarrow> enum i = enum j \<longleftrightarrow> i = j"
61520
8f85bb443d33 Cauchy's integral formula, required lemmas, and a bit of reorganisation
paulson <lp15@cam.ac.uk>
parents: 61284
diff changeset
   493
  using inj_enum by (auto simp: inj_on_eq_iff)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   494
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   495
lemma in_enum_image: "A \<subseteq> {.. n} \<Longrightarrow> i \<le> n \<Longrightarrow> enum i \<in> enum ` A \<longleftrightarrow> i \<in> A"
61520
8f85bb443d33 Cauchy's integral formula, required lemmas, and a bit of reorganisation
paulson <lp15@cam.ac.uk>
parents: 61284
diff changeset
   496
  using inj_on_image_mem_iff[OF inj_enum] by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   497
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   498
lemma enum_mono: "i \<le> n \<Longrightarrow> j \<le> n \<Longrightarrow> enum i \<le> enum j \<longleftrightarrow> i \<le> j"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   499
  by (auto simp: enum_def le_fun_def in_upd_image Ball_def[symmetric])
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   500
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   501
lemma enum_strict_mono: "i \<le> n \<Longrightarrow> j \<le> n \<Longrightarrow> enum i < enum j \<longleftrightarrow> i < j"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
   502
  using enum_mono[of i j] enum_inj[of i j] by (auto simp: le_less)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   503
78475
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   504
lemma chain: "a \<in> S \<Longrightarrow> b \<in> S \<Longrightarrow> a \<le> b \<or> b \<le> a"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   505
  by (auto simp: s_eq enum_mono)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   506
78475
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   507
lemma less: "a \<in> S \<Longrightarrow> b \<in> S \<Longrightarrow> a i < b i \<Longrightarrow> a < b"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   508
  using chain[of a b] by (auto simp: less_fun_def le_fun_def not_le[symmetric])
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   509
78475
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   510
lemma enum_0_bot: "a \<in> S \<Longrightarrow> a = enum 0 \<longleftrightarrow> (\<forall>a'\<in>S. a \<le> a')"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   511
  unfolding s_eq by (auto simp: enum_mono Ball_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   512
78475
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   513
lemma enum_n_top: "a \<in> S \<Longrightarrow> a = enum n \<longleftrightarrow> (\<forall>a'\<in>S. a' \<le> a)"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   514
  unfolding s_eq by (auto simp: enum_mono Ball_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   515
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   516
lemma enum_Suc: "i < n \<Longrightarrow> enum (Suc i) = (enum i)(upd i := Suc (enum i (upd i)))"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   517
  by (auto simp: fun_eq_iff enum_def upd_inj)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   518
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   519
lemma enum_eq_p: "i \<le> n \<Longrightarrow> n \<le> j \<Longrightarrow> enum i j = p"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   520
  by (induct i) (auto simp: enum_Suc enum_0 base_out upd_space not_less[symmetric])
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   521
78475
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   522
lemma out_eq_p: "a \<in> S \<Longrightarrow> n \<le> j \<Longrightarrow> a j = p"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
   523
  unfolding s_eq by (auto simp: enum_eq_p)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   524
78475
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   525
lemma s_le_p: "a \<in> S \<Longrightarrow> a j \<le> p"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   526
  using out_eq_p[of a j] s_space by (cases "j < n") auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   527
78475
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   528
lemma le_Suc_base: "a \<in> S \<Longrightarrow> a j \<le> Suc (base j)"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   529
  unfolding s_eq by (auto simp: enum_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   530
78475
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   531
lemma base_le: "a \<in> S \<Longrightarrow> base j \<le> a j"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   532
  unfolding s_eq by (auto simp: enum_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   533
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   534
lemma enum_le_p: "i \<le> n \<Longrightarrow> j < n \<Longrightarrow> enum i j \<le> p"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   535
  using enum_in[of i] s_space by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   536
78475
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   537
lemma enum_less: "a \<in> S \<Longrightarrow> i < n \<Longrightarrow> enum i < a \<longleftrightarrow> enum (Suc i) \<le> a"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   538
  unfolding s_eq by (auto simp: enum_strict_mono enum_mono)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   539
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   540
lemma ksimplex_0:
78475
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   541
  "n = 0 \<Longrightarrow> S = {(\<lambda>x. p)}"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   542
  using s_eq enum_def base_out by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   543
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   544
lemma replace_0:
78475
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   545
  assumes "j < n" "a \<in> S" and p: "\<forall>x\<in>S - {a}. x j = 0" and "x \<in> S"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   546
  shows "x \<le> a"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   547
proof cases
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   548
  assume "x \<noteq> a"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   549
  have "a j \<noteq> 0"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   550
    using assms by (intro one_step[where a=a]) auto
78475
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   551
  with less[OF \<open>x\<in>S\<close> \<open>a\<in>S\<close>, of j] p[rule_format, of x] \<open>x \<in> S\<close> \<open>x \<noteq> a\<close>
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   552
  show ?thesis
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   553
    by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   554
qed simp
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   555
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   556
lemma replace_1:
78475
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   557
  assumes "j < n" "a \<in> S" and p: "\<forall>x\<in>S - {a}. x j = p" and "x \<in> S"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   558
  shows "a \<le> x"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   559
proof cases
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   560
  assume "x \<noteq> a"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   561
  have "a j \<noteq> p"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   562
    using assms by (intro one_step[where a=a]) auto
78475
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   563
  with enum_le_p[of _ j] \<open>j < n\<close> \<open>a\<in>S\<close>
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   564
  have "a j < p"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   565
    by (auto simp: less_le s_eq)
78475
a5f6d2fc1b1f More cosmetic changes
paulson <lp15@cam.ac.uk>
parents: 78457
diff changeset
   566
  with less[OF \<open>a\<in>S\<close> \<open>x\<in>S\<close>, of j] p[rule_format, of x] \<open>x \<in> S\<close> \<open>x \<noteq> a\<close>
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   567
  show ?thesis
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   568
    by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   569
qed simp
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   570
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   571
end
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   572
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   573
locale kuhn_simplex_pair = s: kuhn_simplex p n b_s u_s s + t: kuhn_simplex p n b_t u_t t
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   574
  for p n b_s u_s s b_t u_t t
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   575
begin
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   576
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   577
lemma enum_eq:
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   578
  assumes l: "i \<le> l" "l \<le> j" and "j + d \<le> n"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   579
  assumes eq: "s.enum ` {i .. j} = t.enum ` {i + d .. j + d}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   580
  shows "s.enum l = t.enum (l + d)"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   581
using l proof (induct l rule: dec_induct)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   582
  case base
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   583
  then have s: "s.enum i \<in> t.enum ` {i + d .. j + d}" and t: "t.enum (i + d) \<in> s.enum ` {i .. j}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   584
    using eq by auto
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   585
  from t \<open>i \<le> j\<close> \<open>j + d \<le> n\<close> have "s.enum i \<le> t.enum (i + d)"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   586
    by (auto simp: s.enum_mono)
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   587
  moreover from s \<open>i \<le> j\<close> \<open>j + d \<le> n\<close> have "t.enum (i + d) \<le> s.enum i"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   588
    by (auto simp: t.enum_mono)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   589
  ultimately show ?case
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   590
    by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   591
next
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   592
  case (step l)
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   593
  moreover from step.prems \<open>j + d \<le> n\<close> have
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   594
      "s.enum l < s.enum (Suc l)"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   595
      "t.enum (l + d) < t.enum (Suc l + d)"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   596
    by (simp_all add: s.enum_strict_mono t.enum_strict_mono)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   597
  moreover have
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   598
      "s.enum (Suc l) \<in> t.enum ` {i + d .. j + d}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   599
      "t.enum (Suc l + d) \<in> s.enum ` {i .. j}"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   600
    using step \<open>j + d \<le> n\<close> eq by (auto simp: s.enum_inj t.enum_inj)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   601
  ultimately have "s.enum (Suc l) = t.enum (Suc (l + d))"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   602
    using \<open>j + d \<le> n\<close>
61609
77b453bd616f Coercion "real" now has type nat => real only and is no longer overloaded. Type class "real_of" is gone. Many duplicate theorems removed.
paulson <lp15@cam.ac.uk>
parents: 61520
diff changeset
   603
    by (intro antisym s.enum_less[THEN iffD1] t.enum_less[THEN iffD1])
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   604
       (auto intro!: s.enum_in t.enum_in)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   605
  then show ?case by simp
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   606
qed
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   607
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   608
lemma ksimplex_eq_bot:
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   609
  assumes a: "a \<in> s" "\<And>a'. a' \<in> s \<Longrightarrow> a \<le> a'"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   610
  assumes b: "b \<in> t" "\<And>b'. b' \<in> t \<Longrightarrow> b \<le> b'"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   611
  assumes eq: "s - {a} = t - {b}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   612
  shows "s = t"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   613
proof cases
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   614
  assume "n = 0" with s.ksimplex_0 t.ksimplex_0 show ?thesis by simp
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   615
next
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   616
  assume "n \<noteq> 0"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   617
  have "s.enum 0 = (s.enum (Suc 0)) (u_s 0 := s.enum (Suc 0) (u_s 0) - 1)"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   618
       "t.enum 0 = (t.enum (Suc 0)) (u_t 0 := t.enum (Suc 0) (u_t 0) - 1)"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   619
    using \<open>n \<noteq> 0\<close> by (simp_all add: s.enum_Suc t.enum_Suc)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   620
  moreover have e0: "a = s.enum 0" "b = t.enum 0"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   621
    using a b by (simp_all add: s.enum_0_bot t.enum_0_bot)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   622
  moreover
61609
77b453bd616f Coercion "real" now has type nat => real only and is no longer overloaded. Type class "real_of" is gone. Many duplicate theorems removed.
paulson <lp15@cam.ac.uk>
parents: 61520
diff changeset
   623
  { fix j assume "0 < j" "j \<le> n"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   624
    moreover have "s - {a} = s.enum ` {Suc 0 .. n}" "t - {b} = t.enum ` {Suc 0 .. n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   625
      unfolding s.s_eq t.s_eq e0 by (auto simp: s.enum_inj t.enum_inj)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   626
    ultimately have "s.enum j = t.enum j"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   627
      using enum_eq[of "1" j n 0] eq by auto }
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   628
  note enum_eq = this
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   629
  then have "s.enum (Suc 0) = t.enum (Suc 0)"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   630
    using \<open>n \<noteq> 0\<close> by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   631
  moreover
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   632
  { fix j assume "Suc j < n"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   633
    with enum_eq[of "Suc j"] enum_eq[of "Suc (Suc j)"]
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   634
    have "u_s (Suc j) = u_t (Suc j)"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   635
      using s.enum_Suc[of "Suc j"] t.enum_Suc[of "Suc j"]
62390
842917225d56 more canonical names
nipkow
parents: 62061
diff changeset
   636
      by (auto simp: fun_eq_iff split: if_split_asm) }
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   637
  then have "\<And>j. 0 < j \<Longrightarrow> j < n \<Longrightarrow> u_s j = u_t j"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   638
    by (auto simp: gr0_conv_Suc)
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   639
  with \<open>n \<noteq> 0\<close> have "u_t 0 = u_s 0"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   640
    by (intro bij_betw_singleton_eq[OF t.upd s.upd, of 0]) auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   641
  ultimately have "a = b"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   642
    by simp
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   643
  with assms show "s = t"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   644
    by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   645
qed
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   646
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   647
lemma ksimplex_eq_top:
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   648
  assumes a: "a \<in> s" "\<And>a'. a' \<in> s \<Longrightarrow> a' \<le> a"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   649
  assumes b: "b \<in> t" "\<And>b'. b' \<in> t \<Longrightarrow> b' \<le> b"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   650
  assumes eq: "s - {a} = t - {b}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   651
  shows "s = t"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   652
proof (cases n)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   653
  assume "n = 0" with s.ksimplex_0 t.ksimplex_0 show ?thesis by simp
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   654
next
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   655
  case (Suc n')
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   656
  have "s.enum n = (s.enum n') (u_s n' := Suc (s.enum n' (u_s n')))"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   657
       "t.enum n = (t.enum n') (u_t n' := Suc (t.enum n' (u_t n')))"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   658
    using Suc by (simp_all add: s.enum_Suc t.enum_Suc)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   659
  moreover have en: "a = s.enum n" "b = t.enum n"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   660
    using a b by (simp_all add: s.enum_n_top t.enum_n_top)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   661
  moreover
61609
77b453bd616f Coercion "real" now has type nat => real only and is no longer overloaded. Type class "real_of" is gone. Many duplicate theorems removed.
paulson <lp15@cam.ac.uk>
parents: 61520
diff changeset
   662
  { fix j assume "j < n"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   663
    moreover have "s - {a} = s.enum ` {0 .. n'}" "t - {b} = t.enum ` {0 .. n'}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   664
      unfolding s.s_eq t.s_eq en by (auto simp: s.enum_inj t.enum_inj Suc)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   665
    ultimately have "s.enum j = t.enum j"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   666
      using enum_eq[of "0" j n' 0] eq Suc by auto }
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   667
  note enum_eq = this
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   668
  then have "s.enum n' = t.enum n'"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   669
    using Suc by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   670
  moreover
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   671
  { fix j assume "j < n'"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   672
    with enum_eq[of j] enum_eq[of "Suc j"]
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   673
    have "u_s j = u_t j"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   674
      using s.enum_Suc[of j] t.enum_Suc[of j]
62390
842917225d56 more canonical names
nipkow
parents: 62061
diff changeset
   675
      by (auto simp: Suc fun_eq_iff split: if_split_asm) }
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   676
  then have "\<And>j. j < n' \<Longrightarrow> u_s j = u_t j"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   677
    by (auto simp: gr0_conv_Suc)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   678
  then have "u_t n' = u_s n'"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   679
    by (intro bij_betw_singleton_eq[OF t.upd s.upd, of n']) (auto simp: Suc)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   680
  ultimately have "a = b"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   681
    by simp
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   682
  with assms show "s = t"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   683
    by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   684
qed
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   685
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   686
end
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   687
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   688
inductive ksimplex for p n :: nat where
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   689
  ksimplex: "kuhn_simplex p n base upd s \<Longrightarrow> ksimplex p n s"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   690
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   691
lemma finite_ksimplexes: "finite {s. ksimplex p n s}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   692
proof (rule finite_subset)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   693
  { fix a s assume "ksimplex p n s" "a \<in> s"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   694
    then obtain b u where "kuhn_simplex p n b u s" by (auto elim: ksimplex.cases)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   695
    then interpret kuhn_simplex p n b u s .
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   696
    from s_space \<open>a \<in> s\<close> out_eq_p[OF \<open>a \<in> s\<close>]
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   697
    have "a \<in> (\<lambda>f x. if n \<le> x then p else f x) ` ({..< n} \<rightarrow>\<^sub>E {.. p})"
62390
842917225d56 more canonical names
nipkow
parents: 62061
diff changeset
   698
      by (auto simp: image_iff subset_eq Pi_iff split: if_split_asm
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   699
               intro!: bexI[of _ "restrict a {..< n}"]) }
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   700
  then show "{s. ksimplex p n s} \<subseteq> Pow ((\<lambda>f x. if n \<le> x then p else f x) ` ({..< n} \<rightarrow>\<^sub>E {.. p}))"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   701
    by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   702
qed (simp add: finite_PiE)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   703
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   704
lemma ksimplex_card:
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   705
  assumes "ksimplex p n s" shows "card s = Suc n"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   706
using assms proof cases
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   707
  case (ksimplex u b)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   708
  then interpret kuhn_simplex p n u b s .
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   709
  show ?thesis
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   710
    by (simp add: card_image s_eq inj_enum)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   711
qed
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   712
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   713
lemma simplex_top_face:
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   714
  assumes "0 < p" "\<forall>x\<in>s'. x n = p"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   715
  shows "ksimplex p n s' \<longleftrightarrow> (\<exists>s a. ksimplex p (Suc n) s \<and> a \<in> s \<and> s' = s - {a})"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   716
  using assms
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   717
proof safe
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   718
  fix s a assume "ksimplex p (Suc n) s" and a: "a \<in> s" and na: "\<forall>x\<in>s - {a}. x n = p"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   719
  then show "ksimplex p n (s - {a})"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   720
  proof cases
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   721
    case (ksimplex base upd)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   722
    then interpret kuhn_simplex p "Suc n" base upd "s" .
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   723
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   724
    have "a n < p"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   725
      using one_step[of a n p] na \<open>a\<in>s\<close> s_space by (auto simp: less_le)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   726
    then have "a = enum 0"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   727
      using \<open>a \<in> s\<close> na by (subst enum_0_bot) (auto simp: le_less intro!: less[of a _ n])
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   728
    then have s_eq: "s - {a} = enum ` Suc ` {.. n}"
71172
nipkow
parents: 70802
diff changeset
   729
      using s_eq by (simp add: atMost_Suc_eq_insert_0 insert_ident in_enum_image subset_eq)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   730
    then have "enum 1 \<in> s - {a}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   731
      by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   732
    then have "upd 0 = n"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   733
      using \<open>a n < p\<close> \<open>a = enum 0\<close> na[rule_format, of "enum 1"]
62390
842917225d56 more canonical names
nipkow
parents: 62061
diff changeset
   734
      by (auto simp: fun_eq_iff enum_Suc split: if_split_asm)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   735
    then have "bij_betw upd (Suc ` {..< n}) {..< n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   736
      using upd
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   737
      by (subst notIn_Un_bij_betw3[where b=0])
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   738
         (auto simp: lessThan_Suc[symmetric] lessThan_Suc_eq_insert_0)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   739
    then have "bij_betw (upd\<circ>Suc) {..<n} {..<n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   740
      by (rule bij_betw_trans[rotated]) (auto simp: bij_betw_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   741
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   742
    have "a n = p - 1"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   743
      using enum_Suc[of 0] na[rule_format, OF \<open>enum 1 \<in> s - {a}\<close>] \<open>a = enum 0\<close> by (auto simp: \<open>upd 0 = n\<close>)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   744
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   745
    show ?thesis
61169
4de9ff3ea29a tuned proofs -- less legacy;
wenzelm
parents: 60580
diff changeset
   746
    proof (rule ksimplex.intros, standard)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   747
      show "bij_betw (upd\<circ>Suc) {..< n} {..< n}" by fact
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   748
      show "base(n := p) \<in> {..<n} \<rightarrow> {..<p}" "\<And>i. n\<le>i \<Longrightarrow> (base(n := p)) i = p"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   749
        using base base_out by (auto simp: Pi_iff)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   750
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   751
      have "\<And>i. Suc ` {..< i} = {..< Suc i} - {0}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   752
        by (auto simp: image_iff Ball_def) arith
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   753
      then have upd_Suc: "\<And>i. i \<le> n \<Longrightarrow> (upd\<circ>Suc) ` {..< i} = upd ` {..< Suc i} - {n}"
69661
a03a63b81f44 tuned proofs
haftmann
parents: 69620
diff changeset
   754
        using \<open>upd 0 = n\<close> upd_inj by (auto simp add: image_iff less_Suc_eq_0_disj)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   755
      have n_in_upd: "\<And>i. n \<in> upd ` {..< Suc i}"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   756
        using \<open>upd 0 = n\<close> by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   757
63040
eb4ddd18d635 eliminated old 'def';
wenzelm
parents: 62948
diff changeset
   758
      define f' where "f' i j =
eb4ddd18d635 eliminated old 'def';
wenzelm
parents: 62948
diff changeset
   759
        (if j \<in> (upd\<circ>Suc)`{..< i} then Suc ((base(n := p)) j) else (base(n := p)) j)" for i j
69661
a03a63b81f44 tuned proofs
haftmann
parents: 69620
diff changeset
   760
      { fix x i
a03a63b81f44 tuned proofs
haftmann
parents: 69620
diff changeset
   761
        assume i [arith]: "i \<le> n"
a03a63b81f44 tuned proofs
haftmann
parents: 69620
diff changeset
   762
        with upd_Suc have "(upd \<circ> Suc) ` {..<i} = upd ` {..<Suc i} - {n}" .
a03a63b81f44 tuned proofs
haftmann
parents: 69620
diff changeset
   763
        with \<open>a n < p\<close> \<open>a = enum 0\<close> \<open>upd 0 = n\<close> \<open>a n = p - 1\<close>
a03a63b81f44 tuned proofs
haftmann
parents: 69620
diff changeset
   764
        have "enum (Suc i) x = f' i x"
a03a63b81f44 tuned proofs
haftmann
parents: 69620
diff changeset
   765
          by (auto simp add: f'_def enum_def)  }
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   766
      then show "s - {a} = f' ` {.. n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   767
        unfolding s_eq image_comp by (intro image_cong) auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   768
    qed
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   769
  qed
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   770
next
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   771
  assume "ksimplex p n s'" and *: "\<forall>x\<in>s'. x n = p"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   772
  then show "\<exists>s a. ksimplex p (Suc n) s \<and> a \<in> s \<and> s' = s - {a}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   773
  proof cases
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   774
    case (ksimplex base upd)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   775
    then interpret kuhn_simplex p n base upd s' .
63040
eb4ddd18d635 eliminated old 'def';
wenzelm
parents: 62948
diff changeset
   776
    define b where "b = base (n := p - 1)"
eb4ddd18d635 eliminated old 'def';
wenzelm
parents: 62948
diff changeset
   777
    define u where "u i = (case i of 0 \<Rightarrow> n | Suc i \<Rightarrow> upd i)" for i
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   778
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   779
    have "ksimplex p (Suc n) (s' \<union> {b})"
61169
4de9ff3ea29a tuned proofs -- less legacy;
wenzelm
parents: 60580
diff changeset
   780
    proof (rule ksimplex.intros, standard)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   781
      show "b \<in> {..<Suc n} \<rightarrow> {..<p}"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   782
        using base \<open>0 < p\<close> unfolding lessThan_Suc b_def by (auto simp: PiE_iff)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   783
      show "\<And>i. Suc n \<le> i \<Longrightarrow> b i = p"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   784
        using base_out by (auto simp: b_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   785
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   786
      have "bij_betw u (Suc ` {..< n} \<union> {0}) ({..<n} \<union> {u 0})"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   787
        using upd
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   788
        by (intro notIn_Un_bij_betw) (auto simp: u_def bij_betw_def image_comp comp_def inj_on_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   789
      then show "bij_betw u {..<Suc n} {..<Suc n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   790
        by (simp add: u_def lessThan_Suc[symmetric] lessThan_Suc_eq_insert_0)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   791
63040
eb4ddd18d635 eliminated old 'def';
wenzelm
parents: 62948
diff changeset
   792
      define f' where "f' i j = (if j \<in> u`{..< i} then Suc (b j) else b j)" for i j
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   793
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   794
      have u_eq: "\<And>i. i \<le> n \<Longrightarrow> u ` {..< Suc i} = upd ` {..< i} \<union> { n }"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   795
        by (auto simp: u_def image_iff upd_inj Ball_def split: nat.split) arith
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   796
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   797
      { fix x have "x \<le> n \<Longrightarrow> n \<notin> upd ` {..<x}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   798
          using upd_space by (simp add: image_iff neq_iff) }
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   799
      note n_not_upd = this
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   800
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   801
      have *: "f' ` {.. Suc n} = f' ` (Suc ` {.. n} \<union> {0})"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   802
        unfolding atMost_Suc_eq_insert_0 by simp
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   803
      also have "\<dots> = (f' \<circ> Suc) ` {.. n} \<union> {b}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   804
        by (auto simp: f'_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   805
      also have "(f' \<circ> Suc) ` {.. n} = s'"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   806
        using \<open>0 < p\<close> base_out[of n]
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   807
        unfolding s_eq enum_def[abs_def] f'_def[abs_def] upd_space
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   808
        by (intro image_cong) (simp_all add: u_eq b_def fun_eq_iff n_not_upd)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   809
      finally show "s' \<union> {b} = f' ` {.. Suc n}" ..
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   810
    qed
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   811
    moreover have "b \<notin> s'"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   812
      using * \<open>0 < p\<close> by (auto simp: b_def)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   813
    ultimately show ?thesis by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   814
  qed
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   815
qed
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   816
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   817
lemma ksimplex_replace_0:
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   818
  assumes s: "ksimplex p n s" and a: "a \<in> s"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   819
  assumes j: "j < n" and p: "\<forall>x\<in>s - {a}. x j = 0"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   820
  shows "card {s'. ksimplex p n s' \<and> (\<exists>b\<in>s'. s' - {b} = s - {a})} = 1"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   821
  using s
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   822
proof cases
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   823
  case (ksimplex b_s u_s)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   824
61609
77b453bd616f Coercion "real" now has type nat => real only and is no longer overloaded. Type class "real_of" is gone. Many duplicate theorems removed.
paulson <lp15@cam.ac.uk>
parents: 61520
diff changeset
   825
  { fix t b assume "ksimplex p n t"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   826
    then obtain b_t u_t where "kuhn_simplex p n b_t u_t t"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   827
      by (auto elim: ksimplex.cases)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   828
    interpret kuhn_simplex_pair p n b_s u_s s b_t u_t t
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   829
      by intro_locales fact+
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   830
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   831
    assume b: "b \<in> t" "t - {b} = s - {a}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   832
    with a j p s.replace_0[of _ a] t.replace_0[of _ b] have "s = t"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   833
      by (intro ksimplex_eq_top[of a b]) auto }
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   834
  then have "{s'. ksimplex p n s' \<and> (\<exists>b\<in>s'. s' - {b} = s - {a})} = {s}"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   835
    using s \<open>a \<in> s\<close> by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   836
  then show ?thesis
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   837
    by simp
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   838
qed
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   839
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   840
lemma ksimplex_replace_1:
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   841
  assumes s: "ksimplex p n s" and a: "a \<in> s"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   842
  assumes j: "j < n" and p: "\<forall>x\<in>s - {a}. x j = p"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   843
  shows "card {s'. ksimplex p n s' \<and> (\<exists>b\<in>s'. s' - {b} = s - {a})} = 1"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   844
  using s
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   845
proof cases
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   846
  case (ksimplex b_s u_s)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   847
61609
77b453bd616f Coercion "real" now has type nat => real only and is no longer overloaded. Type class "real_of" is gone. Many duplicate theorems removed.
paulson <lp15@cam.ac.uk>
parents: 61520
diff changeset
   848
  { fix t b assume "ksimplex p n t"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   849
    then obtain b_t u_t where "kuhn_simplex p n b_t u_t t"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   850
      by (auto elim: ksimplex.cases)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   851
    interpret kuhn_simplex_pair p n b_s u_s s b_t u_t t
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   852
      by intro_locales fact+
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   853
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   854
    assume b: "b \<in> t" "t - {b} = s - {a}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   855
    with a j p s.replace_1[of _ a] t.replace_1[of _ b] have "s = t"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   856
      by (intro ksimplex_eq_bot[of a b]) auto }
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   857
  then have "{s'. ksimplex p n s' \<and> (\<exists>b\<in>s'. s' - {b} = s - {a})} = {s}"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   858
    using s \<open>a \<in> s\<close> by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   859
  then show ?thesis
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   860
    by simp
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   861
qed
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   862
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   863
lemma ksimplex_replace_2:
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   864
  assumes s: "ksimplex p n s" and "a \<in> s" and "n \<noteq> 0"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   865
    and lb: "\<forall>j<n. \<exists>x\<in>s - {a}. x j \<noteq> 0"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   866
    and ub: "\<forall>j<n. \<exists>x\<in>s - {a}. x j \<noteq> p"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   867
  shows "card {s'. ksimplex p n s' \<and> (\<exists>b\<in>s'. s' - {b} = s - {a})} = 2"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   868
  using s
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   869
proof cases
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   870
  case (ksimplex base upd)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   871
  then interpret kuhn_simplex p n base upd s .
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   872
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   873
  from \<open>a \<in> s\<close> obtain i where "i \<le> n" "a = enum i"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   874
    unfolding s_eq by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   875
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   876
  from \<open>i \<le> n\<close> have "i = 0 \<or> i = n \<or> (0 < i \<and> i < n)"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   877
    by linarith
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   878
  then have "\<exists>!s'. s' \<noteq> s \<and> ksimplex p n s' \<and> (\<exists>b\<in>s'. s - {a} = s'- {b})"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   879
  proof (elim disjE conjE)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   880
    assume "i = 0"
63040
eb4ddd18d635 eliminated old 'def';
wenzelm
parents: 62948
diff changeset
   881
    define rot where [abs_def]: "rot i = (if i + 1 = n then 0 else i + 1)" for i
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   882
    let ?upd = "upd \<circ> rot"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   883
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   884
    have rot: "bij_betw rot {..< n} {..< n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   885
      by (auto simp: bij_betw_def inj_on_def image_iff Ball_def rot_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   886
         arith+
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   887
    from rot upd have "bij_betw ?upd {..<n} {..<n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   888
      by (rule bij_betw_trans)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   889
63040
eb4ddd18d635 eliminated old 'def';
wenzelm
parents: 62948
diff changeset
   890
    define f' where [abs_def]: "f' i j =
eb4ddd18d635 eliminated old 'def';
wenzelm
parents: 62948
diff changeset
   891
      (if j \<in> ?upd`{..< i} then Suc (enum (Suc 0) j) else enum (Suc 0) j)" for i j
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   892
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   893
    interpret b: kuhn_simplex p n "enum (Suc 0)" "upd \<circ> rot" "f' ` {.. n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   894
    proof
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   895
      from \<open>a = enum i\<close> ub \<open>n \<noteq> 0\<close> \<open>i = 0\<close>
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   896
      obtain i' where "i' \<le> n" "enum i' \<noteq> enum 0" "enum i' (upd 0) \<noteq> p"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   897
        unfolding s_eq by (auto intro: upd_space simp: enum_inj)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   898
      then have "enum 1 \<le> enum i'" "enum i' (upd 0) < p"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
   899
        using enum_le_p[of i' "upd 0"] by (auto simp: enum_inj enum_mono upd_space)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   900
      then have "enum 1 (upd 0) < p"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
   901
        by (auto simp: le_fun_def intro: le_less_trans)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   902
      then show "enum (Suc 0) \<in> {..<n} \<rightarrow> {..<p}"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
   903
        using base \<open>n \<noteq> 0\<close> by (auto simp: enum_0 enum_Suc PiE_iff extensional_def upd_space)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   904
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   905
      { fix i assume "n \<le> i" then show "enum (Suc 0) i = p"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   906
        using \<open>n \<noteq> 0\<close> by (auto simp: enum_eq_p) }
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   907
      show "bij_betw ?upd {..<n} {..<n}" by fact
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   908
    qed (simp add: f'_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   909
    have ks_f': "ksimplex p n (f' ` {.. n})"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   910
      by rule unfold_locales
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   911
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   912
    have b_enum: "b.enum = f'" unfolding f'_def b.enum_def[abs_def] ..
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   913
    with b.inj_enum have inj_f': "inj_on f' {.. n}" by simp
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   914
69661
a03a63b81f44 tuned proofs
haftmann
parents: 69620
diff changeset
   915
    have f'_eq_enum: "f' j = enum (Suc j)" if "j < n" for j
a03a63b81f44 tuned proofs
haftmann
parents: 69620
diff changeset
   916
    proof -
a03a63b81f44 tuned proofs
haftmann
parents: 69620
diff changeset
   917
      from that have "rot ` {..< j} = {0 <..< Suc j}"
a03a63b81f44 tuned proofs
haftmann
parents: 69620
diff changeset
   918
        by (auto simp: rot_def image_Suc_lessThan cong: image_cong_simp)
a03a63b81f44 tuned proofs
haftmann
parents: 69620
diff changeset
   919
      with that \<open>n \<noteq> 0\<close> show ?thesis
a03a63b81f44 tuned proofs
haftmann
parents: 69620
diff changeset
   920
        by (simp only: f'_def enum_def fun_eq_iff image_comp [symmetric])
a03a63b81f44 tuned proofs
haftmann
parents: 69620
diff changeset
   921
          (auto simp add: upd_inj)
a03a63b81f44 tuned proofs
haftmann
parents: 69620
diff changeset
   922
    qed
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   923
    then have "enum ` Suc ` {..< n} = f' ` {..< n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   924
      by (force simp: enum_inj)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   925
    also have "Suc ` {..< n} = {.. n} - {0}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   926
      by (auto simp: image_iff Ball_def) arith
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   927
    also have "{..< n} = {.. n} - {n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   928
      by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   929
    finally have eq: "s - {a} = f' ` {.. n} - {f' n}"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   930
      unfolding s_eq \<open>a = enum i\<close> \<open>i = 0\<close>
69286
nipkow
parents: 68621
diff changeset
   931
      by (simp add: inj_on_image_set_diff[OF inj_enum] inj_on_image_set_diff[OF inj_f'])
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   932
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   933
    have "enum 0 < f' 0"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   934
      using \<open>n \<noteq> 0\<close> by (simp add: enum_strict_mono f'_eq_enum)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   935
    also have "\<dots> < f' n"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   936
      using \<open>n \<noteq> 0\<close> b.enum_strict_mono[of 0 n] unfolding b_enum by simp
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   937
    finally have "a \<noteq> f' n"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   938
      using \<open>a = enum i\<close> \<open>i = 0\<close> by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   939
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   940
    { fix t c assume "ksimplex p n t" "c \<in> t" and eq_sma: "s - {a} = t - {c}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   941
      obtain b u where "kuhn_simplex p n b u t"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   942
        using \<open>ksimplex p n t\<close> by (auto elim: ksimplex.cases)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   943
      then interpret t: kuhn_simplex p n b u t .
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   944
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   945
      { fix x assume "x \<in> s" "x \<noteq> a"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   946
         then have "x (upd 0) = enum (Suc 0) (upd 0)"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   947
           by (auto simp: \<open>a = enum i\<close> \<open>i = 0\<close> s_eq enum_def enum_inj) }
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   948
      then have eq_upd0: "\<forall>x\<in>t-{c}. x (upd 0) = enum (Suc 0) (upd 0)"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   949
        unfolding eq_sma[symmetric] by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   950
      then have "c (upd 0) \<noteq> enum (Suc 0) (upd 0)"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   951
        using \<open>n \<noteq> 0\<close> by (intro t.one_step[OF \<open>c\<in>t\<close> ]) (auto simp: upd_space)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   952
      then have "c (upd 0) < enum (Suc 0) (upd 0) \<or> c (upd 0) > enum (Suc 0) (upd 0)"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   953
        by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   954
      then have "t = s \<or> t = f' ` {..n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   955
      proof (elim disjE conjE)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   956
        assume *: "c (upd 0) < enum (Suc 0) (upd 0)"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   957
        interpret st: kuhn_simplex_pair p n base upd s b u t ..
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   958
        { fix x assume "x \<in> t" with * \<open>c\<in>t\<close> eq_upd0[rule_format, of x] have "c \<le> x"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   959
            by (auto simp: le_less intro!: t.less[of _ _ "upd 0"]) }
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   960
        note top = this
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   961
        have "s = t"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   962
          using \<open>a = enum i\<close> \<open>i = 0\<close> \<open>c \<in> t\<close>
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   963
          by (intro st.ksimplex_eq_bot[OF _ _ _ _ eq_sma])
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   964
             (auto simp: s_eq enum_mono t.s_eq t.enum_mono top)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   965
        then show ?thesis by simp
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   966
      next
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   967
        assume *: "c (upd 0) > enum (Suc 0) (upd 0)"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   968
        interpret st: kuhn_simplex_pair p n "enum (Suc 0)" "upd \<circ> rot" "f' ` {.. n}" b u t ..
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   969
        have eq: "f' ` {..n} - {f' n} = t - {c}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   970
          using eq_sma eq by simp
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   971
        { fix x assume "x \<in> t" with * \<open>c\<in>t\<close> eq_upd0[rule_format, of x] have "x \<le> c"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   972
            by (auto simp: le_less intro!: t.less[of _ _ "upd 0"]) }
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   973
        note top = this
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   974
        have "f' ` {..n} = t"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   975
          using \<open>a = enum i\<close> \<open>i = 0\<close> \<open>c \<in> t\<close>
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   976
          by (intro st.ksimplex_eq_top[OF _ _ _ _ eq])
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   977
             (auto simp: b.s_eq b.enum_mono t.s_eq t.enum_mono b_enum[symmetric] top)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   978
        then show ?thesis by simp
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   979
      qed }
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   980
    with ks_f' eq \<open>a \<noteq> f' n\<close> \<open>n \<noteq> 0\<close> show ?thesis
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   981
      apply (intro ex1I[of _ "f' ` {.. n}"])
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
   982
       apply auto []
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   983
      apply metis
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   984
      done
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   985
  next
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   986
    assume "i = n"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
   987
    from \<open>n \<noteq> 0\<close> obtain n' where n': "n = Suc n'"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   988
      by (cases n) auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   989
63040
eb4ddd18d635 eliminated old 'def';
wenzelm
parents: 62948
diff changeset
   990
    define rot where "rot i = (case i of 0 \<Rightarrow> n' | Suc i \<Rightarrow> i)" for i
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   991
    let ?upd = "upd \<circ> rot"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   992
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   993
    have rot: "bij_betw rot {..< n} {..< n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   994
      by (auto simp: bij_betw_def inj_on_def image_iff Bex_def rot_def n' split: nat.splits)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   995
         arith
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   996
    from rot upd have "bij_betw ?upd {..<n} {..<n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   997
      by (rule bij_betw_trans)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
   998
63040
eb4ddd18d635 eliminated old 'def';
wenzelm
parents: 62948
diff changeset
   999
    define b where "b = base (upd n' := base (upd n') - 1)"
eb4ddd18d635 eliminated old 'def';
wenzelm
parents: 62948
diff changeset
  1000
    define f' where [abs_def]: "f' i j = (if j \<in> ?upd`{..< i} then Suc (b j) else b j)" for i j
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1001
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1002
    interpret b: kuhn_simplex p n b "upd \<circ> rot" "f' ` {.. n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1003
    proof
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1004
      { fix i assume "n \<le> i" then show "b i = p"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1005
          using base_out[of i] upd_space[of n'] by (auto simp: b_def n') }
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1006
      show "b \<in> {..<n} \<rightarrow> {..<p}"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1007
        using base \<open>n \<noteq> 0\<close> upd_space[of n']
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1008
        by (auto simp: b_def PiE_def Pi_iff Ball_def upd_space extensional_def n')
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1009
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1010
      show "bij_betw ?upd {..<n} {..<n}" by fact
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1011
    qed (simp add: f'_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1012
    have f': "b.enum = f'" unfolding f'_def b.enum_def[abs_def] ..
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1013
    have ks_f': "ksimplex p n (b.enum ` {.. n})"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1014
      unfolding f' by rule unfold_locales
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1015
61609
77b453bd616f Coercion "real" now has type nat => real only and is no longer overloaded. Type class "real_of" is gone. Many duplicate theorems removed.
paulson <lp15@cam.ac.uk>
parents: 61520
diff changeset
  1016
    have "0 < n"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1017
      using \<open>n \<noteq> 0\<close> by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1018
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1019
    { from \<open>a = enum i\<close> \<open>n \<noteq> 0\<close> \<open>i = n\<close> lb upd_space[of n']
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1020
      obtain i' where "i' \<le> n" "enum i' \<noteq> enum n" "0 < enum i' (upd n')"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1021
        unfolding s_eq by (auto simp: enum_inj n')
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1022
      moreover have "enum i' (upd n') = base (upd n')"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1023
        unfolding enum_def using \<open>i' \<le> n\<close> \<open>enum i' \<noteq> enum n\<close> by (auto simp: n' upd_inj enum_inj)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1024
      ultimately have "0 < base (upd n')"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1025
        by auto }
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1026
    then have benum1: "b.enum (Suc 0) = base"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1027
      unfolding b.enum_Suc[OF \<open>0<n\<close>] b.enum_0 by (auto simp: b_def rot_def)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1028
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1029
    have [simp]: "\<And>j. Suc j < n \<Longrightarrow> rot ` {..< Suc j} = {n'} \<union> {..< j}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1030
      by (auto simp: rot_def image_iff Ball_def split: nat.splits)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1031
    have rot_simps: "\<And>j. rot (Suc j) = j" "rot 0 = n'"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1032
      by (simp_all add: rot_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1033
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1034
    { fix j assume j: "Suc j \<le> n" then have "b.enum (Suc j) = enum j"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1035
        by (induct j) (auto simp: benum1 enum_0 b.enum_Suc enum_Suc rot_simps) }
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1036
    note b_enum_eq_enum = this
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1037
    then have "enum ` {..< n} = b.enum ` Suc ` {..< n}"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1038
      by (auto simp: image_comp intro!: image_cong)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1039
    also have "Suc ` {..< n} = {.. n} - {0}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1040
      by (auto simp: image_iff Ball_def) arith
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1041
    also have "{..< n} = {.. n} - {n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1042
      by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1043
    finally have eq: "s - {a} = b.enum ` {.. n} - {b.enum 0}"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1044
      unfolding s_eq \<open>a = enum i\<close> \<open>i = n\<close>
60303
00c06f1315d0 New material about paths, and some lemmas
paulson
parents: 59765
diff changeset
  1045
      using inj_on_image_set_diff[OF inj_enum Diff_subset, of "{n}"]
00c06f1315d0 New material about paths, and some lemmas
paulson
parents: 59765
diff changeset
  1046
            inj_on_image_set_diff[OF b.inj_enum Diff_subset, of "{0}"]
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1047
      by (simp add: comp_def)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1048
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1049
    have "b.enum 0 \<le> b.enum n"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1050
      by (simp add: b.enum_mono)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1051
    also have "b.enum n < enum n"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1052
      using \<open>n \<noteq> 0\<close> by (simp add: enum_strict_mono b_enum_eq_enum n')
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1053
    finally have "a \<noteq> b.enum 0"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1054
      using \<open>a = enum i\<close> \<open>i = n\<close> by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1055
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1056
    { fix t c assume "ksimplex p n t" "c \<in> t" and eq_sma: "s - {a} = t - {c}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1057
      obtain b' u where "kuhn_simplex p n b' u t"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1058
        using \<open>ksimplex p n t\<close> by (auto elim: ksimplex.cases)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1059
      then interpret t: kuhn_simplex p n b' u t .
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1060
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1061
      { fix x assume "x \<in> s" "x \<noteq> a"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1062
         then have "x (upd n') = enum n' (upd n')"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1063
           by (auto simp: \<open>a = enum i\<close> n' \<open>i = n\<close> s_eq enum_def enum_inj in_upd_image) }
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1064
      then have eq_upd0: "\<forall>x\<in>t-{c}. x (upd n') = enum n' (upd n')"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1065
        unfolding eq_sma[symmetric] by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1066
      then have "c (upd n') \<noteq> enum n' (upd n')"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1067
        using \<open>n \<noteq> 0\<close> by (intro t.one_step[OF \<open>c\<in>t\<close> ]) (auto simp: n' upd_space[unfolded n'])
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1068
      then have "c (upd n') < enum n' (upd n') \<or> c (upd n') > enum n' (upd n')"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1069
        by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1070
      then have "t = s \<or> t = b.enum ` {..n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1071
      proof (elim disjE conjE)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1072
        assume *: "c (upd n') > enum n' (upd n')"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1073
        interpret st: kuhn_simplex_pair p n base upd s b' u t ..
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1074
        { fix x assume "x \<in> t" with * \<open>c\<in>t\<close> eq_upd0[rule_format, of x] have "x \<le> c"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1075
            by (auto simp: le_less intro!: t.less[of _ _ "upd n'"]) }
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1076
        note top = this
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1077
        have "s = t"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1078
          using \<open>a = enum i\<close> \<open>i = n\<close> \<open>c \<in> t\<close>
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1079
          by (intro st.ksimplex_eq_top[OF _ _ _ _ eq_sma])
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1080
             (auto simp: s_eq enum_mono t.s_eq t.enum_mono top)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1081
        then show ?thesis by simp
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1082
      next
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1083
        assume *: "c (upd n') < enum n' (upd n')"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1084
        interpret st: kuhn_simplex_pair p n b "upd \<circ> rot" "f' ` {.. n}" b' u t ..
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1085
        have eq: "f' ` {..n} - {b.enum 0} = t - {c}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1086
          using eq_sma eq f' by simp
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1087
        { fix x assume "x \<in> t" with * \<open>c\<in>t\<close> eq_upd0[rule_format, of x] have "c \<le> x"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1088
            by (auto simp: le_less intro!: t.less[of _ _ "upd n'"]) }
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1089
        note bot = this
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1090
        have "f' ` {..n} = t"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1091
          using \<open>a = enum i\<close> \<open>i = n\<close> \<open>c \<in> t\<close>
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1092
          by (intro st.ksimplex_eq_bot[OF _ _ _ _ eq])
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1093
             (auto simp: b.s_eq b.enum_mono t.s_eq t.enum_mono bot)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1094
        with f' show ?thesis by simp
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1095
      qed }
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1096
    with ks_f' eq \<open>a \<noteq> b.enum 0\<close> \<open>n \<noteq> 0\<close> show ?thesis
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1097
      apply (intro ex1I[of _ "b.enum ` {.. n}"])
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  1098
      apply fastforce
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1099
      apply metis
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1100
      done
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1101
  next
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1102
    assume i: "0 < i" "i < n"
63040
eb4ddd18d635 eliminated old 'def';
wenzelm
parents: 62948
diff changeset
  1103
    define i' where "i' = i - 1"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1104
    with i have "Suc i' < n"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1105
      by simp
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1106
    with i have Suc_i': "Suc i' = i"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1107
      by (simp add: i'_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1108
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1109
    let ?upd = "Fun.swap i' i upd"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1110
    from i upd have "bij_betw ?upd {..< n} {..< n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1111
      by (subst bij_betw_swap_iff) (auto simp: i'_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1112
63040
eb4ddd18d635 eliminated old 'def';
wenzelm
parents: 62948
diff changeset
  1113
    define f' where [abs_def]: "f' i j = (if j \<in> ?upd`{..< i} then Suc (base j) else base j)"
eb4ddd18d635 eliminated old 'def';
wenzelm
parents: 62948
diff changeset
  1114
      for i j
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1115
    interpret b: kuhn_simplex p n base ?upd "f' ` {.. n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1116
    proof
67682
00c436488398 tuned proofs -- prefer explicit names for facts from 'interpret';
wenzelm
parents: 67673
diff changeset
  1117
      show "base \<in> {..<n} \<rightarrow> {..<p}" by (rule base)
00c436488398 tuned proofs -- prefer explicit names for facts from 'interpret';
wenzelm
parents: 67673
diff changeset
  1118
      { fix i assume "n \<le> i" then show "base i = p" by (rule base_out) }
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1119
      show "bij_betw ?upd {..<n} {..<n}" by fact
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1120
    qed (simp add: f'_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1121
    have f': "b.enum = f'" unfolding f'_def b.enum_def[abs_def] ..
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1122
    have ks_f': "ksimplex p n (b.enum ` {.. n})"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1123
      unfolding f' by rule unfold_locales
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1124
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1125
    have "{i} \<subseteq> {..n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1126
      using i by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1127
    { fix j assume "j \<le> n"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  1128
      with i Suc_i' have "enum j = b.enum j \<longleftrightarrow> j \<noteq> i"
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  1129
        unfolding fun_eq_iff enum_def b.enum_def image_comp [symmetric]
73648
1bd3463e30b8 more elementary swap
haftmann
parents: 73466
diff changeset
  1130
        apply (cases \<open>i = j\<close>)
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  1131
         apply (metis imageI in_upd_image lessI lessThan_iff lessThan_subset_iff order_less_le transpose_apply_first)
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  1132
        by (metis lessThan_iff linorder_not_less not_less_eq_eq order_less_le transpose_image_eq)
73648
1bd3463e30b8 more elementary swap
haftmann
parents: 73466
diff changeset
  1133
      }
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1134
    note enum_eq_benum = this
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1135
    then have "enum ` ({.. n} - {i}) = b.enum ` ({.. n} - {i})"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1136
      by (intro image_cong) auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1137
    then have eq: "s - {a} = b.enum ` {.. n} - {b.enum i}"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1138
      unfolding s_eq \<open>a = enum i\<close>
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1139
      using inj_on_image_set_diff[OF inj_enum Diff_subset \<open>{i} \<subseteq> {..n}\<close>]
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1140
            inj_on_image_set_diff[OF b.inj_enum Diff_subset \<open>{i} \<subseteq> {..n}\<close>]
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1141
      by (simp add: comp_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1142
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1143
    have "a \<noteq> b.enum i"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1144
      using \<open>a = enum i\<close> enum_eq_benum i by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1145
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1146
    { fix t c assume "ksimplex p n t" "c \<in> t" and eq_sma: "s - {a} = t - {c}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1147
      obtain b' u where "kuhn_simplex p n b' u t"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1148
        using \<open>ksimplex p n t\<close> by (auto elim: ksimplex.cases)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1149
      then interpret t: kuhn_simplex p n b' u t .
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1150
      have "enum i' \<in> s - {a}" "enum (i + 1) \<in> s - {a}"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1151
        using \<open>a = enum i\<close> i enum_in by (auto simp: enum_inj i'_def)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1152
      then obtain l k where
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1153
        l: "t.enum l = enum i'" "l \<le> n" "t.enum l \<noteq> c" and
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1154
        k: "t.enum k = enum (i + 1)" "k \<le> n" "t.enum k \<noteq> c"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1155
        unfolding eq_sma by (auto simp: t.s_eq)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1156
      with i have "t.enum l < t.enum k"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1157
        by (simp add: enum_strict_mono i'_def)
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1158
      with \<open>l \<le> n\<close> \<open>k \<le> n\<close> have "l < k"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1159
        by (simp add: t.enum_strict_mono)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1160
      { assume "Suc l = k"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1161
        have "enum (Suc (Suc i')) = t.enum (Suc l)"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1162
          using i by (simp add: k \<open>Suc l = k\<close> i'_def)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1163
        then have False
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1164
          using \<open>l < k\<close> \<open>k \<le> n\<close> \<open>Suc i' < n\<close>
62390
842917225d56 more canonical names
nipkow
parents: 62061
diff changeset
  1165
          by (auto simp: t.enum_Suc enum_Suc l upd_inj fun_eq_iff split: if_split_asm)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1166
             (metis Suc_lessD n_not_Suc_n upd_inj) }
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1167
      with \<open>l < k\<close> have "Suc l < k"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1168
        by arith
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1169
      have c_eq: "c = t.enum (Suc l)"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1170
      proof (rule ccontr)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1171
        assume "c \<noteq> t.enum (Suc l)"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1172
        then have "t.enum (Suc l) \<in> s - {a}"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1173
          using \<open>l < k\<close> \<open>k \<le> n\<close> by (simp add: t.s_eq eq_sma)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1174
        then obtain j where "t.enum (Suc l) = enum j" "j \<le> n" "enum j \<noteq> enum i"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1175
          unfolding s_eq \<open>a = enum i\<close> by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1176
        with i have "t.enum (Suc l) \<le> t.enum l \<or> t.enum k \<le> t.enum (Suc l)"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1177
          by (auto simp: i'_def enum_mono enum_inj l k)
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1178
        with \<open>Suc l < k\<close> \<open>k \<le> n\<close> show False
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1179
          by (simp add: t.enum_mono)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1180
      qed
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1181
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1182
      { have "t.enum (Suc (Suc l)) \<in> s - {a}"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1183
          unfolding eq_sma c_eq t.s_eq using \<open>Suc l < k\<close> \<open>k \<le> n\<close> by (auto simp: t.enum_inj)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1184
        then obtain j where eq: "t.enum (Suc (Suc l)) = enum j" and "j \<le> n" "j \<noteq> i"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1185
          by (auto simp: s_eq \<open>a = enum i\<close>)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1186
        moreover have "enum i' < t.enum (Suc (Suc l))"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1187
          unfolding l(1)[symmetric] using \<open>Suc l < k\<close> \<open>k \<le> n\<close> by (auto simp: t.enum_strict_mono)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1188
        ultimately have "i' < j"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1189
          using i by (simp add: enum_strict_mono i'_def)
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1190
        with \<open>j \<noteq> i\<close> \<open>j \<le> n\<close> have "t.enum k \<le> t.enum (Suc (Suc l))"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1191
          unfolding i'_def by (simp add: enum_mono k eq)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1192
        then have "k \<le> Suc (Suc l)"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1193
          using \<open>k \<le> n\<close> \<open>Suc l < k\<close> by (simp add: t.enum_mono) }
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1194
      with \<open>Suc l < k\<close> have "Suc (Suc l) = k" by simp
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1195
      then have "enum (Suc (Suc i')) = t.enum (Suc (Suc l))"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1196
        using i by (simp add: k i'_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1197
      also have "\<dots> = (enum i') (u l := Suc (enum i' (u l)), u (Suc l) := Suc (enum i' (u (Suc l))))"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1198
        using \<open>Suc l < k\<close> \<open>k \<le> n\<close> by (simp add: t.enum_Suc l t.upd_inj)
61609
77b453bd616f Coercion "real" now has type nat => real only and is no longer overloaded. Type class "real_of" is gone. Many duplicate theorems removed.
paulson <lp15@cam.ac.uk>
parents: 61520
diff changeset
  1199
      finally have "(u l = upd i' \<and> u (Suc l) = upd (Suc i')) \<or>
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1200
        (u l = upd (Suc i') \<and> u (Suc l) = upd i')"
62390
842917225d56 more canonical names
nipkow
parents: 62061
diff changeset
  1201
        using \<open>Suc i' < n\<close> by (auto simp: enum_Suc fun_eq_iff split: if_split_asm)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1202
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1203
      then have "t = s \<or> t = b.enum ` {..n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1204
      proof (elim disjE conjE)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1205
        assume u: "u l = upd i'"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1206
        have "c = t.enum (Suc l)" unfolding c_eq ..
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1207
        also have "t.enum (Suc l) = enum (Suc i')"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1208
          using u \<open>l < k\<close> \<open>k \<le> n\<close> \<open>Suc i' < n\<close> by (simp add: enum_Suc t.enum_Suc l)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1209
        also have "\<dots> = a"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1210
          using \<open>a = enum i\<close> i by (simp add: i'_def)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1211
        finally show ?thesis
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1212
          using eq_sma \<open>a \<in> s\<close> \<open>c \<in> t\<close> by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1213
      next
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1214
        assume u: "u l = upd (Suc i')"
63040
eb4ddd18d635 eliminated old 'def';
wenzelm
parents: 62948
diff changeset
  1215
        define B where "B = b.enum ` {..n}"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1216
        have "b.enum i' = enum i'"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1217
          using enum_eq_benum[of i'] i by (auto simp: i'_def gr0_conv_Suc)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1218
        have "c = t.enum (Suc l)" unfolding c_eq ..
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1219
        also have "t.enum (Suc l) = b.enum (Suc i')"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1220
          using u \<open>l < k\<close> \<open>k \<le> n\<close> \<open>Suc i' < n\<close>
71172
nipkow
parents: 70802
diff changeset
  1221
          by (simp_all add: enum_Suc t.enum_Suc l b.enum_Suc \<open>b.enum i' = enum i'\<close>)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1222
             (simp add: Suc_i')
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1223
        also have "\<dots> = b.enum i"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1224
          using i by (simp add: i'_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1225
        finally have "c = b.enum i" .
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1226
        then have "t - {c} = B - {c}" "c \<in> B"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1227
          unfolding eq_sma[symmetric] eq B_def using i by auto
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1228
        with \<open>c \<in> t\<close> have "t = B"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1229
          by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1230
        then show ?thesis
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1231
          by (simp add: B_def)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1232
      qed }
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1233
    with ks_f' eq \<open>a \<noteq> b.enum i\<close> \<open>n \<noteq> 0\<close> \<open>i \<le> n\<close> show ?thesis
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1234
      apply (intro ex1I[of _ "b.enum ` {.. n}"])
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1235
      apply auto []
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1236
      apply metis
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1237
      done
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1238
  qed
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1239
  then show ?thesis
71449
3cf130a896a3 lemmas about "card A = 2"; prefer iff to implications
nipkow
parents: 71172
diff changeset
  1240
    using s \<open>a \<in> s\<close> by (simp add: card_2_iff' Ex1_def) metis
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1241
qed
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1242
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1243
text \<open>Hence another step towards concreteness.\<close>
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1244
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1245
lemma kuhn_simplex_lemma:
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1246
  assumes "\<forall>s. ksimplex p (Suc n) s \<longrightarrow> rl ` s \<subseteq> {.. Suc n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1247
    and "odd (card {f. \<exists>s a. ksimplex p (Suc n) s \<and> a \<in> s \<and> (f = s - {a}) \<and>
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1248
      rl ` f = {..n} \<and> ((\<exists>j\<le>n. \<forall>x\<in>f. x j = 0) \<or> (\<exists>j\<le>n. \<forall>x\<in>f. x j = p))})"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1249
  shows "odd (card {s. ksimplex p (Suc n) s \<and> rl ` s = {..Suc n}})"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1250
proof (rule kuhn_complete_lemma[OF finite_ksimplexes refl, unfolded mem_Collect_eq,
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1251
    where bnd="\<lambda>f. (\<exists>j\<in>{..n}. \<forall>x\<in>f. x j = 0) \<or> (\<exists>j\<in>{..n}. \<forall>x\<in>f. x j = p)"],
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1252
    safe del: notI)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1253
53186
0f4d9df1eaec tuned proofs;
wenzelm
parents: 53185
diff changeset
  1254
  have *: "\<And>x y. x = y \<Longrightarrow> odd (card x) \<Longrightarrow> odd (card y)"
0f4d9df1eaec tuned proofs;
wenzelm
parents: 53185
diff changeset
  1255
    by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1256
  show "odd (card {f. (\<exists>s\<in>{s. ksimplex p (Suc n) s}. \<exists>a\<in>s. f = s - {a}) \<and>
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1257
    rl ` f = {..n} \<and> ((\<exists>j\<in>{..n}. \<forall>x\<in>f. x j = 0) \<or> (\<exists>j\<in>{..n}. \<forall>x\<in>f. x j = p))})"
53186
0f4d9df1eaec tuned proofs;
wenzelm
parents: 53185
diff changeset
  1258
    apply (rule *[OF _ assms(2)])
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1259
    apply (auto simp: atLeast0AtMost)
53186
0f4d9df1eaec tuned proofs;
wenzelm
parents: 53185
diff changeset
  1260
    done
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1261
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1262
next
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1263
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1264
  fix s assume s: "ksimplex p (Suc n) s"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1265
  then show "card s = n + 2"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1266
    by (simp add: ksimplex_card)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1267
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1268
  fix a assume a: "a \<in> s" then show "rl a \<le> Suc n"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1269
    using assms(1) s by (auto simp: subset_eq)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1270
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1271
  let ?S = "{t. ksimplex p (Suc n) t \<and> (\<exists>b\<in>t. s - {a} = t - {b})}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1272
  { fix j assume j: "j \<le> n" "\<forall>x\<in>s - {a}. x j = 0"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1273
    with s a show "card ?S = 1"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1274
      using ksimplex_replace_0[of p "n + 1" s a j]
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1275
      by (subst eq_commute) simp }
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1276
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1277
  { fix j assume j: "j \<le> n" "\<forall>x\<in>s - {a}. x j = p"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1278
    with s a show "card ?S = 1"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1279
      using ksimplex_replace_1[of p "n + 1" s a j]
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1280
      by (subst eq_commute) simp }
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1281
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1282
  { assume "card ?S \<noteq> 2" "\<not> (\<exists>j\<in>{..n}. \<forall>x\<in>s - {a}. x j = p)"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1283
    with s a show "\<exists>j\<in>{..n}. \<forall>x\<in>s - {a}. x j = 0"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1284
      using ksimplex_replace_2[of p "n + 1" s a]
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1285
      by (subst (asm) eq_commute) auto }
53186
0f4d9df1eaec tuned proofs;
wenzelm
parents: 53185
diff changeset
  1286
qed
0f4d9df1eaec tuned proofs;
wenzelm
parents: 53185
diff changeset
  1287
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
  1288
subsubsection \<open>Reduced labelling\<close>
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1289
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1290
definition reduced :: "nat \<Rightarrow> (nat \<Rightarrow> nat) \<Rightarrow> nat" where "reduced n x = (LEAST k. k = n \<or> x k \<noteq> 0)"
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1291
53186
0f4d9df1eaec tuned proofs;
wenzelm
parents: 53185
diff changeset
  1292
lemma reduced_labelling:
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1293
  shows "reduced n x \<le> n"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1294
    and "\<forall>i<reduced n x. x i = 0"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1295
    and "reduced n x = n \<or> x (reduced n x) \<noteq> 0"
53186
0f4d9df1eaec tuned proofs;
wenzelm
parents: 53185
diff changeset
  1296
proof -
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1297
  show "reduced n x \<le> n"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1298
    unfolding reduced_def by (rule LeastI2_wellorder[where a=n]) auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1299
  show "\<forall>i<reduced n x. x i = 0"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1300
    unfolding reduced_def by (rule LeastI2_wellorder[where a=n]) fastforce+
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1301
  show "reduced n x = n \<or> x (reduced n x) \<noteq> 0"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1302
    unfolding reduced_def by (rule LeastI2_wellorder[where a=n]) fastforce+
53186
0f4d9df1eaec tuned proofs;
wenzelm
parents: 53185
diff changeset
  1303
qed
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1304
53186
0f4d9df1eaec tuned proofs;
wenzelm
parents: 53185
diff changeset
  1305
lemma reduced_labelling_unique:
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1306
  "r \<le> n \<Longrightarrow> \<forall>i<r. x i = 0 \<Longrightarrow> r = n \<or> x r \<noteq> 0 \<Longrightarrow> reduced n x = r"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  1307
  by (metis linorder_less_linear linorder_not_le reduced_labelling)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1308
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1309
lemma reduced_labelling_zero: "j < n \<Longrightarrow> x j = 0 \<Longrightarrow> reduced n x \<noteq> j"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1310
  using reduced_labelling[of n x] by auto
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1311
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1312
lemma reduce_labelling_zero[simp]: "reduced 0 x = 0"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1313
  by (rule reduced_labelling_unique) auto
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1314
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1315
lemma reduced_labelling_nonzero: "j < n \<Longrightarrow> x j \<noteq> 0 \<Longrightarrow> reduced n x \<le> j"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1316
  using reduced_labelling[of n x] by (elim allE[where x=j]) auto
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1317
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1318
lemma reduced_labelling_Suc: "reduced (Suc n) x \<noteq> Suc n \<Longrightarrow> reduced (Suc n) x = reduced n x"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1319
  using reduced_labelling[of "Suc n" x]
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1320
  by (intro reduced_labelling_unique[symmetric]) auto
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1321
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1322
lemma complete_face_top:
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1323
  assumes "\<forall>x\<in>f. \<forall>j\<le>n. x j = 0 \<longrightarrow> lab x j = 0"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1324
    and "\<forall>x\<in>f. \<forall>j\<le>n. x j = p \<longrightarrow> lab x j = 1"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1325
    and eq: "(reduced (Suc n) \<circ> lab) ` f = {..n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1326
  shows "((\<exists>j\<le>n. \<forall>x\<in>f. x j = 0) \<or> (\<exists>j\<le>n. \<forall>x\<in>f. x j = p)) \<longleftrightarrow> (\<forall>x\<in>f. x n = p)"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1327
proof (safe del: disjCI)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1328
  fix x j assume j: "j \<le> n" "\<forall>x\<in>f. x j = 0"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1329
  { fix x assume "x \<in> f" with assms j have "reduced (Suc n) (lab x) \<noteq> j"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1330
      by (intro reduced_labelling_zero) auto }
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1331
  moreover have "j \<in> (reduced (Suc n) \<circ> lab) ` f"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1332
    using j eq by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1333
  ultimately show "x n = p"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1334
    by force
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1335
next
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1336
  fix x j assume j: "j \<le> n" "\<forall>x\<in>f. x j = p" and x: "x \<in> f"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1337
  have "j = n"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1338
  proof (rule ccontr)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1339
    assume "\<not> ?thesis"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1340
    { fix x assume "x \<in> f"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1341
      with assms j have "reduced (Suc n) (lab x) \<le> j"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1342
        by (intro reduced_labelling_nonzero) auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1343
      then have "reduced (Suc n) (lab x) \<noteq> n"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1344
        using \<open>j \<noteq> n\<close> \<open>j \<le> n\<close> by simp }
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1345
    moreover
61609
77b453bd616f Coercion "real" now has type nat => real only and is no longer overloaded. Type class "real_of" is gone. Many duplicate theorems removed.
paulson <lp15@cam.ac.uk>
parents: 61520
diff changeset
  1346
    have "n \<in> (reduced (Suc n) \<circ> lab) ` f"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1347
      using eq by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1348
    ultimately show False
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1349
      by force
53186
0f4d9df1eaec tuned proofs;
wenzelm
parents: 53185
diff changeset
  1350
  qed
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1351
  moreover have "j \<in> (reduced (Suc n) \<circ> lab) ` f"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1352
    using j eq by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1353
  ultimately show "x n = p"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1354
    using j x by auto
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1355
qed auto
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1356
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1357
text \<open>Hence we get just about the nice induction.\<close>
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1358
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1359
lemma kuhn_induction:
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1360
  assumes "0 < p"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1361
    and lab_0: "\<forall>x. \<forall>j\<le>n. (\<forall>j. x j \<le> p) \<and> x j = 0 \<longrightarrow> lab x j = 0"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1362
    and lab_1: "\<forall>x. \<forall>j\<le>n. (\<forall>j. x j \<le> p) \<and> x j = p \<longrightarrow> lab x j = 1"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1363
    and odd: "odd (card {s. ksimplex p n s \<and> (reduced n\<circ>lab) ` s = {..n}})"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1364
  shows "odd (card {s. ksimplex p (Suc n) s \<and> (reduced (Suc n)\<circ>lab) ` s = {..Suc n}})"
53248
7a4b4b3b9ecd tuned proofs;
wenzelm
parents: 53186
diff changeset
  1365
proof -
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1366
  let ?rl = "reduced (Suc n) \<circ> lab" and ?ext = "\<lambda>f v. \<exists>j\<le>n. \<forall>x\<in>f. x j = v"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1367
  let ?ext = "\<lambda>s. (\<exists>j\<le>n. \<forall>x\<in>s. x j = 0) \<or> (\<exists>j\<le>n. \<forall>x\<in>s. x j = p)"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1368
  have "\<forall>s. ksimplex p (Suc n) s \<longrightarrow> ?rl ` s \<subseteq> {..Suc n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1369
    by (simp add: reduced_labelling subset_eq)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1370
  moreover
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1371
  have "{s. ksimplex p n s \<and> (reduced n \<circ> lab) ` s = {..n}} =
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1372
        {f. \<exists>s a. ksimplex p (Suc n) s \<and> a \<in> s \<and> f = s - {a} \<and> ?rl ` f = {..n} \<and> ?ext f}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1373
  proof (intro set_eqI, safe del: disjCI equalityI disjE)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1374
    fix s assume s: "ksimplex p n s" and rl: "(reduced n \<circ> lab) ` s = {..n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1375
    from s obtain u b where "kuhn_simplex p n u b s" by (auto elim: ksimplex.cases)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1376
    then interpret kuhn_simplex p n u b s .
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1377
    have all_eq_p: "\<forall>x\<in>s. x n = p"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1378
      by (auto simp: out_eq_p)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1379
    moreover
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1380
    { fix x assume "x \<in> s"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  1381
      with lab_1[rule_format, of n x] all_eq_p s_le_p[of x] 
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1382
      have "?rl x \<le> n"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1383
        by (auto intro!: reduced_labelling_nonzero)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1384
      then have "?rl x = reduced n (lab x)"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1385
        by (auto intro!: reduced_labelling_Suc) }
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1386
    then have "?rl ` s = {..n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1387
      using rl by (simp cong: image_cong)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1388
    moreover
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1389
    obtain t a where "ksimplex p (Suc n) t" "a \<in> t" "s = t - {a}"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1390
      using s unfolding simplex_top_face[OF \<open>0 < p\<close> all_eq_p] by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1391
    ultimately
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1392
    show "\<exists>t a. ksimplex p (Suc n) t \<and> a \<in> t \<and> s = t - {a} \<and> ?rl ` s = {..n} \<and> ?ext s"
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1393
      by auto
53248
7a4b4b3b9ecd tuned proofs;
wenzelm
parents: 53186
diff changeset
  1394
  next
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1395
    fix x s a assume s: "ksimplex p (Suc n) s" and rl: "?rl ` (s - {a}) = {.. n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1396
      and a: "a \<in> s" and "?ext (s - {a})"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1397
    from s obtain u b where "kuhn_simplex p (Suc n) u b s" by (auto elim: ksimplex.cases)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1398
    then interpret kuhn_simplex p "Suc n" u b s .
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1399
    have all_eq_p: "\<forall>x\<in>s. x (Suc n) = p"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1400
      by (auto simp: out_eq_p)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1401
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1402
    { fix x assume "x \<in> s - {a}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1403
      then have "?rl x \<in> ?rl ` (s - {a})"
53248
7a4b4b3b9ecd tuned proofs;
wenzelm
parents: 53186
diff changeset
  1404
        by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1405
      then have "?rl x \<le> n"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1406
        unfolding rl by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1407
      then have "?rl x = reduced n (lab x)"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1408
        by (auto intro!: reduced_labelling_Suc) }
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1409
    then show rl': "(reduced n\<circ>lab) ` (s - {a}) = {..n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1410
      unfolding rl[symmetric] by (intro image_cong) auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1411
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1412
    from \<open>?ext (s - {a})\<close>
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1413
    have all_eq_p: "\<forall>x\<in>s - {a}. x n = p"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1414
    proof (elim disjE exE conjE)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1415
      fix j assume "j \<le> n" "\<forall>x\<in>s - {a}. x j = 0"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1416
      with lab_0[rule_format, of j] all_eq_p s_le_p
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1417
      have "\<And>x. x \<in> s - {a} \<Longrightarrow> reduced (Suc n) (lab x) \<noteq> j"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1418
        by (intro reduced_labelling_zero) auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1419
      moreover have "j \<in> ?rl ` (s - {a})"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1420
        using \<open>j \<le> n\<close> unfolding rl by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1421
      ultimately show ?thesis
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1422
        by force
53248
7a4b4b3b9ecd tuned proofs;
wenzelm
parents: 53186
diff changeset
  1423
    next
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1424
      fix j assume "j \<le> n" and eq_p: "\<forall>x\<in>s - {a}. x j = p"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1425
      show ?thesis
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1426
      proof cases
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1427
        assume "j = n" with eq_p show ?thesis by simp
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1428
      next
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1429
        assume "j \<noteq> n"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1430
        { fix x assume x: "x \<in> s - {a}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1431
          have "reduced n (lab x) \<le> j"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1432
          proof (rule reduced_labelling_nonzero)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1433
            show "lab x j \<noteq> 0"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1434
              using lab_1[rule_format, of j x] x s_le_p[of x] eq_p \<open>j \<le> n\<close> by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1435
            show "j < n"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1436
              using \<open>j \<le> n\<close> \<open>j \<noteq> n\<close> by simp
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1437
          qed
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1438
          then have "reduced n (lab x) \<noteq> n"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1439
            using \<open>j \<le> n\<close> \<open>j \<noteq> n\<close> by simp }
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1440
        moreover have "n \<in> (reduced n\<circ>lab) ` (s - {a})"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1441
          unfolding rl' by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1442
        ultimately show ?thesis
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1443
          by force
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1444
      qed
53248
7a4b4b3b9ecd tuned proofs;
wenzelm
parents: 53186
diff changeset
  1445
    qed
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1446
    show "ksimplex p n (s - {a})"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1447
      unfolding simplex_top_face[OF \<open>0 < p\<close> all_eq_p] using s a by auto
53248
7a4b4b3b9ecd tuned proofs;
wenzelm
parents: 53186
diff changeset
  1448
  qed
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1449
  ultimately show ?thesis
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1450
    using assms by (intro kuhn_simplex_lemma) auto
53248
7a4b4b3b9ecd tuned proofs;
wenzelm
parents: 53186
diff changeset
  1451
qed
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1452
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1453
text \<open>And so we get the final combinatorial result.\<close>
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1454
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1455
lemma ksimplex_0: "ksimplex p 0 s \<longleftrightarrow> s = {(\<lambda>x. p)}"
53248
7a4b4b3b9ecd tuned proofs;
wenzelm
parents: 53186
diff changeset
  1456
proof
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1457
  assume "ksimplex p 0 s" then show "s = {(\<lambda>x. p)}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1458
    by (blast dest: kuhn_simplex.ksimplex_0 elim: ksimplex.cases)
53248
7a4b4b3b9ecd tuned proofs;
wenzelm
parents: 53186
diff changeset
  1459
next
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1460
  assume s: "s = {(\<lambda>x. p)}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1461
  show "ksimplex p 0 s"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1462
  proof (intro ksimplex, unfold_locales)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1463
    show "(\<lambda>_. p) \<in> {..<0::nat} \<rightarrow> {..<p}" by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1464
    show "bij_betw id {..<0} {..<0}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1465
      by simp
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1466
  qed (auto simp: s)
53248
7a4b4b3b9ecd tuned proofs;
wenzelm
parents: 53186
diff changeset
  1467
qed
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1468
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1469
lemma kuhn_combinatorial:
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1470
  assumes "0 < p"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1471
    and "\<forall>x j. (\<forall>j. x j \<le> p) \<and> j < n \<and> x j = 0 \<longrightarrow> lab x j = 0"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1472
    and "\<forall>x j. (\<forall>j. x j \<le> p) \<and> j < n  \<and> x j = p \<longrightarrow> lab x j = 1"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1473
  shows "odd (card {s. ksimplex p n s \<and> (reduced n\<circ>lab) ` s = {..n}})"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1474
    (is "odd (card (?M n))")
53248
7a4b4b3b9ecd tuned proofs;
wenzelm
parents: 53186
diff changeset
  1475
  using assms
7a4b4b3b9ecd tuned proofs;
wenzelm
parents: 53186
diff changeset
  1476
proof (induct n)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1477
  case 0 then show ?case
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1478
    by (simp add: ksimplex_0 cong: conj_cong)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1479
next
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1480
  case (Suc n)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1481
  then have "odd (card (?M n))"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1482
    by force
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1483
  with Suc show ?case
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1484
    using kuhn_induction[of p n] by (auto simp: comp_def)
53248
7a4b4b3b9ecd tuned proofs;
wenzelm
parents: 53186
diff changeset
  1485
qed
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1486
53248
7a4b4b3b9ecd tuned proofs;
wenzelm
parents: 53186
diff changeset
  1487
lemma kuhn_lemma:
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1488
  fixes n p :: nat
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1489
  assumes "0 < p"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1490
    and "\<forall>x. (\<forall>i<n. x i \<le> p) \<longrightarrow> (\<forall>i<n. label x i = (0::nat) \<or> label x i = 1)"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1491
    and "\<forall>x. (\<forall>i<n. x i \<le> p) \<longrightarrow> (\<forall>i<n. x i = 0 \<longrightarrow> label x i = 0)"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1492
    and "\<forall>x. (\<forall>i<n. x i \<le> p) \<longrightarrow> (\<forall>i<n. x i = p \<longrightarrow> label x i = 1)"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1493
  obtains q where "\<forall>i<n. q i < p"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1494
    and "\<forall>i<n. \<exists>r s. (\<forall>j<n. q j \<le> r j \<and> r j \<le> q j + 1) \<and> (\<forall>j<n. q j \<le> s j \<and> s j \<le> q j + 1) \<and> label r i \<noteq> label s i"
53248
7a4b4b3b9ecd tuned proofs;
wenzelm
parents: 53186
diff changeset
  1495
proof -
60580
7e741e22d7fc tuned proofs;
wenzelm
parents: 60449
diff changeset
  1496
  let ?rl = "reduced n \<circ> label"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1497
  let ?A = "{s. ksimplex p n s \<and> ?rl ` s = {..n}}"
53248
7a4b4b3b9ecd tuned proofs;
wenzelm
parents: 53186
diff changeset
  1498
  have "odd (card ?A)"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1499
    using assms by (intro kuhn_combinatorial[of p n label]) auto
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1500
  then have "?A \<noteq> {}"
69661
a03a63b81f44 tuned proofs
haftmann
parents: 69620
diff changeset
  1501
    by (rule odd_card_imp_not_empty)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1502
  then obtain s b u where "kuhn_simplex p n b u s" and rl: "?rl ` s = {..n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1503
    by (auto elim: ksimplex.cases)
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1504
  interpret kuhn_simplex p n b u s by fact
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1505
53248
7a4b4b3b9ecd tuned proofs;
wenzelm
parents: 53186
diff changeset
  1506
  show ?thesis
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1507
  proof (intro that[of b] allI impI)
60580
7e741e22d7fc tuned proofs;
wenzelm
parents: 60449
diff changeset
  1508
    fix i
7e741e22d7fc tuned proofs;
wenzelm
parents: 60449
diff changeset
  1509
    assume "i < n"
7e741e22d7fc tuned proofs;
wenzelm
parents: 60449
diff changeset
  1510
    then show "b i < p"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1511
      using base by auto
53248
7a4b4b3b9ecd tuned proofs;
wenzelm
parents: 53186
diff changeset
  1512
  next
60580
7e741e22d7fc tuned proofs;
wenzelm
parents: 60449
diff changeset
  1513
    fix i
7e741e22d7fc tuned proofs;
wenzelm
parents: 60449
diff changeset
  1514
    assume "i < n"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1515
    then have "i \<in> {.. n}" "Suc i \<in> {.. n}"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1516
      by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1517
    then obtain u v where u: "u \<in> s" "Suc i = ?rl u" and v: "v \<in> s" "i = ?rl v"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1518
      unfolding rl[symmetric] by blast
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1519
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1520
    have "label u i \<noteq> label v i"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1521
      using reduced_labelling [of n "label u"] reduced_labelling [of n "label v"]
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1522
        u(2)[symmetric] v(2)[symmetric] \<open>i < n\<close>
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1523
      by auto
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1524
    moreover
60580
7e741e22d7fc tuned proofs;
wenzelm
parents: 60449
diff changeset
  1525
    have "b j \<le> u j" "u j \<le> b j + 1" "b j \<le> v j" "v j \<le> b j + 1" if "j < n" for j
7e741e22d7fc tuned proofs;
wenzelm
parents: 60449
diff changeset
  1526
      using that base_le[OF \<open>u\<in>s\<close>] le_Suc_base[OF \<open>u\<in>s\<close>] base_le[OF \<open>v\<in>s\<close>] le_Suc_base[OF \<open>v\<in>s\<close>]
7e741e22d7fc tuned proofs;
wenzelm
parents: 60449
diff changeset
  1527
      by auto
7e741e22d7fc tuned proofs;
wenzelm
parents: 60449
diff changeset
  1528
    ultimately show "\<exists>r s. (\<forall>j<n. b j \<le> r j \<and> r j \<le> b j + 1) \<and>
7e741e22d7fc tuned proofs;
wenzelm
parents: 60449
diff changeset
  1529
        (\<forall>j<n. b j \<le> s j \<and> s j \<le> b j + 1) \<and> label r i \<noteq> label s i"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1530
      by blast
53248
7a4b4b3b9ecd tuned proofs;
wenzelm
parents: 53186
diff changeset
  1531
  qed
7a4b4b3b9ecd tuned proofs;
wenzelm
parents: 53186
diff changeset
  1532
qed
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1533
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
  1534
subsubsection \<open>Main result for the unit cube\<close>
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1535
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1536
lemma kuhn_labelling_lemma':
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1537
  assumes "(\<forall>x::nat\<Rightarrow>real. P x \<longrightarrow> P (f x))"
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1538
    and "\<forall>x. P x \<longrightarrow> (\<forall>i::nat. Q i \<longrightarrow> 0 \<le> x i \<and> x i \<le> 1)"
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1539
  shows "\<exists>l. (\<forall>x i. l x i \<le> (1::nat)) \<and>
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1540
             (\<forall>x i. P x \<and> Q i \<and> x i = 0 \<longrightarrow> l x i = 0) \<and>
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1541
             (\<forall>x i. P x \<and> Q i \<and> x i = 1 \<longrightarrow> l x i = 1) \<and>
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1542
             (\<forall>x i. P x \<and> Q i \<and> l x i = 0 \<longrightarrow> x i \<le> f x i) \<and>
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1543
             (\<forall>x i. P x \<and> Q i \<and> l x i = 1 \<longrightarrow> f x i \<le> x i)"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  1544
  unfolding all_conj_distrib [symmetric] 
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  1545
  apply (subst choice_iff[symmetric])+
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  1546
  by (metis assms choice_iff bot_nat_0.extremum nle_le zero_neq_one)
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1547
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
  1548
subsection \<open>Brouwer's fixed point theorem\<close>
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
  1549
68621
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1550
text \<open>We start proving Brouwer's fixed point theorem for the unit cube = \<open>cbox 0 One\<close>.\<close>
56117
2dbf84ee3deb remove ordered_euclidean_space constraint from brouwer/derivative lemmas;
huffman
parents: 55522
diff changeset
  1551
50526
899c9c4e4a4c Remove the indexed basis from the definition of euclidean spaces and only use the set of Basis vectors
hoelzl
parents: 50514
diff changeset
  1552
lemma brouwer_cube:
56117
2dbf84ee3deb remove ordered_euclidean_space constraint from brouwer/derivative lemmas;
huffman
parents: 55522
diff changeset
  1553
  fixes f :: "'a::euclidean_space \<Rightarrow> 'a"
68621
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1554
  assumes "continuous_on (cbox 0 One) f"
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1555
    and "f ` cbox 0 One \<subseteq> cbox 0 One"
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1556
  shows "\<exists>x\<in>cbox 0 One. f x = x"
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1557
proof (rule ccontr)
63040
eb4ddd18d635 eliminated old 'def';
wenzelm
parents: 62948
diff changeset
  1558
  define n where "n = DIM('a)"
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1559
  have n: "1 \<le> n" "0 < n" "n \<noteq> 0"
71172
nipkow
parents: 70802
diff changeset
  1560
    unfolding n_def by (auto simp: Suc_le_eq)
53674
7ac7b2eaa5e6 tuned proofs;
wenzelm
parents: 53252
diff changeset
  1561
  assume "\<not> ?thesis"
68621
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1562
  then have *: "\<not> (\<exists>x\<in>cbox 0 One. f x - x = 0)"
53674
7ac7b2eaa5e6 tuned proofs;
wenzelm
parents: 53252
diff changeset
  1563
    by auto
55522
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1564
  obtain d where
68621
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1565
      d: "d > 0" "\<And>x. x \<in> cbox 0 One \<Longrightarrow> d \<le> norm (f x - x)"
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  1566
    using brouwer_compactness_lemma[OF compact_cbox _ *] assms
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  1567
    by (metis (no_types, lifting) continuous_on_cong continuous_on_diff continuous_on_id)
68621
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1568
  have *: "\<forall>x. x \<in> cbox 0 One \<longrightarrow> f x \<in> cbox 0 One"
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1569
    "\<forall>x. x \<in> (cbox 0 One::'a set) \<longrightarrow> (\<forall>i\<in>Basis. True \<longrightarrow> 0 \<le> x \<bullet> i \<and> x \<bullet> i \<le> 1)"
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1570
    using assms(2)[unfolded image_subset_iff Ball_def]
68621
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1571
    unfolding cbox_def
55522
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1572
    by auto
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1573
  obtain label :: "'a \<Rightarrow> 'a \<Rightarrow> nat" where label [rule_format]:
55522
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1574
    "\<forall>x. \<forall>i\<in>Basis. label x i \<le> 1"
68621
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1575
    "\<forall>x. \<forall>i\<in>Basis. x \<in> cbox 0 One \<and> x \<bullet> i = 0 \<longrightarrow> label x i = 0"
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1576
    "\<forall>x. \<forall>i\<in>Basis. x \<in> cbox 0 One \<and> x \<bullet> i = 1 \<longrightarrow> label x i = 1"
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1577
    "\<forall>x. \<forall>i\<in>Basis. x \<in> cbox 0 One \<and> label x i = 0 \<longrightarrow> x \<bullet> i \<le> f x \<bullet> i"
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1578
    "\<forall>x. \<forall>i\<in>Basis. x \<in> cbox 0 One \<and> label x i = 1 \<longrightarrow> f x \<bullet> i \<le> x \<bullet> i"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1579
    using kuhn_labelling_lemma[OF *] by auto
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1580
  note label = this [rule_format]
68621
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1581
  have lem1: "\<forall>x\<in>cbox 0 One. \<forall>y\<in>cbox 0 One. \<forall>i\<in>Basis. label x i \<noteq> label y i \<longrightarrow>
61945
1135b8de26c3 more symbols;
wenzelm
parents: 61808
diff changeset
  1582
    \<bar>f x \<bullet> i - x \<bullet> i\<bar> \<le> norm (f y - f x) + norm (y - x)"
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1583
  proof safe
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1584
    fix x y :: 'a
68621
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1585
    assume x: "x \<in> cbox 0 One" and y: "y \<in> cbox 0 One"
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1586
    fix i
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1587
    assume i: "label x i \<noteq> label y i" "i \<in> Basis"
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1588
    have *: "\<And>x y fx fy :: real. x \<le> fx \<and> fy \<le> y \<or> fx \<le> x \<and> y \<le> fy \<Longrightarrow>
61945
1135b8de26c3 more symbols;
wenzelm
parents: 61808
diff changeset
  1589
      \<bar>fx - x\<bar> \<le> \<bar>fy - fx\<bar> + \<bar>y - x\<bar>" by auto
1135b8de26c3 more symbols;
wenzelm
parents: 61808
diff changeset
  1590
    have "\<bar>(f x - x) \<bullet> i\<bar> \<le> \<bar>(f y - f x)\<bullet>i\<bar> + \<bar>(y - x)\<bullet>i\<bar>"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1591
    proof (cases "label x i = 0")
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1592
      case True
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1593
      then have fxy: "\<not> f y \<bullet> i \<le> y \<bullet> i \<Longrightarrow> f x \<bullet> i \<le> x \<bullet> i"
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1594
        by (metis True i label(1) label(5) le_antisym less_one not_le_imp_less y)
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1595
      show ?thesis
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1596
      unfolding inner_simps         
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1597
      by (rule *) (auto simp: True i label x y fxy)
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1598
    next
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1599
      case False
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1600
      then show ?thesis
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1601
        using label [OF \<open>i \<in> Basis\<close>] i(1) x y
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  1602
        by (smt (verit, ccfv_threshold) inner_diff_left less_one order_le_less)
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1603
    qed
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1604
    also have "\<dots> \<le> norm (f y - f x) + norm (y - x)"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1605
      by (simp add: add_mono i(2) norm_bound_Basis_le)
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1606
    finally show "\<bar>f x \<bullet> i - x \<bullet> i\<bar> \<le> norm (f y - f x) + norm (y - x)"
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1607
      unfolding inner_simps .
50526
899c9c4e4a4c Remove the indexed basis from the definition of euclidean spaces and only use the set of Basis vectors
hoelzl
parents: 50514
diff changeset
  1608
  qed
68621
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1609
  have "\<exists>e>0. \<forall>x\<in>cbox 0 One. \<forall>y\<in>cbox 0 One. \<forall>z\<in>cbox 0 One. \<forall>i\<in>Basis.
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1610
    norm (x - z) < e \<longrightarrow> norm (y - z) < e \<longrightarrow> label x i \<noteq> label y i \<longrightarrow>
61945
1135b8de26c3 more symbols;
wenzelm
parents: 61808
diff changeset
  1611
      \<bar>(f(z) - z)\<bullet>i\<bar> < d / (real n)"
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1612
  proof -
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1613
    have d': "d / real n / 8 > 0"
71172
nipkow
parents: 70802
diff changeset
  1614
      using d(1) by (simp add: n_def)
68621
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1615
    have *: "uniformly_continuous_on (cbox 0 One) f"
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1616
      by (rule compact_uniformly_continuous[OF assms(1) compact_cbox])
55522
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1617
    obtain e where e:
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1618
        "e > 0"
68621
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1619
        "\<And>x x'. x \<in> cbox 0 One \<Longrightarrow>
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1620
          x' \<in> cbox 0 One \<Longrightarrow>
55522
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1621
          norm (x' - x) < e \<Longrightarrow>
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1622
          norm (f x' - f x) < d / real n / 8"
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1623
      using *[unfolded uniformly_continuous_on_def,rule_format,OF d']
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1624
      unfolding dist_norm
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1625
      by blast
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1626
    show ?thesis
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1627
    proof (intro exI conjI ballI impI)
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1628
      show "0 < min (e / 2) (d / real n / 8)"
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1629
        using d' e by auto
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1630
      fix x y z i
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1631
      assume as:
68621
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1632
        "x \<in> cbox 0 One" "y \<in> cbox 0 One" "z \<in> cbox 0 One"
37489
44e42d392c6e Introduce a type class for euclidean spaces, port most lemmas from real^'n to this type class.
hoelzl
parents: 36587
diff changeset
  1633
        "norm (x - z) < min (e / 2) (d / real n / 8)"
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1634
        "norm (y - z) < min (e / 2) (d / real n / 8)"
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1635
        "label x i \<noteq> label y i"
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1636
      assume i: "i \<in> Basis"
61945
1135b8de26c3 more symbols;
wenzelm
parents: 61808
diff changeset
  1637
      have *: "\<And>z fz x fx n1 n2 n3 n4 d4 d :: real. \<bar>fx - x\<bar> \<le> n1 + n2 \<Longrightarrow>
1135b8de26c3 more symbols;
wenzelm
parents: 61808
diff changeset
  1638
        \<bar>fx - fz\<bar> \<le> n3 \<Longrightarrow> \<bar>x - z\<bar> \<le> n4 \<Longrightarrow>
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1639
        n1 < d4 \<Longrightarrow> n2 < 2 * d4 \<Longrightarrow> n3 < d4 \<Longrightarrow> n4 < d4 \<Longrightarrow>
61945
1135b8de26c3 more symbols;
wenzelm
parents: 61808
diff changeset
  1640
        (8 * d4 = d) \<Longrightarrow> \<bar>fz - z\<bar> < d"
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1641
        by auto
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1642
      show "\<bar>(f z - z) \<bullet> i\<bar> < d / real n"
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1643
        unfolding inner_simps
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1644
      proof (rule *)
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1645
        show "\<bar>f x \<bullet> i - x \<bullet> i\<bar> \<le> norm (f y -f x) + norm (y - x)"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1646
          using as(1) as(2) as(6) i lem1 by blast
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1647
        show "norm (f x - f z) < d / real n / 8"
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1648
          using d' e as by auto
50526
899c9c4e4a4c Remove the indexed basis from the definition of euclidean spaces and only use the set of Basis vectors
hoelzl
parents: 50514
diff changeset
  1649
        show "\<bar>f x \<bullet> i - f z \<bullet> i\<bar> \<le> norm (f x - f z)" "\<bar>x \<bullet> i - z \<bullet> i\<bar> \<le> norm (x - z)"
55522
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1650
          unfolding inner_diff_left[symmetric]
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1651
          by (rule Basis_le_norm[OF i])+
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1652
        have tria: "norm (y - x) \<le> norm (y - z) + norm (x - z)"
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1653
          using dist_triangle[of y x z, unfolded dist_norm]
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1654
          unfolding norm_minus_commute
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1655
          by auto
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1656
        also have "\<dots> < e / 2 + e / 2"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1657
          using as(4) as(5) by auto
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1658
        finally show "norm (f y - f x) < d / real n / 8"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1659
          using as(1) as(2) e(2) by auto
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1660
        have "norm (y - z) + norm (x - z) < d / real n / 8 + d / real n / 8"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1661
          using as(4) as(5) by auto
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1662
        with tria show "norm (y - x) < 2 * (d / real n / 8)"
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1663
          by auto
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1664
      qed (use as in auto)
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1665
    qed
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1666
  qed
55522
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1667
  then
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1668
  obtain e where e:
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1669
    "e > 0"
68621
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1670
    "\<And>x y z i. x \<in> cbox 0 One \<Longrightarrow>
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1671
      y \<in> cbox 0 One \<Longrightarrow>
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1672
      z \<in> cbox 0 One \<Longrightarrow>
55522
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1673
      i \<in> Basis \<Longrightarrow>
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1674
      norm (x - z) < e \<and> norm (y - z) < e \<and> label x i \<noteq> label y i \<Longrightarrow>
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1675
      \<bar>(f z - z) \<bullet> i\<bar> < d / real n"
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1676
    by blast
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1677
  obtain p :: nat where p: "1 + real n / e \<le> real p"
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1678
    using real_arch_simple ..
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1679
  have "1 + real n / e > 0"
56541
0e3abadbef39 made divide_pos_pos a simp rule
nipkow
parents: 56371
diff changeset
  1680
    using e(1) n by (simp add: add_pos_pos)
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1681
  then have "p > 0"
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1682
    using p by auto
50526
899c9c4e4a4c Remove the indexed basis from the definition of euclidean spaces and only use the set of Basis vectors
hoelzl
parents: 50514
diff changeset
  1683
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1684
  obtain b :: "nat \<Rightarrow> 'a" where b: "bij_betw b {..< n} Basis"
50526
899c9c4e4a4c Remove the indexed basis from the definition of euclidean spaces and only use the set of Basis vectors
hoelzl
parents: 50514
diff changeset
  1685
    by atomize_elim (auto simp: n_def intro!: finite_same_card_bij)
63040
eb4ddd18d635 eliminated old 'def';
wenzelm
parents: 62948
diff changeset
  1686
  define b' where "b' = inv_into {..< n} b"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1687
  then have b': "bij_betw b' Basis {..< n}"
50526
899c9c4e4a4c Remove the indexed basis from the definition of euclidean spaces and only use the set of Basis vectors
hoelzl
parents: 50514
diff changeset
  1688
    using bij_betw_inv_into[OF b] by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1689
  then have b'_Basis: "\<And>i. i \<in> Basis \<Longrightarrow> b' i \<in> {..< n}"
50526
899c9c4e4a4c Remove the indexed basis from the definition of euclidean spaces and only use the set of Basis vectors
hoelzl
parents: 50514
diff changeset
  1690
    unfolding bij_betw_def by (auto simp: set_eq_iff)
899c9c4e4a4c Remove the indexed basis from the definition of euclidean spaces and only use the set of Basis vectors
hoelzl
parents: 50514
diff changeset
  1691
  have bb'[simp]:"\<And>i. i \<in> Basis \<Longrightarrow> b (b' i) = i"
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1692
    unfolding b'_def
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1693
    using b
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1694
    by (auto simp: f_inv_into_f bij_betw_def)
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1695
  have b'b[simp]:"\<And>i. i < n \<Longrightarrow> b' (b i) = i"
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1696
    unfolding b'_def
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1697
    using b
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1698
    by (auto simp: inv_into_f_eq bij_betw_def)
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1699
  have *: "\<And>x :: nat. x = 0 \<or> x = 1 \<longleftrightarrow> x \<le> 1"
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1700
    by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1701
  have b'': "\<And>j. j < n \<Longrightarrow> b j \<in> Basis"
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1702
    using b unfolding bij_betw_def by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1703
  have q1: "0 < p" "\<forall>x. (\<forall>i<n. x i \<le> p) \<longrightarrow>
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1704
    (\<forall>i<n. (label (\<Sum>i\<in>Basis. (real (x (b' i)) / real p) *\<^sub>R i) \<circ> b) i = 0 \<or>
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1705
           (label (\<Sum>i\<in>Basis. (real (x (b' i)) / real p) *\<^sub>R i) \<circ> b) i = 1)"
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1706
    unfolding *
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1707
    using \<open>p > 0\<close> \<open>n > 0\<close>
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1708
    using label(1)[OF b'']
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1709
    by auto
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1710
  { fix x :: "nat \<Rightarrow> nat" and i assume "\<forall>i<n. x i \<le> p" "i < n" "x i = p \<or> x i = 0"
68621
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1711
    then have "(\<Sum>i\<in>Basis. (real (x (b' i)) / real p) *\<^sub>R i) \<in> (cbox 0 One::'a set)"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1712
      using b'_Basis
71172
nipkow
parents: 70802
diff changeset
  1713
      by (auto simp: cbox_def bij_betw_def zero_le_divide_iff divide_le_eq_1) }
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1714
  note cube = this
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1715
  have q2: "\<forall>x. (\<forall>i<n. x i \<le> p) \<longrightarrow> (\<forall>i<n. x i = 0 \<longrightarrow>
50526
899c9c4e4a4c Remove the indexed basis from the definition of euclidean spaces and only use the set of Basis vectors
hoelzl
parents: 50514
diff changeset
  1716
      (label (\<Sum>i\<in>Basis. (real (x (b' i)) / real p) *\<^sub>R i) \<circ> b) i = 0)"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1717
    unfolding o_def using cube \<open>p > 0\<close> by (intro allI impI label(2)) (auto simp: b'')
61609
77b453bd616f Coercion "real" now has type nat => real only and is no longer overloaded. Type class "real_of" is gone. Many duplicate theorems removed.
paulson <lp15@cam.ac.uk>
parents: 61520
diff changeset
  1718
  have q3: "\<forall>x. (\<forall>i<n. x i \<le> p) \<longrightarrow> (\<forall>i<n. x i = p \<longrightarrow>
50526
899c9c4e4a4c Remove the indexed basis from the definition of euclidean spaces and only use the set of Basis vectors
hoelzl
parents: 50514
diff changeset
  1719
      (label (\<Sum>i\<in>Basis. (real (x (b' i)) / real p) *\<^sub>R i) \<circ> b) i = 1)"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1720
    using cube \<open>p > 0\<close> unfolding o_def by (intro allI impI label(3)) (auto simp: b'')
55522
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1721
  obtain q where q:
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1722
      "\<forall>i<n. q i < p"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1723
      "\<forall>i<n.
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1724
         \<exists>r s. (\<forall>j<n. q j \<le> r j \<and> r j \<le> q j + 1) \<and>
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1725
               (\<forall>j<n. q j \<le> s j \<and> s j \<le> q j + 1) \<and>
55522
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1726
               (label (\<Sum>i\<in>Basis. (real (r (b' i)) / real p) *\<^sub>R i) \<circ> b) i \<noteq>
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1727
               (label (\<Sum>i\<in>Basis. (real (s (b' i)) / real p) *\<^sub>R i) \<circ> b) i"
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1728
    by (rule kuhn_lemma[OF q1 q2 q3])
63040
eb4ddd18d635 eliminated old 'def';
wenzelm
parents: 62948
diff changeset
  1729
  define z :: 'a where "z = (\<Sum>i\<in>Basis. (real (q (b' i)) / real p) *\<^sub>R i)"
61945
1135b8de26c3 more symbols;
wenzelm
parents: 61808
diff changeset
  1730
  have "\<exists>i\<in>Basis. d / real n \<le> \<bar>(f z - z)\<bullet>i\<bar>"
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1731
  proof (rule ccontr)
50526
899c9c4e4a4c Remove the indexed basis from the definition of euclidean spaces and only use the set of Basis vectors
hoelzl
parents: 50514
diff changeset
  1732
    have "\<forall>i\<in>Basis. q (b' i) \<in> {0..p}"
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1733
      using q(1) b'
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1734
      by (auto intro: less_imp_le simp: bij_betw_def)
68621
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1735
    then have "z \<in> cbox 0 One"
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1736
      unfolding z_def cbox_def
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1737
      using b'_Basis
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1738
      by (auto simp: bij_betw_def zero_le_divide_iff divide_le_eq_1)
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1739
    then have d_fz_z: "d \<le> norm (f z - z)"
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1740
      by (rule d)
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1741
    assume "\<not> ?thesis"
53674
7ac7b2eaa5e6 tuned proofs;
wenzelm
parents: 53252
diff changeset
  1742
    then have as: "\<forall>i\<in>Basis. \<bar>f z \<bullet> i - z \<bullet> i\<bar> < d / real n"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1743
      using \<open>n > 0\<close>
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1744
      by (auto simp: not_le inner_diff)
50526
899c9c4e4a4c Remove the indexed basis from the definition of euclidean spaces and only use the set of Basis vectors
hoelzl
parents: 50514
diff changeset
  1745
    have "norm (f z - z) \<le> (\<Sum>i\<in>Basis. \<bar>f z \<bullet> i - z \<bullet> i\<bar>)"
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1746
      unfolding inner_diff_left[symmetric]
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1747
      by (rule norm_le_l1)
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1748
    also have "\<dots> < (\<Sum>(i::'a) \<in> Basis. d / real n)"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1749
      by (meson as finite_Basis nonempty_Basis sum_strict_mono)
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1750
    also have "\<dots> = d"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1751
      using DIM_positive[where 'a='a] by (auto simp: n_def)
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1752
    finally show False
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1753
      using d_fz_z by auto
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1754
  qed
55522
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1755
  then obtain i where i: "i \<in> Basis" "d / real n \<le> \<bar>(f z - z) \<bullet> i\<bar>" ..
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1756
  have *: "b' i < n"
55522
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1757
    using i and b'[unfolded bij_betw_def]
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1758
    by auto
55522
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1759
  obtain r s where rs:
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1760
    "\<And>j. j < n \<Longrightarrow> q j \<le> r j \<and> r j \<le> q j + 1"
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1761
    "\<And>j. j < n \<Longrightarrow> q j \<le> s j \<and> s j \<le> q j + 1"
55522
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1762
    "(label (\<Sum>i\<in>Basis. (real (r (b' i)) / real p) *\<^sub>R i) \<circ> b) (b' i) \<noteq>
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1763
      (label (\<Sum>i\<in>Basis. (real (s (b' i)) / real p) *\<^sub>R i) \<circ> b) (b' i)"
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1764
    using q(2)[rule_format,OF *] by blast
56273
def3bbe6f2a5 cleanup auxiliary proofs for Brouwer fixpoint theorem (removes ~2400 lines)
hoelzl
parents: 56226
diff changeset
  1765
  have b'_im: "\<And>i. i \<in> Basis \<Longrightarrow>  b' i < n"
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1766
    using b' unfolding bij_betw_def by auto
63040
eb4ddd18d635 eliminated old 'def';
wenzelm
parents: 62948
diff changeset
  1767
  define r' ::'a where "r' = (\<Sum>i\<in>Basis. (real (r (b' i)) / real p) *\<^sub>R i)"
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1768
  have "\<And>i. i \<in> Basis \<Longrightarrow> r (b' i) \<le> p"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  1769
    using b'_im q(1) rs(1) by fastforce
68621
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1770
  then have "r' \<in> cbox 0 One"
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1771
    unfolding r'_def cbox_def
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1772
    using b'_Basis
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1773
    by (auto simp: bij_betw_def zero_le_divide_iff divide_le_eq_1)
63040
eb4ddd18d635 eliminated old 'def';
wenzelm
parents: 62948
diff changeset
  1774
  define s' :: 'a where "s' = (\<Sum>i\<in>Basis. (real (s (b' i)) / real p) *\<^sub>R i)"
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1775
  have "\<And>i. i \<in> Basis \<Longrightarrow> s (b' i) \<le> p"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1776
    using b'_im q(1) rs(2) by fastforce
68621
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1777
  then have "s' \<in> cbox 0 One"
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1778
    unfolding s'_def cbox_def
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1779
    using b'_Basis by (auto simp: bij_betw_def zero_le_divide_iff divide_le_eq_1)
68621
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1780
  have "z \<in> cbox 0 One"
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1781
    unfolding z_def cbox_def
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1782
    using b'_Basis q(1)[rule_format,OF b'_im] \<open>p > 0\<close>
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1783
    by (auto simp: bij_betw_def zero_le_divide_iff divide_le_eq_1 less_imp_le)
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1784
  {
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1785
    have "(\<Sum>i\<in>Basis. \<bar>real (r (b' i)) - real (q (b' i))\<bar>) \<le> (\<Sum>(i::'a)\<in>Basis. 1)"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1786
      by (rule sum_mono) (use rs(1)[OF b'_im] in force)
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1787
    also have "\<dots> < e * real p"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1788
      using p \<open>e > 0\<close> \<open>p > 0\<close>
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1789
      by (auto simp: field_simps n_def)
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1790
    finally have "(\<Sum>i\<in>Basis. \<bar>real (r (b' i)) - real (q (b' i))\<bar>) < e * real p" .
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1791
  }
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1792
  moreover
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1793
  {
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1794
    have "(\<Sum>i\<in>Basis. \<bar>real (s (b' i)) - real (q (b' i))\<bar>) \<le> (\<Sum>(i::'a)\<in>Basis. 1)"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1795
      by (rule sum_mono) (use rs(2)[OF b'_im] in force)
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1796
    also have "\<dots> < e * real p"
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1797
      using p \<open>e > 0\<close> \<open>p > 0\<close>
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1798
      by (auto simp: field_simps n_def)
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1799
    finally have "(\<Sum>i\<in>Basis. \<bar>real (s (b' i)) - real (q (b' i))\<bar>) < e * real p" .
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1800
  }
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1801
  ultimately
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1802
  have "norm (r' - z) < e" and "norm (s' - z) < e"
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1803
    unfolding r'_def s'_def z_def
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1804
    using \<open>p > 0\<close>
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1805
    apply (rule_tac[!] le_less_trans[OF norm_le_l1])
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1806
    apply (auto simp: field_simps sum_divide_distrib[symmetric] inner_diff_left)
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1807
    done
53674
7ac7b2eaa5e6 tuned proofs;
wenzelm
parents: 53252
diff changeset
  1808
  then have "\<bar>(f z - z) \<bullet> i\<bar> < d / real n"
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1809
    using rs(3) i
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1810
    unfolding r'_def[symmetric] s'_def[symmetric] o_def bb'
68621
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1811
    by (intro e(2)[OF \<open>r'\<in>cbox 0 One\<close> \<open>s'\<in>cbox 0 One\<close> \<open>z\<in>cbox 0 One\<close>]) auto
53688
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1812
  then show False
63892cfef47f tuned proofs;
wenzelm
parents: 53674
diff changeset
  1813
    using i by auto
50526
899c9c4e4a4c Remove the indexed basis from the definition of euclidean spaces and only use the set of Basis vectors
hoelzl
parents: 50514
diff changeset
  1814
qed
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1815
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
  1816
text \<open>Next step is to prove it for nonempty interiors.\<close>
56117
2dbf84ee3deb remove ordered_euclidean_space constraint from brouwer/derivative lemmas;
huffman
parents: 55522
diff changeset
  1817
50526
899c9c4e4a4c Remove the indexed basis from the definition of euclidean spaces and only use the set of Basis vectors
hoelzl
parents: 50514
diff changeset
  1818
lemma brouwer_weak:
56117
2dbf84ee3deb remove ordered_euclidean_space constraint from brouwer/derivative lemmas;
huffman
parents: 55522
diff changeset
  1819
  fixes f :: "'a::euclidean_space \<Rightarrow> 'a"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1820
  assumes "compact S"
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1821
    and "convex S"
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1822
    and "interior S \<noteq> {}"
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1823
    and "continuous_on S f"
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  1824
    and "f \<in> S \<rightarrow> S"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1825
  obtains x where "x \<in> S" and "f x = x"
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1826
proof -
68621
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1827
  let ?U = "cbox 0 One :: 'a set"
56117
2dbf84ee3deb remove ordered_euclidean_space constraint from brouwer/derivative lemmas;
huffman
parents: 55522
diff changeset
  1828
  have "\<Sum>Basis /\<^sub>R 2 \<in> interior ?U"
2dbf84ee3deb remove ordered_euclidean_space constraint from brouwer/derivative lemmas;
huffman
parents: 55522
diff changeset
  1829
  proof (rule interiorI)
2dbf84ee3deb remove ordered_euclidean_space constraint from brouwer/derivative lemmas;
huffman
parents: 55522
diff changeset
  1830
    let ?I = "(\<Inter>i\<in>Basis. {x::'a. 0 < x \<bullet> i} \<inter> {x. x \<bullet> i < 1})"
2dbf84ee3deb remove ordered_euclidean_space constraint from brouwer/derivative lemmas;
huffman
parents: 55522
diff changeset
  1831
    show "open ?I"
71172
nipkow
parents: 70802
diff changeset
  1832
      by (intro open_INT finite_Basis ballI open_Int, auto intro: open_Collect_less simp: continuous_on_inner)
56117
2dbf84ee3deb remove ordered_euclidean_space constraint from brouwer/derivative lemmas;
huffman
parents: 55522
diff changeset
  1833
    show "\<Sum>Basis /\<^sub>R 2 \<in> ?I"
2dbf84ee3deb remove ordered_euclidean_space constraint from brouwer/derivative lemmas;
huffman
parents: 55522
diff changeset
  1834
      by simp
68621
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1835
    show "?I \<subseteq> cbox 0 One"
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1836
      unfolding cbox_def by force
56117
2dbf84ee3deb remove ordered_euclidean_space constraint from brouwer/derivative lemmas;
huffman
parents: 55522
diff changeset
  1837
  qed
2dbf84ee3deb remove ordered_euclidean_space constraint from brouwer/derivative lemmas;
huffman
parents: 55522
diff changeset
  1838
  then have *: "interior ?U \<noteq> {}" by fast
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1839
  have *: "?U homeomorphic S"
68621
27432da24236 unit_cube = cbox 0 One
nipkow
parents: 68617
diff changeset
  1840
    using homeomorphic_convex_compact[OF convex_box(1) compact_cbox * assms(2,1,3)] .
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  1841
  have "\<forall>f. continuous_on ?U f \<and> f \<in> ?U \<rightarrow> ?U \<longrightarrow> (\<exists>x\<in>?U. f x = x)"
37489
44e42d392c6e Introduce a type class for euclidean spaces, port most lemmas from real^'n to this type class.
hoelzl
parents: 36587
diff changeset
  1842
    using brouwer_cube by auto
53674
7ac7b2eaa5e6 tuned proofs;
wenzelm
parents: 53252
diff changeset
  1843
  then show ?thesis
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1844
    unfolding homeomorphic_fixpoint_property[OF *]
53252
4766fbe322b5 tuned proofs;
wenzelm
parents: 53248
diff changeset
  1845
    using assms
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1846
    by (auto intro: that)
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1847
qed
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1848
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
  1849
text \<open>Then the particular case for closed balls.\<close>
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1850
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1851
lemma brouwer_ball:
56117
2dbf84ee3deb remove ordered_euclidean_space constraint from brouwer/derivative lemmas;
huffman
parents: 55522
diff changeset
  1852
  fixes f :: "'a::euclidean_space \<Rightarrow> 'a"
53674
7ac7b2eaa5e6 tuned proofs;
wenzelm
parents: 53252
diff changeset
  1853
  assumes "e > 0"
7ac7b2eaa5e6 tuned proofs;
wenzelm
parents: 53252
diff changeset
  1854
    and "continuous_on (cball a e) f"
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  1855
    and "f \<in> cball a e \<rightarrow> cball a e"
53674
7ac7b2eaa5e6 tuned proofs;
wenzelm
parents: 53252
diff changeset
  1856
  obtains x where "x \<in> cball a e" and "f x = x"
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1857
  using brouwer_weak[OF compact_cball convex_cball, of a e f]
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1858
  unfolding interior_cball ball_eq_empty
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1859
  using assms by auto
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1860
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
  1861
text \<open>And finally we prove Brouwer's fixed point theorem in its general version.\<close>
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
  1862
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
  1863
theorem brouwer:
56117
2dbf84ee3deb remove ordered_euclidean_space constraint from brouwer/derivative lemmas;
huffman
parents: 55522
diff changeset
  1864
  fixes f :: "'a::euclidean_space \<Rightarrow> 'a"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1865
  assumes S: "compact S" "convex S" "S \<noteq> {}"
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1866
    and contf: "continuous_on S f"
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  1867
    and fim: "f \<in> S \<rightarrow> S"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1868
  obtains x where "x \<in> S" and "f x = x"
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1869
proof -
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1870
  have "\<exists>e>0. S \<subseteq> cball 0 e"
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1871
    using compact_imp_bounded[OF \<open>compact S\<close>]  unfolding bounded_pos
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1872
    by auto
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1873
  then obtain e where e: "e > 0" "S \<subseteq> cball 0 e"
55522
23d2cbac6dce tuned proofs;
wenzelm
parents: 55493
diff changeset
  1874
    by blast
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1875
  have "\<exists>x\<in> cball 0 e. (f \<circ> closest_point S) x = x"
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1876
  proof (rule_tac brouwer_ball[OF e(1)])
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1877
    show "continuous_on (cball 0 e) (f \<circ> closest_point S)"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  1878
      by (meson assms closest_point_in_set compact_eq_bounded_closed contf continuous_on_closest_point
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  1879
          continuous_on_compose continuous_on_subset image_subsetI)
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  1880
    show "f \<circ> closest_point S \<in> cball 0 e \<rightarrow> cball 0 e"
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  1881
      by (smt (verit) Pi_iff assms(1) assms(3) closest_point_in_set comp_apply compact_eq_bounded_closed e(2) fim subset_eq)
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1882
  qed (use assms in auto)
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1883
  then obtain x where x: "x \<in> cball 0 e" "(f \<circ> closest_point S) x = x" ..
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  1884
  with S have "x \<in> S"
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  1885
    by (metis PiE closest_point_in_set comp_apply compact_imp_closed fim)
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1886
  then have *: "closest_point S x = x"
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1887
    by (rule closest_point_self)
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1888
  show thesis
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1889
  proof
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1890
    show "closest_point S x \<in> S"
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1891
      by (simp add: "*" \<open>x \<in> S\<close>)
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1892
    show "f (closest_point S x) = closest_point S x"
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  1893
      using "*" x by auto
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1894
  qed
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1895
qed
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1896
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
  1897
subsection \<open>Applications\<close>
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
  1898
60420
884f54e01427 isabelle update_cartouches;
wenzelm
parents: 60303
diff changeset
  1899
text \<open>So we get the no-retraction theorem.\<close>
33741
4c414d0835ab Added derivation and Brouwer's fixpoint theorem in Multivariate Analysis (translated by Robert Himmelmann from HOL-light)
hoelzl
parents:
diff changeset
  1900
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
  1901
corollary no_retraction_cball:
56117
2dbf84ee3deb remove ordered_euclidean_space constraint from brouwer/derivative lemmas;
huffman
parents: 55522
diff changeset
  1902
  fixes a :: "'a::euclidean_space"
53674
7ac7b2eaa5e6 tuned proofs;
wenzelm
parents: 53252
diff changeset
  1903
  assumes "e > 0"
7ac7b2eaa5e6 tuned proofs;
wenzelm
parents: 53252
diff changeset
  1904
  shows "\<not> (frontier (cball a e) retract_of (cball a e))"
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1905
proof
60580
7e741e22d7fc tuned proofs;
wenzelm
parents: 60449
diff changeset
  1906
  assume *: "frontier (cball a e) retract_of (cball a e)"
7e741e22d7fc tuned proofs;
wenzelm
parents: 60449
diff changeset
  1907
  have **: "\<And>xa. a - (2 *\<^sub>R a - xa) = - (a - xa)"
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1908
    using scaleR_left_distrib[of 1 1 a] by auto
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1909
  obtain x where x: "x \<in> {x. norm (a - x) = e}" "2 *\<^sub>R a - x = x"
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1910
  proof (rule retract_fixpoint_property[OF *, of "\<lambda>x. scaleR 2 a - x"])
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1911
    show "continuous_on (frontier (cball a e)) ((-) (2 *\<^sub>R a))"
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1912
      by (intro continuous_intros)
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  1913
    show "(-) (2 *\<^sub>R a) \<in> frontier (cball a e) \<rightarrow> frontier (cball a e)"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1914
      by clarsimp (metis "**" dist_norm norm_minus_cancel)
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1915
  qed (auto simp: dist_norm intro: brouwer_ball[OF assms])
53674
7ac7b2eaa5e6 tuned proofs;
wenzelm
parents: 53252
diff changeset
  1916
  then have "scaleR 2 a = scaleR 1 x + scaleR 1 x"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1917
    by (auto simp: algebra_simps)
53674
7ac7b2eaa5e6 tuned proofs;
wenzelm
parents: 53252
diff changeset
  1918
  then have "a = x"
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  1919
    unfolding scaleR_left_distrib[symmetric] by auto
53674
7ac7b2eaa5e6 tuned proofs;
wenzelm
parents: 53252
diff changeset
  1920
  then show False
7ac7b2eaa5e6 tuned proofs;
wenzelm
parents: 53252
diff changeset
  1921
    using x assms by auto
53185
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1922
qed
752e05d09708 tuned proofs;
wenzelm
parents: 51478
diff changeset
  1923
64006
0de4736dad8b new theorems including the theory FurtherTopology
paulson <lp15@cam.ac.uk>
parents: 63928
diff changeset
  1924
corollary contractible_sphere:
0de4736dad8b new theorems including the theory FurtherTopology
paulson <lp15@cam.ac.uk>
parents: 63928
diff changeset
  1925
  fixes a :: "'a::euclidean_space"
0de4736dad8b new theorems including the theory FurtherTopology
paulson <lp15@cam.ac.uk>
parents: 63928
diff changeset
  1926
  shows "contractible(sphere a r) \<longleftrightarrow> r \<le> 0"
0de4736dad8b new theorems including the theory FurtherTopology
paulson <lp15@cam.ac.uk>
parents: 63928
diff changeset
  1927
proof (cases "0 < r")
0de4736dad8b new theorems including the theory FurtherTopology
paulson <lp15@cam.ac.uk>
parents: 63928
diff changeset
  1928
  case True
0de4736dad8b new theorems including the theory FurtherTopology
paulson <lp15@cam.ac.uk>
parents: 63928
diff changeset
  1929
  then show ?thesis
0de4736dad8b new theorems including the theory FurtherTopology
paulson <lp15@cam.ac.uk>
parents: 63928
diff changeset
  1930
    unfolding contractible_def nullhomotopic_from_sphere_extension
0de4736dad8b new theorems including the theory FurtherTopology
paulson <lp15@cam.ac.uk>
parents: 63928
diff changeset
  1931
    using no_retraction_cball [OF True, of a]
0de4736dad8b new theorems including the theory FurtherTopology
paulson <lp15@cam.ac.uk>
parents: 63928
diff changeset
  1932
    by (auto simp: retract_of_def retraction_def)
0de4736dad8b new theorems including the theory FurtherTopology
paulson <lp15@cam.ac.uk>
parents: 63928
diff changeset
  1933
next
0de4736dad8b new theorems including the theory FurtherTopology
paulson <lp15@cam.ac.uk>
parents: 63928
diff changeset
  1934
  case False
0de4736dad8b new theorems including the theory FurtherTopology
paulson <lp15@cam.ac.uk>
parents: 63928
diff changeset
  1935
  then show ?thesis
0de4736dad8b new theorems including the theory FurtherTopology
paulson <lp15@cam.ac.uk>
parents: 63928
diff changeset
  1936
    unfolding contractible_def nullhomotopic_from_sphere_extension
71172
nipkow
parents: 70802
diff changeset
  1937
    using less_eq_real_def by auto
64006
0de4736dad8b new theorems including the theory FurtherTopology
paulson <lp15@cam.ac.uk>
parents: 63928
diff changeset
  1938
qed
0de4736dad8b new theorems including the theory FurtherTopology
paulson <lp15@cam.ac.uk>
parents: 63928
diff changeset
  1939
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
  1940
corollary connected_sphere_eq:
64789
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1941
  fixes a :: "'a :: euclidean_space"
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1942
  shows "connected(sphere a r) \<longleftrightarrow> 2 \<le> DIM('a) \<or> r \<le> 0"
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1943
    (is "?lhs = ?rhs")
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1944
proof (cases r "0::real" rule: linorder_cases)
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1945
  case less
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1946
  then show ?thesis by auto
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1947
next
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1948
  case equal
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1949
  then show ?thesis by auto
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1950
next
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1951
  case greater
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1952
  show ?thesis
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1953
  proof
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1954
    assume L: ?lhs
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1955
    have "False" if 1: "DIM('a) = 1"
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1956
    proof -
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1957
      obtain x y where xy: "sphere a r = {x,y}" "x \<noteq> y"
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1958
        using sphere_1D_doubleton [OF 1 greater]
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1959
        by (metis dist_self greater insertI1 less_add_same_cancel1 mem_sphere mult_2 not_le zero_le_dist)
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1960
      then have "finite (sphere a r)"
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1961
        by auto
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1962
      with L \<open>r > 0\<close> xy show "False"
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  1963
        using connected_finite_iff_sing by auto
64789
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1964
    qed
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1965
    with greater show ?rhs
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1966
      by (metis DIM_ge_Suc0 One_nat_def Suc_1 le_antisym not_less_eq_eq)
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1967
  next
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1968
    assume ?rhs
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1969
    then show ?lhs
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1970
      using connected_sphere greater by auto
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1971
  qed
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1972
qed
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1973
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
  1974
corollary path_connected_sphere_eq:
64789
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1975
  fixes a :: "'a :: euclidean_space"
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1976
  shows "path_connected(sphere a r) \<longleftrightarrow> 2 \<le> DIM('a) \<or> r \<le> 0"
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1977
         (is "?lhs = ?rhs")
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1978
proof
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1979
  assume ?lhs
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1980
  then show ?rhs
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1981
    using connected_sphere_eq path_connected_imp_connected by blast
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1982
next
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1983
  assume R: ?rhs
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1984
  then show ?lhs
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1985
    by (auto simp: contractible_imp_path_connected contractible_sphere path_connected_sphere)
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1986
qed
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  1987
64122
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  1988
proposition frontier_subset_retraction:
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  1989
  fixes S :: "'a::euclidean_space set"
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  1990
  assumes "bounded S" and fros: "frontier S \<subseteq> T"
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  1991
      and contf: "continuous_on (closure S) f"
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  1992
      and fim: "f \<in> S \<rightarrow> T"
64122
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  1993
      and fid: "\<And>x. x \<in> T \<Longrightarrow> f x = x"
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  1994
    shows "S \<subseteq> T"
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  1995
proof (rule ccontr)
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  1996
  assume "\<not> S \<subseteq> T"
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  1997
  then obtain a where "a \<in> S" "a \<notin> T" by blast
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  1998
  define g where "g \<equiv> \<lambda>z. if z \<in> closure S then f z else z"
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  1999
  have "continuous_on (closure S \<union> closure(-S)) g"
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2000
    unfolding g_def using fros fid frontier_closures
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2001
    by (intro continuous_on_cases) (auto simp: contf)
64122
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2002
  moreover have "closure S \<union> closure(- S) = UNIV"
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2003
    using closure_Un by fastforce
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2004
  ultimately have contg: "continuous_on UNIV g" by metis
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2005
  obtain B where "0 < B" and B: "closure S \<subseteq> ball a B"
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2006
    using \<open>bounded S\<close> bounded_subset_ballD by blast
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2007
  have notga: "g x \<noteq> a" for x
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2008
    unfolding g_def using fros fim \<open>a \<notin> T\<close>
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2009
    by (metis PiE Un_iff \<open>a \<in> S\<close> closure_Un_frontier fid subsetD)
64122
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2010
  define h where "h \<equiv> (\<lambda>y. a + (B / norm(y - a)) *\<^sub>R (y - a)) \<circ> g"
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2011
  have "\<not> (frontier (cball a B) retract_of (cball a B))"
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2012
    by (metis no_retraction_cball \<open>0 < B\<close>)
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2013
  then have "\<And>k. \<not> retraction (cball a B) (frontier (cball a B)) k"
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2014
    by (simp add: retract_of_def)
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2015
  moreover have "retraction (cball a B) (frontier (cball a B)) h"
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2016
    unfolding retraction_def
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2017
  proof (intro conjI ballI)
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2018
    show "frontier (cball a B) \<subseteq> cball a B"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  2019
      by force
64122
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2020
    show "continuous_on (cball a B) h"
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2021
      unfolding h_def
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  2022
      by (intro continuous_intros) (use contg continuous_on_subset notga in auto)
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2023
    show "h \<in> cball a B \<rightarrow> frontier (cball a B)"
64122
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2024
      using \<open>0 < B\<close> by (auto simp: h_def notga dist_norm)
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2025
    show "\<And>x. x \<in> frontier (cball a B) \<Longrightarrow> h x = x"
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2026
      using notga \<open>0 < B\<close>
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2027
      apply (simp add: g_def h_def field_simps)
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2028
      by (metis B dist_commute dist_norm mem_ball order_less_irrefl subset_eq)
64122
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2029
  qed
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2030
  ultimately show False by simp
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2031
qed
74fde524799e invariance of domain
paulson <lp15@cam.ac.uk>
parents: 64006
diff changeset
  2032
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
  2033
subsubsection \<open>Punctured affine hulls, etc\<close>
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
  2034
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
  2035
lemma rel_frontier_deformation_retract_of_punctured_convex:
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2036
  fixes S :: "'a::euclidean_space set"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2037
  assumes "convex S" "convex T" "bounded S"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2038
      and arelS: "a \<in> rel_interior S"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2039
      and relS: "rel_frontier S \<subseteq> T"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2040
      and affS: "T \<subseteq> affine hull S"
69986
f2d327275065 generalised homotopic_with to topologies; homotopic_with_canon is the old version
paulson <lp15@cam.ac.uk>
parents: 69945
diff changeset
  2041
  obtains r where "homotopic_with_canon (\<lambda>x. True) (T - {a}) (T - {a}) id r"
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2042
                  "retraction (T - {a}) (rel_frontier S) r"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2043
proof -
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2044
  have "\<exists>d. 0 < d \<and> (a + d *\<^sub>R l) \<in> rel_frontier S \<and>
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2045
            (\<forall>e. 0 \<le> e \<and> e < d \<longrightarrow> (a + e *\<^sub>R l) \<in> rel_interior S)"
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2046
    if "(a + l) \<in> affine hull S" "l \<noteq> 0" for l
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2047
    using ray_to_rel_frontier [OF \<open>bounded S\<close> arelS] that by metis
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2048
  then obtain dd
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2049
    where dd1: "\<And>l. \<lbrakk>(a + l) \<in> affine hull S; l \<noteq> 0\<rbrakk> \<Longrightarrow> 0 < dd l \<and> (a + dd l *\<^sub>R l) \<in> rel_frontier S"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2050
      and dd2: "\<And>l e. \<lbrakk>(a + l) \<in> affine hull S; e < dd l; 0 \<le> e; l \<noteq> 0\<rbrakk>
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2051
                      \<Longrightarrow> (a + e *\<^sub>R l) \<in> rel_interior S"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2052
    by metis+
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2053
  have aaffS: "a \<in> affine hull S"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2054
    by (meson arelS subsetD hull_inc rel_interior_subset)
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2055
  have "((\<lambda>z. z - a) ` (affine hull S - {a})) = ((\<lambda>z. z - a) ` (affine hull S)) - {0}"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  2056
    by auto
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2057
  moreover have "continuous_on (((\<lambda>z. z - a) ` (affine hull S)) - {0}) (\<lambda>x. dd x *\<^sub>R x)"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2058
  proof (rule continuous_on_compact_surface_projection)
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2059
    show "compact (rel_frontier ((\<lambda>z. z - a) ` S))"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2060
      by (simp add: \<open>bounded S\<close> bounded_translation_minus compact_rel_frontier_bounded)
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2061
    have releq: "rel_frontier ((\<lambda>z. z - a) ` S) = (\<lambda>z. z - a) ` rel_frontier S"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2062
      using rel_frontier_translation [of "-a"] add.commute by simp
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  2063
    also have "\<dots> \<subseteq> (\<lambda>z. z - a) ` (affine hull S) - {0}"
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2064
      using rel_frontier_affine_hull arelS rel_frontier_def by fastforce
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2065
    finally show "rel_frontier ((\<lambda>z. z - a) ` S) \<subseteq> (\<lambda>z. z - a) ` (affine hull S) - {0}" .
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2066
    show "cone ((\<lambda>z. z - a) ` (affine hull S))"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  2067
      by (rule subspace_imp_cone)
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  2068
         (use aaffS in \<open>simp add: subspace_affine image_comp o_def affine_translation_aux [of a]\<close>)
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2069
    show "(0 < k \<and> k *\<^sub>R x \<in> rel_frontier ((\<lambda>z. z - a) ` S)) \<longleftrightarrow> (dd x = k)"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2070
         if x: "x \<in> (\<lambda>z. z - a) ` (affine hull S) - {0}" for k x
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2071
    proof
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2072
      show "dd x = k \<Longrightarrow> 0 < k \<and> k *\<^sub>R x \<in> rel_frontier ((\<lambda>z. z - a) ` S)"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2073
      using dd1 [of x] that image_iff by (fastforce simp add: releq)
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2074
    next
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2075
      assume k: "0 < k \<and> k *\<^sub>R x \<in> rel_frontier ((\<lambda>z. z - a) ` S)"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2076
      have False if "dd x < k"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2077
      proof -
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2078
        have "k \<noteq> 0" "a + k *\<^sub>R x \<in> closure S"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2079
          using k closure_translation [of "-a"]
69661
a03a63b81f44 tuned proofs
haftmann
parents: 69620
diff changeset
  2080
          by (auto simp: rel_frontier_def cong: image_cong_simp)
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2081
        then have segsub: "open_segment a (a + k *\<^sub>R x) \<subseteq> rel_interior S"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2082
          by (metis rel_interior_closure_convex_segment [OF \<open>convex S\<close> arelS])
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2083
        have "x \<noteq> 0" and xaffS: "a + x \<in> affine hull S"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  2084
          using x by auto
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2085
        then have "0 < dd x" and inS: "a + dd x *\<^sub>R x \<in> rel_frontier S"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2086
          using dd1 by auto
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2087
        moreover have "a + dd x *\<^sub>R x \<in> open_segment a (a + k *\<^sub>R x)"
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2088
          unfolding in_segment
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2089
        proof (intro conjI exI)
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2090
          show "a + dd x *\<^sub>R x = (1 - dd x / k) *\<^sub>R a + (dd x / k) *\<^sub>R (a + k *\<^sub>R x)"
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2091
            using k by (simp add: that algebra_simps)
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2092
        qed (use \<open>x \<noteq> 0\<close> \<open>0 < dd x\<close> that in auto)
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2093
        ultimately show ?thesis
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  2094
          using segsub by (auto simp: rel_frontier_def)
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2095
      qed
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2096
      moreover have False if "k < dd x"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2097
        using x k that rel_frontier_def
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2098
        by (fastforce simp: algebra_simps releq dest!: dd2)
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2099
      ultimately show "dd x = k"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2100
        by fastforce
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2101
    qed
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2102
  qed
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2103
  ultimately have *: "continuous_on ((\<lambda>z. z - a) ` (affine hull S - {a})) (\<lambda>x. dd x *\<^sub>R x)"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2104
    by auto
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2105
  have "continuous_on (affine hull S - {a}) ((\<lambda>x. a + dd x *\<^sub>R x) \<circ> (\<lambda>z. z - a))"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2106
    by (intro * continuous_intros continuous_on_compose)
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2107
  with affS have contdd: "continuous_on (T - {a}) ((\<lambda>x. a + dd x *\<^sub>R x) \<circ> (\<lambda>z. z - a))"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  2108
    by (blast intro: continuous_on_subset)
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2109
  show ?thesis
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2110
  proof
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2111
    show "homotopic_with_canon (\<lambda>x. True) (T - {a}) (T - {a}) id (\<lambda>x. a + dd (x-a) *\<^sub>R (x-a))"
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2112
    proof (rule homotopic_with_linear)
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2113
      show "continuous_on (T - {a}) id"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2114
        by (intro continuous_intros continuous_on_compose)
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2115
      show "continuous_on (T - {a}) (\<lambda>x. a + dd (x-a) *\<^sub>R (x-a))"
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2116
        using contdd by (simp add: o_def)
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2117
      show "closed_segment (id x) (a + dd (x-a) *\<^sub>R (x-a)) \<subseteq> T - {a}"
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2118
           if "x \<in> T - {a}" for x
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2119
      proof (clarsimp simp: in_segment, intro conjI)
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2120
        fix u::real assume u: "0 \<le> u" "u \<le> 1"
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2121
        have "a + dd (x-a) *\<^sub>R (x-a) \<in> T"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  2122
          by (metis DiffD1 DiffD2 add.commute add.right_neutral affS dd1 diff_add_cancel relS singletonI subsetCE that)
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2123
        then show "(1 - u) *\<^sub>R x + u *\<^sub>R (a + dd (x-a) *\<^sub>R (x-a)) \<in> T"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  2124
          using convexD [OF \<open>convex T\<close>] that u by simp
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2125
        have iff: "(1 - u) *\<^sub>R x + u *\<^sub>R (a + d *\<^sub>R (x-a)) = a \<longleftrightarrow>
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2126
                  (1 - u + u * d) *\<^sub>R (x-a) = 0" for d
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2127
          by (auto simp: algebra_simps)
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2128
        have "x \<in> T" "x \<noteq> a" using that by auto
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2129
        then have axa: "a + (x-a) \<in> affine hull S"
69712
dc85b5b3a532 renamings and new material
paulson <lp15@cam.ac.uk>
parents: 69700
diff changeset
  2130
           by (metis (no_types) add.commute affS diff_add_cancel rev_subsetD)
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2131
        then have "\<not> dd (x-a) \<le> 0 \<and> a + dd (x-a) *\<^sub>R (x-a) \<in> rel_frontier S"
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2132
          using \<open>x \<noteq> a\<close> dd1 by fastforce
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2133
        with \<open>x \<noteq> a\<close> show "(1 - u) *\<^sub>R x + u *\<^sub>R (a + dd (x-a) *\<^sub>R (x-a)) \<noteq> a"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2134
          using less_eq_real_def mult_le_0_iff not_less u by (fastforce simp: iff)
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2135
      qed
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2136
    qed
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2137
    show "retraction (T - {a}) (rel_frontier S) (\<lambda>x. a + dd (x-a) *\<^sub>R (x-a))"
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2138
    proof (simp add: retraction_def, intro conjI ballI)
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2139
      show "rel_frontier S \<subseteq> T - {a}"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2140
        using arelS relS rel_frontier_def by fastforce
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2141
      show "continuous_on (T - {a}) (\<lambda>x. a + dd (x-a) *\<^sub>R (x-a))"
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2142
        using contdd by (simp add: o_def)
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2143
      show "(\<lambda>x. a + dd (x-a) *\<^sub>R (x-a)) \<in> (T - {a}) \<rightarrow> rel_frontier S"
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2144
        unfolding Pi_iff using affS dd1 subset_eq by force
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2145
      show "a + dd (x-a) *\<^sub>R (x-a) = x" if x: "x \<in> rel_frontier S" for x
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2146
      proof -
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2147
        have "x \<noteq> a"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  2148
          using that arelS by (auto simp: rel_frontier_def)
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2149
        have False if "dd (x-a) < 1"
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2150
        proof -
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2151
          have "x \<in> closure S"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2152
            using x by (auto simp: rel_frontier_def)
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2153
          then have segsub: "open_segment a x \<subseteq> rel_interior S"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2154
            by (metis rel_interior_closure_convex_segment [OF \<open>convex S\<close> arelS])
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2155
          have  xaffS: "x \<in> affine hull S"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2156
            using affS relS x by auto
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2157
          then have "0 < dd (x-a)" and inS: "a + dd (x-a) *\<^sub>R (x-a) \<in> rel_frontier S"
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  2158
            using dd1 by (auto simp: \<open>x \<noteq> a\<close>)
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2159
          moreover have "a + dd (x-a) *\<^sub>R (x-a) \<in> open_segment a x"
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2160
            unfolding in_segment
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2161
          proof (intro exI conjI)
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2162
            show "a + dd (x-a) *\<^sub>R (x-a) = (1 - dd (x-a)) *\<^sub>R a + (dd (x-a)) *\<^sub>R x"
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2163
              by (simp add: algebra_simps)
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2164
          qed (use  \<open>x \<noteq> a\<close> \<open>0 < dd (x-a)\<close> that in auto)
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2165
          ultimately show ?thesis
68022
c8a506be83bd Tidied a lot of messy proofs
paulson <lp15@cam.ac.uk>
parents: 68017
diff changeset
  2166
            using segsub by (auto simp: rel_frontier_def)
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2167
        qed
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2168
        moreover have False if "1 < dd (x-a)"
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2169
          using x that dd2 [of "x - a" 1] \<open>x \<noteq> a\<close> closure_affine_hull
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2170
          by (auto simp: rel_frontier_def)
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2171
        ultimately have "dd (x-a) = 1" \<comment> \<open>similar to another proof above\<close>
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2172
          by fastforce
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2173
        with that show ?thesis
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2174
          by (simp add: rel_frontier_def)
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2175
      qed
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2176
    qed
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2177
  qed
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2178
qed
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2179
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2180
corollary rel_frontier_retract_of_punctured_affine_hull:
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2181
  fixes S :: "'a::euclidean_space set"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2182
  assumes "bounded S" "convex S" "a \<in> rel_interior S"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2183
    shows "rel_frontier S retract_of (affine hull S - {a})"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2184
  by (meson assms convex_affine_hull dual_order.refl rel_frontier_affine_hull 
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2185
      rel_frontier_deformation_retract_of_punctured_convex retract_of_def)
63492
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2186
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2187
corollary rel_boundary_retract_of_punctured_affine_hull:
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2188
  fixes S :: "'a::euclidean_space set"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2189
  assumes "compact S" "convex S" "a \<in> rel_interior S"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2190
    shows "(S - rel_interior S) retract_of (affine hull S - {a})"
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2191
by (metis assms closure_closed compact_eq_bounded_closed rel_frontier_def
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2192
          rel_frontier_retract_of_punctured_affine_hull)
a662e8139804 More advanced theorems about retracts, homotopies., etc
paulson <lp15@cam.ac.uk>
parents: 63469
diff changeset
  2193
64789
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  2194
lemma homotopy_eqv_rel_frontier_punctured_convex:
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  2195
  fixes S :: "'a::euclidean_space set"
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  2196
  assumes "convex S" "bounded S" "a \<in> rel_interior S" "convex T" "rel_frontier S \<subseteq> T" "T \<subseteq> affine hull S"
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  2197
  shows "(rel_frontier S) homotopy_eqv (T - {a})"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2198
  by (meson assms deformation_retract_imp_homotopy_eqv homotopy_equivalent_space_sym 
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2199
      rel_frontier_deformation_retract_of_punctured_convex[of S T])
64789
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  2200
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  2201
lemma homotopy_eqv_rel_frontier_punctured_affine_hull:
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  2202
  fixes S :: "'a::euclidean_space set"
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  2203
  assumes "convex S" "bounded S" "a \<in> rel_interior S"
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  2204
    shows "(rel_frontier S) homotopy_eqv (affine hull S - {a})"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2205
  by (simp add: assms homotopy_eqv_rel_frontier_punctured_convex rel_frontier_affine_hull)
64789
6440577e34ee connectedness, circles not simply connected , punctured universe
paulson <lp15@cam.ac.uk>
parents: 64394
diff changeset
  2206
64394
141e1ed8d5a0 more new material
paulson <lp15@cam.ac.uk>
parents: 64267
diff changeset
  2207
lemma path_connected_sphere_gen:
141e1ed8d5a0 more new material
paulson <lp15@cam.ac.uk>
parents: 64267
diff changeset
  2208
  assumes "convex S" "bounded S" "aff_dim S \<noteq> 1"
141e1ed8d5a0 more new material
paulson <lp15@cam.ac.uk>
parents: 64267
diff changeset
  2209
  shows "path_connected(rel_frontier S)"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2210
proof -
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2211
  have "convex (closure S)" 
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2212
    using assms by auto
64394
141e1ed8d5a0 more new material
paulson <lp15@cam.ac.uk>
parents: 64267
diff changeset
  2213
  then show ?thesis
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2214
    by (metis Diff_empty aff_dim_affine_hull assms convex_affine_hull convex_imp_path_connected equals0I 
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2215
       path_connected_punctured_convex rel_frontier_def rel_frontier_retract_of_punctured_affine_hull retract_of_path_connected)
64394
141e1ed8d5a0 more new material
paulson <lp15@cam.ac.uk>
parents: 64267
diff changeset
  2216
qed
141e1ed8d5a0 more new material
paulson <lp15@cam.ac.uk>
parents: 64267
diff changeset
  2217
141e1ed8d5a0 more new material
paulson <lp15@cam.ac.uk>
parents: 64267
diff changeset
  2218
lemma connected_sphere_gen:
141e1ed8d5a0 more new material
paulson <lp15@cam.ac.uk>
parents: 64267
diff changeset
  2219
  assumes "convex S" "bounded S" "aff_dim S \<noteq> 1"
141e1ed8d5a0 more new material
paulson <lp15@cam.ac.uk>
parents: 64267
diff changeset
  2220
  shows "connected(rel_frontier S)"
141e1ed8d5a0 more new material
paulson <lp15@cam.ac.uk>
parents: 64267
diff changeset
  2221
  by (simp add: assms path_connected_imp_connected path_connected_sphere_gen)
141e1ed8d5a0 more new material
paulson <lp15@cam.ac.uk>
parents: 64267
diff changeset
  2222
68617
75129a73aca3 more economic tagging
nipkow
parents: 68361
diff changeset
  2223
subsubsection\<open>Borsuk-style characterization of separation\<close>
63301
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2224
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2225
lemma continuous_on_Borsuk_map:
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2226
   "a \<notin> S \<Longrightarrow>  continuous_on S (\<lambda>x. inverse(norm (x-a)) *\<^sub>R (x-a))"
63301
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2227
by (rule continuous_intros | force)+
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2228
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2229
lemma Borsuk_map_into_sphere:
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2230
   "(\<lambda>x. inverse(norm (x-a)) *\<^sub>R (x-a)) \<in> S \<rightarrow> sphere 0 1 \<longleftrightarrow> (a \<notin> S)"
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2231
proof -
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2232
  have "\<And>x. \<lbrakk>a \<notin> S; x \<in> S\<rbrakk> \<Longrightarrow> inverse (norm (x-a)) * norm (x-a) = 1"
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2233
    by (metis left_inverse norm_eq_zero right_minus_eq)
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2234
  then show ?thesis
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2235
    by force
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2236
qed
63301
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2237
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2238
lemma Borsuk_maps_homotopic_in_path_component:
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2239
  assumes "path_component (- S) a b"
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2240
    shows "homotopic_with_canon (\<lambda>x. True) S (sphere 0 1)
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2241
                   (\<lambda>x. inverse(norm(x-a)) *\<^sub>R (x-a))
63301
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2242
                   (\<lambda>x. inverse(norm(x - b)) *\<^sub>R (x - b))"
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2243
proof -
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2244
  obtain g where g: "path g" "path_image g \<subseteq> -S" "pathstart g = a" "pathfinish g = b"
63301
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2245
    using assms by (auto simp: path_component_def)
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2246
  define h where "h \<equiv> \<lambda>z. (snd z - (g \<circ> fst) z) /\<^sub>R norm (snd z - (g \<circ> fst) z)"
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2247
  have "continuous_on ({0..1} \<times> S) h"
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2248
    unfolding h_def using g by (intro continuous_intros) (auto simp: path_defs)
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2249
  moreover
82323
b022c013b04b Function space instead of image closure
paulson <lp15@cam.ac.uk>
parents: 80095
diff changeset
  2250
  have "h \<in> ({0..1} \<times> S) \<rightarrow> sphere 0 1"
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2251
    unfolding h_def using g  by (auto simp: divide_simps path_defs)
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2252
  ultimately show ?thesis
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2253
    using g by (auto simp: h_def path_defs homotopic_with_def)
63301
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2254
qed
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2255
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2256
lemma non_extensible_Borsuk_map:
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2257
  fixes a :: "'a :: euclidean_space"
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2258
  assumes "compact S" and cin: "C \<in> components(- S)" and boc: "bounded C" and "a \<in> C"
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2259
    shows "\<not> (\<exists>g. continuous_on (S \<union> C) g \<and>
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2260
                  g \<in> (S \<union> C) \<rightarrow> sphere 0 1 \<and>
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2261
                  (\<forall>x \<in> S. g x = inverse(norm(x-a)) *\<^sub>R (x-a)))"
63301
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2262
proof -
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2263
  have "closed S" using assms by (simp add: compact_imp_closed)
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2264
  have "C \<subseteq> -S"
63301
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2265
    using assms by (simp add: in_components_subset)
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2266
  with \<open>a \<in> C\<close> have "a \<notin> S" by blast
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2267
  then have ceq: "C = connected_component_set (- S) a"
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2268
    by (metis \<open>a \<in> C\<close> cin components_iff connected_component_eq)
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2269
  then have "bounded (S \<union> connected_component_set (- S) a)"
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2270
    using \<open>compact S\<close> boc compact_imp_bounded by auto
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2271
  with bounded_subset_ballD obtain r where "0 < r" and r: "(S \<union> connected_component_set (- S) a) \<subseteq> ball a r"
63301
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2272
    by blast
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2273
  { fix g
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2274
    assume "continuous_on (S \<union> C) g"
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2275
            "g \<in> (S \<union> C) \<rightarrow> sphere 0 1"
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2276
       and [simp]: "\<And>x. x \<in> S \<Longrightarrow> g x = (x-a) /\<^sub>R norm (x-a)"
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2277
    then have norm_g1[simp]: "\<And>x. x \<in> S \<union> C \<Longrightarrow> norm (g x) = 1"
63301
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2278
      by force
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2279
    have cb_eq: "cball a r = (S \<union> connected_component_set (- S) a) \<union>
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2280
                      (cball a r - connected_component_set (- S) a)"
63301
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2281
      using ball_subset_cball [of a r] r by auto
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2282
    have cont1: "continuous_on (S \<union> connected_component_set (- S) a)
63301
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2283
                     (\<lambda>x. a + r *\<^sub>R g x)"
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2284
      using \<open>continuous_on (S \<union> C) g\<close> ceq
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2285
      by (intro continuous_intros) blast
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2286
    have cont2: "continuous_on (cball a r - connected_component_set (- S) a)
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2287
            (\<lambda>x. a + r *\<^sub>R ((x-a) /\<^sub>R norm (x-a)))"
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2288
      by (rule continuous_intros | force simp: \<open>a \<notin> S\<close>)+
63301
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2289
    have 1: "continuous_on (cball a r)
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2290
             (\<lambda>x. if connected_component (- S) a x
63301
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2291
                  then a + r *\<^sub>R g x
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2292
                  else a + r *\<^sub>R ((x-a) /\<^sub>R norm (x-a)))"
63301
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2293
      apply (subst cb_eq)
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2294
      apply (rule continuous_on_cases [OF _ _ cont1 cont2])
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2295
      using \<open>closed S\<close> ceq cin 
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2296
      by (force simp: closed_Diff open_Compl closed_Un_complement_component open_connected_component)+
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2297
    have 2: "(\<lambda>x. a + r *\<^sub>R g x) ` (cball a r \<inter> connected_component_set (- S) a)
63301
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2298
             \<subseteq> sphere a r "
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2299
      using \<open>0 < r\<close> by (force simp: dist_norm ceq)
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2300
    have "retraction (cball a r) (sphere a r)
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2301
            (\<lambda>x. if x \<in> connected_component_set (- S) a
63301
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2302
                 then a + r *\<^sub>R g x
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2303
                 else a + r *\<^sub>R ((x-a) /\<^sub>R norm (x-a)))"
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2304
      using  \<open>0 < r\<close> \<open>a \<notin> S\<close> \<open>a \<in> C\<close> r
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2305
      by (auto simp: norm_minus_commute retraction_def Pi_iff ceq dist_norm abs_if 
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2306
          mult_less_0_iff divide_simps 1 2)
63301
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2307
    then have False
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2308
      using no_retraction_cball
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2309
             [OF \<open>0 < r\<close>, of a, unfolded retract_of_def, simplified, rule_format,
78248
740b23f1138a EXPERIMENTAL replacement of f ` A <= B by f : A -> B in Analysis
paulson <lp15@cam.ac.uk>
parents: 76786
diff changeset
  2310
              of "\<lambda>x. if x \<in> connected_component_set (- S) a
63301
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2311
                      then a + r *\<^sub>R g x
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2312
                      else a + r *\<^sub>R inverse(norm(x-a)) *\<^sub>R (x-a)"]
63301
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2313
      by blast
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2314
  }
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2315
  then show ?thesis
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2316
    by blast
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2317
qed
d3c87eb0bad2 new results about topology
paulson <lp15@cam.ac.uk>
parents: 63129
diff changeset
  2318
70620
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2319
subsubsection \<open>Proving surjectivity via Brouwer fixpoint theorem\<close>
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2320
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2321
lemma brouwer_surjective:
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2322
  fixes f :: "'n::euclidean_space \<Rightarrow> 'n"
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2323
  assumes T: "compact T" "convex T" "T \<noteq> {}"
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2324
    and f: "continuous_on T f"
70620
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2325
    and "\<And>x y. \<lbrakk>x\<in>S; y\<in>T\<rbrakk> \<Longrightarrow> x + (y - f y) \<in> T"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2326
    and "x \<in> S"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2327
  shows "\<exists>y\<in>T. f y = x"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2328
proof -
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2329
  have *: "\<And>x y. f y = x \<longleftrightarrow> x + (y - f y) = y"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2330
    by (auto simp add: algebra_simps)
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2331
  show ?thesis
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2332
    unfolding *
80095
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2333
  proof (rule brouwer[OF T])
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2334
    show "continuous_on T (\<lambda>y. x + (y - f y))"
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2335
      by (intro continuous_intros f)
0f9cd1a5edbe Tidying ugly proofs
paulson <lp15@cam.ac.uk>
parents: 79566
diff changeset
  2336
  qed (use assms in auto)
70620
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2337
qed
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2338
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2339
lemma brouwer_surjective_cball:
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2340
  fixes f :: "'n::euclidean_space \<Rightarrow> 'n"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2341
  assumes "continuous_on (cball a e) f"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2342
    and "e > 0"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2343
    and "x \<in> S"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2344
    and "\<And>x y. \<lbrakk>x\<in>S; y\<in>cball a e\<rbrakk> \<Longrightarrow> x + (y - f y) \<in> cball a e"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2345
  shows "\<exists>y\<in>cball a e. f y = x"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2346
  by (smt (verit, best) assms brouwer_surjective cball_eq_empty compact_cball convex_cball)
70620
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2347
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2348
subsubsection \<open>Inverse function theorem\<close>
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2349
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2350
text \<open>See Sussmann: "Multidifferential calculus", Theorem 2.1.1\<close>
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2351
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2352
lemma sussmann_open_mapping:
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2353
  fixes f :: "'a::real_normed_vector \<Rightarrow> 'b::euclidean_space"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2354
  assumes "open S"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2355
    and contf: "continuous_on S f"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2356
    and "x \<in> S"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2357
    and derf: "(f has_derivative f') (at x)"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2358
    and "bounded_linear g'" "f' \<circ> g' = id"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2359
    and "T \<subseteq> S"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2360
    and x: "x \<in> interior T"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2361
  shows "f x \<in> interior (f ` T)"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2362
proof -
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2363
  interpret f': bounded_linear f'
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2364
    using assms unfolding has_derivative_def by auto
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2365
  interpret g': bounded_linear g'
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2366
    using assms by auto
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2367
  obtain B where B: "0 < B" "\<forall>x. norm (g' x) \<le> norm x * B"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2368
    using bounded_linear.pos_bounded[OF assms(5)] by blast
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2369
  hence *: "1 / (2 * B) > 0" by auto
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2370
  obtain e0 where e0:
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2371
      "0 < e0"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2372
      "\<forall>y. norm (y - x) < e0 \<longrightarrow> norm (f y - f x - f' (y - x)) \<le> 1 / (2 * B) * norm (y - x)"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2373
    using derf unfolding has_derivative_at_alt
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2374
    using * by blast
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2375
  obtain e1 where e1: "0 < e1" "cball x e1 \<subseteq> T"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2376
    using mem_interior_cball x by blast
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2377
  have *: "0 < e0 / B" "0 < e1 / B" using e0 e1 B by auto
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2378
  obtain e where e: "0 < e" "e < e0 / B" "e < e1 / B"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2379
    using field_lbound_gt_zero[OF *] by blast
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2380
  have lem: "\<exists>y\<in>cball (f x) e. f (x + g' (y - f x)) = z" if "z\<in>cball (f x) (e / 2)" for z
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2381
  proof (rule brouwer_surjective_cball)
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2382
    have z: "z \<in> S" if as: "y \<in>cball (f x) e" "z = x + (g' y - g' (f x))" for y z
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2383
    proof-
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2384
      have "dist x z = norm (g' (f x) - g' y)"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2385
        unfolding as(2) and dist_norm by auto
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2386
      also have "\<dots> \<le> norm (f x - y) * B"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2387
        by (metis B(2) g'.diff)
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2388
      also have "\<dots> \<le> e * B"
79566
f783490c6c99 A small number of new lemmas
paulson <lp15@cam.ac.uk>
parents: 78475
diff changeset
  2389
        by (metis B(1) dist_norm mem_cball mult_le_cancel_right_pos that(1))
70620
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2390
      also have "\<dots> \<le> e1"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2391
        using B(1) e(3) pos_less_divide_eq by fastforce
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2392
      finally have "z \<in> cball x e1"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2393
        by force
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2394
      then show "z \<in> S"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2395
        using e1 assms(7) by auto
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2396
    qed
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2397
    show "continuous_on (cball (f x) e) (\<lambda>y. f (x + g' (y - f x)))"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2398
      unfolding g'.diff
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2399
    proof (rule continuous_on_compose2 [OF _ _ order_refl, of _ _ f])
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2400
      show "continuous_on ((\<lambda>y. x + (g' y - g' (f x))) ` cball (f x) e) f"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2401
        by (rule continuous_on_subset[OF contf]) (use z in blast)
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2402
      show "continuous_on (cball (f x) e) (\<lambda>y. x + (g' y - g' (f x)))"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2403
        by (intro continuous_intros linear_continuous_on[OF \<open>bounded_linear g'\<close>])
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2404
    qed
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2405
  next
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2406
    fix y z
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2407
    assume y: "y \<in> cball (f x) (e / 2)" and z: "z \<in> cball (f x) e"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2408
    have "norm (g' (z - f x)) \<le> norm (z - f x) * B"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2409
      using B by auto
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2410
    also have "\<dots> \<le> e * B"
79566
f783490c6c99 A small number of new lemmas
paulson <lp15@cam.ac.uk>
parents: 78475
diff changeset
  2411
      by (metis B(1) z dist_norm mem_cball norm_minus_commute mult_le_cancel_right_pos)
70620
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2412
    also have "\<dots> < e0"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2413
      using B(1) e(2) pos_less_divide_eq by blast
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2414
    finally have *: "norm (x + g' (z - f x) - x) < e0"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2415
      by auto
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2416
    have **: "f x + f' (x + g' (z - f x) - x) = z"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2417
      using assms(6)[unfolded o_def id_def,THEN cong]
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2418
      by auto
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2419
    have "norm (f x - (y + (z - f (x + g' (z - f x))))) \<le>
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2420
          norm (f (x + g' (z - f x)) - z) + norm (f x - y)"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2421
      using norm_triangle_ineq[of "f (x + g'(z - f x)) - z" "f x - y"]
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2422
      by (auto simp add: algebra_simps)
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2423
    also have "\<dots> \<le> 1 / (B * 2) * norm (g' (z - f x)) + norm (f x - y)"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2424
      using e0(2)[rule_format, OF *]
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2425
      by (simp only: algebra_simps **) auto
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2426
    also have "\<dots> \<le> 1 / (B * 2) * norm (g' (z - f x)) + e/2"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2427
      using y by (auto simp: dist_norm)
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2428
    also have "\<dots> \<le> 1 / (B * 2) * B * norm (z - f x) + e/2"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2429
      using * B by (auto simp add: field_simps)
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2430
    also have "\<dots> \<le> 1 / 2 * norm (z - f x) + e/2"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2431
      by auto
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2432
    also have "\<dots> \<le> e/2 + e/2"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2433
      using B(1) \<open>norm (z - f x) * B \<le> e * B\<close> by auto
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2434
    finally show "y + (z - f (x + g' (z - f x))) \<in> cball (f x) e"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2435
      by (auto simp: dist_norm)
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2436
  qed (use e that in auto) 
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2437
  show ?thesis
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2438
    unfolding mem_interior
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2439
  proof (intro exI conjI subsetI)
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2440
    fix y
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2441
    assume "y \<in> ball (f x) (e / 2)"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2442
    then have *: "y \<in> cball (f x) (e / 2)"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2443
      by auto
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2444
    obtain z where z: "z \<in> cball (f x) e" "f (x + g' (z - f x)) = y"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2445
      using lem * by blast
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2446
    then have "norm (g' (z - f x)) \<le> norm (z - f x) * B"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2447
      using B
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2448
      by (auto simp add: field_simps)
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2449
    also have "\<dots> \<le> e * B"
79566
f783490c6c99 A small number of new lemmas
paulson <lp15@cam.ac.uk>
parents: 78475
diff changeset
  2450
      by (metis B(1) dist_norm mem_cball norm_minus_commute mult_le_cancel_right_pos z(1))
70620
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2451
    also have "\<dots> \<le> e1"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2452
      using e B unfolding less_divide_eq by auto
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2453
    finally have "x + g'(z - f x) \<in> T"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2454
      by (metis add_diff_cancel diff_diff_add dist_norm e1(2) mem_cball norm_minus_commute subset_eq)
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2455
    then show "y \<in> f ` T"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2456
      using z by auto
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2457
  qed (use e in auto)
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2458
qed
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2459
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2460
text \<open>Hence the following eccentric variant of the inverse function theorem.
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2461
  This has no continuity assumptions, but we do need the inverse function.
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2462
  We could put \<open>f' \<circ> g = I\<close> but this happens to fit with the minimal linear
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2463
  algebra theory I've set up so far.\<close>
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2464
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2465
lemma has_derivative_inverse_strong:
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2466
  fixes f :: "'n::euclidean_space \<Rightarrow> 'n"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2467
  assumes S: "open S" "x \<in> S"
70620
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2468
    and contf: "continuous_on S f"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2469
    and gf: "\<And>x. x \<in> S \<Longrightarrow> g (f x) = x"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2470
    and derf: "(f has_derivative f') (at x)"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2471
    and id: "f' \<circ> g' = id"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2472
  shows "(g has_derivative g') (at (f x))"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2473
proof -
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2474
  have linf: "bounded_linear f'"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2475
    using derf unfolding has_derivative_def by auto
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2476
  then have ling: "bounded_linear g'"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2477
    unfolding linear_conv_bounded_linear[symmetric]
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2478
    using id right_inverse_linear by blast
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2479
  moreover have "g' \<circ> f' = id"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2480
    using id linear_inverse_left linear_linear linf ling by blast
70620
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2481
  moreover have *: "\<And>T. \<lbrakk>T \<subseteq> S; x \<in> interior T\<rbrakk> \<Longrightarrow> f x \<in> interior (f ` T)"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2482
    using S derf contf id ling sussmann_open_mapping by blast
70620
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2483
  have "continuous (at (f x)) g"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2484
    unfolding continuous_at Lim_at
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2485
  proof (intro strip)
70620
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2486
    fix e :: real
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2487
    assume "e > 0"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2488
    then have "f x \<in> interior (f ` (ball x e \<inter> S))"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2489
      by (simp add: "*" S interior_open)
70620
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2490
    then obtain d where d: "0 < d" "ball (f x) d \<subseteq> f ` (ball x e \<inter> S)"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2491
      unfolding mem_interior by blast
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2492
    show "\<exists>d>0. \<forall>y. 0 < dist y (f x) \<and> dist y (f x) < d \<longrightarrow> dist (g y) (g (f x)) < e"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2493
    proof (intro exI allI impI conjI)
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2494
      fix y
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2495
      assume "0 < dist y (f x) \<and> dist y (f x) < d"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2496
      then have "g y \<in> g ` f ` (ball x e \<inter> S)"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2497
        by (metis d(2) dist_commute mem_ball rev_image_eqI subset_iff)
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2498
      then show "dist (g y) (g (f x)) < e"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2499
        using \<open>x \<in> S\<close> by (simp add: gf dist_commute image_iff)
70620
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2500
    qed (use d in auto)
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2501
  qed
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2502
  moreover have "f x \<in> interior (f ` S)"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2503
    using "*" S interior_eq by blast
70620
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2504
  moreover have "f (g y) = y" if "y \<in> interior (f ` S)" for y
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2505
    by (metis gf imageE interiorE subsetD that)
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2506
  ultimately show ?thesis using assms
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2507
    by (metis has_derivative_inverse_basic_x open_interior)
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2508
qed
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2509
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2510
text \<open>A rewrite based on the other domain.\<close>
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2511
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2512
lemma has_derivative_inverse_strong_x:
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2513
  fixes f :: "'a::euclidean_space \<Rightarrow> 'a"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2514
  assumes "open S"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2515
    and "g y \<in> S"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2516
    and "continuous_on S f"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2517
    and "\<And>x. x \<in> S \<Longrightarrow> g (f x) = x"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2518
    and "(f has_derivative f') (at (g y))"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2519
    and "f' \<circ> g' = id"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2520
    and f: "f (g y) = y"
70620
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2521
  shows "(g has_derivative g') (at y)"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2522
  using has_derivative_inverse_strong[OF assms(1-6)] by (simp add: f)
70620
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2523
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2524
text \<open>On a region.\<close>
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2525
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2526
theorem has_derivative_inverse_on:
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2527
  fixes f :: "'n::euclidean_space \<Rightarrow> 'n"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2528
  assumes "open S"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2529
    and "\<And>x. x \<in> S \<Longrightarrow> (f has_derivative f'(x)) (at x)"
70620
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2530
    and "\<And>x. x \<in> S \<Longrightarrow> g (f x) = x"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2531
    and "f' x \<circ> g' x = id"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2532
    and "x \<in> S"
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2533
  shows "(g has_derivative g'(x)) (at (f x))"
76786
50672d2d78db tidied some messy old proofs
paulson <lp15@cam.ac.uk>
parents: 73932
diff changeset
  2534
  by (meson assms continuous_on_eq_continuous_at has_derivative_continuous has_derivative_inverse_strong)
70620
f95193669ad7 removed Brouwer_Fixpoint from imports of Derivative
immler
parents: 70136
diff changeset
  2535
34291
4e896680897e finite annotation on cartesian product is now implicit.
hoelzl
parents: 34289
diff changeset
  2536
end