src/HOL/Inductive.thy
author nipkow
Mon, 12 Aug 2019 15:57:40 +0200
changeset 70504 8d4abdbc6de9
parent 69913 ca515cf61651
child 80932 261cd8722677
permissions -rw-r--r--
simplified defs (thanks to Mohammad)
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
7700
38b6d2643630 load / setup datatype package;
wenzelm
parents: 7357
diff changeset
     1
(*  Title:      HOL/Inductive.thy
10402
5e82d6cafb5f inductive_atomize, inductive_rulify;
wenzelm
parents: 10312
diff changeset
     2
    Author:     Markus Wenzel, TU Muenchen
11688
56833637db2a generic induct_method.ML;
wenzelm
parents: 11439
diff changeset
     3
*)
10727
2ccafccb81c0 added inductive_conj;
wenzelm
parents: 10434
diff changeset
     4
60758
d8d85a8172b5 isabelle update_cartouches;
wenzelm
parents: 60636
diff changeset
     5
section \<open>Knaster-Tarski Fixpoint Theorem and inductive definitions\<close>
1187
bc94f00e47ba Includes Sum.thy as a parent for mutual recursion
lcp
parents: 923
diff changeset
     6
54398
100c0eaf63d5 moved 'Ctr_Sugar' further up the theory hierarchy, so that 'Datatype' can use it
blanchet
parents: 52143
diff changeset
     7
theory Inductive
63588
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
     8
  imports Complete_Lattices Ctr_Sugar
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
     9
  keywords
69913
ca515cf61651 more specific keyword kinds;
wenzelm
parents: 69605
diff changeset
    10
    "inductive" "coinductive" "inductive_cases" "inductive_simps" :: thy_defn and
63588
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
    11
    "monos" and
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
    12
    "print_inductives" :: diag and
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
    13
    "old_rep_datatype" :: thy_goal and
69913
ca515cf61651 more specific keyword kinds;
wenzelm
parents: 69605
diff changeset
    14
    "primrec" :: thy_defn
15131
c69542757a4d New theory header syntax.
nipkow
parents: 14981
diff changeset
    15
begin
10727
2ccafccb81c0 added inductive_conj;
wenzelm
parents: 10434
diff changeset
    16
63979
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    17
subsection \<open>Least fixed points\<close>
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
    18
26013
8764a1f1253b Theorem Inductive.lfp_ordinal_induct generalized to complete lattices
haftmann
parents: 25557
diff changeset
    19
context complete_lattice
8764a1f1253b Theorem Inductive.lfp_ordinal_induct generalized to complete lattices
haftmann
parents: 25557
diff changeset
    20
begin
8764a1f1253b Theorem Inductive.lfp_ordinal_induct generalized to complete lattices
haftmann
parents: 25557
diff changeset
    21
63979
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    22
definition lfp :: "('a \<Rightarrow> 'a) \<Rightarrow> 'a"
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
    23
  where "lfp f = Inf {u. f u \<le> u}"
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
    24
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
    25
lemma lfp_lowerbound: "f A \<le> A \<Longrightarrow> lfp f \<le> A"
63981
6f7db4f8df4c tuned proofs;
wenzelm
parents: 63980
diff changeset
    26
  unfolding lfp_def by (rule Inf_lower) simp
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
    27
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
    28
lemma lfp_greatest: "(\<And>u. f u \<le> u \<Longrightarrow> A \<le> u) \<Longrightarrow> A \<le> lfp f"
63981
6f7db4f8df4c tuned proofs;
wenzelm
parents: 63980
diff changeset
    29
  unfolding lfp_def by (rule Inf_greatest) simp
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
    30
26013
8764a1f1253b Theorem Inductive.lfp_ordinal_induct generalized to complete lattices
haftmann
parents: 25557
diff changeset
    31
end
8764a1f1253b Theorem Inductive.lfp_ordinal_induct generalized to complete lattices
haftmann
parents: 25557
diff changeset
    32
63979
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    33
lemma lfp_fixpoint:
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    34
  assumes "mono f"
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    35
  shows "f (lfp f) = lfp f"
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    36
  unfolding lfp_def
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    37
proof (rule order_antisym)
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    38
  let ?H = "{u. f u \<le> u}"
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    39
  let ?a = "\<Sqinter>?H"
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    40
  show "f ?a \<le> ?a"
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    41
  proof (rule Inf_greatest)
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    42
    fix x
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    43
    assume "x \<in> ?H"
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    44
    then have "?a \<le> x" by (rule Inf_lower)
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    45
    with \<open>mono f\<close> have "f ?a \<le> f x" ..
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    46
    also from \<open>x \<in> ?H\<close> have "f x \<le> x" ..
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    47
    finally show "f ?a \<le> x" .
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    48
  qed
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    49
  show "?a \<le> f ?a"
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    50
  proof (rule Inf_lower)
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    51
    from \<open>mono f\<close> and \<open>f ?a \<le> ?a\<close> have "f (f ?a) \<le> f ?a" ..
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    52
    then show "f ?a \<in> ?H" ..
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    53
  qed
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    54
qed
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
    55
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
    56
lemma lfp_unfold: "mono f \<Longrightarrow> lfp f = f (lfp f)"
63979
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
    57
  by (rule lfp_fixpoint [symmetric])
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
    58
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
    59
lemma lfp_const: "lfp (\<lambda>x. t) = t"
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
    60
  by (rule lfp_unfold) (simp add: mono_def)
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
    61
63588
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
    62
lemma lfp_eqI: "mono F \<Longrightarrow> F x = x \<Longrightarrow> (\<And>z. F z = z \<Longrightarrow> x \<le> z) \<Longrightarrow> lfp F = x"
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
    63
  by (rule antisym) (simp_all add: lfp_lowerbound lfp_unfold[symmetric])
63561
fba08009ff3e add lemmas contributed by Peter Gammie
Andreas Lochbihler
parents: 63540
diff changeset
    64
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
    65
60758
d8d85a8172b5 isabelle update_cartouches;
wenzelm
parents: 60636
diff changeset
    66
subsection \<open>General induction rules for least fixed points\<close>
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
    67
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
    68
lemma lfp_ordinal_induct [case_names mono step union]:
61076
bdc1e2f0a86a eliminated \<Colon>;
wenzelm
parents: 60758
diff changeset
    69
  fixes f :: "'a::complete_lattice \<Rightarrow> 'a"
26013
8764a1f1253b Theorem Inductive.lfp_ordinal_induct generalized to complete lattices
haftmann
parents: 25557
diff changeset
    70
  assumes mono: "mono f"
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
    71
    and P_f: "\<And>S. P S \<Longrightarrow> S \<le> lfp f \<Longrightarrow> P (f S)"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
    72
    and P_Union: "\<And>M. \<forall>S\<in>M. P S \<Longrightarrow> P (Sup M)"
26013
8764a1f1253b Theorem Inductive.lfp_ordinal_induct generalized to complete lattices
haftmann
parents: 25557
diff changeset
    73
  shows "P (lfp f)"
8764a1f1253b Theorem Inductive.lfp_ordinal_induct generalized to complete lattices
haftmann
parents: 25557
diff changeset
    74
proof -
8764a1f1253b Theorem Inductive.lfp_ordinal_induct generalized to complete lattices
haftmann
parents: 25557
diff changeset
    75
  let ?M = "{S. S \<le> lfp f \<and> P S}"
63588
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
    76
  from P_Union have "P (Sup ?M)" by simp
26013
8764a1f1253b Theorem Inductive.lfp_ordinal_induct generalized to complete lattices
haftmann
parents: 25557
diff changeset
    77
  also have "Sup ?M = lfp f"
8764a1f1253b Theorem Inductive.lfp_ordinal_induct generalized to complete lattices
haftmann
parents: 25557
diff changeset
    78
  proof (rule antisym)
63588
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
    79
    show "Sup ?M \<le> lfp f"
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
    80
      by (blast intro: Sup_least)
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
    81
    then have "f (Sup ?M) \<le> f (lfp f)"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
    82
      by (rule mono [THEN monoD])
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
    83
    then have "f (Sup ?M) \<le> lfp f"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
    84
      using mono [THEN lfp_unfold] by simp
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
    85
    then have "f (Sup ?M) \<in> ?M"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
    86
      using P_Union by simp (intro P_f Sup_least, auto)
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
    87
    then have "f (Sup ?M) \<le> Sup ?M"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
    88
      by (rule Sup_upper)
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
    89
    then show "lfp f \<le> Sup ?M"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
    90
      by (rule lfp_lowerbound)
26013
8764a1f1253b Theorem Inductive.lfp_ordinal_induct generalized to complete lattices
haftmann
parents: 25557
diff changeset
    91
  qed
8764a1f1253b Theorem Inductive.lfp_ordinal_induct generalized to complete lattices
haftmann
parents: 25557
diff changeset
    92
  finally show ?thesis .
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
    93
qed
26013
8764a1f1253b Theorem Inductive.lfp_ordinal_induct generalized to complete lattices
haftmann
parents: 25557
diff changeset
    94
60174
70d8f7abde8f strengthened lfp_ordinal_induct; added dual gfp variant
hoelzl
parents: 60173
diff changeset
    95
theorem lfp_induct:
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
    96
  assumes mono: "mono f"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
    97
    and ind: "f (inf (lfp f) P) \<le> P"
60174
70d8f7abde8f strengthened lfp_ordinal_induct; added dual gfp variant
hoelzl
parents: 60173
diff changeset
    98
  shows "lfp f \<le> P"
63588
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
    99
proof (induct rule: lfp_ordinal_induct)
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   100
  case mono
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   101
  show ?case by fact
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   102
next
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   103
  case (step S)
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   104
  then show ?case
60174
70d8f7abde8f strengthened lfp_ordinal_induct; added dual gfp variant
hoelzl
parents: 60173
diff changeset
   105
    by (intro order_trans[OF _ ind] monoD[OF mono]) auto
63588
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   106
next
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   107
  case (union M)
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   108
  then show ?case
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   109
    by (auto intro: Sup_least)
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   110
qed
60174
70d8f7abde8f strengthened lfp_ordinal_induct; added dual gfp variant
hoelzl
parents: 60173
diff changeset
   111
70d8f7abde8f strengthened lfp_ordinal_induct; added dual gfp variant
hoelzl
parents: 60173
diff changeset
   112
lemma lfp_induct_set:
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   113
  assumes lfp: "a \<in> lfp f"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   114
    and mono: "mono f"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   115
    and hyp: "\<And>x. x \<in> f (lfp f \<inter> {x. P x}) \<Longrightarrow> P x"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   116
  shows "P a"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   117
  by (rule lfp_induct [THEN subsetD, THEN CollectD, OF mono _ lfp]) (auto intro: hyp)
60174
70d8f7abde8f strengthened lfp_ordinal_induct; added dual gfp variant
hoelzl
parents: 60173
diff changeset
   118
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   119
lemma lfp_ordinal_induct_set:
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   120
  assumes mono: "mono f"
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   121
    and P_f: "\<And>S. P S \<Longrightarrow> P (f S)"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   122
    and P_Union: "\<And>M. \<forall>S\<in>M. P S \<Longrightarrow> P (\<Union>M)"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   123
  shows "P (lfp f)"
46008
c296c75f4cf4 reverted some changes for set->predicate transition, according to "hg log -u berghofe -r Isabelle2007:Isabelle2008";
wenzelm
parents: 45907
diff changeset
   124
  using assms by (rule lfp_ordinal_induct)
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   125
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   126
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   127
text \<open>Definition forms of \<open>lfp_unfold\<close> and \<open>lfp_induct\<close>, to control unfolding.\<close>
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   128
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   129
lemma def_lfp_unfold: "h \<equiv> lfp f \<Longrightarrow> mono f \<Longrightarrow> h = f h"
45899
df887263a379 prefer Name.context operations;
wenzelm
parents: 45897
diff changeset
   130
  by (auto intro!: lfp_unfold)
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   131
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   132
lemma def_lfp_induct: "A \<equiv> lfp f \<Longrightarrow> mono f \<Longrightarrow> f (inf A P) \<le> P \<Longrightarrow> A \<le> P"
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   133
  by (blast intro: lfp_induct)
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   134
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   135
lemma def_lfp_induct_set:
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   136
  "A \<equiv> lfp f \<Longrightarrow> mono f \<Longrightarrow> a \<in> A \<Longrightarrow> (\<And>x. x \<in> f (A \<inter> {x. P x}) \<Longrightarrow> P x) \<Longrightarrow> P a"
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   137
  by (blast intro: lfp_induct_set)
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   138
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   139
text \<open>Monotonicity of \<open>lfp\<close>!\<close>
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   140
lemma lfp_mono: "(\<And>Z. f Z \<le> g Z) \<Longrightarrow> lfp f \<le> lfp g"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   141
  by (rule lfp_lowerbound [THEN lfp_greatest]) (blast intro: order_trans)
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   142
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   143
63979
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   144
subsection \<open>Greatest fixed points\<close>
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   145
63979
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   146
context complete_lattice
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   147
begin
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   148
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   149
definition gfp :: "('a \<Rightarrow> 'a) \<Rightarrow> 'a"
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   150
  where "gfp f = Sup {u. u \<le> f u}"
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   151
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   152
lemma gfp_upperbound: "X \<le> f X \<Longrightarrow> X \<le> gfp f"
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   153
  by (auto simp add: gfp_def intro: Sup_upper)
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   154
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   155
lemma gfp_least: "(\<And>u. u \<le> f u \<Longrightarrow> u \<le> X) \<Longrightarrow> gfp f \<le> X"
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   156
  by (auto simp add: gfp_def intro: Sup_least)
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   157
63979
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   158
end
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   159
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   160
lemma lfp_le_gfp: "mono f \<Longrightarrow> lfp f \<le> gfp f"
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   161
  by (rule gfp_upperbound) (simp add: lfp_fixpoint)
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   162
63979
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   163
lemma gfp_fixpoint:
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   164
  assumes "mono f"
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   165
  shows "f (gfp f) = gfp f"
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   166
  unfolding gfp_def
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   167
proof (rule order_antisym)
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   168
  let ?H = "{u. u \<le> f u}"
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   169
  let ?a = "\<Squnion>?H"
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   170
  show "?a \<le> f ?a"
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   171
  proof (rule Sup_least)
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   172
    fix x
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   173
    assume "x \<in> ?H"
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   174
    then have "x \<le> f x" ..
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   175
    also from \<open>x \<in> ?H\<close> have "x \<le> ?a" by (rule Sup_upper)
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   176
    with \<open>mono f\<close> have "f x \<le> f ?a" ..
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   177
    finally show "x \<le> f ?a" .
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   178
  qed
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   179
  show "f ?a \<le> ?a"
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   180
  proof (rule Sup_upper)
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   181
    from \<open>mono f\<close> and \<open>?a \<le> f ?a\<close> have "f ?a \<le> f (f ?a)" ..
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   182
    then show "f ?a \<in> ?H" ..
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   183
  qed
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   184
qed
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   185
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   186
lemma gfp_unfold: "mono f \<Longrightarrow> gfp f = f (gfp f)"
63979
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   187
  by (rule gfp_fixpoint [symmetric])
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   188
63561
fba08009ff3e add lemmas contributed by Peter Gammie
Andreas Lochbihler
parents: 63540
diff changeset
   189
lemma gfp_const: "gfp (\<lambda>x. t) = t"
63588
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   190
  by (rule gfp_unfold) (simp add: mono_def)
63561
fba08009ff3e add lemmas contributed by Peter Gammie
Andreas Lochbihler
parents: 63540
diff changeset
   191
63588
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   192
lemma gfp_eqI: "mono F \<Longrightarrow> F x = x \<Longrightarrow> (\<And>z. F z = z \<Longrightarrow> z \<le> x) \<Longrightarrow> gfp F = x"
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   193
  by (rule antisym) (simp_all add: gfp_upperbound gfp_unfold[symmetric])
63561
fba08009ff3e add lemmas contributed by Peter Gammie
Andreas Lochbihler
parents: 63540
diff changeset
   194
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   195
60758
d8d85a8172b5 isabelle update_cartouches;
wenzelm
parents: 60636
diff changeset
   196
subsection \<open>Coinduction rules for greatest fixed points\<close>
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   197
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   198
text \<open>Weak version.\<close>
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   199
lemma weak_coinduct: "a \<in> X \<Longrightarrow> X \<subseteq> f X \<Longrightarrow> a \<in> gfp f"
45899
df887263a379 prefer Name.context operations;
wenzelm
parents: 45897
diff changeset
   200
  by (rule gfp_upperbound [THEN subsetD]) auto
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   201
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   202
lemma weak_coinduct_image: "a \<in> X \<Longrightarrow> g`X \<subseteq> f (g`X) \<Longrightarrow> g a \<in> gfp f"
45899
df887263a379 prefer Name.context operations;
wenzelm
parents: 45897
diff changeset
   203
  apply (erule gfp_upperbound [THEN subsetD])
df887263a379 prefer Name.context operations;
wenzelm
parents: 45897
diff changeset
   204
  apply (erule imageI)
df887263a379 prefer Name.context operations;
wenzelm
parents: 45897
diff changeset
   205
  done
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   206
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   207
lemma coinduct_lemma: "X \<le> f (sup X (gfp f)) \<Longrightarrow> mono f \<Longrightarrow> sup X (gfp f) \<le> f (sup X (gfp f))"
63979
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   208
  apply (frule gfp_unfold [THEN eq_refl])
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   209
  apply (drule mono_sup)
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   210
  apply (rule le_supI)
63588
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   211
   apply assumption
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   212
  apply (rule order_trans)
63588
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   213
   apply (rule order_trans)
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   214
    apply assumption
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   215
   apply (rule sup_ge2)
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   216
  apply assumption
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   217
  done
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   218
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   219
text \<open>Strong version, thanks to Coen and Frost.\<close>
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   220
lemma coinduct_set: "mono f \<Longrightarrow> a \<in> X \<Longrightarrow> X \<subseteq> f (X \<union> gfp f) \<Longrightarrow> a \<in> gfp f"
55604
42e4e8c2e8dc less flex-flex pairs
noschinl
parents: 55575
diff changeset
   221
  by (rule weak_coinduct[rotated], rule coinduct_lemma) blast+
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   222
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   223
lemma gfp_fun_UnI2: "mono f \<Longrightarrow> a \<in> gfp f \<Longrightarrow> a \<in> f (X \<union> gfp f)"
63979
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   224
  by (blast dest: gfp_fixpoint mono_Un)
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   225
60174
70d8f7abde8f strengthened lfp_ordinal_induct; added dual gfp variant
hoelzl
parents: 60173
diff changeset
   226
lemma gfp_ordinal_induct[case_names mono step union]:
61076
bdc1e2f0a86a eliminated \<Colon>;
wenzelm
parents: 60758
diff changeset
   227
  fixes f :: "'a::complete_lattice \<Rightarrow> 'a"
60174
70d8f7abde8f strengthened lfp_ordinal_induct; added dual gfp variant
hoelzl
parents: 60173
diff changeset
   228
  assumes mono: "mono f"
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   229
    and P_f: "\<And>S. P S \<Longrightarrow> gfp f \<le> S \<Longrightarrow> P (f S)"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   230
    and P_Union: "\<And>M. \<forall>S\<in>M. P S \<Longrightarrow> P (Inf M)"
60174
70d8f7abde8f strengthened lfp_ordinal_induct; added dual gfp variant
hoelzl
parents: 60173
diff changeset
   231
  shows "P (gfp f)"
70d8f7abde8f strengthened lfp_ordinal_induct; added dual gfp variant
hoelzl
parents: 60173
diff changeset
   232
proof -
70d8f7abde8f strengthened lfp_ordinal_induct; added dual gfp variant
hoelzl
parents: 60173
diff changeset
   233
  let ?M = "{S. gfp f \<le> S \<and> P S}"
63588
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   234
  from P_Union have "P (Inf ?M)" by simp
60174
70d8f7abde8f strengthened lfp_ordinal_induct; added dual gfp variant
hoelzl
parents: 60173
diff changeset
   235
  also have "Inf ?M = gfp f"
70d8f7abde8f strengthened lfp_ordinal_induct; added dual gfp variant
hoelzl
parents: 60173
diff changeset
   236
  proof (rule antisym)
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   237
    show "gfp f \<le> Inf ?M"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   238
      by (blast intro: Inf_greatest)
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   239
    then have "f (gfp f) \<le> f (Inf ?M)"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   240
      by (rule mono [THEN monoD])
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   241
    then have "gfp f \<le> f (Inf ?M)"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   242
      using mono [THEN gfp_unfold] by simp
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   243
    then have "f (Inf ?M) \<in> ?M"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   244
      using P_Union by simp (intro P_f Inf_greatest, auto)
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   245
    then have "Inf ?M \<le> f (Inf ?M)"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   246
      by (rule Inf_lower)
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   247
    then show "Inf ?M \<le> gfp f"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   248
      by (rule gfp_upperbound)
60174
70d8f7abde8f strengthened lfp_ordinal_induct; added dual gfp variant
hoelzl
parents: 60173
diff changeset
   249
  qed
70d8f7abde8f strengthened lfp_ordinal_induct; added dual gfp variant
hoelzl
parents: 60173
diff changeset
   250
  finally show ?thesis .
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   251
qed
60174
70d8f7abde8f strengthened lfp_ordinal_induct; added dual gfp variant
hoelzl
parents: 60173
diff changeset
   252
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   253
lemma coinduct:
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   254
  assumes mono: "mono f"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   255
    and ind: "X \<le> f (sup X (gfp f))"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   256
  shows "X \<le> gfp f"
63588
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   257
proof (induct rule: gfp_ordinal_induct)
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   258
  case mono
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   259
  then show ?case by fact
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   260
next
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   261
  case (step S)
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   262
  then show ?case
60174
70d8f7abde8f strengthened lfp_ordinal_induct; added dual gfp variant
hoelzl
parents: 60173
diff changeset
   263
    by (intro order_trans[OF ind _] monoD[OF mono]) auto
63588
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   264
next
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   265
  case (union M)
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   266
  then show ?case
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   267
    by (auto intro: mono Inf_greatest)
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   268
qed
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   269
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   270
60758
d8d85a8172b5 isabelle update_cartouches;
wenzelm
parents: 60636
diff changeset
   271
subsection \<open>Even Stronger Coinduction Rule, by Martin Coen\<close>
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   272
69593
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 64674
diff changeset
   273
text \<open>Weakens the condition \<^term>\<open>X \<subseteq> f X\<close> to one expressed using both
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 64674
diff changeset
   274
  \<^term>\<open>lfp\<close> and \<^term>\<open>gfp\<close>\<close>
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   275
lemma coinduct3_mono_lemma: "mono f \<Longrightarrow> mono (\<lambda>x. f x \<union> X \<union> B)"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   276
  by (iprover intro: subset_refl monoI Un_mono monoD)
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   277
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   278
lemma coinduct3_lemma:
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   279
  "X \<subseteq> f (lfp (\<lambda>x. f x \<union> X \<union> gfp f)) \<Longrightarrow> mono f \<Longrightarrow>
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   280
    lfp (\<lambda>x. f x \<union> X \<union> gfp f) \<subseteq> f (lfp (\<lambda>x. f x \<union> X \<union> gfp f))"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   281
  apply (rule subset_trans)
63979
95c3ae4baba8 clarified lfp/gfp statements and proofs;
wenzelm
parents: 63976
diff changeset
   282
   apply (erule coinduct3_mono_lemma [THEN lfp_unfold [THEN eq_refl]])
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   283
  apply (rule Un_least [THEN Un_least])
63588
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   284
    apply (rule subset_refl, assumption)
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   285
  apply (rule gfp_unfold [THEN equalityD1, THEN subset_trans], assumption)
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   286
  apply (rule monoD, assumption)
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   287
  apply (subst coinduct3_mono_lemma [THEN lfp_unfold], auto)
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   288
  done
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   289
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   290
lemma coinduct3: "mono f \<Longrightarrow> a \<in> X \<Longrightarrow> X \<subseteq> f (lfp (\<lambda>x. f x \<union> X \<union> gfp f)) \<Longrightarrow> a \<in> gfp f"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   291
  apply (rule coinduct3_lemma [THEN [2] weak_coinduct])
63588
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   292
    apply (rule coinduct3_mono_lemma [THEN lfp_unfold, THEN ssubst])
d0e2bad67bd4 misc tuning and modernization;
wenzelm
parents: 63561
diff changeset
   293
     apply simp_all
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   294
  done
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   295
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   296
text  \<open>Definition forms of \<open>gfp_unfold\<close> and \<open>coinduct\<close>, to control unfolding.\<close>
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   297
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   298
lemma def_gfp_unfold: "A \<equiv> gfp f \<Longrightarrow> mono f \<Longrightarrow> A = f A"
45899
df887263a379 prefer Name.context operations;
wenzelm
parents: 45897
diff changeset
   299
  by (auto intro!: gfp_unfold)
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   300
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   301
lemma def_coinduct: "A \<equiv> gfp f \<Longrightarrow> mono f \<Longrightarrow> X \<le> f (sup X A) \<Longrightarrow> X \<le> A"
45899
df887263a379 prefer Name.context operations;
wenzelm
parents: 45897
diff changeset
   302
  by (iprover intro!: coinduct)
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   303
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   304
lemma def_coinduct_set: "A \<equiv> gfp f \<Longrightarrow> mono f \<Longrightarrow> a \<in> X \<Longrightarrow> X \<subseteq> f (X \<union> A) \<Longrightarrow> a \<in> A"
45899
df887263a379 prefer Name.context operations;
wenzelm
parents: 45897
diff changeset
   305
  by (auto intro!: coinduct_set)
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   306
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   307
lemma def_Collect_coinduct:
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   308
  "A \<equiv> gfp (\<lambda>w. Collect (P w)) \<Longrightarrow> mono (\<lambda>w. Collect (P w)) \<Longrightarrow> a \<in> X \<Longrightarrow>
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   309
    (\<And>z. z \<in> X \<Longrightarrow> P (X \<union> A) z) \<Longrightarrow> a \<in> A"
45899
df887263a379 prefer Name.context operations;
wenzelm
parents: 45897
diff changeset
   310
  by (erule def_coinduct_set) auto
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   311
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   312
lemma def_coinduct3: "A \<equiv> gfp f \<Longrightarrow> mono f \<Longrightarrow> a \<in> X \<Longrightarrow> X \<subseteq> f (lfp (\<lambda>x. f x \<union> X \<union> A)) \<Longrightarrow> a \<in> A"
45899
df887263a379 prefer Name.context operations;
wenzelm
parents: 45897
diff changeset
   313
  by (auto intro!: coinduct3)
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   314
69593
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 64674
diff changeset
   315
text \<open>Monotonicity of \<^term>\<open>gfp\<close>!\<close>
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   316
lemma gfp_mono: "(\<And>Z. f Z \<le> g Z) \<Longrightarrow> gfp f \<le> gfp g"
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   317
  by (rule gfp_upperbound [THEN gfp_least]) (blast intro: order_trans)
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   318
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   319
60758
d8d85a8172b5 isabelle update_cartouches;
wenzelm
parents: 60636
diff changeset
   320
subsection \<open>Rules for fixed point calculus\<close>
60173
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   321
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   322
lemma lfp_rolling:
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   323
  assumes "mono g" "mono f"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   324
  shows "g (lfp (\<lambda>x. f (g x))) = lfp (\<lambda>x. g (f x))"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   325
proof (rule antisym)
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   326
  have *: "mono (\<lambda>x. f (g x))"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   327
    using assms by (auto simp: mono_def)
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   328
  show "lfp (\<lambda>x. g (f x)) \<le> g (lfp (\<lambda>x. f (g x)))"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   329
    by (rule lfp_lowerbound) (simp add: lfp_unfold[OF *, symmetric])
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   330
  show "g (lfp (\<lambda>x. f (g x))) \<le> lfp (\<lambda>x. g (f x))"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   331
  proof (rule lfp_greatest)
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   332
    fix u
63540
f8652d0534fa tuned proofs -- avoid unstructured calculation;
wenzelm
parents: 63400
diff changeset
   333
    assume u: "g (f u) \<le> u"
f8652d0534fa tuned proofs -- avoid unstructured calculation;
wenzelm
parents: 63400
diff changeset
   334
    then have "g (lfp (\<lambda>x. f (g x))) \<le> g (f u)"
60173
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   335
      by (intro assms[THEN monoD] lfp_lowerbound)
63540
f8652d0534fa tuned proofs -- avoid unstructured calculation;
wenzelm
parents: 63400
diff changeset
   336
    with u show "g (lfp (\<lambda>x. f (g x))) \<le> u"
60173
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   337
      by auto
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   338
  qed
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   339
qed
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   340
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   341
lemma lfp_lfp:
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   342
  assumes f: "\<And>x y w z. x \<le> y \<Longrightarrow> w \<le> z \<Longrightarrow> f x w \<le> f y z"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   343
  shows "lfp (\<lambda>x. lfp (f x)) = lfp (\<lambda>x. f x x)"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   344
proof (rule antisym)
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   345
  have *: "mono (\<lambda>x. f x x)"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   346
    by (blast intro: monoI f)
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   347
  show "lfp (\<lambda>x. lfp (f x)) \<le> lfp (\<lambda>x. f x x)"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   348
    by (intro lfp_lowerbound) (simp add: lfp_unfold[OF *, symmetric])
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   349
  show "lfp (\<lambda>x. lfp (f x)) \<ge> lfp (\<lambda>x. f x x)" (is "?F \<ge> _")
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   350
  proof (intro lfp_lowerbound)
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   351
    have *: "?F = lfp (f ?F)"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   352
      by (rule lfp_unfold) (blast intro: monoI lfp_mono f)
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   353
    also have "\<dots> = f ?F (lfp (f ?F))"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   354
      by (rule lfp_unfold) (blast intro: monoI lfp_mono f)
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   355
    finally show "f ?F ?F \<le> ?F"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   356
      by (simp add: *[symmetric])
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   357
  qed
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   358
qed
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   359
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   360
lemma gfp_rolling:
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   361
  assumes "mono g" "mono f"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   362
  shows "g (gfp (\<lambda>x. f (g x))) = gfp (\<lambda>x. g (f x))"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   363
proof (rule antisym)
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   364
  have *: "mono (\<lambda>x. f (g x))"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   365
    using assms by (auto simp: mono_def)
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   366
  show "g (gfp (\<lambda>x. f (g x))) \<le> gfp (\<lambda>x. g (f x))"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   367
    by (rule gfp_upperbound) (simp add: gfp_unfold[OF *, symmetric])
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   368
  show "gfp (\<lambda>x. g (f x)) \<le> g (gfp (\<lambda>x. f (g x)))"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   369
  proof (rule gfp_least)
63540
f8652d0534fa tuned proofs -- avoid unstructured calculation;
wenzelm
parents: 63400
diff changeset
   370
    fix u
f8652d0534fa tuned proofs -- avoid unstructured calculation;
wenzelm
parents: 63400
diff changeset
   371
    assume u: "u \<le> g (f u)"
f8652d0534fa tuned proofs -- avoid unstructured calculation;
wenzelm
parents: 63400
diff changeset
   372
    then have "g (f u) \<le> g (gfp (\<lambda>x. f (g x)))"
60173
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   373
      by (intro assms[THEN monoD] gfp_upperbound)
63540
f8652d0534fa tuned proofs -- avoid unstructured calculation;
wenzelm
parents: 63400
diff changeset
   374
    with u show "u \<le> g (gfp (\<lambda>x. f (g x)))"
60173
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   375
      by auto
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   376
  qed
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   377
qed
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   378
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   379
lemma gfp_gfp:
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   380
  assumes f: "\<And>x y w z. x \<le> y \<Longrightarrow> w \<le> z \<Longrightarrow> f x w \<le> f y z"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   381
  shows "gfp (\<lambda>x. gfp (f x)) = gfp (\<lambda>x. f x x)"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   382
proof (rule antisym)
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   383
  have *: "mono (\<lambda>x. f x x)"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   384
    by (blast intro: monoI f)
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   385
  show "gfp (\<lambda>x. f x x) \<le> gfp (\<lambda>x. gfp (f x))"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   386
    by (intro gfp_upperbound) (simp add: gfp_unfold[OF *, symmetric])
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   387
  show "gfp (\<lambda>x. gfp (f x)) \<le> gfp (\<lambda>x. f x x)" (is "?F \<le> _")
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   388
  proof (intro gfp_upperbound)
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   389
    have *: "?F = gfp (f ?F)"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   390
      by (rule gfp_unfold) (blast intro: monoI gfp_mono f)
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   391
    also have "\<dots> = f ?F (gfp (f ?F))"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   392
      by (rule gfp_unfold) (blast intro: monoI gfp_mono f)
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   393
    finally show "?F \<le> f ?F ?F"
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   394
      by (simp add: *[symmetric])
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   395
  qed
6a61bb577d5b add rules for least/greatest fixed point calculus
hoelzl
parents: 58889
diff changeset
   396
qed
24915
fc90277c0dd7 integrated FixedPoint into Inductive
haftmann
parents: 24845
diff changeset
   397
63400
249fa34faba2 misc tuning and modernization;
wenzelm
parents: 61955
diff changeset
   398
60758
d8d85a8172b5 isabelle update_cartouches;
wenzelm
parents: 60636
diff changeset
   399
subsection \<open>Inductive predicates and sets\<close>
11688
56833637db2a generic induct_method.ML;
wenzelm
parents: 11439
diff changeset
   400
60758
d8d85a8172b5 isabelle update_cartouches;
wenzelm
parents: 60636
diff changeset
   401
text \<open>Package setup.\<close>
10402
5e82d6cafb5f inductive_atomize, inductive_rulify;
wenzelm
parents: 10312
diff changeset
   402
61337
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents: 61076
diff changeset
   403
lemmas basic_monos =
22218
30a8890d2967 dropped lemma duplicates in HOL.thy
haftmann
parents: 21018
diff changeset
   404
  subset_refl imp_refl disj_mono conj_mono ex_mono all_mono if_bool_eq_conj
11688
56833637db2a generic induct_method.ML;
wenzelm
parents: 11439
diff changeset
   405
  Collect_mono in_mono vimage_mono
56833637db2a generic induct_method.ML;
wenzelm
parents: 11439
diff changeset
   406
63863
d14e580c3b8f don't expose internal construction in the coinduction rule for mutual coinductive predicates
traytel
parents: 63588
diff changeset
   407
lemma le_rel_bool_arg_iff: "X \<le> Y \<longleftrightarrow> X False \<le> Y False \<and> X True \<le> Y True"
d14e580c3b8f don't expose internal construction in the coinduction rule for mutual coinductive predicates
traytel
parents: 63588
diff changeset
   408
  unfolding le_fun_def le_bool_def using bool_induct by auto
d14e580c3b8f don't expose internal construction in the coinduction rule for mutual coinductive predicates
traytel
parents: 63588
diff changeset
   409
d14e580c3b8f don't expose internal construction in the coinduction rule for mutual coinductive predicates
traytel
parents: 63588
diff changeset
   410
lemma imp_conj_iff: "((P \<longrightarrow> Q) \<and> P) = (P \<and> Q)"
d14e580c3b8f don't expose internal construction in the coinduction rule for mutual coinductive predicates
traytel
parents: 63588
diff changeset
   411
  by blast
d14e580c3b8f don't expose internal construction in the coinduction rule for mutual coinductive predicates
traytel
parents: 63588
diff changeset
   412
d14e580c3b8f don't expose internal construction in the coinduction rule for mutual coinductive predicates
traytel
parents: 63588
diff changeset
   413
lemma meta_fun_cong: "P \<equiv> Q \<Longrightarrow> P a \<equiv> Q a"
d14e580c3b8f don't expose internal construction in the coinduction rule for mutual coinductive predicates
traytel
parents: 63588
diff changeset
   414
  by auto
d14e580c3b8f don't expose internal construction in the coinduction rule for mutual coinductive predicates
traytel
parents: 63588
diff changeset
   415
69605
a96320074298 isabelle update -u path_cartouches;
wenzelm
parents: 69593
diff changeset
   416
ML_file \<open>Tools/inductive.ML\<close>
21018
e6b8d6784792 Added new package for inductive definitions, moved old package
berghofe
parents: 20604
diff changeset
   417
61337
4645502c3c64 fewer aliases for toplevel theorem statements;
wenzelm
parents: 61076
diff changeset
   418
lemmas [mono] =
22218
30a8890d2967 dropped lemma duplicates in HOL.thy
haftmann
parents: 21018
diff changeset
   419
  imp_refl disj_mono conj_mono ex_mono all_mono if_bool_eq_conj
33934
25d6a8982e37 Streamlined setup for monotonicity rules (no longer requires classical rules).
berghofe
parents: 32701
diff changeset
   420
  imp_mono not_mono
21018
e6b8d6784792 Added new package for inductive definitions, moved old package
berghofe
parents: 20604
diff changeset
   421
  Ball_def Bex_def
e6b8d6784792 Added new package for inductive definitions, moved old package
berghofe
parents: 20604
diff changeset
   422
  induct_rulify_fallback
e6b8d6784792 Added new package for inductive definitions, moved old package
berghofe
parents: 20604
diff changeset
   423
11688
56833637db2a generic induct_method.ML;
wenzelm
parents: 11439
diff changeset
   424
63980
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   425
subsection \<open>The Schroeder-Bernstein Theorem\<close>
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   426
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   427
text \<open>
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   428
  See also:
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   429
  \<^item> \<^file>\<open>$ISABELLE_HOME/src/HOL/ex/Set_Theory.thy\<close>
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   430
  \<^item> \<^url>\<open>http://planetmath.org/proofofschroederbernsteintheoremusingtarskiknastertheorem\<close>
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   431
  \<^item> Springer LNCS 828 (cover page)
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   432
\<close>
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   433
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   434
theorem Schroeder_Bernstein:
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   435
  fixes f :: "'a \<Rightarrow> 'b" and g :: "'b \<Rightarrow> 'a"
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   436
    and A :: "'a set" and B :: "'b set"
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   437
  assumes inj1: "inj_on f A" and sub1: "f ` A \<subseteq> B"
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   438
    and inj2: "inj_on g B" and sub2: "g ` B \<subseteq> A"
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   439
  shows "\<exists>h. bij_betw h A B"
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   440
proof (rule exI, rule bij_betw_imageI)
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   441
  define X where "X = lfp (\<lambda>X. A - (g ` (B - (f ` X))))"
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   442
  define g' where "g' = the_inv_into (B - (f ` X)) g"
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   443
  let ?h = "\<lambda>z. if z \<in> X then f z else g' z"
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   444
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   445
  have X: "X = A - (g ` (B - (f ` X)))"
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   446
    unfolding X_def by (rule lfp_unfold) (blast intro: monoI)
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   447
  then have X_compl: "A - X = g ` (B - (f ` X))"
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   448
    using sub2 by blast
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   449
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   450
  from inj2 have inj2': "inj_on g (B - (f ` X))"
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   451
    by (rule inj_on_subset) auto
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   452
  with X_compl have *: "g' ` (A - X) = B - (f ` X)"
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   453
    by (simp add: g'_def)
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   454
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   455
  from X have X_sub: "X \<subseteq> A" by auto
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   456
  from X sub1 have fX_sub: "f ` X \<subseteq> B" by auto
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   457
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   458
  show "?h ` A = B"
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   459
  proof -
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   460
    from X_sub have "?h ` A = ?h ` (X \<union> (A - X))" by auto
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   461
    also have "\<dots> = ?h ` X \<union> ?h ` (A - X)" by (simp only: image_Un)
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   462
    also have "?h ` X = f ` X" by auto
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   463
    also from * have "?h ` (A - X) = B - (f ` X)" by auto
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   464
    also from fX_sub have "f ` X \<union> (B - f ` X) = B" by blast
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   465
    finally show ?thesis .
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   466
  qed
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   467
  show "inj_on ?h A"
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   468
  proof -
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   469
    from inj1 X_sub have on_X: "inj_on f X"
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   470
      by (rule subset_inj_on)
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   471
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   472
    have on_X_compl: "inj_on g' (A - X)"
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   473
      unfolding g'_def X_compl
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   474
      by (rule inj_on_the_inv_into) (rule inj2')
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   475
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   476
    have impossible: False if eq: "f a = g' b" and a: "a \<in> X" and b: "b \<in> A - X" for a b
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   477
    proof -
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   478
      from a have fa: "f a \<in> f ` X" by (rule imageI)
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   479
      from b have "g' b \<in> g' ` (A - X)" by (rule imageI)
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   480
      with * have "g' b \<in> - (f ` X)" by simp
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   481
      with eq fa show False by simp
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   482
    qed
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   483
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   484
    show ?thesis
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   485
    proof (rule inj_onI)
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   486
      fix a b
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   487
      assume h: "?h a = ?h b"
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   488
      assume "a \<in> A" and "b \<in> A"
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   489
      then consider "a \<in> X" "b \<in> X" | "a \<in> A - X" "b \<in> A - X"
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   490
        | "a \<in> X" "b \<in> A - X" | "a \<in> A - X" "b \<in> X"
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   491
        by blast
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   492
      then show "a = b"
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   493
      proof cases
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   494
        case 1
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   495
        with h on_X show ?thesis by (simp add: inj_on_eq_iff)
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   496
      next
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   497
        case 2
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   498
        with h on_X_compl show ?thesis by (simp add: inj_on_eq_iff)
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   499
      next
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   500
        case 3
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   501
        with h impossible [of a b] have False by simp
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   502
        then show ?thesis ..
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   503
      next
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   504
        case 4
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   505
        with h impossible [of b a] have False by simp
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   506
        then show ?thesis ..
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   507
      qed
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   508
    qed
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   509
  qed
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   510
qed
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   511
f8e556c8ad6f Isar proof of Schroeder_Bernstein without using Hilbert_Choice (and metis);
wenzelm
parents: 63979
diff changeset
   512
60758
d8d85a8172b5 isabelle update_cartouches;
wenzelm
parents: 60636
diff changeset
   513
subsection \<open>Inductive datatypes and primitive recursion\<close>
11688
56833637db2a generic induct_method.ML;
wenzelm
parents: 11439
diff changeset
   514
60758
d8d85a8172b5 isabelle update_cartouches;
wenzelm
parents: 60636
diff changeset
   515
text \<open>Package setup.\<close>
11825
ef7d619e2c88 moved InductMethod.setup to theory HOL;
wenzelm
parents: 11688
diff changeset
   516
69605
a96320074298 isabelle update -u path_cartouches;
wenzelm
parents: 69593
diff changeset
   517
ML_file \<open>Tools/Old_Datatype/old_datatype_aux.ML\<close>
a96320074298 isabelle update -u path_cartouches;
wenzelm
parents: 69593
diff changeset
   518
ML_file \<open>Tools/Old_Datatype/old_datatype_prop.ML\<close>
a96320074298 isabelle update -u path_cartouches;
wenzelm
parents: 69593
diff changeset
   519
ML_file \<open>Tools/Old_Datatype/old_datatype_data.ML\<close>
a96320074298 isabelle update -u path_cartouches;
wenzelm
parents: 69593
diff changeset
   520
ML_file \<open>Tools/Old_Datatype/old_rep_datatype.ML\<close>
a96320074298 isabelle update -u path_cartouches;
wenzelm
parents: 69593
diff changeset
   521
ML_file \<open>Tools/Old_Datatype/old_datatype_codegen.ML\<close>
a96320074298 isabelle update -u path_cartouches;
wenzelm
parents: 69593
diff changeset
   522
ML_file \<open>Tools/BNF/bnf_fp_rec_sugar_util.ML\<close>
a96320074298 isabelle update -u path_cartouches;
wenzelm
parents: 69593
diff changeset
   523
ML_file \<open>Tools/Old_Datatype/old_primrec.ML\<close>
a96320074298 isabelle update -u path_cartouches;
wenzelm
parents: 69593
diff changeset
   524
ML_file \<open>Tools/BNF/bnf_lfp_rec_sugar.ML\<close>
55575
a5e33e18fb5c moved 'primrec' up (for real this time) and removed temporary 'old_primrec'
blanchet
parents: 55534
diff changeset
   525
61955
e96292f32c3c former "xsymbols" syntax is used by default, and ASCII replacement syntax with print mode "ASCII";
wenzelm
parents: 61952
diff changeset
   526
text \<open>Lambda-abstractions with pattern matching:\<close>
e96292f32c3c former "xsymbols" syntax is used by default, and ASCII replacement syntax with print mode "ASCII";
wenzelm
parents: 61952
diff changeset
   527
syntax (ASCII)
e96292f32c3c former "xsymbols" syntax is used by default, and ASCII replacement syntax with print mode "ASCII";
wenzelm
parents: 61952
diff changeset
   528
  "_lam_pats_syntax" :: "cases_syn \<Rightarrow> 'a \<Rightarrow> 'b"  ("(%_)" 10)
23526
936dc616a7fb Added pattern maatching for lambda abstraction
nipkow
parents: 23389
diff changeset
   529
syntax
61955
e96292f32c3c former "xsymbols" syntax is used by default, and ASCII replacement syntax with print mode "ASCII";
wenzelm
parents: 61952
diff changeset
   530
  "_lam_pats_syntax" :: "cases_syn \<Rightarrow> 'a \<Rightarrow> 'b"  ("(\<lambda>_)" 10)
60758
d8d85a8172b5 isabelle update_cartouches;
wenzelm
parents: 60636
diff changeset
   531
parse_translation \<open>
52143
36ffe23b25f8 syntax translations always depend on context;
wenzelm
parents: 51692
diff changeset
   532
  let
36ffe23b25f8 syntax translations always depend on context;
wenzelm
parents: 51692
diff changeset
   533
    fun fun_tr ctxt [cs] =
36ffe23b25f8 syntax translations always depend on context;
wenzelm
parents: 51692
diff changeset
   534
      let
36ffe23b25f8 syntax translations always depend on context;
wenzelm
parents: 51692
diff changeset
   535
        val x = Syntax.free (fst (Name.variant "x" (Term.declare_term_frees cs Name.context)));
36ffe23b25f8 syntax translations always depend on context;
wenzelm
parents: 51692
diff changeset
   536
        val ft = Case_Translation.case_tr true ctxt [x, cs];
36ffe23b25f8 syntax translations always depend on context;
wenzelm
parents: 51692
diff changeset
   537
      in lambda x ft end
69593
3dda49e08b9d isabelle update -u control_cartouches;
wenzelm
parents: 64674
diff changeset
   538
  in [(\<^syntax_const>\<open>_lam_pats_syntax\<close>, fun_tr)] end
60758
d8d85a8172b5 isabelle update_cartouches;
wenzelm
parents: 60636
diff changeset
   539
\<close>
23526
936dc616a7fb Added pattern maatching for lambda abstraction
nipkow
parents: 23389
diff changeset
   540
936dc616a7fb Added pattern maatching for lambda abstraction
nipkow
parents: 23389
diff changeset
   541
end