src/HOL/Isar_Examples/Schroeder_Bernstein.thy
author wenzelm
Sat, 11 Jun 2016 20:54:31 +0200
changeset 63291 b1d7950285cf
parent 63040 eb4ddd18d635
child 63297 ce995deef4b0
permissions -rw-r--r--
tuned;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
61938
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
     1
(*  Title:      HOL/Isar_Examples/Schroeder_Bernstein.thy
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
     3
*)
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
     4
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
     5
section \<open>Schröder-Bernstein Theorem\<close>
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
     6
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
     7
theory Schroeder_Bernstein
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
     8
imports Main
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
     9
begin
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    10
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    11
text \<open>
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    12
  See also:
61939
3c8c390a8f0a tuned document;
wenzelm
parents: 61938
diff changeset
    13
  \<^item> @{file "$ISABELLE_HOME/src/HOL/ex/Set_Theory.thy"}
61938
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    14
  \<^item> @{url "http://planetmath.org/proofofschroederbernsteintheoremusingtarskiknastertheorem"}
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    15
  \<^item> Springer LNCS 828 (cover page)
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    16
\<close>
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    17
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    18
theorem Schroeder_Bernstein:
63291
wenzelm
parents: 63040
diff changeset
    19
  fixes f :: \<open>'a \<Rightarrow> 'b\<close>
wenzelm
parents: 63040
diff changeset
    20
    and g :: \<open>'b \<Rightarrow> 'a\<close>
wenzelm
parents: 63040
diff changeset
    21
  assumes \<open>inj f\<close> and \<open>inj g\<close>
wenzelm
parents: 63040
diff changeset
    22
  shows \<open>\<exists>h :: 'a \<Rightarrow> 'b. inj h \<and> surj h\<close>
61938
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    23
proof
63291
wenzelm
parents: 63040
diff changeset
    24
  define A where \<open>A = lfp (\<lambda>X. - (g ` (- (f ` X))))\<close>
wenzelm
parents: 63040
diff changeset
    25
  define g' where \<open>g' = inv g\<close>
wenzelm
parents: 63040
diff changeset
    26
  let ?h = \<open>\<lambda>z. if z \<in> A then f z else g' z\<close>
61938
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    27
63291
wenzelm
parents: 63040
diff changeset
    28
  have \<open>A = - (g ` (- (f ` A)))\<close>
61938
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    29
    unfolding A_def by (rule lfp_unfold) (blast intro: monoI)
63291
wenzelm
parents: 63040
diff changeset
    30
  then have A_compl: \<open>- A = g ` (- (f ` A))\<close> by blast
wenzelm
parents: 63040
diff changeset
    31
  then have *: \<open>g' ` (- A) = - (f ` A)\<close>
61938
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    32
    using g'_def \<open>inj g\<close> by auto
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    33
63291
wenzelm
parents: 63040
diff changeset
    34
  show \<open>inj ?h \<and> surj ?h\<close>
61938
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    35
  proof
63291
wenzelm
parents: 63040
diff changeset
    36
    from * show \<open>surj ?h\<close> by auto
wenzelm
parents: 63040
diff changeset
    37
    have \<open>inj_on f A\<close>
61938
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    38
      using \<open>inj f\<close> by (rule subset_inj_on) blast
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    39
    moreover
63291
wenzelm
parents: 63040
diff changeset
    40
    have \<open>inj_on g' (- A)\<close>
61938
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    41
      unfolding g'_def
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    42
    proof (rule inj_on_inv_into)
63291
wenzelm
parents: 63040
diff changeset
    43
      have \<open>g ` (- (f ` A)) \<subseteq> range g\<close> by blast
wenzelm
parents: 63040
diff changeset
    44
      then show \<open>- A \<subseteq> range g\<close> by (simp only: A_compl)
61938
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    45
    qed
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    46
    moreover
63291
wenzelm
parents: 63040
diff changeset
    47
    have False if eq: \<open>f a = g' b\<close> and a: \<open>a \<in> A\<close> and b: \<open>b \<in> - A\<close> for a b
61938
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    48
    proof -
63291
wenzelm
parents: 63040
diff changeset
    49
      from a have fa: \<open>f a \<in> f ` A\<close> by (rule imageI)
wenzelm
parents: 63040
diff changeset
    50
      from b have \<open>g' b \<in> g' ` (- A)\<close> by (rule imageI)
wenzelm
parents: 63040
diff changeset
    51
      with * have \<open>g' b \<in> - (f ` A)\<close> by simp
61938
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    52
      with eq fa show False by simp
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    53
    qed
63291
wenzelm
parents: 63040
diff changeset
    54
    ultimately show \<open>inj ?h\<close>
61938
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    55
      unfolding inj_on_def by (metis ComplI)
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    56
  qed
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    57
qed
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    58
e1205f814159 more proofs;
wenzelm
parents:
diff changeset
    59
end