src/HOL/Probability/Weak_Convergence.thy
author wenzelm
Thu, 08 Dec 2022 11:24:43 +0100
changeset 76598 9f97eda3fcf1
parent 75607 3c544d64c218
permissions -rw-r--r--
tuned;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
63329
6b26c378ab35 Probability: tuned headers; cleanup Radon_Nikodym
hoelzl
parents: 63040
diff changeset
     1
(*  Title:     HOL/Probability/Weak_Convergence.thy
6b26c378ab35 Probability: tuned headers; cleanup Radon_Nikodym
hoelzl
parents: 63040
diff changeset
     2
    Authors:   Jeremy Avigad (CMU), Johannes Hölzl (TUM)
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
     3
*)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
     4
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
     5
section \<open>Weak Convergence of Functions and Distributions\<close>
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
     6
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
     7
text \<open>Properties of weak convergence of functions and measures, including the portmanteau theorem.\<close>
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
     8
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
     9
theory Weak_Convergence
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    10
  imports Distribution_Functions
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    11
begin
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    12
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    13
section \<open>Weak Convergence of Functions\<close>
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    14
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    15
definition
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    16
  weak_conv :: "(nat \<Rightarrow> (real \<Rightarrow> real)) \<Rightarrow> (real \<Rightarrow> real) \<Rightarrow> bool"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    17
where
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    18
  "weak_conv F_seq F \<equiv> \<forall>x. isCont F x \<longrightarrow> (\<lambda>n. F_seq n x) \<longlonglongrightarrow> F x"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    19
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    20
section \<open>Weak Convergence of Distributions\<close>
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    21
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    22
definition
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    23
  weak_conv_m :: "(nat \<Rightarrow> real measure) \<Rightarrow> real measure \<Rightarrow> bool"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    24
where
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    25
  "weak_conv_m M_seq M \<equiv> weak_conv (\<lambda>n. cdf (M_seq n)) (cdf M)"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    26
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    27
section \<open>Skorohod's theorem\<close>
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    28
62375
670063003ad3 add extended nonnegative real numbers
hoelzl
parents: 62083
diff changeset
    29
locale right_continuous_mono =
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    30
  fixes f :: "real \<Rightarrow> real" and a b :: real
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    31
  assumes cont: "\<And>x. continuous (at_right x) f"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    32
  assumes mono: "mono f"
62375
670063003ad3 add extended nonnegative real numbers
hoelzl
parents: 62083
diff changeset
    33
  assumes bot: "(f \<longlongrightarrow> a) at_bot"
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    34
  assumes top: "(f \<longlongrightarrow> b) at_top"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    35
begin
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    36
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    37
abbreviation I :: "real \<Rightarrow> real" where
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    38
  "I \<omega> \<equiv> Inf {x. \<omega> \<le> f x}"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    39
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    40
lemma pseudoinverse: assumes "a < \<omega>" "\<omega> < b" shows "\<omega> \<le> f x \<longleftrightarrow> I \<omega> \<le> x"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    41
proof
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    42
  let ?F = "{x. \<omega> \<le> f x}"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    43
  obtain y where "f y < \<omega>"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    44
    by (metis eventually_happens' trivial_limit_at_bot_linorder order_tendstoD(2) bot \<open>a < \<omega>\<close>)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    45
  with mono have bdd: "bdd_below ?F"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    46
    by (auto intro!: bdd_belowI[of _ y] elim: mono_invE[OF _ less_le_trans])
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    47
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    48
  have ne: "?F \<noteq> {}"
62375
670063003ad3 add extended nonnegative real numbers
hoelzl
parents: 62083
diff changeset
    49
    using order_tendstoD(1)[OF top \<open>\<omega> < b\<close>]
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    50
    by (auto dest!: eventually_happens'[OF trivial_limit_at_top_linorder] intro: less_imp_le)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    51
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    52
  show "\<omega> \<le> f x \<Longrightarrow> I \<omega> \<le> x"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    53
    by (auto intro!: cInf_lower bdd)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    54
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    55
  { assume *: "I \<omega> \<le> x"
69260
0a9688695a1b removed relics of ASCII syntax for indexed big operators
haftmann
parents: 63952
diff changeset
    56
    have "\<omega> \<le> (INF s\<in>{x. \<omega> \<le> f x}. f s)"
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    57
      by (rule cINF_greatest[OF ne]) auto
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    58
    also have "\<dots> = f (I \<omega>)"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    59
      using continuous_at_Inf_mono[OF mono cont ne bdd] ..
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    60
    also have "\<dots> \<le> f x"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    61
      using * by (rule monoD[OF \<open>mono f\<close>])
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    62
    finally show "\<omega> \<le> f x" . }
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    63
qed
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    64
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    65
lemma pseudoinverse': "\<forall>\<omega>\<in>{a<..<b}. \<forall>x. \<omega> \<le> f x \<longleftrightarrow> I \<omega> \<le> x"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    66
  by (intro ballI allI impI pseudoinverse) auto
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    67
75607
3c544d64c218 changed argument order of mono_on and strict_mono_on to uniformize with monotone_on and other predicates
desharna
parents: 70365
diff changeset
    68
lemma mono_I: "mono_on {a <..< b} I"
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    69
  unfolding mono_on_def by (metis order.trans order.refl pseudoinverse')
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    70
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    71
end
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    72
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    73
locale cdf_distribution = real_distribution
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    74
begin
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    75
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    76
abbreviation "C \<equiv> cdf M"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    77
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    78
sublocale right_continuous_mono C 0 1
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    79
  by standard
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    80
     (auto intro: cdf_nondecreasing cdf_is_right_cont cdf_lim_at_top_prob cdf_lim_at_bot monoI)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    81
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    82
lemma measurable_C[measurable]: "C \<in> borel_measurable borel"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    83
  by (intro borel_measurable_mono mono)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    84
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    85
lemma measurable_CI[measurable]: "I \<in> borel_measurable (restrict_space borel {0<..<1})"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    86
  by (intro borel_measurable_mono_on_fnc mono_I)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    87
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    88
lemma emeasure_distr_I: "emeasure (distr (restrict_space lborel {0<..<1::real}) borel I) UNIV = 1"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    89
  by (simp add: emeasure_distr space_restrict_space emeasure_restrict_space )
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    90
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    91
lemma distr_I_eq_M: "distr (restrict_space lborel {0<..<1::real}) borel I = M" (is "?I = _")
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    92
proof (intro cdf_unique ext)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    93
  let ?\<Omega> = "restrict_space lborel {0<..<1}::real measure"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    94
  interpret \<Omega>: prob_space ?\<Omega>
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    95
    by (auto simp add: emeasure_restrict_space space_restrict_space intro!: prob_spaceI)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    96
  show "real_distribution ?I"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    97
    by auto
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    98
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
    99
  fix x
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   100
  have "cdf ?I x = measure lborel {\<omega>\<in>{0<..<1}. \<omega> \<le> C x}"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   101
    by (subst cdf_def)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   102
       (auto simp: pseudoinverse[symmetric] measure_distr space_restrict_space measure_restrict_space
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   103
             intro!: arg_cong2[where f="measure"])
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   104
  also have "\<dots> = measure lborel {0 <..< C x}"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   105
    using cdf_bounded_prob[of x] AE_lborel_singleton[of "C x"]
62975
1d066f6ab25d Probability: move emeasure and nn_integral from ereal to ennreal
hoelzl
parents: 62375
diff changeset
   106
    by (auto intro!: arg_cong[where f=enn2real] emeasure_eq_AE simp: measure_def)
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   107
  also have "\<dots> = C x"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   108
    by (simp add: cdf_nonneg)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   109
  finally show "cdf (distr ?\<Omega> borel I) x = C x" .
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   110
qed standard
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   111
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   112
end
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   113
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   114
context
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   115
  fixes \<mu> :: "nat \<Rightarrow> real measure"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   116
    and M :: "real measure"
62375
670063003ad3 add extended nonnegative real numbers
hoelzl
parents: 62083
diff changeset
   117
  assumes \<mu>: "\<And>n. real_distribution (\<mu> n)"
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   118
  assumes M: "real_distribution M"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   119
  assumes \<mu>_to_M: "weak_conv_m \<mu> M"
62375
670063003ad3 add extended nonnegative real numbers
hoelzl
parents: 62083
diff changeset
   120
begin
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   121
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   122
(* state using obtains? *)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   123
theorem Skorohod:
62375
670063003ad3 add extended nonnegative real numbers
hoelzl
parents: 62083
diff changeset
   124
 "\<exists> (\<Omega> :: real measure) (Y_seq :: nat \<Rightarrow> real \<Rightarrow> real) (Y :: real \<Rightarrow> real).
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   125
    prob_space \<Omega> \<and>
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   126
    (\<forall>n. Y_seq n \<in> measurable \<Omega> borel) \<and>
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   127
    (\<forall>n. distr \<Omega> borel (Y_seq n) = \<mu> n) \<and>
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   128
    Y \<in> measurable \<Omega> lborel \<and>
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   129
    distr \<Omega> borel Y = M \<and>
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   130
    (\<forall>x \<in> space \<Omega>. (\<lambda>n. Y_seq n x) \<longlonglongrightarrow> Y x)"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   131
proof -
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   132
  interpret \<mu>: cdf_distribution "\<mu> n" for n
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   133
    unfolding cdf_distribution_def by (rule \<mu>)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   134
  interpret M: cdf_distribution M
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   135
    unfolding cdf_distribution_def by (rule M)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   136
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   137
  have conv: "measure M {x} = 0 \<Longrightarrow> (\<lambda>n. \<mu>.C n x) \<longlonglongrightarrow> M.C x" for x
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   138
    using \<mu>_to_M M.isCont_cdf by (auto simp: weak_conv_m_def weak_conv_def)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   139
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   140
  let ?\<Omega> = "restrict_space lborel {0<..<1} :: real measure"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   141
  have "prob_space ?\<Omega>"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   142
    by (auto simp: space_restrict_space emeasure_restrict_space intro!: prob_spaceI)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   143
  interpret \<Omega>: prob_space ?\<Omega>
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   144
    by fact
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   145
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   146
  have Y_distr: "distr ?\<Omega> borel M.I = M"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   147
    by (rule M.distr_I_eq_M)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   148
62375
670063003ad3 add extended nonnegative real numbers
hoelzl
parents: 62083
diff changeset
   149
  have Y_cts_cnv: "(\<lambda>n. \<mu>.I n \<omega>) \<longlonglongrightarrow> M.I \<omega>"
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   150
    if \<omega>: "\<omega> \<in> {0<..<1}" "isCont M.I \<omega>" for \<omega> :: real
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   151
  proof (intro limsup_le_liminf_real)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   152
    show "liminf (\<lambda>n. \<mu>.I n \<omega>) \<ge> M.I \<omega>"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   153
      unfolding le_Liminf_iff
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   154
    proof safe
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   155
      fix B :: ereal assume B: "B < M.I \<omega>"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   156
      then show "\<forall>\<^sub>F n in sequentially. B < \<mu>.I n \<omega>"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   157
      proof (cases B)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   158
        case (real r)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   159
        with B have r: "r < M.I \<omega>"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   160
          by simp
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   161
        then obtain x where x: "r < x" "x < M.I \<omega>" "measure M {x} = 0"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   162
          using open_minus_countable[OF M.countable_support, of "{r<..<M.I \<omega>}"] by auto
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   163
        then have Fx_less: "M.C x < \<omega>"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   164
          using M.pseudoinverse' \<omega> not_less by blast
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   165
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   166
        have "\<forall>\<^sub>F n in sequentially. \<mu>.C n x < \<omega>"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   167
          using order_tendstoD(2)[OF conv[OF x(3)] Fx_less] .
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   168
        then have "\<forall>\<^sub>F n in sequentially. x < \<mu>.I n \<omega>"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   169
          by eventually_elim (insert \<omega> \<mu>.pseudoinverse[symmetric], simp add: not_le[symmetric])
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   170
        then show ?thesis
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   171
          by eventually_elim (insert x(1), simp add: real)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   172
      qed auto
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   173
    qed
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   174
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   175
    have *: "limsup (\<lambda>n. \<mu>.I n \<omega>) \<le> M.I \<omega>'"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   176
      if \<omega>': "0 < \<omega>'" "\<omega>' < 1" "\<omega> < \<omega>'" for \<omega>' :: real
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   177
    proof (rule dense_ge_bounded)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   178
      fix B' assume "ereal (M.I \<omega>') < B'" "B' < ereal (M.I \<omega>' + 1)"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   179
      then obtain B where "M.I \<omega>' < B" and [simp]: "B' = ereal B"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   180
        by (cases B') auto
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   181
      then obtain y where y: "M.I \<omega>' < y" "y < B" "measure M {y} = 0"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   182
        using open_minus_countable[OF M.countable_support, of "{M.I \<omega>'<..<B}"] by auto
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   183
      then have "\<omega>' \<le> M.C (M.I \<omega>')"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   184
        using M.pseudoinverse' \<omega>' by (metis greaterThanLessThan_iff order_refl)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   185
      also have "... \<le> M.C y"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   186
        using M.mono y unfolding mono_def by auto
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   187
      finally have Fy_gt: "\<omega> < M.C y"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   188
        using \<omega>'(3) by simp
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   189
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   190
      have "\<forall>\<^sub>F n in sequentially. \<omega> \<le> \<mu>.C n y"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   191
        using order_tendstoD(1)[OF conv[OF y(3)] Fy_gt] by eventually_elim (rule less_imp_le)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   192
      then have 2: "\<forall>\<^sub>F n in sequentially. \<mu>.I n \<omega> \<le> ereal y"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   193
        by simp (subst \<mu>.pseudoinverse'[rule_format, OF \<omega>(1), symmetric])
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   194
      then show "limsup (\<lambda>n. \<mu>.I n \<omega>) \<le> B'"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   195
        using \<open>y < B\<close>
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   196
        by (intro Limsup_bounded[rotated]) (auto intro: le_less_trans elim: eventually_mono)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   197
    qed simp
62375
670063003ad3 add extended nonnegative real numbers
hoelzl
parents: 62083
diff changeset
   198
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   199
    have **: "(M.I \<longlongrightarrow> ereal (M.I \<omega>)) (at_right \<omega>)"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   200
      using \<omega>(2) by (auto intro: tendsto_within_subset simp: continuous_at)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   201
    show "limsup (\<lambda>n. \<mu>.I n \<omega>) \<le> M.I \<omega>"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   202
      using \<omega>
63952
354808e9f44b new material connected with HOL Light measure theory, plus more rationalisation
paulson <lp15@cam.ac.uk>
parents: 63329
diff changeset
   203
      by (intro tendsto_lowerbound[OF **])
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   204
         (auto intro!: exI[of _ 1] * simp: eventually_at_right[of _ 1])
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   205
  qed
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   206
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   207
  let ?D = "{\<omega>\<in>{0<..<1}. \<not> isCont M.I \<omega>}"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   208
  have D_countable: "countable ?D"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   209
    using mono_on_ctble_discont[OF M.mono_I] by (simp add: at_within_open[of _ "{0 <..< 1}"] cong: conj_cong)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   210
  hence D: "emeasure ?\<Omega> ?D = 0"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   211
    using emeasure_lborel_countable[OF D_countable]
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   212
    by (subst emeasure_restrict_space) auto
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   213
63040
eb4ddd18d635 eliminated old 'def';
wenzelm
parents: 62975
diff changeset
   214
  define Y' where "Y' \<omega> = (if \<omega> \<in> ?D then 0 else M.I \<omega>)" for \<omega>
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   215
  have Y'_AE: "AE \<omega> in ?\<Omega>. Y' \<omega> = M.I \<omega>"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   216
    by (rule AE_I [OF _ D]) (auto simp: space_restrict_space sets_restrict_space_iff Y'_def)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   217
63040
eb4ddd18d635 eliminated old 'def';
wenzelm
parents: 62975
diff changeset
   218
  define Y_seq' where "Y_seq' n \<omega> = (if \<omega> \<in> ?D then 0 else \<mu>.I n \<omega>)" for n \<omega>
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   219
  have Y_seq'_AE: "\<And>n. AE \<omega> in ?\<Omega>. Y_seq' n \<omega> = \<mu>.I n \<omega>"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   220
    by (rule AE_I [OF _ D]) (auto simp: space_restrict_space sets_restrict_space_iff Y_seq'_def)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   221
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   222
  have Y'_cnv: "\<forall>\<omega>\<in>{0<..<1}. (\<lambda>n. Y_seq' n \<omega>) \<longlonglongrightarrow> Y' \<omega>"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   223
    by (auto simp: Y'_def Y_seq'_def Y_cts_cnv)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   224
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   225
  have [simp]: "Y_seq' n \<in> borel_measurable ?\<Omega>" for n
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   226
    by (rule measurable_discrete_difference[of "\<mu>.I n" _ _ ?D])
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   227
       (insert \<mu>.measurable_CI[of n] D_countable, auto simp: sets_restrict_space Y_seq'_def)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   228
  moreover have "distr ?\<Omega> borel (Y_seq' n) = \<mu> n" for n
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   229
    using \<mu>.distr_I_eq_M [of n] Y_seq'_AE [of n]
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   230
    by (subst distr_cong_AE[where f = "Y_seq' n" and g = "\<mu>.I n"], auto)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   231
  moreover have [simp]: "Y' \<in> borel_measurable ?\<Omega>"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   232
    by (rule measurable_discrete_difference[of M.I _ _ ?D])
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   233
       (insert M.measurable_CI D_countable, auto simp: sets_restrict_space Y'_def)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   234
  moreover have "distr ?\<Omega> borel Y' = M"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   235
    using M.distr_I_eq_M Y'_AE
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   236
    by (subst distr_cong_AE[where f = Y' and g = M.I], auto)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   237
  ultimately have "prob_space ?\<Omega> \<and> (\<forall>n. Y_seq' n \<in> borel_measurable ?\<Omega>) \<and>
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   238
    (\<forall>n. distr ?\<Omega> borel (Y_seq' n) = \<mu> n) \<and> Y' \<in> measurable ?\<Omega> lborel \<and> distr ?\<Omega> borel Y' = M \<and>
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   239
    (\<forall>x\<in>space ?\<Omega>. (\<lambda>n. Y_seq' n x) \<longlonglongrightarrow> Y' x)"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   240
    using Y'_cnv \<open>prob_space ?\<Omega>\<close> by (auto simp: space_restrict_space)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   241
  thus ?thesis by metis
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   242
qed
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   243
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   244
text \<open>
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   245
  The Portmanteau theorem, that is, the equivalence of various definitions of weak convergence.
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   246
\<close>
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   247
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   248
theorem weak_conv_imp_bdd_ae_continuous_conv:
62375
670063003ad3 add extended nonnegative real numbers
hoelzl
parents: 62083
diff changeset
   249
  fixes
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   250
    f :: "real \<Rightarrow> 'a::{banach, second_countable_topology}"
62375
670063003ad3 add extended nonnegative real numbers
hoelzl
parents: 62083
diff changeset
   251
  assumes
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   252
    discont_null: "M ({x. \<not> isCont f x}) = 0" and
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   253
    f_bdd: "\<And>x. norm (f x) \<le> B" and
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   254
    [measurable]: "f \<in> borel_measurable borel"
62375
670063003ad3 add extended nonnegative real numbers
hoelzl
parents: 62083
diff changeset
   255
  shows
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   256
    "(\<lambda> n. integral\<^sup>L (\<mu> n) f) \<longlonglongrightarrow> integral\<^sup>L M f"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   257
proof -
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   258
  have "0 \<le> B"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   259
    using norm_ge_zero f_bdd by (rule order_trans)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   260
  note Skorohod
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   261
  then obtain Omega Y_seq Y where
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   262
    ps_Omega [simp]: "prob_space Omega" and
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   263
    Y_seq_measurable [measurable]: "\<And>n. Y_seq n \<in> borel_measurable Omega" and
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   264
    distr_Y_seq: "\<And>n. distr Omega borel (Y_seq n) = \<mu> n" and
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   265
    Y_measurable [measurable]: "Y \<in> borel_measurable Omega" and
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   266
    distr_Y: "distr Omega borel Y = M" and
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   267
    YnY: "\<And>x :: real. x \<in> space Omega \<Longrightarrow> (\<lambda>n. Y_seq n x) \<longlonglongrightarrow> Y x"  by force
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   268
  interpret prob_space Omega by fact
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   269
  have *: "emeasure Omega (Y -` {x. \<not> isCont f x} \<inter> space Omega) = 0"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   270
    by (subst emeasure_distr [symmetric, where N=borel]) (auto simp: distr_Y discont_null)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   271
  have *: "AE x in Omega. (\<lambda>n. f (Y_seq n x)) \<longlonglongrightarrow> f (Y x)"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   272
    by (rule AE_I [OF _ *]) (auto intro: isCont_tendsto_compose YnY)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   273
  show ?thesis
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   274
    by (auto intro!: integral_dominated_convergence[where w="\<lambda>x. B"]
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   275
             simp: f_bdd * integral_distr distr_Y_seq [symmetric] distr_Y [symmetric])
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   276
qed
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   277
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   278
theorem weak_conv_imp_integral_bdd_continuous_conv:
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   279
  fixes f :: "real \<Rightarrow> 'a::{banach, second_countable_topology}"
62375
670063003ad3 add extended nonnegative real numbers
hoelzl
parents: 62083
diff changeset
   280
  assumes
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   281
    "\<And>x. isCont f x" and
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   282
    "\<And>x. norm (f x) \<le> B"
62375
670063003ad3 add extended nonnegative real numbers
hoelzl
parents: 62083
diff changeset
   283
  shows
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   284
    "(\<lambda> n. integral\<^sup>L (\<mu> n) f) \<longlonglongrightarrow> integral\<^sup>L M f"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   285
  using assms
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   286
  by (intro weak_conv_imp_bdd_ae_continuous_conv)
70365
4df0628e8545 a few new lemmas and a bit of tidying
paulson <lp15@cam.ac.uk>
parents: 69710
diff changeset
   287
     (auto intro!: borel_measurable_continuous_onI continuous_at_imp_continuous_on)
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   288
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   289
theorem weak_conv_imp_continuity_set_conv:
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   290
  fixes f :: "real \<Rightarrow> real"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   291
  assumes [measurable]: "A \<in> sets borel" and "M (frontier A) = 0"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   292
  shows "(\<lambda>n. measure (\<mu> n) A) \<longlonglongrightarrow> measure M A"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   293
proof -
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   294
  interpret M: real_distribution M by fact
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   295
  interpret \<mu>: real_distribution "\<mu> n" for n by fact
62375
670063003ad3 add extended nonnegative real numbers
hoelzl
parents: 62083
diff changeset
   296
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   297
  have "(\<lambda>n. (\<integral>x. indicator A x \<partial>\<mu> n) :: real) \<longlonglongrightarrow> (\<integral>x. indicator A x \<partial>M)"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   298
    by (intro weak_conv_imp_bdd_ae_continuous_conv[where B=1])
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   299
       (auto intro: assms simp: isCont_indicator)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   300
  then show ?thesis
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   301
    by simp
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   302
qed
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   303
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   304
end
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   305
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   306
definition
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   307
  cts_step :: "real \<Rightarrow> real \<Rightarrow> real \<Rightarrow> real"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   308
where
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   309
  "cts_step a b x \<equiv> if x \<le> a then 1 else if x \<ge> b then 0 else (b - x) / (b - a)"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   310
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   311
lemma cts_step_uniformly_continuous:
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   312
  assumes [arith]: "a < b"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   313
  shows "uniformly_continuous_on UNIV (cts_step a b)"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   314
  unfolding uniformly_continuous_on_def
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   315
proof clarsimp
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   316
  fix e :: real assume [arith]: "0 < e"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   317
  let ?d = "min (e * (b - a)) (b - a)"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   318
  have "?d > 0"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   319
    by (auto simp add: field_simps)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   320
  moreover have "dist x' x < ?d \<Longrightarrow> dist (cts_step a b x') (cts_step a b x) < e" for x x'
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   321
    by (auto simp: dist_real_def divide_simps cts_step_def)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   322
  ultimately show "\<exists>d > 0. \<forall>x x'. dist x' x < d \<longrightarrow> dist (cts_step a b x') (cts_step a b x) < e"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   323
    by blast
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   324
qed
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   325
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   326
lemma (in real_distribution) integrable_cts_step: "a < b \<Longrightarrow> integrable M (cts_step a b)"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   327
  by (rule integrable_const_bound [of _ 1]) (auto simp: cts_step_def[abs_def])
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   328
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   329
lemma (in real_distribution) cdf_cts_step:
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   330
  assumes [arith]: "x < y"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   331
  shows "cdf M x \<le> integral\<^sup>L M (cts_step x y)" and "integral\<^sup>L M (cts_step x y) \<le> cdf M y"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   332
proof -
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   333
  have "cdf M x = integral\<^sup>L M (indicator {..x})"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   334
    by (simp add: cdf_def)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   335
  also have "\<dots> \<le> expectation (cts_step x y)"
62975
1d066f6ab25d Probability: move emeasure and nn_integral from ereal to ennreal
hoelzl
parents: 62375
diff changeset
   336
    by (intro integral_mono integrable_cts_step)
1d066f6ab25d Probability: move emeasure and nn_integral from ereal to ennreal
hoelzl
parents: 62375
diff changeset
   337
       (auto simp: cts_step_def less_top[symmetric] split: split_indicator)
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   338
  finally show "cdf M x \<le> expectation (cts_step x y)" .
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   339
next
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   340
  have "expectation (cts_step x y) \<le> integral\<^sup>L M (indicator {..y})"
62975
1d066f6ab25d Probability: move emeasure and nn_integral from ereal to ennreal
hoelzl
parents: 62375
diff changeset
   341
    by (intro integral_mono integrable_cts_step)
1d066f6ab25d Probability: move emeasure and nn_integral from ereal to ennreal
hoelzl
parents: 62375
diff changeset
   342
       (auto simp: cts_step_def less_top[symmetric] split: split_indicator)
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   343
  also have "\<dots> = cdf M y"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   344
    by (simp add: cdf_def)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   345
  finally show "expectation (cts_step x y) \<le> cdf M y" .
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   346
qed
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   347
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   348
context
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   349
  fixes M_seq :: "nat \<Rightarrow> real measure"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   350
    and M :: "real measure"
62375
670063003ad3 add extended nonnegative real numbers
hoelzl
parents: 62083
diff changeset
   351
  assumes distr_M_seq [simp]: "\<And>n. real_distribution (M_seq n)"
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   352
  assumes distr_M [simp]: "real_distribution M"
62375
670063003ad3 add extended nonnegative real numbers
hoelzl
parents: 62083
diff changeset
   353
begin
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   354
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   355
theorem continuity_set_conv_imp_weak_conv:
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   356
  fixes f :: "real \<Rightarrow> real"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   357
  assumes *: "\<And>A. A \<in> sets borel \<Longrightarrow> M (frontier A) = 0 \<Longrightarrow> (\<lambda> n. (measure (M_seq n) A)) \<longlonglongrightarrow> measure M A"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   358
  shows "weak_conv_m M_seq M"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   359
proof -
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   360
  interpret real_distribution M by simp
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   361
  show ?thesis
69710
61372780515b some renamings and a bit of new material
paulson <lp15@cam.ac.uk>
parents: 69260
diff changeset
   362
    by (auto intro!: * simp: frontier_real_atMost isCont_cdf emeasure_eq_measure weak_conv_m_def weak_conv_def cdf_def2)
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   363
qed
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   364
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   365
theorem integral_cts_step_conv_imp_weak_conv:
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   366
  assumes integral_conv: "\<And>x y. x < y \<Longrightarrow> (\<lambda>n. integral\<^sup>L (M_seq n) (cts_step x y)) \<longlonglongrightarrow> integral\<^sup>L M (cts_step x y)"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   367
  shows "weak_conv_m M_seq M"
62375
670063003ad3 add extended nonnegative real numbers
hoelzl
parents: 62083
diff changeset
   368
  unfolding weak_conv_m_def weak_conv_def
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   369
proof (clarsimp)
62375
670063003ad3 add extended nonnegative real numbers
hoelzl
parents: 62083
diff changeset
   370
  interpret real_distribution M by (rule distr_M)
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   371
  fix x assume "isCont (cdf M) x"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   372
  hence left_cont: "continuous (at_left x) (cdf M)"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   373
    unfolding continuous_at_split ..
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   374
  { fix y :: real assume [arith]: "x < y"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   375
    have "limsup (\<lambda>n. cdf (M_seq n) x) \<le> limsup (\<lambda>n. integral\<^sup>L (M_seq n) (cts_step x y))"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   376
      by (auto intro!: Limsup_mono always_eventually real_distribution.cdf_cts_step)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   377
    also have "\<dots> = integral\<^sup>L M (cts_step x y)"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   378
      by (intro lim_imp_Limsup) (auto intro: integral_conv)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   379
    also have "\<dots> \<le> cdf M y"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   380
      by (simp add: cdf_cts_step)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   381
    finally have "limsup (\<lambda>n. cdf (M_seq n) x) \<le> cdf M y" .
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   382
  } note * = this
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   383
  { fix y :: real assume [arith]: "x > y"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   384
    have "cdf M y \<le> ereal (integral\<^sup>L M (cts_step y x))"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   385
      by (simp add: cdf_cts_step)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   386
    also have "\<dots> = liminf (\<lambda>n. integral\<^sup>L (M_seq n) (cts_step y x))"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   387
      by (intro lim_imp_Liminf[symmetric]) (auto intro: integral_conv)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   388
    also have "\<dots> \<le> liminf (\<lambda>n. cdf (M_seq n) x)"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   389
      by (auto intro!: Liminf_mono always_eventually real_distribution.cdf_cts_step)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   390
    finally have "liminf (\<lambda>n. cdf (M_seq n) x) \<ge> cdf M y" .
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   391
  } note ** = this
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   392
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   393
  have "limsup (\<lambda>n. cdf (M_seq n) x) \<le> cdf M x"
63952
354808e9f44b new material connected with HOL Light measure theory, plus more rationalisation
paulson <lp15@cam.ac.uk>
parents: 63329
diff changeset
   394
  proof (rule tendsto_lowerbound)
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   395
    show "\<forall>\<^sub>F i in at_right x. limsup (\<lambda>xa. ereal (cdf (M_seq xa) x)) \<le> ereal (cdf M i)"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   396
      by (subst eventually_at_right[of _ "x + 1"]) (auto simp: * intro: exI [of _ "x+1"])
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   397
  qed (insert cdf_is_right_cont, auto simp: continuous_within)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   398
  moreover have "cdf M x \<le> liminf (\<lambda>n. cdf (M_seq n) x)"
63952
354808e9f44b new material connected with HOL Light measure theory, plus more rationalisation
paulson <lp15@cam.ac.uk>
parents: 63329
diff changeset
   399
  proof (rule tendsto_upperbound)
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   400
    show "\<forall>\<^sub>F i in at_left x. ereal (cdf M i) \<le> liminf (\<lambda>xa. ereal (cdf (M_seq xa) x))"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   401
      by (subst eventually_at_left[of "x - 1"]) (auto simp: ** intro: exI [of _ "x-1"])
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   402
  qed (insert left_cont, auto simp: continuous_within)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   403
  ultimately show "(\<lambda>n. cdf (M_seq n) x) \<longlonglongrightarrow> cdf M x"
62375
670063003ad3 add extended nonnegative real numbers
hoelzl
parents: 62083
diff changeset
   404
    by (elim limsup_le_liminf_real)
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   405
qed
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   406
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   407
theorem integral_bdd_continuous_conv_imp_weak_conv:
62375
670063003ad3 add extended nonnegative real numbers
hoelzl
parents: 62083
diff changeset
   408
  assumes
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   409
    "\<And>f. (\<And>x. isCont f x) \<Longrightarrow> (\<And>x. abs (f x) \<le> 1) \<Longrightarrow> (\<lambda>n. integral\<^sup>L (M_seq n) f::real) \<longlonglongrightarrow> integral\<^sup>L M f"
62375
670063003ad3 add extended nonnegative real numbers
hoelzl
parents: 62083
diff changeset
   410
  shows
62083
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   411
    "weak_conv_m M_seq M"
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   412
  apply (rule integral_cts_step_conv_imp_weak_conv [OF assms])
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   413
  apply (rule continuous_on_interior)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   414
  apply (rule uniformly_continuous_imp_continuous)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   415
  apply (rule cts_step_uniformly_continuous)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   416
  apply (auto simp: cts_step_def)
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   417
  done
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   418
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   419
end
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   420
7582b39f51ed add the proof of the central limit theorem
hoelzl
parents:
diff changeset
   421
end