Module mathcomp.analysis.measure_theory.probability_measure
From HB Require Import structures.From mathcomp Require Import all_ssreflect_compat all_algebra.
From mathcomp Require Import boolp classical_sets functions cardinality reals.
From mathcomp Require Import interval_inference ereal topology normedtype.
From mathcomp Require Import measurable_structure measure_function dirac_measure.
Set SsrOldRewriteGoalsOrder.
Set Implicit Arguments.
Unset Strict Implicit.
Unset Printing Implicit Defensive.
Import Order.TTheory GRing.Theory Num.Theory.
Local Open Scope classical_set_scope.
Local Open Scope ring_scope.
HB.mixin Record isSubProbability d (T : sigmaRingType d) (R : realType)
(P : set T -> \bar R) := { sprobability_setT : (P setT <= 1)%E }.
#[short(type=subprobability)]
HB.structure Definition SubProbability d (T : measurableType d) (R : realType)
:= {mu of @FiniteMeasure d T R mu & isSubProbability d T R mu }.
HB.factory Record Measure_isSubProbability d (T : measurableType d)
(R : realType) (P : set T -> \bar R) & isMeasure _ _ _ P :=
{ sprobability_setT : (P setT <= 1)%E }.
HB.builders Context d (T : measurableType d) (R : realType)
P & Measure_isSubProbability d T R P.
Let finite : @Measure_isFinite d T R P.
Proof.
HB.instance Definition _ := finite.
HB.instance Definition _ := @isSubProbability.Build _ _ _ P sprobability_setT.
HB.end.
Section mzero_subprobability.
Context d (T : measurableType d) (R : realType).
Let mzero_setT : (@mzero d T R setT <= 1)%E.
Proof.
HB.instance Definition _ :=
Measure_isSubProbability.Build _ _ _ (@mzero d T R) mzero_setT.
End mzero_subprobability.
HB.mixin Record isProbability d (T : measurableType d) (R : realType)
(P : set T -> \bar R) := { probability_setT : P setT = 1%E }.
#[short(type=probability)]
HB.structure Definition Probability d (T : measurableType d) (R : realType) :=
{P of @SubProbability d T R P & isProbability d T R P }.
Arguments probability_setT {d T R} s.
HB.instance Definition _ d (T : measurableType d) (R : realType) :=
gen_eqMixin (probability T R).
HB.instance Definition _ d (T : measurableType d) (R : realType) :=
gen_choiceMixin (probability T R).
Section probability_lemmas.
Local Open Scope ereal_scope.
Context d (T : measurableType d) (R : realType) (P : probability T R).
Lemma probability_le1 (A : set T) : measurable A -> P A <= 1.
Proof.
Lemma probability_setC (A : set T) : measurable A -> P (~` A) = 1 - P A.
Proof.
- by rewrite fin_num_measure.
- exact: measurableC.
Qed.
End probability_lemmas.
HB.factory Record Measure_isProbability d (T : measurableType d)
(R : realType) (P : set T -> \bar R) & isMeasure _ _ _ P :=
{ probability_setT : P setT = 1%E }.
HB.builders Context d (T : measurableType d) (R : realType)
P & Measure_isProbability d T R P.
Let subprobability : @Measure_isSubProbability d T R P.
Proof.
HB.instance Definition _ := subprobability.
HB.instance Definition _ := @isProbability.Build _ _ _ P probability_setT.
HB.end.
Section pdirac.
Context d (T : measurableType d) (R : realType).
HB.instance Definition _ x :=
Measure_isProbability.Build _ _ _ (@dirac _ T x R) (diracT R x).
End pdirac.
Section mnormalize.
Local Open Scope ereal_scope.
Context d (T : measurableType d) (R : realType).
Variables (mu : {measure set T -> \bar R}) (P : probability T R).
Definition
mnormalize : forall [d : measure_display] [T : measurableType d] [R : realType], measure T R -> probability T R -> set T -> \bar R mnormalize is not universe polymorphic Arguments mnormalize [d]%_measure_display_scope [T R] mu P U%_classical_set_scope mnormalize is transparent Expands to: Constant mathcomp.analysis.measure_theory.probability_measure.mnormalize Declared in library mathcomp.analysis.measure_theory.probability_measure, line 146, characters 11-21
let evidence := mu [set: T] in
if (evidence == 0) || (evidence == +oo) then fun U => P U
else fun U => mu U * (fine evidence)^-1%:E.
Let mnormalize0 : mnormalize set0 = 0.
Proof.
Let mnormalize_ge0 U : 0 <= mnormalize U.
Proof.
Let mnormalize_sigma_additive : semi_sigma_additive mnormalize.
Proof.
case: ifPn => [_|_]; first exact: measure_semi_sigma_additive.
rewrite [X in X @ _ --> _](_ : _ = (fun n => \sum_(0 <= i < n) mu (F i)) \*
cst (fine (mu setT))^-1%:E); last first.
by apply/funext => n; rewrite -ge0_sume_distrl.
by apply: cvgeZr => //; exact: measure_semi_sigma_additive.
Qed.
HB.instance Definition _ := isMeasure.Build _ _ _ mnormalize
mnormalize0 mnormalize_ge0 mnormalize_sigma_additive.
Let mnormalize1 : mnormalize [set: T] = 1.
Proof.
HB.instance Definition _ :=
Measure_isProbability.Build _ _ _ mnormalize mnormalize1.
End mnormalize.
Lemma mnormalize_id d (T : measurableType d) (R : realType)
(P P' : probability T R) : mnormalize P P' = P.
Proof.
HB.instance Definition _ d (T : measurableType d) (R : realType) :=
isPointed.Build (probability T R) (dirac point).
Section dist_sigma_algebra_instance.
Context d (T : measurableType d) (R : realType).
Definition
mset : forall [d : measure_display] [T : measurableType d] [R : realType], set T -> R -> set (probability T R) mset is not universe polymorphic Arguments mset [d]%_measure_display_scope [T R] U%_classical_set_scope r%_ring_scope _ mset is transparent Expands to: Constant mathcomp.analysis.measure_theory.probability_measure.mset Declared in library mathcomp.analysis.measure_theory.probability_measure, line 198, characters 11-15
[set mu : probability T R | mu U < r%:E]%E.
Lemma lt0_mset (U : set T) (r : R) : (r < 0)%R -> mset U r = set0.
Proof.
Lemma gt1_mset (U : set T) (r : R) :
measurable U -> (1 < r)%R -> mset U r = [set: probability T R].
Proof.
by rewrite /mset/= (le_lt_trans (probability_le1 _ _)).
Qed.
Definition
pset : forall [d : measure_display] [T : measurableType d] [R : realType], set (set (probability T R)) pset is not universe polymorphic Arguments pset [d]%_measure_display_scope [T R] _ pset is transparent Expands to: Constant mathcomp.analysis.measure_theory.probability_measure.pset Declared in library mathcomp.analysis.measure_theory.probability_measure, line 214, characters 11-15
[set mset U r | r in `[0%R,1%R] & U in measurable].
Definition
pprobability : forall [d : measure_display] (T : measurableType d) (R : realType), measurableType (pset (T:=T) (R:=R)).-sigma pprobability is not universe polymorphic Arguments pprobability [d]%_measure_display_scope T R pprobability is transparent Expands to: Constant mathcomp.analysis.measure_theory.probability_measure.pprobability Declared in library mathcomp.analysis.measure_theory.probability_measure, line 217, characters 11-23
g_sigma_algebraType pset.
End dist_sigma_algebra_instance.