Require Import Morphisms.
Require Import Equivalence.
Require Import Program.Basics.
Require Import Lra Lia.
Require Import Classical ClassicalChoice RelationClasses.
Require Import FunctionalExtensionality.
Require Import IndefiniteDescription ClassicalDescription.
Require Import hilbert.
Require Export RandomVariableLpR RandomVariableL2 OrthoProject.
Require Import quotient_space.
Require Import RbarExpectation.
Require Import Event.
Require Import Almost DVector.
Require Import utils.Utils.
Require Import List.
Require Import NumberIso.
Require Import PushNeg.
Set Bullet Behavior "
Strict Subproofs".
Section is_cond_exp.
Context {
Ts:
Type}
{
dom:
SigmaAlgebra Ts}
(
prts:
ProbSpace dom).
Definition is_conditional_expectation
(
dom2 :
SigmaAlgebra Ts)
(
f :
Ts ->
R)
(
ce :
Ts ->
Rbar)
{
rvf :
RandomVariable dom borel_sa f}
{
rvce :
RandomVariable dom2 Rbar_borel_sa ce}
:=
forall P (
dec:
dec_pre_event P),
sa_sigma (
SigmaAlgebra :=
dom2)
P ->
Expectation (
rvmult f (
EventIndicator dec)) =
Rbar_Expectation (
Rbar_rvmult ce (
EventIndicator dec)).
Context {
dom2 :
SigmaAlgebra Ts}
(
sub :
sa_sub dom2 dom).
Theorem is_conditional_expectation_id
(
f :
Ts ->
R)
{
rvf :
RandomVariable dom borel_sa f}
{
rvf2 :
RandomVariable dom2 borel_sa f} :
is_conditional_expectation dom2 f (
fun x =>
Finite (
f x)).
Proof.
Theorem is_conditional_expectation_Expectation
(
f :
Ts ->
R)
(
ce :
Ts ->
Rbar)
{
rvf :
RandomVariable dom borel_sa f}
{
rvce :
RandomVariable dom2 Rbar_borel_sa ce} :
is_conditional_expectation dom2 f ce ->
Expectation f =
Rbar_Expectation ce.
Proof.
Lemma is_conditional_expectation_FiniteExpectation
(
f :
Ts ->
R)
(
ce :
Ts ->
Rbar)
{
rvf :
RandomVariable dom borel_sa f}
{
rvce :
RandomVariable dom2 Rbar_borel_sa ce} :
is_conditional_expectation dom2 f ce ->
IsFiniteExpectation prts f <->
Rbar_IsFiniteExpectation prts ce.
Proof.
Theorem is_conditional_expectation_proper
(
f1 f2 :
Ts ->
R)
(
ce1 ce2 :
Ts ->
Rbar)
{
rvf1 :
RandomVariable dom borel_sa f1}
{
rvf2 :
RandomVariable dom borel_sa f2}
{
rvce1 :
RandomVariable dom2 Rbar_borel_sa ce1}
{
rvce2 :
RandomVariable dom2 Rbar_borel_sa ce2}
:
almostR2 prts eq f1 f2 ->
almostR2 prts eq ce1 ce2 ->
is_conditional_expectation dom2 f1 ce1 ->
is_conditional_expectation dom2 f2 ce2.
Proof.
Lemma is_conditional_expectation_nneg_le
(
f :
Ts->
R)
(
ce1 ce2 :
Ts ->
Rbar)
{
rvf :
RandomVariable dom borel_sa f}
{
rvce1 :
RandomVariable dom2 Rbar_borel_sa ce1}
{
rvce2 :
RandomVariable dom2 Rbar_borel_sa ce2}
{
nnf :
NonnegativeFunction f}
{
nnf1 :
Rbar_NonnegativeFunction ce1}
{
nnf2 :
Rbar_NonnegativeFunction ce2}
:
is_conditional_expectation dom2 f ce1 ->
is_conditional_expectation dom2 f ce2 ->
almostR2 (
prob_space_sa_sub prts sub)
Rbar_le ce1 ce2.
Proof.
unfold is_conditional_expectation;
intros isce1 isce2.
pose (
G :=
fun x:
R =>
pre_event_inter (
fun omega =>
Rbar_gt (
ce1 omega) (
ce2 omega)) (
fun omega =>
Rbar_gt x (
ce2 omega))).
assert (
sa_G :
forall x:
R,
sa_sigma (
G x)).
{
intros x.
unfold G.
unfold pre_event_inter.
apply (
sa_proper _
(
fun x0 :
Ts => (
Rbar_gt ((
Rbar_rvminus ce1 (
Rbar_finite_part ce2))
x0) 0) /\
Rbar_lt (
ce2 x0)
x )).
-
intro z.
unfold Rbar_rvminus,
Rbar_rvopp,
Rbar_finite_part.
split;
intros.
+
destruct H.
split;
try easy.
unfold Rbar_rvplus in H.
assert (
is_finite (
ce2 z)).
*
eapply bounded_is_finite.
apply nnf2.
apply Rbar_lt_le.
apply H0.
*
rewrite <-
H1 in H |- *.
unfold Rbar_opp in H.
unfold Rbar_gt in *.
apply (
Rbar_plus_lt_compat_r _ _ (
ce2 z))
in H.
rewrite Rbar_plus_0_l in H.
destruct ((
ce1 z));
simpl in *;
trivial.
f_equal;
lra.
+
destruct H.
unfold Rbar_gt in H0.
assert (
is_finite (
ce2 z)).
*
eapply bounded_is_finite.
apply nnf2.
apply Rbar_lt_le.
apply H0.
*
split;
try easy.
unfold Rbar_rvplus.
rewrite <-
H1 in H |- *.
unfold Rbar_opp.
unfold Rbar_gt in *.
apply (
Rbar_plus_lt_compat_r _ _ (-
ce2 z))
in H.
destruct ((
ce1 z));
simpl in *;
trivial.
f_equal;
lra.
-
apply sa_inter.
+
apply Rbar_sa_le_gt;
intros.
apply Rbar_plus_measurable.
*
typeclasses eauto.
*
apply rv_Rbar_measurable.
apply Rbar_rvopp_rv.
apply Real_Rbar_rv.
apply measurable_rv.
now apply Rbar_finite_part_meas.
+
apply Rbar_sa_le_lt.
intros.
now apply rv_Rbar_measurable.
}
pose (
IG :=
fun x:
R =>
EventIndicator (
classic_dec (
G x))).
assert (
nneg12I:
forall x:
R,
Rbar_NonnegativeFunction (
Rbar_rvmult (
Rbar_rvminus ce1 ce2) (
fun omega :
Ts =>
IG x omega))).
{
intros x omega.
unfold IG,
classic_dec;
simpl.
unfold Rbar_rvmult,
Rbar_rvminus,
Rbar_rvplus,
Rbar_rvopp;
simpl.
rv_unfold.
destruct (
excluded_middle_informative (
G x omega)).
-
rewrite Rbar_mult_1_r.
destruct g.
destruct (
ce1 omega);
destruct (
ce2 omega);
simpl in *;
try tauto.
lra.
-
rewrite Rbar_mult_0_r.
lra.
}
assert (
eqq1:
forall x,
Rbar_NonnegExpectation (
Rbar_rvmult (
Rbar_rvminus ce1 ce2) (
IG x)) =
Rbar_minus (
Rbar_NonnegExpectation (
Rbar_rvmult ce1 (
IG x)))
(
Rbar_NonnegExpectation (
Rbar_rvmult ce2 (
IG x)))).
{
intros x.
generalize (@
Rbar_NonnegExpectation_minus_bounded2 _ _ prts (
Rbar_rvmult ce1 (
IG x)) (
Rbar_rvmult ce2 (
IG x)));
intros HH.
cut_to HH.
-
unfold IG in HH.
specialize (
HH _ (
Rabs x) (
Rabs_pos _)).
cut_to HH.
+
specialize (
HH _).
assert (
nnf12 :
Rbar_NonnegativeFunction
(
Rbar_rvminus (
Rbar_rvmult ce1 (
IG x))
(
Rbar_rvmult ce2 (
IG x)))).
{
intros a.
unfold Rbar_rvmult,
Rbar_rvminus,
Rbar_rvplus,
Rbar_rvopp,
IG,
EventIndicator;
simpl.
destruct (
classic_dec (
G x)
a);
simpl.
-
repeat rewrite Rbar_mult_1_r.
destruct g as [??].
destruct (
ce1 a);
destruct (
ce2 a);
simpl in *;
lra.
-
repeat rewrite Rbar_mult_0_r;
simpl.
lra.
}
specialize (
HH nnf12).
unfold IG.
rewrite <-
HH.
eapply Rbar_NonnegExpectation_ext.
intros a.
unfold Rbar_rvmult,
Rbar_rvminus,
Rbar_rvplus,
Rbar_rvopp,
EventIndicator;
simpl.
match_destr.
*
now repeat rewrite Rbar_mult_1_r.
*
repeat rewrite Rbar_mult_0_r.
simpl;
f_equal;
lra.
+
intros ?.
unfold G.
unfold Rbar_rvmult,
EventIndicator,
const;
simpl.
match_destr.
*
destruct p.
destruct (
ce2 a);
simpl in *;
try tauto.
--
field_simplify.
eapply Rle_trans; [|
apply RRle_abs].
now left.
--
destruct (
Rle_dec 0 1);
try lra.
destruct (
Rle_lt_or_eq_dec 0 1
r);
try lra.
now simpl.
*
rewrite Rbar_mult_0_r.
simpl.
apply Rabs_pos.
-
apply Rbar_rvmult_rv;
trivial.
+
eapply RandomVariable_sa_sub;
eauto.
+
apply borel_Rbar_borel.
apply EventIndicator_pre_rv.
now apply sub.
-
apply Rbar_rvmult_rv;
trivial.
+
eapply RandomVariable_sa_sub;
eauto.
+
apply borel_Rbar_borel.
apply EventIndicator_pre_rv.
now apply sub.
}
assert (
eqq2:
forall x,
Rbar_NonnegExpectation (
Rbar_rvmult (
Rbar_rvminus ce1 ce2) (
IG x)) = 0).
{
intros.
rewrite eqq1.
generalize (
isce1 (
G x) (
classic_dec (
G x)) (
sa_G x))
;
intros HH1.
generalize (
isce2 (
G x) (
classic_dec (
G x)) (
sa_G x))
;
intros HH2.
rewrite (
Rbar_Expectation_pos_pofrf _ (
nnf:=
_))
in HH1.
rewrite (
Rbar_Expectation_pos_pofrf _ (
nnf:=
_))
in HH2.
rewrite (
Expectation_pos_pofrf _ (
nnf:=
_))
in HH1.
rewrite (
Expectation_pos_pofrf _ (
nnf:=
_))
in HH2.
invcs HH1.
invcs HH2.
unfold IG.
rewrite <-
H0, <-
H1.
apply Rbar_minus_eq_0.
}
assert (
psG0:
forall x,
ps_P (
ProbSpace:=((
prob_space_sa_sub prts sub))) (
exist _ (
G x) (
sa_G x)) = 0).
{
intros x.
specialize (
eqq2 x).
assert (
Rbar_NonnegExpectation_zero_pos':
almostR2 prts eq (
Rbar_rvmult (
Rbar_rvminus ce1 ce2) (
fun x0 :
Ts =>
IG x x0)) (
const 0)).
{
apply Rbar_Expectation_nonneg_zero_almost_zero;
trivial.
-
apply (
RandomVariable_proper _ _ (
reflexivity _)
_ _ (
reflexivity _) (
Rbar_rvminus (
Rbar_rvmult ce1 (
IG x))
(
Rbar_rvmult ce2 (
IG x)))).
+
intros ?.
unfold Rbar_rvminus,
Rbar_rvplus,
Rbar_rvopp,
Rbar_rvmult;
simpl.
unfold IG,
EventIndicator;
simpl.
match_destr.
*
now repeat rewrite Rbar_mult_1_r.
*
repeat rewrite Rbar_mult_0_r.
simpl.
f_equal;
lra.
+
apply Rbar_rvplus_rv.
*
apply Rbar_rvmult_rv.
--
eapply RandomVariable_sa_sub;
eauto.
--
apply borel_Rbar_borel.
apply EventIndicator_pre_rv.
now apply sub.
*
apply Rbar_rvopp_rv.
apply Rbar_rvmult_rv.
--
eapply RandomVariable_sa_sub;
eauto.
--
apply borel_Rbar_borel.
apply EventIndicator_pre_rv.
now apply sub.
-
now rewrite (
Rbar_Expectation_pos_pofrf _ (
nnf:=
_)),
eqq2.
}
destruct Rbar_NonnegExpectation_zero_pos'
as [
P [
pone pH]].
unfold const in pH.
unfold Rbar_rvmult,
IG,
EventIndicator in pH.
apply NNPP.
intros neq.
assert (
HH1:
ps_P (
ProbSpace:=
prts) (
event_inter P (
event_sa_sub sub (
exist sa_sigma (
G x) (
sa_G x)))) <> 0).
{
rewrite ps_inter_l1;
trivial.
}
destruct (
zero_prob_or_witness _ HH1)
as [
a [
Pa Ga]];
simpl in *.
specialize (
pH _ Pa).
match_destr_in pH;
try tauto.
rewrite Rbar_mult_1_r in pH.
destruct Ga as [??].
unfold Rbar_rvminus,
Rbar_rvplus,
Rbar_rvopp in pH.
destruct (
ce1 a);
destruct (
ce2 a);
simpl in *;
try (
invcs pH;
lra).
}
generalize (
is_lim_ascending (
prob_space_sa_sub prts sub) (
fun n =>
exist _ _ (
sa_G (
INR n))))
;
intros HH.
cut_to HH.
-
apply (
is_lim_seq_ext _ (
fun _ => 0))
in HH.
+
apply is_lim_seq_unique in HH.
rewrite Lim_seq_const in HH.
assert (
eqq3:
pre_event_equiv (
union_of_collection (
fun n :
nat =>
exist sa_sigma (
G (
INR n)) (
sa_G (
INR n))))
(
fun omega :
Ts =>
Rbar_gt (
ce1 omega) (
ce2 omega))).
{
intros a.
split;
simpl.
-
now intros [?[??]].
-
unfold G.
intros.
exists (
Z.to_nat (
up (
ce2 a))).
split;
trivial.
assert (
isf:
is_finite (
ce2 a)).
{
generalize (
nnf2 a);
intros ?.
destruct (
ce2 a).
-
reflexivity.
-
destruct (
ce1 a);
simpl in *;
tauto.
-
simpl in H0;
tauto.
}
rewrite <-
isf.
simpl.
rewrite INR_up_pos.
*
apply archimed.
*
generalize (
nnf2 a);
intros HH2.
rewrite <-
isf in HH2;
simpl in HH2.
lra.
}
destruct (
sa_proper dom2 _ _ eqq3)
as [
sa1 _].
cut_to sa1.
*
rewrite (
ps_proper _ (
exist _ _ sa1))
in HH by (
now red).
generalize (
ps_complement (
prob_space_sa_sub prts sub)
(
exist _ _ sa1))
;
intros eqq4.
invcs HH.
simpl in *.
rewrite <-
H0 in eqq4.
field_simplify in eqq4.
eexists.
split; [
apply eqq4|].
intros a;
simpl.
unfold pre_event_complement.
unfold Rbar_gt.
intros.
now apply Rbar_not_lt_le.
*
apply sa_sigma_event_pre.
+
trivial.
-
intros ??.
unfold G.
intros [??].
split;
trivial.
unfold Rbar_gt in *.
eapply Rbar_lt_le_trans;
try eapply H0.
apply le_INR;
lia.
Qed.
Local Existing Instance Rbar_le_part.
Theorem is_conditional_expectation_nneg_unique
(
f :
Ts->
R)
(
ce1 ce2 :
Ts ->
Rbar)
{
rvf :
RandomVariable dom borel_sa f}
{
rvce1 :
RandomVariable dom2 Rbar_borel_sa ce1}
{
rvce2 :
RandomVariable dom2 Rbar_borel_sa ce2}
{
nnf :
NonnegativeFunction f}
{
nnf1 :
Rbar_NonnegativeFunction ce1}
{
nnf2 :
Rbar_NonnegativeFunction ce2}
:
is_conditional_expectation dom2 f ce1 ->
is_conditional_expectation dom2 f ce2 ->
almostR2 (
prob_space_sa_sub prts sub)
eq ce1 ce2.
Proof.
Lemma is_conditional_expectation_almostfinite_le
(
f :
Ts->
R)
(
ce1 ce2 :
Ts ->
Rbar)
{
rvf :
RandomVariable dom borel_sa f}
{
rvce1 :
RandomVariable dom2 Rbar_borel_sa ce1}
{
rvce2 :
RandomVariable dom2 Rbar_borel_sa ce2}
(
isf2:
almost (
prob_space_sa_sub prts sub) (
fun a =>
is_finite (
ce2 a))) :
is_conditional_expectation dom2 f ce1 ->
is_conditional_expectation dom2 f ce2 ->
almostR2 (
prob_space_sa_sub prts sub)
Rbar_le ce1 ce2.
Proof.
unfold is_conditional_expectation;
intros isce1 isce2.
pose (
G :=
fun x:
R =>
pre_event_inter (
fun omega =>
Rbar_gt (
ce1 omega) (
ce2 omega))
(
fun omega =>
Rbar_ge x ((
Rbar_rvabs ce2)
omega))).
assert (
sa_G :
forall x:
R,
sa_sigma (
G x)).
{
intros x.
unfold G.
unfold pre_event_inter.
apply (
sa_proper _
(
fun x0 :
Ts => (
Rbar_gt ((
Rbar_rvminus ce1 (
Rbar_finite_part ce2))
x0) 0) /\
Rbar_le (
Rbar_abs (
ce2 x0))
x )).
-
intro z.
unfold Rbar_rvminus,
Rbar_rvopp,
Rbar_finite_part.
split;
intros.
+
destruct H.
split;
try easy.
unfold Rbar_rvplus in H.
assert (
is_finite (
ce2 z)).
*
destruct (
ce2 z).
--
now unfold is_finite.
--
now simpl in H0.
--
now simpl in H0.
*
rewrite <-
H1 in H |- *.
unfold Rbar_opp in H.
unfold Rbar_gt in *.
apply (
Rbar_plus_lt_compat_r _ _ (
ce2 z))
in H.
rewrite Rbar_plus_0_l in H.
destruct ((
ce1 z));
simpl in *;
trivial.
f_equal;
lra.
+
destruct H.
unfold Rbar_gt in H0.
assert (
is_finite (
ce2 z)).
*
unfold Rbar_rvabs in H0.
destruct (
ce2 z).
--
now unfold is_finite.
--
now simpl in H0.
--
now simpl in H0.
*
split;
try easy.
unfold Rbar_rvplus.
rewrite <-
H1 in H |- *.
unfold Rbar_opp.
unfold Rbar_gt in *.
apply (
Rbar_plus_lt_compat_r _ _ (-
ce2 z))
in H.
destruct ((
ce1 z));
simpl in *;
trivial.
f_equal;
lra.
-
apply sa_inter.
+
apply Rbar_sa_le_gt;
intros.
apply Rbar_plus_measurable.
*
typeclasses eauto.
*
apply rv_Rbar_measurable.
apply Rbar_rvopp_rv.
apply Real_Rbar_rv.
apply measurable_rv.
now apply Rbar_finite_part_meas.
+
apply Rbar_Rabs_measurable.
now apply rv_Rbar_measurable.
}
assert (
nnf12:
forall x,
Rbar_NonnegativeFunction (
Rbar_rvmult (
Rbar_rvminus ce1 ce2) (
EventIndicator (
classic_dec (
G x))))).
{
intros x a.
unfold Rbar_rvmult,
Rbar_rvminus,
Rbar_rvplus,
Rbar_rvopp,
EventIndicator;
simpl.
destruct (
classic_dec (
G x)
a);
simpl.
-
rewrite Rbar_mult_1_r.
unfold G,
Rbar_rvabs in g.
destruct g as [??].
destruct (
ce1 a);
destruct (
ce2 a);
simpl in *;
try tauto.
lra.
-
now rewrite Rbar_mult_0_r.
}
assert (
isfe2abs :
forall x,
match Rbar_Expectation (
Rbar_rvabs (
Rbar_rvmult ce2 (
EventIndicator (
classic_dec (
G x)))))
with
|
Some (
Finite _) =>
True
|
_ =>
False
end).
{
intros x.
rewrite (
Rbar_Expectation_pos_pofrf _ (
nnf:=
_)).
generalize (
Rbar_NonnegExpectation_le (
nnf2:=(@
nnfconst Ts (
Rabs x) (
Rabs_pos x))) (
Rbar_rvabs (
Rbar_rvmult ce2 (
fun x0 :
Ts =>
EventIndicator (
classic_dec (
G x))
x0))) (
const (
Rabs x)))
;
intros HH1.
cut_to HH1.
-
simpl in *.
rewrite Rbar_NonnegExpectation_const in HH1.
generalize (
Rbar_NonnegExpectation_pos
(
Rbar_rvabs (
Rbar_rvmult ce2 (
fun x0 :
Ts =>
EventIndicator (
classic_dec (
G x))
x0))))
;
intros HH2.
simpl in *.
match_destr.
-
intros a.
unfold Rbar_rvabs,
Rbar_rvmult,
const,
EventIndicator.
match_destr.
+
rewrite Rbar_mult_1_r.
destruct g as [??].
unfold Rbar_rvabs in *.
destruct (
Rbar_abs (
ce2 a));
simpl in *;
try tauto.
etransitivity;
try eapply H0.
apply RRle_abs.
+
rewrite Rbar_mult_0_r;
simpl.
rewrite Rabs_R0.
apply Rabs_pos.
}
assert (
isfe2 :
forall x,
match Rbar_Expectation (
Rbar_rvmult ce2 (
EventIndicator (
classic_dec (
G x))))
with
|
Some (
Finite _) =>
True
|
_ =>
False
end).
{
intros.
apply Rbar_Expectation_abs_then_finite.
apply isfe2abs.
}
assert (
isfe1 :
forall x,
match Rbar_Expectation (
Rbar_rvmult ce1 (
EventIndicator (
classic_dec (
G x))))
with
|
Some (
Finite _) =>
True
|
_ =>
False
end).
{
intros a.
specialize (
isfe2 a).
specialize (
isce1 _ (
classic_dec _) (
sa_G a)).
specialize (
isce2 _ (
classic_dec _) (
sa_G a)).
rewrite <-
isce1.
now rewrite <-
isce2 in isfe2.
}
assert (
eqq0:
forall x,
rv_eq (
Rbar_rvmult (
Rbar_rvminus ce1 ce2) (
EventIndicator (
classic_dec (
G x))))
((
Rbar_rvminus (
Rbar_rvmult ce1 (
EventIndicator (
classic_dec (
G x))))
(
Rbar_rvmult ce2 (
EventIndicator (
classic_dec (
G x))))))).
{
intros x a.
unfold Rbar_rvminus,
Rbar_rvmult,
Rbar_rvplus,
Rbar_rvopp.
rewrite Rbar_mult_plus_distr_fin_r.
now rewrite Rbar_mult_opp_l.
}
assert (
eqqlin:
forall x,
Rbar_Expectation (
Rbar_rvmult (
Rbar_rvminus ce1 ce2) (
EventIndicator (
classic_dec (
G x)))) =
match Rbar_Expectation (
Rbar_rvmult ce1 (
EventIndicator (
classic_dec (
G x)))),
Rbar_Expectation (
Rbar_rvmult ce2 (
EventIndicator (
classic_dec (
G x))))
with
|
Some exp1,
Some exp2 =>
Some (
Rbar_minus exp1 exp2)
|
_,
_ =>
None
end).
{
intros x.
transitivity (
Rbar_Expectation (
Rbar_rvminus (
Rbar_rvmult ce1 (
EventIndicator (
classic_dec (
G x))))
(
Rbar_rvmult ce2 (
EventIndicator (
classic_dec (
G x)))))).
{
now apply Rbar_Expectation_ext.
}
specialize (
isfe1 x);
specialize (
isfe2 x).
match_case_in isfe1;
intros;
rewrite H in isfe1;
try tauto.
match_destr_in isfe1;
try tauto.
match_case_in isfe2;
intros;
rewrite H0 in isfe2;
try tauto.
match_destr_in isfe2;
try tauto.
apply Rbar_Expectation_minus_finite;
trivial.
-
apply Rbar_rvmult_rv.
+
now apply RandomVariable_sa_sub.
+
apply Real_Rbar_rv.
apply EventIndicator_pre_rv.
now apply sub.
-
apply Rbar_rvmult_rv.
+
now apply RandomVariable_sa_sub.
+
apply Real_Rbar_rv.
apply EventIndicator_pre_rv.
now apply sub.
}
assert (
eqq2:
forall x,
Rbar_Expectation (
Rbar_rvmult (
Rbar_rvminus ce1 ce2) (
fun x0 :
Ts =>
EventIndicator (
classic_dec (
G x))
x0)) =
Some (
Finite 0)).
{
intros x.
rewrite eqqlin.
specialize (
isce1 _ (
classic_dec _) (
sa_G x)).
specialize (
isce2 _ (
classic_dec _) (
sa_G x)).
specialize (
isfe2 x).
rewrite <-
isce1, <-
isce2.
rewrite <-
isce2 in isfe2.
match_destr_in isfe2;
try tauto.
now rewrite Rbar_minus_eq_0.
}
assert (
rv12 :
forall x,
RandomVariable dom2 Rbar_borel_sa
(
Rbar_rvmult (
Rbar_rvminus ce1 ce2) (
fun x0 :
Ts =>
EventIndicator (
classic_dec (
G x))
x0))).
{
intros x.
eapply (
RandomVariable_proper _ _ (
reflexivity _)
_ _ (
reflexivity _));
try eapply eqq0.
apply Rbar_rvplus_rv.
-
apply Rbar_rvmult_rv;
trivial.
apply Real_Rbar_rv.
now apply EventIndicator_pre_rv.
-
apply Rbar_rvopp_rv.
apply Rbar_rvmult_rv;
trivial.
apply Real_Rbar_rv.
now apply EventIndicator_pre_rv.
}
assert (
psG0:
forall x,
ps_P (
ProbSpace:=((
prob_space_sa_sub prts sub))) (
exist _ (
G x) (
sa_G x)) = 0).
{
intros x.
specialize (
eqq2 x).
generalize (@
Rbar_Expectation_nonneg_zero_almost_zero _ _ ((
prob_space_sa_sub prts sub))
(
Rbar_rvmult (
Rbar_rvminus ce1 ce2) (
fun x0 :
Ts =>
EventIndicator (
classic_dec (
G x))
x0)))
;
intros HH2.
cut_to HH2;
trivial.
-
destruct HH2 as [
P [
pone pH]].
unfold const in pH.
unfold Rbar_rvmult,
Rbar_rvminus,
Rbar_rvplus,
Rbar_rvopp,
EventIndicator in pH.
apply NNPP.
intros neq.
simpl in *.
assert (
HH1:
ps_P (
ProbSpace:=((
prob_space_sa_sub prts sub))) (
event_inter P (
exist sa_sigma (
G x) (
sa_G x))) <> 0).
{
rewrite ps_inter_l1;
trivial.
}
destruct (
zero_prob_or_witness _ HH1)
as [
a [
Pa Ga]];
simpl in *.
specialize (
pH _ Pa).
match_destr_in pH;
try tauto.
rewrite Rbar_mult_1_r in pH.
destruct Ga as [??].
unfold Rbar_rvminus,
Rbar_rvplus,
Rbar_rvopp in pH.
destruct (
ce1 a);
destruct (
ce2 a);
simpl in *;
try (
invcs pH;
lra).
-
rewrite Rbar_Expectation_prob_space_sa_sub;
trivial.
}
destruct isf2 as [
P [
Pone ?]].
assert (
psG0' :
forall x,
ps_P
(
event_inter
(
event_sa_sub sub (
exist _ (
G x) (
sa_G x)))
(
event_sa_sub sub P))
= 0).
{
intros a;
simpl in *.
now rewrite ps_inter_r1.
}
generalize (
is_lim_ascending prts (
fun x => (
event_inter
(
event_sa_sub sub (
exist _ (
G (
INR x)) (
sa_G (
INR x))))
(
exist _ _ (
sa_finite_Rbar ce2 (
RandomVariable_sa_sub sub _))))))
;
intros HH.
cut_to HH.
-
apply (
is_lim_seq_ext _ (
fun _ => 0))
in HH.
+
apply is_lim_seq_unique in HH.
rewrite Lim_seq_const in HH.
assert (
eqq3:
pre_event_equiv
(
union_of_collection
(
fun x :
nat =>
event_inter (
event_sa_sub sub (
exist sa_sigma (
G (
INR x)) (
sa_G (
INR x)))) (
exist _ _ (
sa_finite_Rbar ce2 (
RandomVariable_sa_sub sub _)))))
(
pre_event_inter
(
fun omega :
Ts =>
Rbar_gt (
ce1 omega) (
ce2 omega))
(
fun a =>
is_finite (
ce2 a)))).
{
intros a.
split;
simpl.
-
intros [?[[??]?]].
split;
trivial.
-
unfold G.
intros [??].
exists (
Z.to_nat (
up (
Rabs (
ce2 a)))).
split;
trivial.
split;
trivial.
unfold Rbar_ge,
Rbar_rvabs.
rewrite <-
H1;
simpl.
rewrite INR_up_pos.
*
apply Rge_le.
left.
apply archimed.
*
apply Rle_ge.
apply Rabs_pos.
}
destruct (
sa_proper dom2 _ _ eqq3)
as [
sa1 _].
cut_to sa1.
*
rewrite (
ps_proper _ (
event_sa_sub sub ((
exist _ _ sa1))))
in HH by (
now red).
generalize (
ps_complement (
prob_space_sa_sub prts sub)
((
exist _ _ sa1)))
;
intros eqq4.
invcs HH.
simpl in *.
rewrite <-
H1 in eqq4.
field_simplify in eqq4.
eexists.
split.
--
rewrite ps_inter_r1.
++
apply eqq4.
++
apply Pone.
--
intros a;
simpl.
unfold pre_event_complement.
unfold Rbar_gt.
intros [??].
apply not_and_or in H0.
specialize (
H _ H2).
destruct H0;
try tauto.
now apply Rbar_not_lt_le.
*
apply sa_countable_union
;
intros n.
simpl.
apply sa_inter;
trivial.
now apply sa_finite_Rbar.
+
intros n.
simpl in *.
rewrite ps_inter_r1;
trivial.
erewrite <-
ps_inter_r1;
try eapply Pone.
rewrite ps_proper;
try eapply Pone.
intros ?;
simpl.
split.
*
intros [??];
trivial.
*
intros;
split;
auto.
-
intros ??.
unfold G.
intros [[??]?].
split;
trivial.
split;
trivial.
unfold Rbar_gt,
Rbar_ge in *.
eapply Rbar_le_trans;
try eapply H1.
apply le_INR;
lia.
Qed.
Theorem is_conditional_expectation_almostfinite_unique
(
f :
Ts->
R)
(
ce1 ce2 :
Ts ->
Rbar)
{
rvf :
RandomVariable dom borel_sa f}
{
rvce1 :
RandomVariable dom2 Rbar_borel_sa ce1}
{
rvce2 :
RandomVariable dom2 Rbar_borel_sa ce2}
(
isf1:
almost (
prob_space_sa_sub prts sub) (
fun a =>
is_finite (
ce1 a)))
(
isf2:
almost (
prob_space_sa_sub prts sub) (
fun a =>
is_finite (
ce2 a))) :
is_conditional_expectation dom2 f ce1 ->
is_conditional_expectation dom2 f ce2 ->
almostR2 (
prob_space_sa_sub prts sub)
eq ce1 ce2.
Proof.
Theorem is_conditional_expectation_unique
(
f :
Ts->
R)
(
ce1 ce2 :
Ts ->
Rbar)
{
rvf :
RandomVariable dom borel_sa f}
{
rvce1 :
RandomVariable dom2 Rbar_borel_sa ce1}
{
rvce2 :
RandomVariable dom2 Rbar_borel_sa ce2}
{
isfe:
IsFiniteExpectation prts f} :
is_conditional_expectation dom2 f ce1 ->
is_conditional_expectation dom2 f ce2 ->
almostR2 (
prob_space_sa_sub prts sub)
eq ce1 ce2.
Proof.
Existing Instance Rbar_rvmult_rv.
Lemma Rbar_rvmult_assoc (
a:
Ts->
Rbar) (
b:
Ts->
Rbar) (
c:
Ts->
Rbar) :
rv_eq (
Rbar_rvmult a (
Rbar_rvmult b c)) (
Rbar_rvmult (
Rbar_rvmult a b)
c).
Proof.
Lemma rvmult_rvscale c (
a b:
Ts->
R) :
rv_eq (
rvmult (
rvscale c a)
b) (
rvscale c (
rvmult a b)).
Proof.
intros ?.
rv_unfold; lra.
Qed.
Theorem is_conditional_expectation_const (
c:
R)
:
is_conditional_expectation dom2 (
const c) (
const c).
Proof.
Lemma is_conditional_expectation_scale_nzero (
c:
R)
(
f :
Ts ->
R)
(
ce :
Ts ->
Rbar)
{
rv :
RandomVariable dom borel_sa f}
{
rvce :
RandomVariable dom2 Rbar_borel_sa ce}
:
c <> 0 ->
is_conditional_expectation dom2 f ce ->
is_conditional_expectation dom2 (
rvscale c f) (
Rbar_rvmult (
const c)
ce)
(
rvce:=
Rbar_rvmult_rv _ _)
.
Proof.
Corollary is_conditional_expectation_propere
{
f1 f2 :
Ts ->
R}
(
eq1:
almostR2 prts eq f1 f2)
{
ce1 ce2 :
Ts ->
Rbar}
(
eq2:
almostR2 prts eq ce1 ce2)
(
rvf1 :
RandomVariable dom borel_sa f1)
(
rvf2 :
RandomVariable dom borel_sa f2)
(
rvce1 :
RandomVariable dom2 Rbar_borel_sa ce1)
(
rvce2 :
RandomVariable dom2 Rbar_borel_sa ce2)
:
is_conditional_expectation dom2 f1 ce1 ->
is_conditional_expectation dom2 f2 ce2.
Proof.
Theorem is_conditional_expectation_scale (
c:
R)
(
f :
Ts ->
R)
(
ce :
Ts ->
Rbar)
{
rv :
RandomVariable dom borel_sa f}
{
rvce :
RandomVariable dom2 Rbar_borel_sa ce}
:
is_conditional_expectation dom2 f ce ->
is_conditional_expectation dom2 (
rvscale c f) (
Rbar_rvmult (
const c)
ce)
(
rvce:=
Rbar_rvmult_rv _ _).
Proof.
Corollary is_conditional_expectation_scale_inv (
c:
R)
(
f :
Ts ->
R)
(
ce :
Ts ->
Rbar)
{
rv :
RandomVariable dom borel_sa f}
{
rvce :
RandomVariable dom2 Rbar_borel_sa ce}
:
c <> 0 ->
is_conditional_expectation dom2 (
rvscale c f) (
Rbar_rvmult (
const c)
ce)
(
rvce:=
Rbar_rvmult_rv _ _) ->
is_conditional_expectation dom2 f ce.
Proof.
Corollary is_conditional_expectation_opp
(
f :
Ts ->
R)
(
ce :
Ts ->
Rbar)
{
rv :
RandomVariable dom borel_sa f}
{
rvce :
RandomVariable dom2 Rbar_borel_sa ce}
:
is_conditional_expectation dom2 f ce ->
is_conditional_expectation dom2 (
rvopp f) (
Rbar_rvopp ce)
(
rvce:=
Rbar_rvopp_rv _).
Proof.
Theorem is_conditional_expectation_plus
(
f1 f2 :
Ts ->
R)
(
ce1 ce2 :
Ts ->
Rbar)
{
rvf1 :
RandomVariable dom borel_sa f1}
{
rvf2 :
RandomVariable dom borel_sa f2}
{
isfe1:
IsFiniteExpectation prts f1}
{
isfe2:
IsFiniteExpectation prts f2}
{
rvce1 :
RandomVariable dom2 Rbar_borel_sa ce1}
{
rvce2 :
RandomVariable dom2 Rbar_borel_sa ce2}
:
is_conditional_expectation dom2 f1 ce1 ->
is_conditional_expectation dom2 f2 ce2 ->
is_conditional_expectation dom2 (
rvplus f1 f2) (
Rbar_rvplus ce1 ce2)
(
rvce:=
Rbar_rvplus_rv _ _).
Proof.
Corollary is_conditional_expectation_minus
(
f1 f2 :
Ts ->
R)
(
ce1 ce2 :
Ts ->
Rbar)
{
rvf1 :
RandomVariable dom borel_sa f1}
{
rvf2 :
RandomVariable dom borel_sa f2}
{
isfe1:
IsFiniteExpectation prts f1}
{
isfe2:
IsFiniteExpectation prts f2}
{
rvce1 :
RandomVariable dom2 Rbar_borel_sa ce1}
{
rvce2 :
RandomVariable dom2 Rbar_borel_sa ce2}
:
is_conditional_expectation dom2 f1 ce1 ->
is_conditional_expectation dom2 f2 ce2 ->
is_conditional_expectation dom2 (
rvminus f1 f2) (
Rbar_rvminus ce1 ce2)
(
rvce:=
Rbar_rvplus_rv _ _).
Proof.
Lemma Rbar_rvlim_almost_proper (
f1 f2:
nat->
Ts->
Rbar) :
(
forall n,
almostR2 prts eq (
f1 n) (
f2 n)) ->
almostR2 prts eq (
Rbar_rvlim f1) (
Rbar_rvlim f2).
Proof.
Global Instance rvmin_almost_proper :
Proper (
almostR2 prts eq ==>
almostR2 prts eq ==>
almostR2 prts eq)
rvmin.
Proof.
intros ?? [
p1[?
eqq1]] ?? [
p2[?
eqq2]].
exists (
event_inter p1 p2).
split.
-
rewrite ps_inter_l1;
trivial.
-
intros ? [??].
unfold rvmin.
rewrite eqq1,
eqq2;
trivial.
Qed.
Global Instance Rbar_rvplus_almost_proper {
DOM:
SigmaAlgebra Ts} (
PRTS:
ProbSpace DOM) :
Proper (
almostR2 PRTS eq ==>
almostR2 PRTS eq ==>
almostR2 PRTS eq)
Rbar_rvplus.
Proof.
intros ?? [
p1[?
eqq1]] ?? [
p2[?
eqq2]].
exists (
event_inter p1 p2).
split.
-
rewrite ps_inter_l1;
trivial.
-
intros ? [??].
unfold Rbar_rvplus.
rewrite eqq1,
eqq2;
trivial.
Qed.
Global Instance Rbar_rvopp_almost_proper {
DOM:
SigmaAlgebra Ts} (
PRTS:
ProbSpace DOM) :
Proper (
almostR2 PRTS eq ==>
almostR2 PRTS eq)
Rbar_rvopp.
Proof.
intros ?? [
p1[?
eqq1]].
exists p1.
split;
trivial.
-
intros ??.
unfold Rbar_rvopp.
rewrite eqq1;
trivial.
Qed.
Lemma sa_le_Rbar_ge_rv {
domm}
(
rv_X :
Ts ->
Rbar) {
rv :
RandomVariable domm Rbar_borel_sa rv_X}
x
:
sa_sigma (
fun omega =>
Rbar_ge (
rv_X omega)
x).
Proof.
Definition event_Rbar_ge {
domm}
(
rv_X :
Ts ->
Rbar) {
rv :
RandomVariable domm Rbar_borel_sa rv_X}
x
:
event domm
:= @
exist (
pre_event Ts)
_ _ (
sa_le_Rbar_ge_rv rv_X x).
Theorem is_conditional_expectation_isfe
f ce
{
rvf:
RandomVariable dom borel_sa f}
{
rvce:
RandomVariable dom2 Rbar_borel_sa ce} :
is_conditional_expectation dom2 f ce ->
IsFiniteExpectation prts f ->
Rbar_IsFiniteExpectation prts ce.
Proof.
Theorem is_conditional_expectation_nneg
(
f :
Ts ->
R)
(
ce :
Ts ->
Rbar)
{
rvf :
RandomVariable dom borel_sa f}
{
rvce :
RandomVariable dom2 Rbar_borel_sa ce}
{
nnf:
NonnegativeFunction f}
:
is_conditional_expectation dom2 f ce ->
almostR2 (
prob_space_sa_sub prts sub)
Rbar_le (
const 0)
ce.
Proof.
Lemma is_conditional_expectation_anneg
(
f :
Ts ->
R)
(
ce :
Ts ->
Rbar)
{
rvf :
RandomVariable dom borel_sa f}
{
rvce :
RandomVariable dom2 Rbar_borel_sa ce}
:
almostR2 prts Rle (
const 0)
f ->
is_conditional_expectation dom2 f ce ->
almostR2 (
prob_space_sa_sub prts sub)
Rbar_le (
const 0)
ce.
Proof.
Theorem is_conditional_expectation_ale
(
f1 :
Ts ->
R)
(
f2 :
Ts ->
R)
(
ce1 :
Ts ->
Rbar)
(
ce2 :
Ts ->
Rbar)
{
rvf1 :
RandomVariable dom borel_sa f1}
{
rvce1 :
RandomVariable dom2 Rbar_borel_sa ce1}
{
isfe1:
IsFiniteExpectation prts f1}
{
rvf2 :
RandomVariable dom borel_sa f2}
{
rvce2 :
RandomVariable dom2 Rbar_borel_sa ce2}
{
isfe2:
IsFiniteExpectation prts f2}
:
almostR2 prts Rle f1 f2 ->
is_conditional_expectation dom2 f1 ce1 ->
is_conditional_expectation dom2 f2 ce2 ->
almostR2 (
prob_space_sa_sub prts sub)
Rbar_le ce1 ce2.
Proof.
Fixpoint list_Rbar_sum (
l :
list Rbar) :
Rbar :=
match l with
|
nil => 0
|
x ::
xs =>
Rbar_plus x (
list_Rbar_sum xs)
end.
Lemma list_Rbar_sum_const_mulR {
A :
Type}
f (
l :
list A) :
forall (
r:
R),
list_Rbar_sum (
map (
fun x =>
Rbar_mult r (
f x))
l) =
Rbar_mult r (
list_Rbar_sum (
map (
fun x =>
f x)
l)).
Proof.
Lemma is_conditional_expectation_finexp
(
f :
Ts ->
R)
(
ce :
Ts ->
Rbar)
{
rvf :
RandomVariable dom borel_sa f}
{
rvce :
RandomVariable dom2 Rbar_borel_sa ce}
:
is_conditional_expectation dom2 f ce ->
forall P (
dec:
dec_pre_event P),
sa_sigma (
SigmaAlgebra :=
dom2)
P ->
forall {
isfef:
IsFiniteExpectation prts (
rvmult f (
EventIndicator dec))}
{
isfece:
Rbar_IsFiniteExpectation prts (
Rbar_rvmult ce (
EventIndicator dec))},
FiniteExpectation prts (
rvmult f (
EventIndicator dec)) =
Rbar_FiniteExpectation prts (
Rbar_rvmult ce (
EventIndicator dec)).
Proof.
Lemma is_conditional_expectation_isfe_finite_part
{
f :
Ts ->
R}
{
ce :
Ts ->
Rbar}
{
rvf :
RandomVariable dom borel_sa f}
{
isfe:
IsFiniteExpectation prts f}
{
rvce :
RandomVariable dom2 Rbar_borel_sa ce}
:
is_conditional_expectation dom2 f ce ->
is_conditional_expectation dom2 f (
Rbar_finite_part ce).
Proof.
Lemma is_conditional_expectation_isfe_finite_part_b
{
f :
Ts ->
R}
{
ce :
Ts ->
Rbar}
{
rvf :
RandomVariable dom borel_sa f}
{
isfe:
Rbar_IsFiniteExpectation prts ce}
{
rvce :
RandomVariable dom2 Rbar_borel_sa ce}
:
is_conditional_expectation dom2 f (
Rbar_finite_part ce) ->
is_conditional_expectation dom2 f ce.
Proof.
Lemma IsFiniteExpectation_factor_out_scale_indicator (
g:
Ts->
R) (
f:
Ts->
R)
{
rvg :
RandomVariable dom borel_sa g}
{
rvf :
RandomVariable dom borel_sa f}
{
isfe:
IsFiniteExpectation prts f}
(
a:
R) :
IsFiniteExpectation prts (
rvmult (
scale_val_indicator g a)
f).
Proof.
Lemma IsFiniteExpectation_factor_out_frf (
g:
Ts->
R) (
f:
Ts->
R)
{
rvg :
RandomVariable dom borel_sa g}
{
rvf :
RandomVariable dom borel_sa f}
{
isfe:
IsFiniteExpectation prts f}
{
frfg :
FiniteRangeFunction g} :
IsFiniteExpectation prts (
rvmult (
fun x :
Ts =>
g x)
f).
Proof.
Lemma Rbar_IsFiniteExpectation_factor_out_frf (
g:
Ts->
R) (
f:
Ts->
Rbar)
{
rvg :
RandomVariable dom borel_sa g}
{
rvf :
RandomVariable dom Rbar_borel_sa f}
{
isfe:
Rbar_IsFiniteExpectation prts f}
{
frfg :
FiniteRangeFunction g} :
Rbar_IsFiniteExpectation prts (
Rbar_rvmult (
fun x :
Ts =>
g x)
f).
Proof.
Lemma Rbar_FinExp_FinExp (
f:
Ts->
Rbar)
{
rv:
RandomVariable dom Rbar_borel_sa f}
{
isfe:
Rbar_IsFiniteExpectation prts f}
{
isfe':
IsFiniteExpectation prts (
Rbar_finite_part f)}:
Rbar_FiniteExpectation prts f =
FiniteExpectation prts (
Rbar_finite_part f).
Proof.
Lemma is_conditional_expectation_factor_out_frf
(
f g:
Ts->
R) (
ce:
Ts->
Rbar)
{
frfg :
FiniteRangeFunction g}
{
rvf :
RandomVariable dom borel_sa f}
{
rvg :
RandomVariable dom2 borel_sa g}
{
rvce :
RandomVariable dom2 Rbar_borel_sa ce}
{
rvgf:
RandomVariable dom borel_sa (
rvmult g f)}
{
rvgce:
RandomVariable dom2 Rbar_borel_sa (
Rbar_rvmult g ce)} :
IsFiniteExpectation prts f ->
is_conditional_expectation dom2 f ce ->
is_conditional_expectation dom2 (
rvmult g f) (
Rbar_rvmult g ce).
Proof.
intros isfe isce.
assert (
isfe_ce:
Rbar_IsFiniteExpectation prts ce).
{
apply is_conditional_expectation_FiniteExpectation in isce.
now apply isce.
}
assert (
isfe_ce':
Rbar_IsFiniteExpectation prts (
Rbar_rvmult (
fun x :
Ts =>
g x)
ce)).
{
apply Rbar_IsFiniteExpectation_factor_out_frf;
trivial.
-
now apply RandomVariable_sa_sub.
-
now apply RandomVariable_sa_sub.
}
assert (
isfe_ce'':
IsFiniteExpectation prts (
fun x =>
real (
ce x))).
{
apply Rbar_finexp_finexp;
trivial.
now apply RandomVariable_sa_sub.
}
apply is_conditional_expectation_isfe_finite_part_b.
intros P decP saP.
unfold Rbar_rvmult,
Rbar_finite_part;
simpl.
rewrite <-
Expectation_Rbar_Expectation.
apply finexp_almost_finite_part in isfe_ce; [|
now apply RandomVariable_sa_sub].
symmetry.
transitivity (
Expectation
(
rvmult (
rvmult g (
fun x => (
Finite (
ce x)))) (
EventIndicator decP))).
{
apply Expectation_almostR2_proper.
+
apply rvmult_rv.
*
apply Rbar_real_rv.
apply Rbar_rvmult_rv.
--
apply Real_Rbar_rv.
apply RandomVariable_sa_sub;
trivial.
--
now apply RandomVariable_sa_sub.
*
apply EventIndicator_pre_rv.
now apply sub.
+
apply rvmult_rv.
*
apply rvmult_rv.
--
now apply RandomVariable_sa_sub.
--
apply Rbar_real_rv.
apply Real_Rbar_rv.
apply Rbar_real_rv.
now apply RandomVariable_sa_sub.
*
apply EventIndicator_pre_rv.
now apply sub.
+
apply almostR2_eq_mult_proper;
try reflexivity.
revert isfe_ce.
apply almost_impl.
apply all_almost;
intros ?
eqq.
now rewrite eqq.
}
assert (
eqq1:
forall f,
rv_eq
(
rvmult (
rvmult g f) (
EventIndicator decP))
(
rvmult (
rvmult (
frf_indicator g)
f) (
EventIndicator decP))).
{
intros.
apply rvmult_proper;
try reflexivity.
apply rvmult_proper;
try reflexivity.
apply (
frf_indicator_sum g).
}
rewrite (
Expectation_ext (
eqq1 f)).
rewrite (
Expectation_ext (
eqq1 ce)).
unfold frf_indicator.
assert (
eqq2:
forall f,
rv_eq
(
rvmult (
rvmult (
frf_indicator g)
f) (
EventIndicator decP))
(
fun omega :
Ts =>
RealAdd.list_sum
(
map (
fun c :
R => (
scale_val_indicator g c omega) * (
f omega) *
EventIndicator decP omega)
(
nodup Req_EM_T frf_vals)))).
{
intros ??.
unfold rvmult,
frf_indicator.
rewrite Rmult_assoc.
rewrite Rmult_comm.
rewrite <-
list_sum_const_mul.
f_equal.
apply map_ext;
intros.
lra.
}
rewrite (
Expectation_ext (
eqq2 f)).
rewrite (
Expectation_ext (
eqq2 ce)).
assert (
isfe1:
forall ff,
RandomVariable dom borel_sa ff ->
IsFiniteExpectation prts ff ->
forall c,
IsFiniteExpectation prts
(
fun omega :
Ts =>
val_indicator g c omega *
ff omega *
EventIndicator decP omega)).
{
intros.
unfold val_indicator.
assert (
eqq:
rv_eq
(
fun omega :
Ts =>
val_indicator g c omega *
ff omega *
EventIndicator decP omega)
(
fun omega :
Ts =>
(
ff omega *
EventIndicator (
classic_dec (
fun omega0 :
Ts =>
g omega0 =
c))
omega) *
EventIndicator decP omega)).
{
intros ?.
unfold val_indicator.
lra.
}
rewrite eqq.
apply IsFiniteExpectation_indicator;
trivial.
-
apply rvmult_rv;
trivial.
apply EventIndicator_pre_rv.
apply sa_le_pt.
apply rv_measurable.
now apply RandomVariable_sa_sub.
-
now apply sub.
-
apply IsFiniteExpectation_indicator;
trivial.
apply sa_le_pt.
apply rv_measurable.
now apply RandomVariable_sa_sub.
}
assert (
isfe1':
forall ff,
RandomVariable dom borel_sa ff ->
IsFiniteExpectation prts ff ->
forall c,
IsFiniteExpectation prts
(
fun omega :
Ts =>
scale_val_indicator g c omega *
ff omega *
EventIndicator decP omega)).
{
intros.
unfold scale_val_indicator.
generalize (
IsFiniteExpectation_scale prts c _ (
isfe:=
isfe1 ff H H0 c)).
apply IsFiniteExpectation_proper.
intros ?.
unfold scale_val_indicator,
rvscale.
lra.
}
assert (
rvff:
forall ff,
RandomVariable dom borel_sa ff ->
forall c,
RandomVariable dom borel_sa
(
fun omega :
Ts =>
scale_val_indicator g c omega *
ff omega *
EventIndicator decP omega)).
{
intros.
apply rvmult_rv.
-
apply rvmult_rv;
trivial.
apply scale_val_indicator_rv.
now apply RandomVariable_sa_sub.
-
apply EventIndicator_pre_rv.
now apply sub.
}
generalize (
isfe1'
f);
intros isfef.
cut_to isfef;
trivial.
rewrite (
FiniteExpectation_list_sum _ _ _ (
isfe:=
isfef)).
assert (
RandomVariable dom borel_sa (
fun x :
Ts =>
ce x)).
{
apply Rbar_real_rv.
now apply RandomVariable_sa_sub.
}
generalize (
rvff ce);
intros rvfce.
cut_to rvfce;
trivial.
generalize (
isfe1'
ce);
intros isfece.
cut_to isfece;
trivial.
rewrite (
FiniteExpectation_list_sum _ _ _ (
isfe:=
isfece)).
do 3
f_equal.
apply map_ext;
intros.
unfold scale_val_indicator.
assert (
eqq3:
forall ff,
rv_eq (
fun omega :
Ts =>
rvscale a (
val_indicator g a)
omega *
ff omega *
EventIndicator decP omega)
(
rvscale a (
rvmult ff (
EventIndicator (
classic_dec (
pre_event_inter
(
fun omega0 :
Ts =>
g omega0 =
a)
P)))))).
{
intros ??.
unfold val_indicator,
pre_event_inter.
rv_unfold.
repeat rewrite Rmult_assoc.
f_equal.
rewrite Rmult_comm.
rewrite Rmult_assoc.
f_equal.
repeat match_destr;
intuition lra.
}
rewrite (
FiniteExpectation_ext_alt _ _ _ (
eqq3 ce)).
rewrite (
FiniteExpectation_ext_alt _ _ _ (
eqq3 f)).
assert (
isfee:
forall ff,
RandomVariable dom borel_sa (
fun x :
Ts =>
ff x) ->
IsFiniteExpectation prts ff ->
IsFiniteExpectation prts (
rvmult (
fun x :
Ts =>
ff x)
(
EventIndicator
(
classic_dec (
pre_event_inter (
fun omega0 :
Ts =>
g omega0 =
a)
P))))).
{
intros.
apply IsFiniteExpectation_indicator;
trivial.
apply sa_inter;
trivial.
-
apply sa_le_pt.
apply rv_measurable.
now apply RandomVariable_sa_sub.
-
now apply sub.
}
generalize (
isfee f)
;
intros isfef1.
cut_to isfef1;
trivial.
generalize (
isfee ce)
;
intros isfece1.
cut_to isfece1;
trivial.
rewrite (
FiniteExpectation_scale'
_ _ _ (
isfe:=
isfef1)).
rewrite (
FiniteExpectation_scale'
_ _ _ (
isfe:=
isfece1)).
f_equal.
apply is_conditional_expectation_isfe_finite_part in isce.
assert (
sa_sigma (
SigmaAlgebra:=
dom2) (
pre_event_inter (
fun omega0 :
Ts =>
g omega0 =
a)
P)).
{
apply sa_inter;
trivial.
apply sa_le_pt.
apply rv_measurable.
now apply RandomVariable_sa_sub.
}
assert (
sa_sigma (
SigmaAlgebra:=
dom) (
pre_event_inter (
fun omega0 :
Ts =>
g omega0 =
a)
P)).
{
apply sa_inter.
-
apply sa_le_pt.
apply rv_measurable.
now apply RandomVariable_sa_sub.
-
now apply sub.
}
assert (
Rbar_IsFiniteExpectation prts
(
Rbar_rvmult (
fun x :
Ts =>
Rbar_finite_part ce x)
(
fun x :
Ts =>
EventIndicator
(
classic_dec (
pre_event_inter (
fun omega0 :
Ts =>
g omega0 =
a)
P))
x))).
{
unfold Rbar_rvmult;
simpl.
unfold Rbar_finite_part.
unfold Rbar_IsFiniteExpectation.
rewrite <-
Expectation_Rbar_Expectation.
apply IsFiniteExpectation_indicator;
trivial.
}
erewrite (
is_conditional_expectation_finexp _ _ isce);
trivial.
unfold Rbar_rvmult;
simpl.
erewrite Rbar_FinExp_FinExp.
-
reflexivity.
-
apply Real_Rbar_rv.
apply rvmult_rv;
trivial.
apply EventIndicator_pre_rv;
trivial.
Qed.
Lemma frf_min (
f :
Ts ->
R)
{
frf :
FiniteRangeFunction f} :
forall x,
RList.MinRlist frf_vals <=
f x.
Proof.
Lemma frf_max (
f :
Ts ->
R)
{
frf :
FiniteRangeFunction f} :
forall x,
f x <=
RList.MaxRlist frf_vals.
Proof.
Lemma IsFiniteExpectation_mult_finite_range_pos (
f g :
Ts ->
R)
{
frf :
FiniteRangeFunction g} :
NonnegativeFunction f ->
IsFiniteExpectation prts f ->
IsFiniteExpectation prts (
rvmult f g).
Proof.
Lemma IsFiniteExpectation_mult_finite_range (
f g :
Ts ->
R)
{
rvf :
RandomVariable dom borel_sa f}
{
rvg :
RandomVariable dom borel_sa g}
{
frf :
FiniteRangeFunction g} :
IsFiniteExpectation prts f ->
IsFiniteExpectation prts (
rvmult f g).
Proof.
Theorem is_conditional_expectation_factor_out_nneg_both
(
f g:
Ts ->
R)
(
ce :
Ts ->
R)
{
nnegf :
NonnegativeFunction f}
{
nnegg :
NonnegativeFunction g}
{
nnegce :
NonnegativeFunction ce}
{
rvf :
RandomVariable dom borel_sa f}
{
rvg :
RandomVariable dom2 borel_sa g}
{
rvce :
RandomVariable dom2 borel_sa ce}
{
rvgf:
RandomVariable dom borel_sa (
rvmult f g)} :
IsFiniteExpectation prts f ->
is_conditional_expectation dom2 f ce ->
is_conditional_expectation dom2 (
rvmult f g) (
Rbar_rvmult g ce).
Proof.
intros isfef iscondf.
unfold is_conditional_expectation.
intros.
generalize (
simple_approx_lim_seq g nnegg);
intros.
assert (
forall n,
FiniteRangeFunction (
simple_approx g n))
by apply simple_approx_frf.
assert (
forall n,
RandomVariable dom2 borel_sa (
simple_approx g n)).
{
intros.
apply simple_approx_rv;
trivial.
now apply Real_Rbar_rv.
}
assert (
forall n,
RandomVariable dom borel_sa (
rvmult f (
simple_approx g n))).
{
intros.
apply rvmult_rv;
trivial.
now apply RandomVariable_sa_sub.
}
assert (
rvgf2:
forall n,
RandomVariable dom borel_sa (
rvmult (
simple_approx g n)
f)).
{
intros.
apply rvmult_rv;
trivial.
now apply RandomVariable_sa_sub.
}
assert (
forall n,
Expectation
(
rvmult (
rvmult f (
simple_approx (
fun x :
Ts =>
g x)
n))
(
EventIndicator dec)) =
Rbar_Expectation
(
Rbar_rvmult
(
Rbar_rvmult (
simple_approx (
fun x0 :
Ts =>
g x0)
n)
ce)
(
EventIndicator dec))).
{
intros.
generalize (
is_conditional_expectation_factor_out_frf f (
simple_approx g n)
ce _ iscondf) ;
intros.
rewrite <- (
H3 P dec H).
apply Expectation_ext;
intros ?.
rv_unfold;
lra.
}
assert (
forall (
x:
Ts),
is_lim_seq (
fun n => (
rvmult (
rvmult f (
simple_approx g n))
(
EventIndicator dec))
x)
((
rvmult (
rvmult f g) (
EventIndicator dec))
x)).
{
intros.
unfold rvmult.
replace (
Finite (
f x *
g x *
EventIndicator dec x))
with
(
Rbar_mult ((
f x)*(
g x)) (
EventIndicator dec x))
by now simpl.
apply is_lim_seq_scal_r.
replace (
Finite (
f x *
g x))
with (
Rbar_mult (
f x) (
g x))
by now simpl.
now apply is_lim_seq_scal_l.
}
assert (
RandomVariable dom Rbar_borel_sa (
rvmult (
rvmult f g) (
EventIndicator dec))).
{
apply Real_Rbar_rv.
apply rvmult_rv;
trivial.
apply RandomVariable_sa_sub;
trivial.
apply EventIndicator_pre_rv;
trivial.
}
generalize (
Rbar_monotone_convergence (
rvmult (
rvmult f g) (
EventIndicator dec)));
intros.
specialize (
H6 (
fun n => (
rvmult (
rvmult f (
simple_approx g n))
(
EventIndicator dec))) ).
assert (
Rbar_NonnegativeFunction (
rvmult (
rvmult f g) (
EventIndicator dec)))
by
typeclasses eauto.
assert (
forall n :
nat,
RandomVariable
dom Rbar_borel_sa
(
rvmult (
rvmult f (
simple_approx g n))
(
EventIndicator dec))).
{
intros.
apply Real_Rbar_rv.
apply rvmult_rv.
-
apply rvmult_rv;
trivial.
apply RandomVariable_sa_sub;
trivial.
-
apply RandomVariable_sa_sub;
trivial.
apply EventIndicator_pre_rv;
trivial.
}
assert (
forall n :
nat,
Rbar_NonnegativeFunction
((
fun n0 :
nat =>
rvmult (
rvmult f (
simple_approx (
fun x :
Ts =>
g x)
n0))
(
EventIndicator dec))
n)).
{
intros.
apply NonNegMult.
-
typeclasses eauto.
-
apply NonNegMult;
trivial.
apply simple_approx_pofrf.
}
assert (
forall n:
nat,
Rbar_NonnegativeFunction
(
rvmult (
rvmult (
fun x :
Ts =>
simple_approx (
fun x0 :
Ts =>
g x0)
n x) (
fun x :
Ts =>
ce x))
(
fun x :
Ts =>
EventIndicator dec x))).
{
intros.
apply NonNegMult.
-
typeclasses eauto.
-
apply NonNegMult;
trivial.
apply simple_approx_pofrf.
}
specialize (
H6 H5 H7 H8 H9).
assert (
forall n,
Rbar_NonnegExpectation
(
rvmult (
rvmult f (
simple_approx (
fun x :
Ts =>
g x)
n))
(
EventIndicator dec)) =
Rbar_NonnegExpectation
(
rvmult
(
rvmult (
fun x :
Ts =>
simple_approx (
fun x0 :
Ts =>
g x0)
n x)
(
fun x :
Ts =>
ce x))
(
fun x :
Ts =>
EventIndicator dec x))).
{
intros.
specialize (
H3 n).
rewrite Expectation_pos_pofrf with (
nnf := (
H9 n))
in H3.
assert (
rv_eq
(
Rbar_rvmult (
Rbar_rvmult (
fun x :
Ts =>
simple_approx (
fun x0 :
Ts =>
g x0)
n x) (
fun x :
Ts =>
ce x))
(
fun x :
Ts =>
EventIndicator dec x))
(
rvmult
(
rvmult (
fun x :
Ts =>
simple_approx (
fun x0 :
Ts =>
g x0)
n x)
(
fun x :
Ts =>
ce x))
(
fun x :
Ts =>
EventIndicator dec x))).
{
intro x.
now rv_unfold;
unfold Rbar_rvmult;
simpl.
}
rewrite (
Rbar_Expectation_ext H11)
in H3.
rewrite <-
Expectation_Rbar_Expectation in H3.
rewrite Expectation_pos_pofrf with (
nnf := (
H10 n))
in H3.
now inversion H3.
}
clear H3.
cut_to H6.
-
rewrite Expectation_pos_pofrf with (
nnf :=
H7).
rewrite (
NNExpectation_Rbar_NNExpectation'
_ _ _).
rewrite <-
H6.
assert (
rv_eq
(
Rbar_rvmult (
Rbar_rvmult (
fun x :
Ts =>
g x) (
fun x :
Ts =>
ce x)) (
fun x :
Ts =>
EventIndicator dec x))
(
rvmult (
rvmult (
fun x :
Ts =>
g x) (
fun x :
Ts =>
ce x)) (
fun x :
Ts =>
EventIndicator dec x))).
{
intro x.
now rv_unfold;
unfold Rbar_rvmult;
simpl.
}
rewrite (
Rbar_Expectation_ext H3).
assert (
Rbar_NonnegativeFunction (
rvmult (
rvmult (
fun x :
Ts =>
g x) (
fun x :
Ts =>
ce x)) (
fun x :
Ts =>
EventIndicator dec x))).
{
apply NonNegMult.
-
typeclasses eauto.
-
apply NonNegMult;
trivial.
}
rewrite Rbar_Expectation_pos_pofrf with (
nnf :=
H12).
f_equal.
rewrite (
ELim_seq_ext _ _ H11).
generalize (
monotone_convergence_Rbar_rvlim
(
fun n =>
(
rvmult (
rvmult (
fun x :
Ts =>
simple_approx (
fun x0 :
Ts =>
g x0)
n x) (
fun x :
Ts =>
ce x))
(
fun x :
Ts =>
EventIndicator dec x))) );
intros.
assert (
forall n :
nat,
RandomVariable dom Rbar_borel_sa
(
fun omega :
Ts =>
rvmult
(
rvmult (
fun x :
Ts =>
simple_approx (
fun x0 :
Ts =>
g x0)
n x)
(
fun x :
Ts =>
ce x)) (
fun x :
Ts =>
EventIndicator dec x)
omega)).
{
intros.
apply Real_Rbar_rv.
apply rvmult_rv.
-
apply rvmult_rv.
+
apply simple_approx_rv;
trivial.
apply RandomVariable_sa_sub;
trivial.
now apply Real_Rbar_rv.
+
now apply RandomVariable_sa_sub;
trivial.
-
apply EventIndicator_pre_rv;
trivial.
apply sub.
apply H.
}
specialize (
H13 H14 H10).
cut_to H13.
+
rewrite H13.
apply Rbar_NonnegExpectation_ext.
intro x.
unfold Rbar_rvlim.
unfold rvmult.
replace (
Finite (
g x *
ce x *
EventIndicator dec x))
with
(
Rbar_mult ((
g x)*(
ce x)) (
EventIndicator dec x))
by now simpl.
rewrite Elim_seq_fin.
rewrite Lim_seq_scal_r.
f_equal.
replace (
Finite (
g x *
ce x))
with (
Rbar_mult (
g x) (
ce x))
by now simpl.
rewrite Lim_seq_scal_r.
f_equal.
specialize (
H0 x).
now apply is_lim_seq_unique in H0.
+
intros n x.
unfold rvmult.
apply Rmult_le_compat_r.
*
apply EventIndicator_pos.
*
apply Rmult_le_compat_r;
trivial.
now apply simple_approx_increasing.
-
intros n x.
unfold rvmult.
apply Rmult_le_compat_r.
+
apply EventIndicator_pos.
+
apply Rmult_le_compat_l;
trivial.
generalize (
simple_approx_le g nnegg n x);
intros.
apply H3.
-
intros n x.
unfold rvmult.
apply Rmult_le_compat_r.
+
apply EventIndicator_pos.
+
apply Rmult_le_compat_l;
trivial.
now apply simple_approx_increasing.
-
intros.
unfold rvmult.
replace (
Finite (
f omega *
g omega *
EventIndicator dec omega))
with
(
Rbar_mult (
f omega *
g omega) (
EventIndicator dec omega))
by now simpl.
rewrite is_Elim_seq_fin.
apply is_lim_seq_scal_r.
replace (
Finite (
f omega *
g omega))
with (
Rbar_mult (
f omega) (
g omega))
by now simpl.
apply is_lim_seq_scal_l.
apply H0.
Qed.
Lemma IsFiniteExpectation_abs f
{
rv :
RandomVariable dom borel_sa f} :
IsFiniteExpectation prts f ->
IsFiniteExpectation prts (
rvabs f).
Proof.
Lemma is_cond_rle_abs f ce ace
{
rvf :
RandomVariable dom borel_sa f}
{
rvce :
RandomVariable dom2 Rbar_borel_sa ce}
{
rvace :
RandomVariable dom2 Rbar_borel_sa ace} :
IsFiniteExpectation prts f ->
is_conditional_expectation dom2 f ce ->
is_conditional_expectation dom2 (
rvabs f)
ace ->
almostR2 prts Rbar_le (
Rbar_rvabs ce)
ace.
Proof.
Lemma Jensen (
rv_X :
Ts ->
R) (
phi :
R ->
R)
{
rv :
RandomVariable dom borel_sa rv_X}
{
isfe :
IsFiniteExpectation prts rv_X}
{
isfephi :
IsFiniteExpectation prts (
fun x =>
phi (
rv_X x))} :
(
forall c x y,
convex phi c x y) ->
FiniteExpectation prts (
fun x =>
phi (
rv_X x)) >=
phi (
FiniteExpectation prts rv_X).
Proof.
Lemma is_condexp_Jensen_helper (
rv_X ce phice:
Ts ->
R) (
phi :
R ->
R) (
a b :
nat ->
R)
{
rv :
RandomVariable dom borel_sa rv_X}
{
rvphi :
RandomVariable dom borel_sa (
fun x =>
phi (
rv_X x))}
{
rvce :
RandomVariable dom2 borel_sa ce}
{
rvace :
RandomVariable dom2 borel_sa phice}
{
isfe :
IsFiniteExpectation prts rv_X}
{
isfephi :
IsFiniteExpectation prts (
fun x =>
phi (
rv_X x))}
(
iscondce :
is_conditional_expectation dom2 rv_X ce)
(
iscond_phice :
is_conditional_expectation dom2 (
fun x =>
phi (
rv_X x))
phice) :
(
forall (
x:
R),
is_sup_seq (
fun n => (
a n) *
x + (
b n)) (
phi x)) ->
almostR2 (
prob_space_sa_sub prts sub)
Rbar_le
(
fun x =>
phi (
ce x))
phice.
Proof.
Lemma is_condexp_Jensen (
rv_X ce phice:
Ts ->
R) (
phi :
R ->
R)
{
rv :
RandomVariable dom borel_sa rv_X}
{
rvphi :
RandomVariable dom borel_sa (
fun x =>
phi (
rv_X x))}
{
rvce :
RandomVariable dom2 borel_sa ce}
{
rvace :
RandomVariable dom2 borel_sa phice}
{
isfe :
IsFiniteExpectation prts rv_X}
{
isfephi :
IsFiniteExpectation prts (
fun x =>
phi (
rv_X x))}
(
iscondce :
is_conditional_expectation dom2 rv_X ce)
(
iscond_phice :
is_conditional_expectation dom2 (
fun x =>
phi (
rv_X x))
phice) :
(
forall c x y,
convex phi c x y) ->
almostR2 (
prob_space_sa_sub prts sub)
Rbar_le
(
fun x =>
phi (
ce x))
phice.
Proof.
Lemma is_condexp_Jensen_abs (
rv_X ce ace :
Ts ->
R)
{
rv :
RandomVariable dom borel_sa rv_X}
{
rvce :
RandomVariable dom2 borel_sa ce}
{
rvace :
RandomVariable dom2 borel_sa ace}
{
isfe :
IsFiniteExpectation prts rv_X} :
is_conditional_expectation dom2 rv_X ce ->
is_conditional_expectation dom2 (
rvabs rv_X)
ace ->
almostR2 (
prob_space_sa_sub prts sub)
Rle
(
rvabs ce)
ace.
Proof.
Lemma Rbar_mult_le_compat_l (
r r1 r2 :
Rbar) :
Rbar_le 0
r ->
Rbar_le r1 r2 ->
Rbar_le (
Rbar_mult r r1) (
Rbar_mult r r2).
Proof.
Lemma Rbar_mult_le_compat_r (
r r1 r2 :
Rbar) :
Rbar_le 0
r ->
Rbar_le r1 r2 ->
Rbar_le (
Rbar_mult r1 r) (
Rbar_mult r2 r).
Proof.
Theorem is_conditional_expectation_factor_out_nneg
(
f g :
Ts ->
R)
(
ce ace :
Ts ->
R)
{
nnegg :
NonnegativeFunction g}
{
nnegace :
NonnegativeFunction ace}
{
rvf :
RandomVariable dom borel_sa f}
{
rvg :
RandomVariable dom2 borel_sa g}
{
rvce :
RandomVariable dom2 borel_sa ce}
{
rvace :
RandomVariable dom2 borel_sa ace}
{
rvgf:
RandomVariable dom borel_sa (
rvmult f g)}
{
rvgaf:
RandomVariable dom borel_sa (
rvmult (
rvabs f)
g)}
{
rvgce:
RandomVariable dom2 borel_sa (
rvmult g ce)} :
IsFiniteExpectation prts f ->
IsFiniteExpectation prts (
rvmult f g) ->
is_conditional_expectation dom2 f ce ->
is_conditional_expectation dom2 (
rvabs f)
ace ->
is_conditional_expectation dom2 (
rvmult f g) (
Rbar_rvmult g ce).
Proof.
intros.
generalize (
simple_approx_pofrf g);
intros.
generalize (
is_cond_rle_abs f ce ace H H1 H2);
intros.
assert (
forall n,
almostR2 prts Rle
(
rvabs (
rvmult (
simple_approx g n)
ce))
(
rvmult g ace)).
{
intros.
assert (
almostR2 prts Rle
(
rvabs (
rvmult (
simple_approx g n)
ce))
(
rvmult (
simple_approx g n)
ace)).
{
assert (
rv_eq
(
rvabs
(
rvmult (
simple_approx g n)
ce))
(
rvmult (
simple_approx g n) (
rvabs ce))).
-
intro x.
unfold rvabs,
rvmult.
rewrite Rabs_mult.
rewrite Rabs_right;
trivial.
simpl.
apply Rle_ge.
apply simple_approx_pofrf.
-
destruct H4 as [? [? ?]].
exists x;
split;
trivial;
intros.
specialize (
H6 x0 H7).
rewrite H5.
unfold rvmult.
apply Rmult_le_compat_l;
trivial.
apply simple_approx_pofrf.
}
assert (
almostR2 prts Rle
(
rvmult (
simple_approx g n)
ace)
(
rvmult g ace)).
{
apply all_almost;
intros x.
unfold rvmult.
apply Rmult_le_compat_r.
-
apply nnegace.
-
apply (
simple_approx_le g nnegg n).
}
eapply almostR2_trans.
-
apply Rle_pre.
-
apply H5.
-
apply H6.
}
generalize (
IsFiniteExpectation_abs f H);
intros.
generalize (
is_conditional_expectation_factor_out_nneg_both (
rvabs f)
g ace H6);
intros.
generalize (
IsFiniteExpectation_abs (
rvmult f g)
H0);
intros.
assert (
rv_eq
(
rvabs (
rvmult f g))
(
rvmult (
rvabs f)
g)).
{
intro x.
unfold rvabs,
rvmult.
rewrite Rabs_mult.
replace (
Rabs (
g x))
with (
g x);
trivial.
rewrite Rabs_right;
trivial.
apply Rle_ge.
apply nnegg.
}
rewrite H9 in H8.
specialize (
H7 H2).
unfold is_conditional_expectation;
intros.
assert (
rv_eq
(
Rbar_rvmult (
Rbar_rvmult (
fun x :
Ts =>
g x) (
fun x :
Ts =>
ce x))
(
fun x :
Ts =>
EventIndicator dec x))
(
rvmult (
rvmult g ce) (
EventIndicator dec))).
{
intro x.
unfold Rbar_rvmult,
rvmult.
now simpl.
}
rewrite (
Rbar_Expectation_ext H11).
rewrite <-
Expectation_Rbar_Expectation.
generalize (
Dominated_convergence_almost _
(
fun n =>
rvmult (
rvmult (
simple_approx g n)
ce) (
EventIndicator dec))
(
rvmult (
rvmult g ce) (
EventIndicator dec)) ) ;
intros.
assert (
rvg1 :
RandomVariable dom borel_sa g)
by now apply RandomVariable_sa_sub.
assert (
rvce1 :
RandomVariable dom borel_sa ce)
by now apply RandomVariable_sa_sub.
assert (
rvind :
RandomVariable dom borel_sa (
EventIndicator dec)).
{
apply EventIndicator_pre_rv.
now apply sub.
}
assert (
forall n :
nat,
RandomVariable
dom borel_sa
(
rvmult (
rvmult (
simple_approx g n)
ce)
(
EventIndicator dec))).
{
intros.
apply rvmult_rv;
trivial.
apply rvmult_rv;
trivial.
apply simple_approx_rv;
trivial.
now apply Real_Rbar_rv.
}
assert (
RandomVariable dom borel_sa
(
rvmult (
rvmult g ce)
(
EventIndicator dec))).
{
apply rvmult_rv;
trivial.
now apply rvmult_rv.
}
assert (
RandomVariable dom borel_sa
(
rvmult g ace)).
{
apply rvmult_rv;
trivial.
now apply RandomVariable_sa_sub.
}
assert (
IsFiniteExpectation prts
(
rvmult (
rvmult g ce)
(
EventIndicator dec))).
{
apply IsFiniteExpectation_indicator.
-
now apply rvmult_rv.
-
now apply sub.
-
apply (
IsFiniteExpectation_abs_bound_almost prts (
rvmult g ce) (
rvmult g ace)).
+
apply (
almost_impl'
_ H4);
intros.
apply all_almost;
intros.
unfold rvabs,
rvmult.
unfold rvabs in H16.
rewrite Rabs_mult.
rewrite Rabs_right.
*
now apply Rmult_le_compat_l.
*
now apply Rle_ge.
+
generalize (
is_conditional_expectation_FiniteExpectation (
rvmult (
rvabs f)
g) (
rvmult g ace )
H7 );
intros.
apply H16 in H8.
unfold Rbar_IsFiniteExpectation in H8.
rewrite <-
Expectation_Rbar_Expectation in H8.
apply H8.
}
assert (
forall n :
nat,
IsFiniteExpectation
prts
(
rvmult (
rvmult (
simple_approx g n)
ce)
(
EventIndicator dec))).
{
intro.
generalize (
simple_approx_rv g n);
intros.
assert (
RandomVariable dom borel_sa (
simple_approx (
fun x :
Ts =>
g x)
n))
by
now apply RandomVariable_sa_sub.
apply IsFiniteExpectation_indicator.
-
apply rvmult_rv;
trivial.
-
now apply sub.
-
rewrite rvmult_comm.
apply IsFiniteExpectation_mult_finite_range;
trivial.
+
apply simple_approx_frf.
+
generalize (
is_conditional_expectation_isfe f ce H1 H);
intros.
apply Rbar_finexp_finexp in H19.
assert (
rv_eq ce (
Rbar_finite_part ce)).
{
intro x.
now unfold Rbar_finite_part.
}
now rewrite <-
H20 in H19.
now apply Real_Rbar_rv.
}
rewrite FiniteExpectation_Expectation with (
isfe :=
H16).
assert (
isfe'1:
forall n :
nat,
Rbar_IsFiniteExpectation prts
(
fun omega :
Ts =>
rvmult (
rvmult (
simple_approx (
fun x :
Ts =>
g x)
n)
ce) (
EventIndicator dec)
omega)).
{
intros.
apply IsFiniteExpectation_Rbar.
typeclasses eauto.
}
assert (
isfe'2:
Rbar_IsFiniteExpectation prts (
rvmult (
rvmult g ce) (
EventIndicator dec))).
{
apply IsFiniteExpectation_Rbar;
typeclasses eauto.
}
specialize (
H12 (
rvmult g ace)
_ _ _ _ _).
clear H13 H14 H15.
cut_to H12.
apply is_lim_seq_unique in H12.
rewrite (
Rbar_FinExp_FinExp _)
in H12.
erewrite (
FiniteExpectation_pf_irrel _)
in H12.
rewrite <-
H12.
generalize (
Dominated_convergence _
(
fun n =>
rvmult (
rvmult f (
simple_approx g n)) (
EventIndicator dec))
(
rvmult (
rvmult f g) (
EventIndicator dec)));
intros.
assert (
forall n :
nat,
RandomVariable dom borel_sa
(
rvmult (
rvmult f (
simple_approx (
fun x :
Ts =>
g x)
n)) (
EventIndicator dec))).
{
intro.
apply rvmult_rv;
trivial.
apply rvmult_rv;
trivial.
apply simple_approx_rv;
trivial.
now apply Real_Rbar_rv.
}
assert (
RandomVariable dom borel_sa (
rvmult (
rvmult f g) (
EventIndicator dec)))
by
typeclasses eauto.
assert (
isfe'5:
forall n :
nat,
IsFiniteExpectation
prts
(
rvmult (
rvmult f (
simple_approx (
fun x :
Ts =>
g x)
n)) (
EventIndicator dec))).
{
intros.
apply IsFiniteExpectation_indicator.
-
apply rvmult_rv;
trivial.
apply simple_approx_rv;
trivial.
now apply Real_Rbar_rv.
-
now apply sub.
-
apply IsFiniteExpectation_mult_finite_range;
trivial.
apply simple_approx_rv;
trivial.
+
now apply Real_Rbar_rv.
+
apply simple_approx_frf.
}
assert (
forall n :
nat,
Rbar_IsFiniteExpectation
prts
(
rvmult (
rvmult f (
simple_approx (
fun x :
Ts =>
g x)
n)) (
EventIndicator dec))).
{
intros.
now apply IsFiniteExpectation_Rbar.
}
assert (
IsFiniteExpectation prts (
rvmult (
rvmult f g) (
EventIndicator dec))).
{
apply IsFiniteExpectation_indicator;
trivial.
now apply sub.
}
assert (
isfe'3:
Rbar_IsFiniteExpectation prts (
rvmult (
rvmult f g) (
EventIndicator dec))).
{
now apply IsFiniteExpectation_Rbar.
}
assert (
isfe'4:
Rbar_IsFiniteExpectation prts (
fun x :
Ts =>
rvmult (
rvabs f)
g x)).
{
now apply IsFiniteExpectation_Rbar.
}
specialize (
H13 (
rvmult (
rvabs f)
g)
_ _ _ _ _ _).
clear H14 H15.
cut_to H13.
apply is_lim_seq_unique in H13.
rewrite (
FiniteExpectation_Expectation _ _).
f_equal.
rewrite (
Rbar_FinExp_FinExp _)
in H13.
erewrite (
FiniteExpectation_pf_irrel _)
in H13.
rewrite <-
H13.
-
apply Lim_seq_ext.
intros.
generalize (
simple_approx_frf g);
intros.
generalize (
simple_approx_rv g);
intros.
generalize (
is_conditional_expectation_factor_out_frf
f (
simple_approx g n) );
intros.
assert (
RandomVariable dom borel_sa (
rvmult (
simple_approx (
fun x :
Ts =>
g x)
n)
f)).
{
apply rvmult_rv;
trivial.
apply simple_approx_rv;
trivial.
now apply Real_Rbar_rv.
}
assert (
RandomVariable dom2 Rbar_borel_sa
(
Rbar_rvmult (
fun x :
Ts =>
simple_approx (
fun x0 :
Ts =>
g x0)
n x)
(
fun x :
Ts =>
ce x))).
{
apply Rbar_rvmult_rv.
-
now apply Real_Rbar_rv.
-
now apply Real_Rbar_rv.
}
specialize (
H15 ce _ _ _ _ _ _ _ H1 P dec H10).
assert (
rv_eq
(
Rbar_rvmult
(
Rbar_rvmult (
fun x :
Ts =>
simple_approx (
fun x0 :
Ts =>
g x0)
n x)
(
fun x :
Ts =>
ce x)) (
fun x :
Ts =>
EventIndicator dec x))
(
rvmult
(
rvmult (
fun x :
Ts =>
simple_approx (
fun x0 :
Ts =>
g x0)
n x)
(
fun x :
Ts =>
ce x)) (
fun x :
Ts =>
EventIndicator dec x))).
{
intro x.
unfold Rbar_rvmult,
rvmult.
now simpl.
}
rewrite (
Rbar_Expectation_ext H22)
in H15.
rewrite <-
Expectation_Rbar_Expectation in H15.
assert (
rv_eq
(
rvmult (
rvmult (
simple_approx (
fun x :
Ts =>
g x)
n)
f) (
EventIndicator dec))
(
rvmult (
rvmult f (
simple_approx (
fun x :
Ts =>
g x)
n) ) (
EventIndicator dec)))
by (
intro x;
unfold rvmult;
lra).
rewrite (
Expectation_ext H23)
in H15.
rewrite (
FiniteExpectation_Expectation _ _)
in H15.
clear H9 H11 H12 H13 H14 H20 H21 H22 H23.
assert (
IsFiniteExpectation prts
(@
rvmult Ts
(@
rvmult Ts (
fun x :
Ts => @
simple_approx Ts (
fun x0 :
Ts =>
Finite (
g x0))
n x)
(
fun x :
Ts =>
ce x)) (
fun x :
Ts => @
EventIndicator Ts P dec x)))
by easy.
rewrite FiniteExpectation_Expectation with (
isfe :=
H9)
in H15.
invcs H15.
unfold Rbar_FiniteExpectation,
proj1_sig.
repeat match_destr.
unfold FiniteExpectation,
proj1_sig in H12.
repeat match_destr_in H12.
rewrite Expectation_Rbar_Expectation in e1,
e2.
rewrite e1 in e.
simpl in e2.
cut (
Some (
Finite x0) =
Some (
Finite x2));
try congruence.
rewrite <-
e2, <-
e0.
apply Rbar_Expectation_ext;
intros ?.
reflexivity.
-
intros n x.
generalize (
simple_approx_le g nnegg n x);
intros.
unfold rvmult,
rvabs,
EventIndicator.
simpl.
match_destr.
+
rewrite Rmult_1_r.
rewrite Rabs_mult.
apply Rmult_le_compat_l.
*
apply Rabs_pos.
*
rewrite Rabs_right;
trivial.
apply Rle_ge.
apply simple_approx_pofrf.
+
rewrite Rmult_0_r.
rewrite Rabs_R0.
apply Rmult_le_pos;
trivial.
apply Rabs_pos.
-
intro.
unfold rvmult.
apply is_Elim_seq_fin.
apply is_lim_seq_mult'.
+
apply is_lim_seq_mult'.
*
apply is_lim_seq_const.
*
now generalize (
simple_approx_lim_seq g nnegg x);
intros.
+
apply is_lim_seq_const.
-
generalize (
is_conditional_expectation_FiniteExpectation _ _ H7);
intros.
generalize (
IsFiniteExpectation_abs (
rvmult f g)
H0);
intros.
rewrite H9 in H14.
apply H13 in H14.
assert (
rv_eq (
Rbar_rvmult (
fun x :
Ts =>
g x) (
fun x :
Ts =>
ace x))
(
rvmult (
fun x :
Ts =>
g x) (
fun x :
Ts =>
ace x))).
{
intro x.
now unfold Rbar_rvmult,
rvmult.
}
rewrite H15 in H14.
apply H14.
-
intros n.
generalize (
is_conditional_expectation_nneg (
rvabs f)
ace H2);
intros.
apply almost_prob_space_sa_sub_lift in H13.
generalize (
almost_and prts H4 H13);
intros.
apply (
almost_impl'
_ H14);
intros.
apply all_almost;
intros.
destruct H15.
unfold rvabs,
Rbar_rvmult,
rvmult,
EventIndicator.
simpl.
match_destr.
+
rewrite Rmult_1_r.
rewrite Rabs_mult.
apply Rmult_le_compat.
*
apply Rabs_pos.
*
apply Rabs_pos.
*
rewrite Rabs_right.
--
generalize (
simple_approx_le g nnegg n x);
intros.
apply H19.
--
apply Rle_ge.
apply simple_approx_pofrf.
*
apply H15.
+
rewrite Rmult_0_r.
rewrite Rabs_R0.
apply Rmult_le_pos.
*
apply nnegg.
*
apply H18.
-
apply all_almost;
intros.
unfold rvmult.
apply is_Elim_seq_fin.
apply is_lim_seq_mult'.
+
apply is_lim_seq_mult'.
*
now generalize (
simple_approx_lim_seq g nnegg x).
*
apply is_lim_seq_const.
+
apply is_lim_seq_const.
Qed.
Theorem is_conditional_expectation_factor_out
(
f g ce ace :
Ts ->
R)
{
nnegace :
NonnegativeFunction ace}
{
rvf :
RandomVariable dom borel_sa f}
{
rvg :
RandomVariable dom2 borel_sa g}
{
rvce :
RandomVariable dom2 borel_sa ce}
{
rvace :
RandomVariable dom2 borel_sa ace}
{
rvgf:
RandomVariable dom borel_sa (
rvmult f g)} :
IsFiniteExpectation prts f ->
IsFiniteExpectation prts (
rvmult f g) ->
is_conditional_expectation dom2 f ce ->
is_conditional_expectation dom2 (
rvabs f)
ace ->
is_conditional_expectation dom2 (
rvmult f g) (
Rbar_rvmult g ce).
Proof.
Lemma is_conditional_expectation_monotone_convergence
(
f :
Ts ->
R )
(
ce :
Ts ->
Rbar )
(
fn :
nat ->
Ts ->
R)
(
cen :
nat ->
Ts ->
Rbar)
(
rvf :
RandomVariable dom borel_sa f)
{
rvce :
RandomVariable dom2 Rbar_borel_sa ce}
(
nnf:
NonnegativeFunction f)
(
nnce:
Rbar_NonnegativeFunction ce)
(
rvfn :
forall n,
RandomVariable dom borel_sa (
fn n))
(
nnfn :
forall n,
NonnegativeFunction (
fn n))
(
nncen :
forall n,
Rbar_NonnegativeFunction (
cen n))
(
rvcen :
forall n,
RandomVariable dom2 Rbar_borel_sa (
cen n))
:
(
forall (
n:
nat),
Rbar_rv_le (
fn n)
f) ->
(
forall (
n:
nat),
rv_le (
fn n) (
fn (
S n))) ->
(
forall (
n:
nat),
Rbar_rv_le (
cen n)
ce) ->
(
forall (
n:
nat),
Rbar_rv_le (
cen n) (
cen (
S n))) ->
(
forall (
omega:
Ts),
is_Elim_seq (
fun n =>
fn n omega) (
f omega)) ->
(
forall (
omega:
Ts),
is_Elim_seq (
fun n =>
cen n omega) (
ce omega)) ->
(
forall (
n:
nat),
is_conditional_expectation dom2 (
fn n) (
cen n)) ->
is_conditional_expectation dom2 f ce.
Proof.
Lemma is_conditional_expectation_monotone_convergence_almost
(
f :
Ts ->
R )
(
ce :
Ts ->
Rbar )
(
fn :
nat ->
Ts ->
R)
(
cen :
nat ->
Ts ->
Rbar)
(
rvf :
RandomVariable dom borel_sa f)
{
rvce :
RandomVariable dom2 Rbar_borel_sa ce}
(
nnf:
almostR2 prts Rle (
const 0)
f)
(
nnce:
almostR2 (
prob_space_sa_sub prts sub)
Rbar_le (
const 0)
ce)
(
rvfn :
forall n,
RandomVariable dom borel_sa (
fn n))
(
nnfn :
forall n,
almostR2 prts Rle (
const 0) (
fn n))
(
nncen :
forall n,
almostR2 (
prob_space_sa_sub prts sub)
Rbar_le (
const 0) (
cen n))
(
rvcen :
forall n,
RandomVariable dom2 Rbar_borel_sa (
cen n))
:
(
forall (
n:
nat),
almostR2 prts Rle (
fn n)
f) ->
(
forall (
n:
nat),
almostR2 prts Rle (
fn n) (
fn (
S n))) ->
(
forall (
n:
nat),
almostR2 (
prob_space_sa_sub prts sub)
Rbar_le (
cen n)
ce) ->
(
forall (
n:
nat),
almostR2 (
prob_space_sa_sub prts sub)
Rbar_le (
cen n) (
cen (
S n))) ->
(
almost prts (
fun omega =>
is_Elim_seq (
fun n =>
fn n omega) (
f omega))) ->
(
almost (
prob_space_sa_sub prts sub) (
fun (
omega:
Ts) =>
is_Elim_seq (
fun n =>
cen n omega) (
ce omega))) ->
(
forall (
n:
nat),
is_conditional_expectation dom2 (
fn n) (
cen n)) ->
is_conditional_expectation dom2 f ce.
Proof.
intros fnbound fnincr cenbound cenincr flim celim iscen.
apply almost_forall in nnfn.
apply almost_forall in nncen.
apply almost_forall in fnbound.
apply almost_forall in fnincr.
apply almost_forall in cenbound.
apply almost_forall in cenincr.
generalize (
almost_and _ nnf (
almost_and _ nnfn (
almost_and _ fnbound (
almost_and _ fnincr flim))))
;
intros almostf.
generalize (
almost_and _ nnce (
almost_and _ nncen (
almost_and _ cenbound (
almost_and _ cenincr celim))));
intros almostce.
destruct almostf as [
pf [
pfone pfH]].
destruct almostce as [
pce [
pceone pceH]].
pose (
f' :=
(
rvchoice (
fun x =>
if Req_EM_T (((
EventIndicator (
classic_dec pf)))
x) 0
then false else true)
f
(
const 0)
)).
pose (
ce' :=
(
Rbar_rvchoice (
fun x =>
if Req_EM_T (((
EventIndicator (
classic_dec pce)))
x) 0
then false else true)
ce
(
const (
Finite 0))
)).
pose (
fn' :=
fun n =>
(
rvchoice (
fun x =>
if Req_EM_T (((
EventIndicator (
classic_dec pf)))
x) 0
then false else true)
(
fn n)
(
const 0)
)).
pose (
cen' :=
fun n =>
(
Rbar_rvchoice (
fun x =>
if Req_EM_T (((
EventIndicator (
classic_dec pce)))
x) 0
then false else true)
(
cen n)
(
const (
Finite 0))
)).
assert (
feqq:
almostR2 prts eq f'
f).
{
exists pf.
split;
trivial.
intros.
unfold f',
EventIndicator,
rvchoice.
destruct (
classic_dec pf x);
try tauto.
destruct (
Req_EM_T 1 0);
try lra.
}
assert (
ceeqq:
almostR2 (
prob_space_sa_sub prts sub)
eq ce'
ce).
{
exists pce.
split;
trivial.
intros.
unfold ce',
EventIndicator,
Rbar_rvchoice.
destruct (
classic_dec pce x);
try tauto.
now destruct (
Req_EM_T 1 0);
try lra.
}
assert (
fneqq:
forall n,
almostR2 prts eq (
fn'
n) (
fn n)).
{
intros.
exists pf.
split;
trivial.
intros.
unfold fn',
EventIndicator,
rvchoice.
destruct (
classic_dec pf x);
try tauto.
destruct (
Req_EM_T 1 0);
try lra.
}
assert (
ceneqq:
forall n,
almostR2 (
prob_space_sa_sub prts sub)
eq (
cen'
n) (
cen n)).
{
intros.
exists pce.
split;
trivial.
intros.
unfold cen',
EventIndicator,
Rbar_rvchoice.
destruct (
classic_dec pce x);
try tauto.
now destruct (
Req_EM_T 1 0);
try lra.
}
assert (
rvf' :
RandomVariable dom borel_sa f').
{
unfold f'.
apply rvchoice_rv;
trivial;
typeclasses eauto.
}
assert (
rvce' :
RandomVariable dom2 Rbar_borel_sa ce').
{
unfold ce'.
apply Rbar_rvchoice_rv;
trivial;
typeclasses eauto.
}
assert (
rvfn' :
forall n,
RandomVariable dom borel_sa (
fn'
n)).
{
intros.
unfold fn'.
apply rvchoice_rv;
trivial;
typeclasses eauto.
}
assert (
rvcen' :
forall n,
RandomVariable dom2 Rbar_borel_sa (
cen'
n)).
{
intros.
unfold cen'.
apply Rbar_rvchoice_rv;
trivial;
typeclasses eauto.
}
cut (
is_conditional_expectation dom2 f'
ce').
{
apply is_conditional_expectation_proper;
trivial.
eapply almost_prob_space_sa_sub_lift;
eauto.
}
assert (
iscen' :
forall n :
nat,
is_conditional_expectation dom2 (
fn'
n) (
cen'
n)).
{
intros.
generalize (
iscen n).
apply is_conditional_expectation_proper.
-
now symmetry.
-
symmetry.
eapply almost_prob_space_sa_sub_lift.
apply ceneqq.
}
eapply (@
is_conditional_expectation_monotone_convergence _ _ fn'
cen')
;
unfold f',
fn',
ce',
cen',
rvchoice,
Rbar_rvchoice,
EventIndicator,
const,
pre_inter_of_collection in *
;
repeat intros ?
;
try (
destruct (
classic_dec _ _)
;
destruct (
Req_EM_T _ _);
try lra
;
try destruct (
pfH _ e)
as [? [? [? [??]]]]
;
try destruct (
pceH _ e)
as [? [? [? [??]]]]
;
simpl;
trivial
;
try apply Rbar_le_refl
;
try apply Rle_refl
;
try apply is_Elim_seq_const).
-
apply H0.
-
now apply iscen'.
Qed.
End is_cond_exp.
Section is_cond_exp_props.
Context {
Ts:
Type}
{
dom:
SigmaAlgebra Ts}
(
prts:
ProbSpace dom)
{
dom2 :
SigmaAlgebra Ts}
(
sub :
sa_sub dom2 dom)
{
dom3 :
SigmaAlgebra Ts}
(
sub2 :
sa_sub dom3 dom2).
Theorem is_conditional_expectation_tower
(
f ce1:
Ts ->
R)
(
ce2:
Ts ->
Rbar)
{
rvf :
RandomVariable dom borel_sa f}
{
rvce1 :
RandomVariable dom2 borel_sa ce1}
{
rvce1' :
RandomVariable dom borel_sa ce1}
{
rvce2 :
RandomVariable dom3 Rbar_borel_sa ce2}
:
is_conditional_expectation prts dom2 f (
fun x =>
ce1 x) ->
is_conditional_expectation prts dom3 f ce2 ->
is_conditional_expectation prts dom3 ce1 ce2.
Proof.
End is_cond_exp_props.
Section cond_exp_l2.
Context {
Ts:
Type}
{
dom:
SigmaAlgebra Ts}
(
prts:
ProbSpace dom)
{
dom2 :
SigmaAlgebra Ts}
(
sub :
sa_sub dom2 dom).
Definition conditional_expectation_L2q
(
x:
LpRRVq prts 2)
: {
v :
L2RRVq_PreHilbert prts
|
unique
(
fun v :
L2RRVq_PreHilbert prts =>
ortho_phi prts dom2 v /\
norm (
minus (
G:=(
PreHilbert.AbelianGroup (
L2RRVq_PreHilbert prts)))
x v) =
Glb_Rbar (
fun r :
R =>
exists w :
L2RRVq_PreHilbert prts,
ortho_phi prts dom2 w /\
r =
norm (
minus (
G:=(
PreHilbert.AbelianGroup (
L2RRVq_PreHilbert prts)))
x w)))
v}.
Proof.
Let nneg2 :
nonnegreal :=
bignneg 2
big2.
Canonical nneg2.
Definition conditional_expectation_L2 (
f :
LpRRV prts 2) :
{
v :
LpRRV prts 2
|
RandomVariable dom2 borel_sa v /\
LpRRVnorm prts (
LpRRVminus prts f v) =
Glb_Rbar (
fun r :
R =>
exists w :
LpRRV prts 2,
RandomVariable dom2 borel_sa (
LpRRV_rv_X prts w) /\
r =
LpRRVnorm prts (
LpRRVminus prts f w)) /\
(
forall w:
LpRRV prts 2,
RandomVariable dom2 borel_sa w ->
L2RRVinner prts (
LpRRVminus prts f v) (
LpRRVminus prts w v) <= 0) /\
(
forall w:
LpRRV prts 2,
RandomVariable dom2 borel_sa w ->
L2RRVinner prts v w =
L2RRVinner prts (
pack_LpRRV prts f)
w) /\
(
forall z:
LpRRV prts 2,
RandomVariable dom2 borel_sa z ->
(
LpRRVnorm prts (
LpRRVminus prts f z) =
Glb_Rbar (
fun r :
R =>
exists w :
LpRRV prts 2,
RandomVariable dom2 borel_sa (
LpRRV_rv_X prts w) /\
r =
LpRRVnorm prts (
LpRRVminus prts f w))) ->
LpRRV_eq prts z v) /\
(
forall z:
LpRRV prts 2,
RandomVariable dom2 borel_sa z ->
(
forall w:
LpRRV prts 2,
RandomVariable dom2 borel_sa w ->
L2RRVinner prts (
LpRRVminus prts f z) (
LpRRVminus prts w z) <= 0) ->
LpRRV_eq prts z v) /\
(
forall z:
LpRRV prts 2,
RandomVariable dom2 borel_sa z ->
(
forall w:
LpRRV prts 2,
RandomVariable dom2 borel_sa w ->
L2RRVinner prts z w =
L2RRVinner prts (
pack_LpRRV prts f)
w) ->
LpRRV_eq prts z v)
}.
Proof.
destruct ((
conditional_expectation_L2q (
Quot _ f))).
destruct u as [[
HH1 HH2]
HH3].
destruct (
charac_ortho_projection_subspace1 _ (
ortho_phi_compatible_m _ sub) (
Quot (
LpRRV_eq prts)
f)
_ HH1)
as [
cops1_f _].
destruct (
charac_ortho_projection_subspace2 _ (
ortho_phi_compatible_m _ sub) (
Quot (
LpRRV_eq prts)
f)
_ HH1)
as [
cops2_f _].
specialize (
cops1_f HH2).
specialize (
cops2_f HH2).
red in HH1.
apply constructive_indefinite_description in HH1.
destruct HH1 as [
y [
eqqy rvy]].
exists y.
split;
trivial.
subst.
unfold norm,
minus,
plus,
opp in *;
simpl in *.
rewrite L2RRVq_norm_norm in HH2.
autorewrite with quot in HH2.
rewrite LpRRVq_normE in HH2.
rewrite LpRRVminus_plus.
unfold nonneg in HH2 |- *;
simpl in *.
rewrite HH2.
assert (
glb_eq:
Glb_Rbar
(
fun r :
R =>
exists w :
LpRRVq prts 2,
ortho_phi prts dom2 w /\
r =
Hnorm (
LpRRVq_plus prts (
Quot (
LpRRV_eq prts)
f) (
LpRRVq_opp prts w)))
=
Glb_Rbar
(
fun r :
R =>
exists w :
LpRRV prts 2,
RandomVariable dom2 borel_sa w /\
r =
LpRRVnorm prts (
LpRRVminus prts f w))).
{
apply Glb_Rbar_eqset;
intros.
split;
intros [
w [
wrv wnorm]].
+
rewrite L2RRVq_norm_norm in wnorm.
destruct wrv as [
w' [?
rvw']];
subst.
exists w'.
split;
trivial.
autorewrite with quot.
rewrite LpRRVq_normE.
now rewrite LpRRVminus_plus.
+
subst.
exists (
Quot _ w).
split.
*
exists w.
split;
trivial.
*
rewrite L2RRVq_norm_norm.
autorewrite with quot.
rewrite LpRRVq_normE.
now rewrite LpRRVminus_plus.
}
repeat split.
-
now f_equal.
-
intros.
specialize (
cops1_f (
Quot _ w)).
cut_to cops1_f.
+
unfold inner in cops1_f;
simpl in cops1_f.
LpRRVq_simpl.
rewrite L2RRVq_innerE in cops1_f.
etransitivity;
try eapply cops1_f.
right.
apply L2RRV_inner_proper.
*
apply LpRRV_seq_eq;
intros ?;
simpl.
rv_unfold;
lra.
*
apply LpRRV_seq_eq;
intros ?;
simpl.
rv_unfold;
lra.
+
red;
eauto.
-
intros.
specialize (
cops2_f (
Quot _ w)).
cut_to cops2_f.
+
unfold inner in cops2_f;
simpl in cops2_f.
repeat rewrite L2RRVq_innerE in cops2_f.
apply cops2_f.
+
red;
eauto.
-
intros x xrv xeqq.
specialize (
HH3 (
Quot _ x)).
cut_to HH3.
+
apply Quot_inj in HH3;
try typeclasses eauto.
now symmetry.
+
split.
*
unfold ortho_phi.
eauto.
*
rewrite L2RRVq_norm_norm.
autorewrite with quot.
rewrite LpRRVq_normE.
rewrite <-
LpRRVminus_plus.
unfold nonneg in *;
simpl in *.
rewrite xeqq.
symmetry.
now f_equal.
-
intros x xrv xeqq.
specialize (
HH3 (
Quot _ x)).
cut_to HH3.
+
apply Quot_inj in HH3;
try typeclasses eauto.
now symmetry.
+
split.
*
unfold ortho_phi.
eauto.
*
destruct (
charac_ortho_projection_subspace1 _
(
ortho_phi_compatible_m _ sub)
(
Quot (
LpRRV_eq prts)
f)
(
Quot _ x))
as [
_ cops1_b].
--
red;
eauto.
--
apply cops1_b;
intros.
destruct H as [
z [?
rvz]];
subst.
specialize (
xeqq _ rvz).
etransitivity;
try eapply xeqq.
right.
unfold inner,
minus,
plus,
opp;
simpl.
LpRRVq_simpl.
rewrite L2RRVq_innerE.
apply L2RRV_inner_proper.
++
now rewrite <-
LpRRVminus_plus.
++
now rewrite <-
LpRRVminus_plus.
-
intros x xrv xeqq.
specialize (
HH3 (
Quot _ x)).
cut_to HH3.
+
apply Quot_inj in HH3;
try typeclasses eauto.
now symmetry.
+
split.
*
unfold ortho_phi.
eauto.
*
destruct (
charac_ortho_projection_subspace2 _
(
ortho_phi_compatible_m _ sub)
(
Quot (
LpRRV_eq prts)
f)
(
Quot _ x))
as [
_ cops2_b].
--
red;
eauto.
--
apply cops2_b;
intros.
destruct H as [
z [?
rvz]];
subst.
specialize (
xeqq _ rvz).
unfold inner,
minus,
plus,
opp;
simpl.
repeat rewrite L2RRVq_innerE.
rewrite xeqq.
apply L2RRV_inner_proper;
try reflexivity.
now apply LpRRV_seq_eq;
intros ?;
simpl.
Qed.
Definition conditional_expectation_L2fun (
f :
Ts ->
R)
{
rv :
RandomVariable dom borel_sa f}
{
isl :
IsLp prts 2
f} :
LpRRV prts 2
:=
proj1_sig (
conditional_expectation_L2 (
pack_LpRRV prts f)).
Instance conditional_expectation_L2fun_rv
(
f :
Ts ->
R)
{
rv :
RandomVariable dom borel_sa f}
{
isl :
IsLp prts 2
f} :
RandomVariable dom2 borel_sa (
conditional_expectation_L2fun f).
Proof.
Instance conditional_expectation_L2fun_L2
(
f :
Ts ->
R)
{
rv :
RandomVariable dom borel_sa f}
{
isl :
IsLp prts 2
f} :
IsLp prts 2 (
conditional_expectation_L2fun f).
Proof.
Lemma conditional_expectation_L2fun_eq
(
f :
Ts ->
R)
{
rv :
RandomVariable dom borel_sa f}
{
isl :
IsLp prts 2
f} :
LpRRVnorm prts (
LpRRVminus prts (
pack_LpRRV prts f) (
conditional_expectation_L2fun f)) =
Glb_Rbar
(
fun r :
R =>
exists w :
LpRRV prts 2,
RandomVariable dom2 borel_sa w /\
r =
LpRRVnorm prts (
LpRRVminus prts (
pack_LpRRV prts f)
w)).
Proof.
Lemma conditional_expectation_L2fun_eq_finite
(
f :
Ts ->
R)
{
rv :
RandomVariable dom borel_sa f}
{
isl :
IsLp prts 2
f} :
is_finite (
Glb_Rbar
(
fun r :
R =>
exists w :
LpRRV prts 2,
RandomVariable dom2 borel_sa w /\
r =
LpRRVnorm prts (
LpRRVminus prts (
pack_LpRRV prts f)
w))).
Proof.
Lemma conditional_expectation_L2fun_eq1
(
f :
Ts ->
R)
{
rv :
RandomVariable dom borel_sa f}
{
isl :
IsLp prts 2
f} :
(
forall w:
LpRRV prts 2,
RandomVariable dom2 borel_sa w ->
L2RRVinner prts (
LpRRVminus prts (
pack_LpRRV prts f) (
conditional_expectation_L2fun f)) (
LpRRVminus prts w (
conditional_expectation_L2fun f)) <= 0).
Proof.
Lemma conditional_expectation_L2fun_eq2
(
f :
Ts ->
R)
{
rv :
RandomVariable dom borel_sa f}
{
isl :
IsLp prts 2
f} :
(
forall w:
LpRRV prts 2,
RandomVariable dom2 borel_sa w ->
L2RRVinner prts (
conditional_expectation_L2fun f)
w =
L2RRVinner prts (
pack_LpRRV prts f)
w).
Proof.
Lemma conditional_expectation_L2fun_eq3
(
f :
Ts ->
R)
{
rv :
RandomVariable dom borel_sa f}
{
isl :
IsLp prts 2
f} :
is_conditional_expectation prts dom2 f (
fun x => (
conditional_expectation_L2fun f)
x).
Proof.
Lemma conditional_expectation_L2fun_unique
(
f :
Ts ->
R)
{
rv :
RandomVariable dom borel_sa f}
{
isl :
IsLp prts 2
f}
(
z:
LpRRV prts 2)
{
z_rv:
RandomVariable dom2 borel_sa z} :
(
LpRRVnorm prts (
LpRRVminus prts (
pack_LpRRV prts f)
z) =
Glb_Rbar (
fun r :
R =>
exists w :
LpRRV prts 2,
RandomVariable dom2 borel_sa (
LpRRV_rv_X prts w) /\
r =
LpRRVnorm prts (
LpRRVminus prts (
pack_LpRRV prts f)
w))) ->
LpRRV_eq prts z (
conditional_expectation_L2fun f).
Proof.
Lemma conditional_expectation_L2fun_unique1
(
f :
Ts ->
R)
{
rv :
RandomVariable dom borel_sa f}
{
isl :
IsLp prts 2
f}
(
z:
LpRRV prts 2)
{
z_rv:
RandomVariable dom2 borel_sa z} :
(
forall w:
LpRRV prts 2,
RandomVariable dom2 borel_sa w ->
L2RRVinner prts (
LpRRVminus prts (
pack_LpRRV prts f)
z) (
LpRRVminus prts w z) <= 0) ->
LpRRV_eq prts z (
conditional_expectation_L2fun f).
Proof.
Lemma conditional_expectation_L2fun_unique2
(
f :
Ts ->
R)
{
rv :
RandomVariable dom borel_sa f}
{
isl :
IsLp prts 2
f}
(
z:
LpRRV prts 2)
{
z_rv:
RandomVariable dom2 borel_sa z} :
(
forall w:
LpRRV prts 2,
RandomVariable dom2 borel_sa w ->
L2RRVinner prts z w =
L2RRVinner prts (
pack_LpRRV prts f)
w) ->
LpRRV_eq prts z (
conditional_expectation_L2fun f).
Proof.
Lemma conditional_expectation_L2fun_const
(
c :
R) :
LpRRV_eq prts
(
LpRRVconst prts c)
(
conditional_expectation_L2fun (
const c)).
Proof.
Instance IsLp_min_const_nat (
f :
Ts ->
R) (
n :
nat)
{
nneg :
NonnegativeFunction f} :
IsLp prts 2 (
rvmin f (
const (
INR n))).
Proof.
Lemma conditional_expectation_L2fun_proper (
f1 f2 :
Ts ->
R)
{
rv1 :
RandomVariable dom borel_sa f1}
{
rv2 :
RandomVariable dom borel_sa f2}
{
isl1 :
IsLp prts 2
f1}
{
isl2 :
IsLp prts 2
f2} :
almostR2 prts eq f1 f2 ->
LpRRV_eq prts
(
conditional_expectation_L2fun f1)
(
conditional_expectation_L2fun f2).
Proof.
Lemma conditional_expectation_L2fun_nonneg (
f :
Ts ->
R)
{
rv :
RandomVariable dom borel_sa f}
{
isl :
IsLp prts 2
f}
{
nneg:
NonnegativeFunction f} :
almostR2 (
prob_space_sa_sub prts sub)
Rle (
const 0) (
conditional_expectation_L2fun f).
Proof.
Lemma conditional_expectation_L2fun_nonneg_prts (
f :
Ts ->
R)
{
rv :
RandomVariable dom borel_sa f}
{
isl :
IsLp prts 2
f}
{
nneg:
NonnegativeFunction f} :
almostR2 prts Rle (
const 0) (
conditional_expectation_L2fun f).
Proof.
Local Existing Instance Rbar_le_pre.
Lemma conditional_expectation_L2fun_plus f1 f2
{
rv1 :
RandomVariable dom borel_sa f1}
{
rv2 :
RandomVariable dom borel_sa f2}
{
isl1 :
IsLp prts 2
f1}
{
isl2 :
IsLp prts 2
f2} :
LpRRV_eq prts
(
conditional_expectation_L2fun (
rvplus f1 f2))
(
LpRRVplus prts (
conditional_expectation_L2fun f1) (
conditional_expectation_L2fun f2)).
Proof.
End cond_exp_l2.
Section cond_exp2.
Context {
Ts:
Type}
{
dom:
SigmaAlgebra Ts}
(
prts:
ProbSpace dom)
{
dom2 :
SigmaAlgebra Ts}
(
sub :
sa_sub dom2 dom).
Lemma conditional_expectation_L2fun_le (
f1 f2 :
Ts ->
R)
{
rv1 :
RandomVariable dom borel_sa f1}
{
rv2 :
RandomVariable dom borel_sa f2}
{
isl1 :
IsLp prts 2
f1}
{
isl2 :
IsLp prts 2
f2} :
rv_le f1 f2 ->
almostR2 (
prob_space_sa_sub prts sub)
Rle (
conditional_expectation_L2fun prts sub f1)
(
conditional_expectation_L2fun prts sub f2).
Proof.
Lemma conditional_expectation_L2fun_le_prts (
f1 f2 :
Ts ->
R)
{
rv1 :
RandomVariable dom borel_sa f1}
{
rv2 :
RandomVariable dom borel_sa f2}
{
isl1 :
IsLp prts 2
f1}
{
isl2 :
IsLp prts 2
f2} :
rv_le f1 f2 ->
almostR2 prts Rle (
conditional_expectation_L2fun prts sub f1)
(
conditional_expectation_L2fun prts sub f2).
Proof.
Local Existing Instance Rbar_le_pre.
Local Existing Instance IsLp_min_const_nat.
Local Existing Instance conditional_expectation_L2fun_rv.
Definition NonNegConditionalExpectation (
f :
Ts ->
R)
{
rv :
RandomVariable dom borel_sa f}
{
nnf :
NonnegativeFunction f} :
Ts ->
Rbar :=
Rbar_rvlim (
fun n =>
LpRRV_rv_X _ (
conditional_expectation_L2fun prts sub (
rvmin f (
const (
INR n))))).
Lemma NonNegCondexp_almost_increasing (
f :
Ts ->
R)
{
rv :
RandomVariable dom borel_sa f}
{
nnf :
NonnegativeFunction f} :
almost (
prob_space_sa_sub prts sub)
(
fun x =>
forall n,
conditional_expectation_L2fun prts sub (
rvmin f (
const (
INR n)))
x
<=
conditional_expectation_L2fun prts sub (
rvmin f (
const (
INR (
S n))))
x).
Proof.
Lemma NonNegCondexp_almost_increasing_prts (
f :
Ts ->
R)
{
rv :
RandomVariable dom borel_sa f}
{
nnf :
NonnegativeFunction f} :
almost prts
(
fun x =>
forall n,
conditional_expectation_L2fun prts sub (
rvmin f (
const (
INR n)))
x
<=
conditional_expectation_L2fun prts sub (
rvmin f (
const (
INR (
S n))))
x).
Proof.
Lemma almost_Rbar_rvlim_condexp_incr_indicator_rv (
f :
Ts ->
R)
{
rv :
RandomVariable dom borel_sa f}
{
nnf :
NonnegativeFunction f}
(
E :
event dom2) :
ps_P (
ProbSpace:=(
prob_space_sa_sub prts sub))
E = 1 ->
(
forall x0 :
Ts,
E x0 ->
forall n :
nat,
conditional_expectation_L2fun prts sub (
rvmin f (
const (
INR n)))
x0 <=
conditional_expectation_L2fun prts sub (
rvmin f (
const (
INR (
S n))))
x0) ->
(
RandomVariable
dom2 Rbar_borel_sa
(
Rbar_rvlim
(
fun n0 :
nat =>
rvmult (
conditional_expectation_L2fun prts sub (
rvmin f (
const (
INR n0))))
(
EventIndicator (
classic_dec E))))).
Proof.
Lemma NonNegCondexp_almost_nonneg (
f :
Ts ->
R)
{
rv :
RandomVariable dom borel_sa f}
{
nnf :
NonnegativeFunction f} :
almostR2 (
prob_space_sa_sub prts sub)
Rbar_le (
const 0) (
NonNegConditionalExpectation f).
Proof.
Lemma NonNegCondexp_almost_nonneg_prts (
f :
Ts ->
R)
{
rv :
RandomVariable dom borel_sa f}
{
nnf :
NonnegativeFunction f} :
almostR2 prts Rbar_le (
const 0) (
NonNegConditionalExpectation f).
Proof.
Lemma rvlim_rvmin_indicator (
f :
Ts ->
R) (
P:
pre_event Ts) (
dec:
dec_pre_event P) :
rv_eq (
fun x=>
Finite (
rvmult f (
EventIndicator dec)
x))
(
Rbar_rvlim (
fun n :
nat =>
rvmult (
rvmin f (
const (
INR n))) (
EventIndicator dec))).
Proof.
Lemma NonNegCondexp_is_Rbar_condexp_almost0 (
f :
Ts ->
R)
{
rv :
RandomVariable dom borel_sa f}
{
nnf :
NonnegativeFunction f} :
exists (
g :
nat ->
Ts ->
R),
(
forall n, (
NonnegativeFunction (
g n)))
/\ (
forall n, (
rv_le (
g n) (
g (
S n))))
/\
RandomVariable dom2 Rbar_borel_sa (
Rbar_rvlim g)
/\
exists (
g_rv:
forall n,
RandomVariable dom2 borel_sa (
g n)),
(
forall n,
is_conditional_expectation prts dom2 (
rvmin f (
const (
INR n))) (
g n)).
Proof.
Lemma NonNegCondexp_is_Rbar_condexp_g (
f :
Ts ->
R)
{
rv :
RandomVariable dom borel_sa f}
{
nnf :
NonnegativeFunction f} :
exists (
g :
nat ->
Ts ->
R),
Rbar_NonnegativeFunction (
Rbar_rvlim g)
/\
exists (
g_rv :
RandomVariable dom2 Rbar_borel_sa (
Rbar_rvlim g)),
is_conditional_expectation prts dom2 f (
Rbar_rvlim g).
Proof.