src/HOL/Probability/Distributions.thy
author nipkow
Fri, 08 Mar 2013 11:28:04 +0100
changeset 51372 d315e9a9ee72
parent 50419 3177d0374701
child 53015 a1119cf551e8
permissions -rw-r--r--
simplified basic termination proof
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
50419
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
     1
theory Distributions
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
     2
  imports Probability_Measure
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
     3
begin
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
     4
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
     5
subsection {* Exponential distribution *}
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
     6
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
     7
definition exponential_density :: "real \<Rightarrow> real \<Rightarrow> real" where
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
     8
  "exponential_density l x = (if x < 0 then 0 else l * exp (- x * l))"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
     9
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    10
lemma borel_measurable_exponential_density[measurable]: "exponential_density l \<in> borel_measurable borel"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    11
  by (auto simp add: exponential_density_def[abs_def])
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    12
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    13
lemma (in prob_space) exponential_distributed_params:
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    14
  assumes D: "distributed M lborel X (exponential_density l)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    15
  shows "0 < l"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    16
proof (cases l "0 :: real" rule: linorder_cases)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    17
  assume "l < 0"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    18
  have "emeasure lborel {0 <.. 1::real} \<le>
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    19
    emeasure lborel {x :: real \<in> space lborel. 0 < x}"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    20
    by (rule emeasure_mono) (auto simp: greaterThan_def[symmetric])
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    21
  also have "emeasure lborel {x :: real \<in> space lborel. 0 < x} = 0"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    22
  proof -
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    23
    have "AE x in lborel. 0 \<le> exponential_density l x"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    24
      using assms by (auto simp: distributed_real_AE)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    25
    then have "AE x in lborel. x \<le> (0::real)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    26
      apply eventually_elim 
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    27
      using `l < 0`
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    28
      apply (auto simp: exponential_density_def zero_le_mult_iff split: split_if_asm)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    29
      done
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    30
    then show "emeasure lborel {x :: real \<in> space lborel. 0 < x} = 0"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    31
      by (subst (asm) AE_iff_measurable[OF _ refl]) (auto simp: not_le greaterThan_def[symmetric])
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    32
  qed
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    33
  finally show "0 < l" by simp
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    34
next
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    35
  assume "l = 0"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    36
  then have [simp]: "\<And>x. ereal (exponential_density l x) = 0"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    37
    by (simp add: exponential_density_def)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    38
  interpret X: prob_space "distr M lborel X"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    39
    using distributed_measurable[OF D] by (rule prob_space_distr)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    40
  from X.emeasure_space_1
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    41
  show "0 < l"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    42
    by (simp add: emeasure_density distributed_distr_eq_density[OF D])
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    43
qed assumption
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    44
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    45
lemma
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    46
  assumes [arith]: "0 < l"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    47
  shows emeasure_exponential_density_le0: "0 \<le> a \<Longrightarrow> emeasure (density lborel (exponential_density l)) {.. a} = 1 - exp (- a * l)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    48
    and prob_space_exponential_density: "prob_space (density lborel (exponential_density l))"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    49
      (is "prob_space ?D")
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    50
proof -
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    51
  let ?f = "\<lambda>x. l * exp (- x * l)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    52
  let ?F = "\<lambda>x. - exp (- x * l)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    53
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    54
  have deriv: "\<And>x. DERIV ?F x :> ?f x" "\<And>x. 0 \<le> l * exp (- x * l)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    55
    by (auto intro!: DERIV_intros simp: zero_le_mult_iff)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    56
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    57
  have "emeasure ?D (space ?D) = (\<integral>\<^isup>+ x. ereal (?f x) * indicator {0..} x \<partial>lborel)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    58
    by (auto simp: emeasure_density exponential_density_def
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    59
             intro!: positive_integral_cong split: split_indicator)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    60
  also have "\<dots> = ereal (0 - ?F 0)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    61
  proof (rule positive_integral_FTC_atLeast)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    62
    have "((\<lambda>x. exp (l * x)) ---> 0) at_bot"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    63
      by (rule filterlim_compose[OF exp_at_bot filterlim_tendsto_pos_mult_at_bot[of _ l]])
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    64
         (simp_all add: tendsto_const filterlim_ident)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    65
    then show "((\<lambda>x. - exp (- x * l)) ---> 0) at_top"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    66
      unfolding filterlim_at_top_mirror
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    67
      by (simp add: tendsto_minus_cancel_left[symmetric] ac_simps)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    68
  qed (insert deriv, auto)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    69
  also have "\<dots> = 1" by (simp add: one_ereal_def)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    70
  finally have "emeasure ?D (space ?D) = 1" .
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    71
  then show "prob_space ?D" by rule
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    72
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    73
  assume "0 \<le> a"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    74
  have "emeasure ?D {..a} = (\<integral>\<^isup>+x. ereal (?f x) * indicator {0..a} x \<partial>lborel)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    75
    by (auto simp add: emeasure_density intro!: positive_integral_cong split: split_indicator)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    76
       (auto simp: exponential_density_def)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    77
  also have "(\<integral>\<^isup>+x. ereal (?f x) * indicator {0..a} x \<partial>lborel) = ereal (?F a) - ereal (?F 0)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    78
    using `0 \<le> a` deriv by (intro positive_integral_FTC_atLeastAtMost) auto
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    79
  also have "\<dots> = 1 - exp (- a * l)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    80
    by simp
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    81
  finally show "emeasure ?D {.. a} = 1 - exp (- a * l)" .
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    82
qed
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    83
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    84
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    85
lemma (in prob_space) exponential_distributedD_le:
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    86
  assumes D: "distributed M lborel X (exponential_density l)" and a: "0 \<le> a"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    87
  shows "\<P>(x in M. X x \<le> a) = 1 - exp (- a * l)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    88
proof -
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    89
  have "emeasure M {x \<in> space M. X x \<le> a } = emeasure (distr M lborel X) {.. a}"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    90
    using distributed_measurable[OF D] 
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    91
    by (subst emeasure_distr) (auto intro!: arg_cong2[where f=emeasure])
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    92
  also have "\<dots> = emeasure (density lborel (exponential_density l)) {.. a}"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    93
    unfolding distributed_distr_eq_density[OF D] ..
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    94
  also have "\<dots> = 1 - exp (- a * l)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    95
    using emeasure_exponential_density_le0[OF exponential_distributed_params[OF D] a] .
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    96
  finally show ?thesis
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    97
    by (auto simp: measure_def)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    98
qed
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
    99
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   100
lemma (in prob_space) exponential_distributedD_gt:
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   101
  assumes D: "distributed M lborel X (exponential_density l)" and a: "0 \<le> a"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   102
  shows "\<P>(x in M. a < X x ) = exp (- a * l)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   103
proof -
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   104
  have "exp (- a * l) = 1 - \<P>(x in M. X x \<le> a)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   105
    unfolding exponential_distributedD_le[OF D a] by simp
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   106
  also have "\<dots> = prob (space M - {x \<in> space M. X x \<le> a })"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   107
    using distributed_measurable[OF D]
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   108
    by (subst prob_compl) auto
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   109
  also have "\<dots> = \<P>(x in M. a < X x )"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   110
    by (auto intro!: arg_cong[where f=prob] simp: not_le)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   111
  finally show ?thesis by simp
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   112
qed
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   113
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   114
lemma (in prob_space) exponential_distributed_memoryless:
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   115
  assumes D: "distributed M lborel X (exponential_density l)" and a: "0 \<le> a"and t: "0 \<le> t"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   116
  shows "\<P>(x in M. a + t < X x \<bar> a < X x) = \<P>(x in M. t < X x)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   117
proof -
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   118
  have "\<P>(x in M. a + t < X x \<bar> a < X x) = \<P>(x in M. a + t < X x) / \<P>(x in M. a < X x)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   119
    using `0 \<le> t` by (auto simp: cond_prob_def intro!: arg_cong[where f=prob] arg_cong2[where f="op /"])
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   120
  also have "\<dots> = exp (- (a + t) * l) / exp (- a * l)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   121
    using a t by (simp add: exponential_distributedD_gt[OF D])
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   122
  also have "\<dots> = exp (- t * l)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   123
    using exponential_distributed_params[OF D] by (auto simp: field_simps exp_add[symmetric])
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   124
  finally show ?thesis
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   125
    using t by (simp add: exponential_distributedD_gt[OF D])
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   126
qed
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   127
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   128
lemma exponential_distributedI:
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   129
  assumes X[measurable]: "X \<in> borel_measurable M" and [arith]: "0 < l"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   130
    and X_distr: "\<And>a. 0 \<le> a \<Longrightarrow> emeasure M {x\<in>space M. X x \<le> a} = 1 - exp (- a * l)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   131
  shows "distributed M lborel X (exponential_density l)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   132
proof (rule distributedI_borel_atMost)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   133
  fix a :: real
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   134
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   135
  { assume "a \<le> 0"  
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   136
    with X have "emeasure M {x\<in>space M. X x \<le> a} \<le> emeasure M {x\<in>space M. X x \<le> 0}"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   137
      by (intro emeasure_mono) auto
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   138
    then have "emeasure M {x\<in>space M. X x \<le> a} = 0"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   139
      using X_distr[of 0] by (simp add: one_ereal_def emeasure_le_0_iff) }
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   140
  note eq_0 = this
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   141
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   142
  have "\<And>x. \<not> 0 \<le> a \<Longrightarrow> ereal (exponential_density l x) * indicator {..a} x = 0"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   143
    by (simp add: exponential_density_def)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   144
  then show "(\<integral>\<^isup>+ x. exponential_density l x * indicator {..a} x \<partial>lborel) = ereal (if 0 \<le> a then 1 - exp (- a * l) else 0)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   145
    using emeasure_exponential_density_le0[of l a]
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   146
    by (auto simp: emeasure_density times_ereal.simps[symmetric] ereal_indicator
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   147
             simp del: times_ereal.simps ereal_zero_times)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   148
  show "emeasure M {x\<in>space M. X x \<le> a} = ereal (if 0 \<le> a then 1 - exp (- a * l) else 0)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   149
    using X_distr[of a] eq_0 by (auto simp: one_ereal_def)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   150
  show "AE x in lborel. 0 \<le> exponential_density l x "
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   151
    by (auto simp: exponential_density_def intro!: AE_I2 mult_nonneg_nonneg)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   152
qed simp_all
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   153
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   154
lemma (in prob_space) exponential_distributed_iff:
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   155
  "distributed M lborel X (exponential_density l) \<longleftrightarrow>
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   156
    (X \<in> borel_measurable M \<and> 0 < l \<and> (\<forall>a\<ge>0. \<P>(x in M. X x \<le> a) = 1 - exp (- a * l)))"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   157
  using
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   158
    distributed_measurable[of M lborel X "exponential_density l"]
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   159
    exponential_distributed_params[of X l]
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   160
    emeasure_exponential_density_le0[of l]
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   161
    exponential_distributedD_le[of X l]
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   162
  by (auto intro!: exponential_distributedI simp: one_ereal_def emeasure_eq_measure)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   163
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   164
lemma borel_integral_x_exp:
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   165
  "(\<integral>x. x * exp (- x) * indicator {0::real ..} x \<partial>lborel) = 1"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   166
proof (rule integral_monotone_convergence)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   167
  let ?f = "\<lambda>i x. x * exp (- x) * indicator {0::real .. i} x"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   168
  have "eventually (\<lambda>b::real. 0 \<le> b) at_top"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   169
    by (rule eventually_ge_at_top)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   170
  then have "eventually (\<lambda>b. 1 - (inverse (exp b) + b / exp b) = integral\<^isup>L lborel (?f b)) at_top"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   171
  proof eventually_elim
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   172
   fix b :: real assume [simp]: "0 \<le> b"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   173
    have "(\<integral>x. (exp (-x)) * indicator {0 .. b} x \<partial>lborel) - (integral\<^isup>L lborel (?f b)) = 
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   174
      (\<integral>x. (exp (-x) - x * exp (-x)) * indicator {0 .. b} x \<partial>lborel)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   175
      by (subst integral_diff(2)[symmetric])
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   176
         (auto intro!: borel_integrable_atLeastAtMost integral_cong split: split_indicator)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   177
    also have "\<dots> = b * exp (-b) - 0 * exp (- 0)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   178
    proof (rule integral_FTC_atLeastAtMost)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   179
      fix x assume "0 \<le> x" "x \<le> b"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   180
      show "DERIV (\<lambda>x. x * exp (-x)) x :> exp (-x) - x * exp (-x)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   181
        by (auto intro!: DERIV_intros)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   182
      show "isCont (\<lambda>x. exp (- x) - x * exp (- x)) x "
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   183
        by (intro isCont_intros isCont_exp')
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   184
    qed fact
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   185
    also have "(\<integral>x. (exp (-x)) * indicator {0 .. b} x \<partial>lborel) = - exp (- b) - - exp (- 0)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   186
      by (rule integral_FTC_atLeastAtMost) (auto intro!: DERIV_intros)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   187
    finally show "1 - (inverse (exp b) + b / exp b) = integral\<^isup>L lborel (?f b)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   188
      by (auto simp: field_simps exp_minus inverse_eq_divide)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   189
  qed
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   190
  then have "((\<lambda>i. integral\<^isup>L lborel (?f i)) ---> 1 - (0 + 0)) at_top"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   191
  proof (rule Lim_transform_eventually)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   192
    show "((\<lambda>i. 1 - (inverse (exp i) + i / exp i)) ---> 1 - (0 + 0 :: real)) at_top"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   193
      using tendsto_power_div_exp_0[of 1]
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   194
      by (intro tendsto_intros tendsto_inverse_0_at_top exp_at_top) simp
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   195
  qed
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   196
  then show "(\<lambda>i. integral\<^isup>L lborel (?f i)) ----> 1"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   197
    by (intro filterlim_compose[OF _ filterlim_real_sequentially]) simp
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   198
  show "AE x in lborel. mono (\<lambda>n::nat. x * exp (- x) * indicator {0..real n} x)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   199
    by (auto simp: mono_def mult_le_0_iff zero_le_mult_iff split: split_indicator)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   200
  show "\<And>i::nat. integrable lborel (\<lambda>x. x * exp (- x) * indicator {0..real i} x)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   201
    by (rule borel_integrable_atLeastAtMost) auto
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   202
  show "AE x in lborel. (\<lambda>i. x * exp (- x) * indicator {0..real i} x) ----> x * exp (- x) * indicator {0..} x"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   203
    apply (intro AE_I2 Lim_eventually )
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   204
    apply (rule_tac c="natfloor x + 1" in eventually_sequentiallyI)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   205
    apply (auto simp add: not_le dest!: ge_natfloor_plus_one_imp_gt[simplified] split: split_indicator)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   206
    done
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   207
qed (auto intro!: borel_measurable_times borel_measurable_exp)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   208
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   209
lemma (in prob_space) exponential_distributed_expectation:
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   210
  assumes D: "distributed M lborel X (exponential_density l)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   211
  shows "expectation X = 1 / l"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   212
proof (subst distributed_integral[OF D, of "\<lambda>x. x", symmetric])
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   213
  have "0 < l"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   214
   using exponential_distributed_params[OF D] .
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   215
  have [simp]: "\<And>x. x * (l * (exp (- (x * l)) * indicator {0..} (x * l))) =
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   216
    x * exponential_density l x"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   217
    using `0 < l`
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   218
    by (auto split: split_indicator simp: zero_le_mult_iff exponential_density_def)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   219
  from borel_integral_x_exp `0 < l`
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   220
  show "(\<integral> x. exponential_density l x * x \<partial>lborel) = 1 / l"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   221
    by (subst (asm) lebesgue_integral_real_affine[of "l" _ 0])
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   222
       (simp_all add: borel_measurable_exp nonzero_eq_divide_eq ac_simps)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   223
qed simp
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   224
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   225
subsection {* Uniform distribution *}
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   226
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   227
lemma uniform_distrI:
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   228
  assumes X: "X \<in> measurable M M'"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   229
    and A: "A \<in> sets M'" "emeasure M' A \<noteq> \<infinity>" "emeasure M' A \<noteq> 0"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   230
  assumes distr: "\<And>B. B \<in> sets M' \<Longrightarrow> emeasure M (X -` B \<inter> space M) = emeasure M' (A \<inter> B) / emeasure M' A"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   231
  shows "distr M M' X = uniform_measure M' A"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   232
  unfolding uniform_measure_def
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   233
proof (intro measure_eqI)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   234
  let ?f = "\<lambda>x. indicator A x / emeasure M' A"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   235
  fix B assume B: "B \<in> sets (distr M M' X)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   236
  with X have "emeasure M (X -` B \<inter> space M) = emeasure M' (A \<inter> B) / emeasure M' A"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   237
    by (simp add: distr[of B] measurable_sets)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   238
  also have "\<dots> = (1 / emeasure M' A) * emeasure M' (A \<inter> B)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   239
     by simp
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   240
  also have "\<dots> = (\<integral>\<^isup>+ x. (1 / emeasure M' A) * indicator (A \<inter> B) x \<partial>M')"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   241
    using A B
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   242
    by (intro positive_integral_cmult_indicator[symmetric]) (auto intro!: zero_le_divide_ereal)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   243
  also have "\<dots> = (\<integral>\<^isup>+ x. ?f x * indicator B x \<partial>M')"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   244
    by (rule positive_integral_cong) (auto split: split_indicator)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   245
  finally show "emeasure (distr M M' X) B = emeasure (density M' ?f) B"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   246
    using A B X by (auto simp add: emeasure_distr emeasure_density)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   247
qed simp
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   248
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   249
lemma uniform_distrI_borel:
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   250
  fixes A :: "real set"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   251
  assumes X[measurable]: "X \<in> borel_measurable M" and A: "emeasure lborel A = ereal r" "0 < r"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   252
    and [measurable]: "A \<in> sets borel"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   253
  assumes distr: "\<And>a. emeasure M {x\<in>space M. X x \<le> a} = emeasure lborel (A \<inter> {.. a}) / r"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   254
  shows "distributed M lborel X (\<lambda>x. indicator A x / measure lborel A)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   255
proof (rule distributedI_borel_atMost)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   256
  let ?f = "\<lambda>x. 1 / r * indicator A x"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   257
  fix a
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   258
  have "emeasure lborel (A \<inter> {..a}) \<le> emeasure lborel A"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   259
    using A by (intro emeasure_mono) auto
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   260
  also have "\<dots> < \<infinity>"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   261
    using A by simp
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   262
  finally have fin: "emeasure lborel (A \<inter> {..a}) \<noteq> \<infinity>"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   263
    by simp
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   264
  from emeasure_eq_ereal_measure[OF this]
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   265
  have fin_eq: "emeasure lborel (A \<inter> {..a}) / r = ereal (measure lborel (A \<inter> {..a}) / r)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   266
    using A by simp
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   267
  then show "emeasure M {x\<in>space M. X x \<le> a} = ereal (measure lborel (A \<inter> {..a}) / r)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   268
    using distr by simp
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   269
 
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   270
  have "(\<integral>\<^isup>+ x. ereal (indicator A x / measure lborel A * indicator {..a} x) \<partial>lborel) =
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   271
    (\<integral>\<^isup>+ x. ereal (1 / measure lborel A) * indicator (A \<inter> {..a}) x \<partial>lborel)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   272
    by (auto intro!: positive_integral_cong split: split_indicator)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   273
  also have "\<dots> = ereal (1 / measure lborel A) * emeasure lborel (A \<inter> {..a})"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   274
    using `A \<in> sets borel`
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   275
    by (intro positive_integral_cmult_indicator) (auto simp: measure_nonneg)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   276
  also have "\<dots> = ereal (measure lborel (A \<inter> {..a}) / r)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   277
    unfolding emeasure_eq_ereal_measure[OF fin] using A by (simp add: measure_def)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   278
  finally show "(\<integral>\<^isup>+ x. ereal (indicator A x / measure lborel A * indicator {..a} x) \<partial>lborel) =
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   279
    ereal (measure lborel (A \<inter> {..a}) / r)" .
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   280
qed (auto intro!: divide_nonneg_nonneg measure_nonneg)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   281
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   282
lemma (in prob_space) uniform_distrI_borel_atLeastAtMost:
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   283
  fixes a b :: real
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   284
  assumes X: "X \<in> borel_measurable M" and "a < b"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   285
  assumes distr: "\<And>t. a \<le> t \<Longrightarrow> t \<le> b \<Longrightarrow> \<P>(x in M. X x \<le> t) = (t - a) / (b - a)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   286
  shows "distributed M lborel X (\<lambda>x. indicator {a..b} x / measure lborel {a..b})"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   287
proof (rule uniform_distrI_borel)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   288
  fix t
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   289
  have "t < a \<or> (a \<le> t \<and> t \<le> b) \<or> b < t"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   290
    by auto
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   291
  then show "emeasure M {x\<in>space M. X x \<le> t} = emeasure lborel ({a .. b} \<inter> {..t}) / (b - a)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   292
  proof (elim disjE conjE)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   293
    assume "t < a" 
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   294
    then have "emeasure M {x\<in>space M. X x \<le> t} \<le> emeasure M {x\<in>space M. X x \<le> a}"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   295
      using X by (auto intro!: emeasure_mono measurable_sets)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   296
    also have "\<dots> = 0"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   297
      using distr[of a] `a < b` by (simp add: emeasure_eq_measure)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   298
    finally have "emeasure M {x\<in>space M. X x \<le> t} = 0"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   299
      by (simp add: antisym measure_nonneg emeasure_le_0_iff)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   300
    with `t < a` show ?thesis by simp
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   301
  next
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   302
    assume bnds: "a \<le> t" "t \<le> b"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   303
    have "{a..b} \<inter> {..t} = {a..t}"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   304
      using bnds by auto
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   305
    then show ?thesis using `a \<le> t` `a < b`
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   306
      using distr[OF bnds] by (simp add: emeasure_eq_measure)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   307
  next
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   308
    assume "b < t" 
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   309
    have "1 = emeasure M {x\<in>space M. X x \<le> b}"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   310
      using distr[of b] `a < b` by (simp add: one_ereal_def emeasure_eq_measure)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   311
    also have "\<dots> \<le> emeasure M {x\<in>space M. X x \<le> t}"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   312
      using X `b < t` by (auto intro!: emeasure_mono measurable_sets)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   313
    finally have "emeasure M {x\<in>space M. X x \<le> t} = 1"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   314
       by (simp add: antisym emeasure_eq_measure one_ereal_def)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   315
    with `b < t` `a < b` show ?thesis by (simp add: measure_def one_ereal_def)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   316
  qed
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   317
qed (insert X `a < b`, auto)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   318
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   319
lemma (in prob_space) uniform_distributed_measure:
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   320
  fixes a b :: real
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   321
  assumes D: "distributed M lborel X (\<lambda>x. indicator {a .. b} x / measure lborel {a .. b})"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   322
  assumes " a \<le> t" "t \<le> b"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   323
  shows "\<P>(x in M. X x \<le> t) = (t - a) / (b - a)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   324
proof -
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   325
  have "emeasure M {x \<in> space M. X x \<le> t} = emeasure (distr M lborel X) {.. t}"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   326
    using distributed_measurable[OF D]
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   327
    by (subst emeasure_distr) (auto intro!: arg_cong2[where f=emeasure])
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   328
  also have "\<dots> = (\<integral>\<^isup>+x. ereal (1 / (b - a)) * indicator {a .. t} x \<partial>lborel)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   329
    using distributed_borel_measurable[OF D] `a \<le> t` `t \<le> b`
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   330
    unfolding distributed_distr_eq_density[OF D]
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   331
    by (subst emeasure_density)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   332
       (auto intro!: positive_integral_cong simp: measure_def split: split_indicator)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   333
  also have "\<dots> = ereal (1 / (b - a)) * (t - a)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   334
    using `a \<le> t` `t \<le> b`
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   335
    by (subst positive_integral_cmult_indicator) auto
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   336
  finally show ?thesis
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   337
    by (simp add: measure_def)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   338
qed
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   339
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   340
lemma (in prob_space) uniform_distributed_bounds:
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   341
  fixes a b :: real
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   342
  assumes D: "distributed M lborel X (\<lambda>x. indicator {a .. b} x / measure lborel {a .. b})"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   343
  shows "a < b"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   344
proof (rule ccontr)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   345
  assume "\<not> a < b"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   346
  then have "{a .. b} = {} \<or> {a .. b} = {a .. a}" by simp
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   347
  with uniform_distributed_params[OF D] show False 
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   348
    by (auto simp: measure_def)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   349
qed
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   350
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   351
lemma (in prob_space) uniform_distributed_iff:
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   352
  fixes a b :: real
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   353
  shows "distributed M lborel X (\<lambda>x. indicator {a..b} x / measure lborel {a..b}) \<longleftrightarrow> 
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   354
    (X \<in> borel_measurable M \<and> a < b \<and> (\<forall>t\<in>{a .. b}. \<P>(x in M. X x \<le> t)= (t - a) / (b - a)))"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   355
  using
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   356
    uniform_distributed_bounds[of X a b]
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   357
    uniform_distributed_measure[of X a b]
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   358
    distributed_measurable[of M lborel X]
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   359
  by (auto intro!: uniform_distrI_borel_atLeastAtMost simp: one_ereal_def emeasure_eq_measure)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   360
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   361
lemma (in prob_space) uniform_distributed_expectation:
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   362
  fixes a b :: real
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   363
  assumes D: "distributed M lborel X (\<lambda>x. indicator {a .. b} x / measure lborel {a .. b})"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   364
  shows "expectation X = (a + b) / 2"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   365
proof (subst distributed_integral[OF D, of "\<lambda>x. x", symmetric])
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   366
  have "a < b"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   367
    using uniform_distributed_bounds[OF D] .
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   368
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   369
  have "(\<integral> x. indicator {a .. b} x / measure lborel {a .. b} * x \<partial>lborel) = 
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   370
    (\<integral> x. (x / measure lborel {a .. b}) * indicator {a .. b} x \<partial>lborel)"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   371
    by (intro integral_cong) auto
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   372
  also have "(\<integral> x. (x / measure lborel {a .. b}) * indicator {a .. b} x \<partial>lborel) = (a + b) / 2"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   373
  proof (subst integral_FTC_atLeastAtMost)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   374
    fix x
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   375
    show "DERIV (\<lambda>x. x ^ 2 / (2 * measure lborel {a..b})) x :> x / measure lborel {a..b}"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   376
      using uniform_distributed_params[OF D]
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   377
      by (auto intro!: DERIV_intros)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   378
    show "isCont (\<lambda>x. x / Sigma_Algebra.measure lborel {a..b}) x"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   379
      using uniform_distributed_params[OF D]
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   380
      by (auto intro!: isCont_divide)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   381
    have *: "b\<twosuperior> / (2 * measure lborel {a..b}) - a\<twosuperior> / (2 * measure lborel {a..b}) =
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   382
      (b*b - a * a) / (2 * (b - a))"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   383
      using `a < b`
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   384
      by (auto simp: measure_def power2_eq_square diff_divide_distrib[symmetric])
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   385
    show "b\<twosuperior> / (2 * measure lborel {a..b}) - a\<twosuperior> / (2 * measure lborel {a..b}) = (a + b) / 2"
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   386
      using `a < b`
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   387
      unfolding * square_diff_square_factored by (auto simp: field_simps)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   388
  qed (insert `a < b`, simp)
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   389
  finally show "(\<integral> x. indicator {a .. b} x / measure lborel {a .. b} * x \<partial>lborel) = (a + b) / 2" .
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   390
qed auto
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   391
3177d0374701 add exponential and uniform distributions
hoelzl
parents:
diff changeset
   392
end