From 3868fce27392ba135fd3e3849423cbead00a4eaa Mon Sep 17 00:00:00 2001 From: Reynald Affeldt Date: Fri, 5 Jul 2024 19:02:45 +0900 Subject: [PATCH 1/7] gen isMeasurableFun --- theories/kernel.v | 2 +- theories/lebesgue_integral.v | 27 +++++++++++++-------------- theories/probability.v | 6 +++--- 3 files changed, 17 insertions(+), 18 deletions(-) diff --git a/theories/kernel.v b/theories/kernel.v index 1594b27f6..1c3e2cb2e 100644 --- a/theories/kernel.v +++ b/theories/kernel.v @@ -963,7 +963,7 @@ HB.instance Definition _ n := @isNonNegFun.Build _ _ _ (k_2_ge0 n). Let mk_2 n : measurable_fun [set: X * Y] (k_2 n). Proof. by apply: measurableT_comp => //; exact: measurable_snd. Qed. -HB.instance Definition _ n := @isMeasurableFun.Build _ _ _ _ (mk_2 n). +HB.instance Definition _ n := @isMeasurableFun.Build _ _ _ _ _ (mk_2 n). Let fk_2 n : finite_set (range (k_2 n)). Proof. diff --git a/theories/lebesgue_integral.v b/theories/lebesgue_integral.v index 176ac5c0a..b9da274d3 100644 --- a/theories/lebesgue_integral.v +++ b/theories/lebesgue_integral.v @@ -101,12 +101,12 @@ Reserved Notation "m1 '\x^' m2" (at level 40, left associativity). #[global] Hint Extern 0 (measurable [set _]) => solve [apply: measurable_set1] : core. -HB.mixin Record isMeasurableFun d (aT : sigmaRingType d) (rT : realType) +HB.mixin Record isMeasurableFun d d' (aT : sigmaRingType d) (rT : sigmaRingType d') (f : aT -> rT) := { measurable_funP : measurable_fun [set: aT] f }. -HB.structure Definition MeasurableFun d aT rT := - {f of @isMeasurableFun d aT rT f}. +HB.structure Definition MeasurableFun d d' aT rT := + {f of @isMeasurableFun d d' aT rT f}. (* HB.mixin Record isMeasurableFun d (aT : measurableType d) (rT : realType) (f : aT -> rT) := { *) (* measurable_funP : measurable_fun setT f *) @@ -118,14 +118,13 @@ Reserved Notation "{ 'mfun' aT >-> T }" (at level 0, format "{ 'mfun' aT >-> T }"). Reserved Notation "[ 'mfun' 'of' f ]" (at level 0, format "[ 'mfun' 'of' f ]"). -Notation "{ 'mfun' aT >-> T }" := (@MeasurableFun.type _ aT T) : form_scope. +Notation "{ 'mfun' aT >-> T }" := (@MeasurableFun.type _ _ aT T) : form_scope. Notation "[ 'mfun' 'of' f ]" := [the {mfun _ >-> _} of f] : form_scope. #[global] Hint Extern 0 (measurable_fun [set: _] _) => solve [apply: measurable_funP] : core. HB.structure Definition SimpleFun d (aT : sigmaRingType d) (rT : realType) := -(* HB.structure Definition SimpleFun d (aT (*rT*) : measurableType d) (rT : realType) := *) - {f of @isMeasurableFun d aT rT f & @FiniteImage aT rT f}. + {f of @isMeasurableFun d _ aT rT f & @FiniteImage aT rT f}. Reserved Notation "{ 'sfun' aT >-> T }" (at level 0, format "{ 'sfun' aT >-> T }"). Reserved Notation "[ 'sfun' 'of' f ]" @@ -174,7 +173,7 @@ Notation T := {mfun aT >-> rT}. Notation mfun := (@mfun _ aT rT). Section Sub. Context (f : aT -> rT) (fP : f \in mfun). -Definition mfun_Sub_subproof := @isMeasurableFun.Build d aT rT f (set_mem fP). +Definition mfun_Sub_subproof := @isMeasurableFun.Build d _ aT rT f (set_mem fP). #[local] HB.instance Definition _ := mfun_Sub_subproof. Definition mfun_Sub := [mfun of f]. End Sub. @@ -196,25 +195,25 @@ Proof. by split=> [->//|fg]; apply/val_inj/funext. Qed. HB.instance Definition _ := [Choice of {mfun aT >-> rT} by <:]. -Lemma cst_mfun_subproof x : @isMeasurableFun d aT rT (cst x). +Lemma cst_mfun_subproof x : @isMeasurableFun d _ aT rT (cst x). Proof. by split. Qed. HB.instance Definition _ x := @cst_mfun_subproof x. Definition cst_mfun x := [the {mfun aT >-> rT} of cst x]. Lemma mfun_cst x : @cst_mfun x =1 cst x. Proof. by []. Qed. -HB.instance Definition _ := @isMeasurableFun.Build _ _ rT +HB.instance Definition _ := @isMeasurableFun.Build _ _ _ rT (@normr rT rT) (@normr_measurable rT setT). HB.instance Definition _ := - isMeasurableFun.Build _ _ _ (@expR rT) (@measurable_expR rT). + isMeasurableFun.Build _ _ _ _ (@expR rT) (@measurable_expR rT). Lemma measurableT_comp_subproof (f : {mfun _ >-> rT}) (g : {mfun aT >-> rT}) : measurable_fun setT (f \o g). Proof. exact: measurableT_comp. Qed. HB.instance Definition _ (f : {mfun _ >-> rT}) (g : {mfun aT >-> rT}) := - isMeasurableFun.Build _ _ _ (f \o g) (measurableT_comp_subproof _ _). + isMeasurableFun.Build _ _ _ _ (f \o g) (measurableT_comp_subproof _ _). End mfun. @@ -261,7 +260,7 @@ Proof. by rewrite /mindic funeqE => t; rewrite indicE. Qed. HB.instance Definition _ (D : set aT) (mD : measurable D) : @FImFun aT rT (mindic mD) := FImFun.on (mindic mD). Lemma indic_mfun_subproof (D : set aT) (mD : measurable D) : - @isMeasurableFun d aT rT (mindic mD). + @isMeasurableFun d _ aT rT (mindic mD). Proof. split=> mA /= B mB; rewrite preimage_indic. case: ifPn => B1; case: ifPn => B0 //. @@ -278,7 +277,7 @@ Definition indic_mfun (D : set aT) (mD : measurable D) := HB.instance Definition _ k f := MeasurableFun.copy (k \o* f) (f * cst_mfun k). Definition scale_mfun k f := [the {mfun aT >-> rT} of k \o* f]. -Lemma max_mfun_subproof f g : @isMeasurableFun d aT rT (f \max g). +Lemma max_mfun_subproof f g : @isMeasurableFun d _ aT rT (f \max g). Proof. by split; apply: measurable_maxr. Qed. HB.instance Definition _ f g := max_mfun_subproof f g. Definition max_mfun f g := [the {mfun aT >-> _} of f \max g]. @@ -313,7 +312,7 @@ Notation sfun := (@sfun _ aT rT). Section Sub. Context (f : aT -> rT) (fP : f \in sfun). Definition sfun_Sub1_subproof := - @isMeasurableFun.Build d aT rT f (set_mem (sub_sfun_mfun fP)). + @isMeasurableFun.Build d _ aT rT f (set_mem (sub_sfun_mfun fP)). #[local] HB.instance Definition _ := sfun_Sub1_subproof. Definition sfun_Sub2_subproof := @FiniteImage.Build aT rT f (set_mem (sub_sfun_fimfun fP)). diff --git a/theories/probability.v b/theories/probability.v index e9d54e429..f6ac45d2c 100644 --- a/theories/probability.v +++ b/theories/probability.v @@ -88,7 +88,7 @@ Proof. by rewrite preimage_range probability_setT. Qed. Definition distribution d (T : measurableType d) (R : realType) (P : probability T R) (X : {mfun T >-> R}) := - pushforward P (@measurable_funP _ _ _ X). + pushforward P (@measurable_funP _ _ _ _ X). Section distribution_is_probability. Context d (T : measurableType d) (R : realType) (P : probability T R) @@ -680,13 +680,13 @@ Qed. End markov_chebyshev_cantelli. HB.mixin Record MeasurableFun_isDiscrete d (T : measurableType d) (R : realType) - (X : T -> R) of @MeasurableFun d T R X := { + (X : T -> R) of @MeasurableFun d _ T R X := { countable_range : countable (range X) }. HB.structure Definition discreteMeasurableFun d (T : measurableType d) (R : realType) := { - X of isMeasurableFun d T R X & MeasurableFun_isDiscrete d T R X + X of isMeasurableFun d _ T R X & MeasurableFun_isDiscrete d T R X }. Notation "{ 'dmfun' aT >-> T }" := From 5fbbfcd66d181ca2694330476e4063184873ea10 Mon Sep 17 00:00:00 2001 From: Reynald Affeldt Date: Fri, 5 Jul 2024 20:38:18 +0900 Subject: [PATCH 2/7] gen section mfun --- CHANGELOG_UNRELEASED.md | 6 ++++++ theories/lebesgue_integral.v | 20 +++++++++++++------- 2 files changed, 19 insertions(+), 7 deletions(-) diff --git a/CHANGELOG_UNRELEASED.md b/CHANGELOG_UNRELEASED.md index 31ab6ca7b..98daa2aa9 100644 --- a/CHANGELOG_UNRELEASED.md +++ b/CHANGELOG_UNRELEASED.md @@ -89,6 +89,12 @@ ### Generalized +- in `lebesgue_integral.v`: + + generalized from `realType` to `sigmaRingType` + * mixin `isMeasurableFun` + * structure `MeasurableFun` + * definition `mfun` + ### Deprecated ### Removed diff --git a/theories/lebesgue_integral.v b/theories/lebesgue_integral.v index b9da274d3..df210d370 100644 --- a/theories/lebesgue_integral.v +++ b/theories/lebesgue_integral.v @@ -161,16 +161,17 @@ Notation "{ 'nnsfun' aT >-> T }" := (@NonNegSimpleFun.type _ aT%type T) : form_s Notation "[ 'nnsfun' 'of' f ]" := [the {nnsfun _ >-> _} of f] : form_scope. Section mfun_pred. -Context {d} {aT : sigmaRingType d} {rT : realType}. +Context {d d'} {aT : sigmaRingType d} {rT : sigmaRingType d'}. Definition mfun : {pred aT -> rT} := mem [set f | measurable_fun setT f]. Definition mfun_key : pred_key mfun. Proof. exact. Qed. Canonical mfun_keyed := KeyedPred mfun_key. End mfun_pred. -Section mfun. -Context {d} {aT : measurableType d} {rT : realType}. +Section mfun_realType. +Context {d} {aT : sigmaRingType d} {rT : realType}. Notation T := {mfun aT >-> rT}. -Notation mfun := (@mfun _ aT rT). +Notation mfun := (@mfun _ _ aT rT). + Section Sub. Context (f : aT -> rT) (fP : f \in mfun). Definition mfun_Sub_subproof := @isMeasurableFun.Build d _ aT rT f (set_mem fP). @@ -202,6 +203,11 @@ Definition cst_mfun x := [the {mfun aT >-> rT} of cst x]. Lemma mfun_cst x : @cst_mfun x =1 cst x. Proof. by []. Qed. +End mfun_realType. + +Section mfun. +Context {d} {aT : measurableType d} {rT : realType}. + HB.instance Definition _ := @isMeasurableFun.Build _ _ _ rT (@normr rT rT) (@normr_measurable rT setT). @@ -220,14 +226,14 @@ End mfun. Section ring. Context d (aT : measurableType d) (rT : realType). -Lemma mfun_subring_closed : subring_closed (@mfun _ aT rT). +Lemma mfun_subring_closed : subring_closed (@mfun _ _ aT rT). Proof. split=> [|f g|f g]; rewrite !inE/=. - exact: measurable_cst. - exact: measurable_funB. - exact: measurable_funM. Qed. -HB.instance Definition _ := GRing.isSubringClosed.Build _ mfun +HB.instance Definition _ := GRing.isSubringClosed.Build _ (@mfun d default_measure_display aT rT) mfun_subring_closed. HB.instance Definition _ := [SubChoice_isSubComRing of {mfun aT >-> rT} by <:]. @@ -298,7 +304,7 @@ Notation measurable_fun_indic := measurable_indic (only parsing). Section sfun_pred. Context {d} {aT : sigmaRingType d} {rT : realType}. -Definition sfun : {pred _ -> _} := [predI @mfun _ aT rT & fimfun]. +Definition sfun : {pred _ -> _} := [predI @mfun _ _ aT rT & fimfun]. Definition sfun_key : pred_key sfun. Proof. exact. Qed. Canonical sfun_keyed := KeyedPred sfun_key. Lemma sub_sfun_mfun : {subset sfun <= mfun}. Proof. by move=> x /andP[]. Qed. From f18d8941d8efb2e4554eba78e101375e71b48bd5 Mon Sep 17 00:00:00 2001 From: Reynald Affeldt Date: Fri, 5 Jul 2024 20:40:44 +0900 Subject: [PATCH 3/7] get rid of problematic cst instance --- CHANGELOG_UNRELEASED.md | 17 ++++++++++++++++- theories/lebesgue_integral.v | 27 +++++++++++++++------------ 2 files changed, 31 insertions(+), 13 deletions(-) diff --git a/CHANGELOG_UNRELEASED.md b/CHANGELOG_UNRELEASED.md index 98daa2aa9..c05d19213 100644 --- a/CHANGELOG_UNRELEASED.md +++ b/CHANGELOG_UNRELEASED.md @@ -84,21 +84,36 @@ + lemmas `set_itvK`, `RhullT`, `RhullK`, `set_itv_setT`, `Rhull_smallest`, `le_Rhull`, `neitv_Rhull`, `Rhull_involutive`, `disj_itv_Rhull` +- in `topology.v`: + + lemmas `subspace_pm_ball_center`, `subspace_pm_ball_sym`, + `subspace_pm_ball_triangle`, `subspace_pm_entourage` turned + into local `Let`'s + +- in `lebesgue_integral.v`: + + lemma `cst_mfun_subproof` now a `Let` ### Renamed ### Generalized - in `lebesgue_integral.v`: - + generalized from `realType` to `sigmaRingType` + + generalized from `sigmaRingType`/`realType` to `sigmaRingType` * mixin `isMeasurableFun` * structure `MeasurableFun` * definition `mfun` + * lemmas `mfun_rect`, `mfun_valP`, `mfuneqP` + + generalized from `measurableType`/`realType` to `sigmaRingType`/`realType` + * lemmas `cst_mfun_subproof`, `mfun_cst` + * definition `cst_mfun` ### Deprecated ### Removed +- in `lebesgue_integral.v`: + + definition `cst_mfun` + + lemma `mfun_cst` + ### Infrastructure ### Misc diff --git a/theories/lebesgue_integral.v b/theories/lebesgue_integral.v index df210d370..b66159afd 100644 --- a/theories/lebesgue_integral.v +++ b/theories/lebesgue_integral.v @@ -167,8 +167,8 @@ Definition mfun_key : pred_key mfun. Proof. exact. Qed. Canonical mfun_keyed := KeyedPred mfun_key. End mfun_pred. -Section mfun_realType. -Context {d} {aT : sigmaRingType d} {rT : realType}. +Section mfun. +Context {d d'} {aT : sigmaRingType d} {rT : sigmaRingType d'}. Notation T := {mfun aT >-> rT}. Notation mfun := (@mfun _ _ aT rT). @@ -196,17 +196,15 @@ Proof. by split=> [->//|fg]; apply/val_inj/funext. Qed. HB.instance Definition _ := [Choice of {mfun aT >-> rT} by <:]. -Lemma cst_mfun_subproof x : @isMeasurableFun d _ aT rT (cst x). -Proof. by split. Qed. -HB.instance Definition _ x := @cst_mfun_subproof x. -Definition cst_mfun x := [the {mfun aT >-> rT} of cst x]. +End mfun. -Lemma mfun_cst x : @cst_mfun x =1 cst x. Proof. by []. Qed. +Section mfun_realType. +Context {d} {aT : sigmaRingType d} {rT : realType}. -End mfun_realType. +Let cst_mfun_subproof x : @isMeasurableFun d _ aT rT (cst x). +Proof. by split. Qed. -Section mfun. -Context {d} {aT : measurableType d} {rT : realType}. +HB.instance Definition _ x := @cst_mfun_subproof x. HB.instance Definition _ := @isMeasurableFun.Build _ _ _ rT (@normr rT rT) (@normr_measurable rT setT). @@ -214,6 +212,11 @@ HB.instance Definition _ := @isMeasurableFun.Build _ _ _ rT HB.instance Definition _ := isMeasurableFun.Build _ _ _ _ (@expR rT) (@measurable_expR rT). +End mfun_realType. + +Section mfun_measurableType. +Context {d d'} {aT : measurableType d} {rT : measurableType d'}. + Lemma measurableT_comp_subproof (f : {mfun _ >-> rT}) (g : {mfun aT >-> rT}) : measurable_fun setT (f \o g). Proof. exact: measurableT_comp. Qed. @@ -221,7 +224,7 @@ Proof. exact: measurableT_comp. Qed. HB.instance Definition _ (f : {mfun _ >-> rT}) (g : {mfun aT >-> rT}) := isMeasurableFun.Build _ _ _ _ (f \o g) (measurableT_comp_subproof _ _). -End mfun. +End mfun_measurableType. Section ring. Context d (aT : measurableType d) (rT : realType). @@ -280,7 +283,7 @@ HB.instance Definition _ D mD := @indic_mfun_subproof D mD. Definition indic_mfun (D : set aT) (mD : measurable D) := [the {mfun aT >-> rT} of mindic mD]. -HB.instance Definition _ k f := MeasurableFun.copy (k \o* f) (f * cst_mfun k). +HB.instance Definition _ k f := MeasurableFun.copy (k \o* f) (f * cst k). Definition scale_mfun k f := [the {mfun aT >-> rT} of k \o* f]. Lemma max_mfun_subproof f g : @isMeasurableFun d _ aT rT (f \max g). From b8a908b51d1dee693e7bf814b2650d3274b76819 Mon Sep 17 00:00:00 2001 From: Reynald Affeldt Date: Fri, 5 Jul 2024 21:34:15 +0900 Subject: [PATCH 4/7] upd doc --- theories/lebesgue_integral.v | 16 ++++++---------- 1 file changed, 6 insertions(+), 10 deletions(-) diff --git a/theories/lebesgue_integral.v b/theories/lebesgue_integral.v index b66159afd..0c7a98d37 100644 --- a/theories/lebesgue_integral.v +++ b/theories/lebesgue_integral.v @@ -39,7 +39,8 @@ From mathcomp Require Import lebesgue_measure numfun realfun function_spaces. (* *) (* Detailed contents: *) (* ```` *) -(* {mfun T >-> R} == type of real-valued measurable functions *) +(* {mfun aT >-> rT} == type of measurable functions *) +(* aT and rT are sigmaRingType's. *) (* {sfun T >-> R} == type of simple functions *) (* {nnsfun T >-> R} == type of non-negative simple functions *) (* cst_nnsfun r == constant simple function *) @@ -108,12 +109,8 @@ HB.mixin Record isMeasurableFun d d' (aT : sigmaRingType d) (rT : sigmaRingType HB.structure Definition MeasurableFun d d' aT rT := {f of @isMeasurableFun d d' aT rT f}. -(* HB.mixin Record isMeasurableFun d (aT : measurableType d) (rT : realType) (f : aT -> rT) := { *) -(* measurable_funP : measurable_fun setT f *) -(* }. *) (* #[global] Hint Resolve fimfun_inP : core. *) -(* HB.structure Definition MeasurableFun d aT rT := {f of @isMeasurableFun d aT rT f}. *) Reserved Notation "{ 'mfun' aT >-> T }" (at level 0, format "{ 'mfun' aT >-> T }"). Reserved Notation "[ 'mfun' 'of' f ]" @@ -148,8 +145,6 @@ Notation "{ 'nnfun' aT >-> T }" := (@NonNegFun.type aT T) : form_scope. Notation "[ 'nnfun' 'of' f ]" := [the {nnfun _ >-> _} of f] : form_scope. #[global] Hint Extern 0 (is_true (0 <= _)) => solve [apply: fun_ge0] : core. -(* HB.structure Definition NonNegSimpleFun d (aT : measurableType d) (rT : realType) := *) - HB.structure Definition NonNegSimpleFun d (aT : sigmaRingType d) (rT : realType) := {f of @SimpleFun d _ _ f & @NonNegFun aT rT f}. @@ -201,10 +196,11 @@ End mfun. Section mfun_realType. Context {d} {aT : sigmaRingType d} {rT : realType}. -Let cst_mfun_subproof x : @isMeasurableFun d _ aT rT (cst x). -Proof. by split. Qed. +Let cst_mfun_subproof x : @measurable_fun d _ aT rT [set: aT] (cst x). +Proof. by []. Qed. -HB.instance Definition _ x := @cst_mfun_subproof x. +HB.instance Definition _ x := isMeasurableFun.Build d _ aT rT (cst x) + (@cst_mfun_subproof x). HB.instance Definition _ := @isMeasurableFun.Build _ _ _ rT (@normr rT rT) (@normr_measurable rT setT). From 72b4a9e5517ec5fde867315465a1704380dd0450 Mon Sep 17 00:00:00 2001 From: Reynald Affeldt Date: Thu, 11 Jul 2024 23:18:01 +0900 Subject: [PATCH 5/7] generalization of cst_mfun to a codomain of measurableType --- theories/lebesgue_integral.v | 194 ++++++++++++++++++++++++++++++++--- 1 file changed, 178 insertions(+), 16 deletions(-) diff --git a/theories/lebesgue_integral.v b/theories/lebesgue_integral.v index 0c7a98d37..5b42f3ad6 100644 --- a/theories/lebesgue_integral.v +++ b/theories/lebesgue_integral.v @@ -120,13 +120,19 @@ Notation "[ 'mfun' 'of' f ]" := [the {mfun _ >-> _} of f] : form_scope. #[global] Hint Extern 0 (measurable_fun [set: _] _) => solve [apply: measurable_funP] : core. -HB.structure Definition SimpleFun d (aT : sigmaRingType d) (rT : realType) := - {f of @isMeasurableFun d _ aT rT f & @FiniteImage aT rT f}. Reserved Notation "{ 'sfun' aT >-> T }" (at level 0, format "{ 'sfun' aT >-> T }"). Reserved Notation "[ 'sfun' 'of' f ]" (at level 0, format "[ 'sfun' 'of' f ]"). -Notation "{ 'sfun' aT >-> T }" := (@SimpleFun.type _ aT T) : form_scope. + +Module HBSimple. + +HB.structure Definition SimpleFun d (aT : sigmaRingType d) (rT : realType) := + {f of @isMeasurableFun d _ aT rT f & @FiniteImage aT rT f}. + +End HBSimple. + +Notation "{ 'sfun' aT >-> T }" := (@HBSimple.SimpleFun.type _ aT T) : form_scope. Notation "[ 'sfun' 'of' f ]" := [the {sfun _ >-> _} of f] : form_scope. Lemma measurable_sfunP {d} {aT : measurableType d} {rT : realType} @@ -145,14 +151,21 @@ Notation "{ 'nnfun' aT >-> T }" := (@NonNegFun.type aT T) : form_scope. Notation "[ 'nnfun' 'of' f ]" := [the {nnfun _ >-> _} of f] : form_scope. #[global] Hint Extern 0 (is_true (0 <= _)) => solve [apply: fun_ge0] : core. -HB.structure Definition NonNegSimpleFun - d (aT : sigmaRingType d) (rT : realType) := - {f of @SimpleFun d _ _ f & @NonNegFun aT rT f}. Reserved Notation "{ 'nnsfun' aT >-> T }" (at level 0, format "{ 'nnsfun' aT >-> T }"). Reserved Notation "[ 'nnsfun' 'of' f ]" (at level 0, format "[ 'nnsfun' 'of' f ]"). -Notation "{ 'nnsfun' aT >-> T }" := (@NonNegSimpleFun.type _ aT%type T) : form_scope. + +Module HBNNSimple. +Import HBSimple. + +HB.structure Definition NonNegSimpleFun + d (aT : sigmaRingType d) (rT : realType) := + {f of @SimpleFun d _ _ f & @NonNegFun aT rT f}. + +End HBNNSimple. + +Notation "{ 'nnsfun' aT >-> T }" := (@HBNNSimple.NonNegSimpleFun.type _ aT%type T) : form_scope. Notation "[ 'nnsfun' 'of' f ]" := [the {nnsfun _ >-> _} of f] : form_scope. Section mfun_pred. @@ -191,17 +204,17 @@ Proof. by split=> [->//|fg]; apply/val_inj/funext. Qed. HB.instance Definition _ := [Choice of {mfun aT >-> rT} by <:]. -End mfun. - -Section mfun_realType. -Context {d} {aT : sigmaRingType d} {rT : realType}. - -Let cst_mfun_subproof x : @measurable_fun d _ aT rT [set: aT] (cst x). +Lemma cst_mfun_subproof x : @measurable_fun d _ aT rT [set: aT] (cst x). Proof. by []. Qed. HB.instance Definition _ x := isMeasurableFun.Build d _ aT rT (cst x) (@cst_mfun_subproof x). +End mfun. + +Section mfun_realType. +Context {d} {aT : sigmaRingType d} {rT : realType}. + HB.instance Definition _ := @isMeasurableFun.Build _ _ _ rT (@normr rT rT) (@normr_measurable rT setT). @@ -321,6 +334,9 @@ Definition sfun_Sub1_subproof := #[local] HB.instance Definition _ := sfun_Sub1_subproof. Definition sfun_Sub2_subproof := @FiniteImage.Build aT rT f (set_mem (sub_sfun_fimfun fP)). + +Import HBSimple. + #[local] HB.instance Definition _ := sfun_Sub2_subproof. Definition sfun_Sub := [sfun of f]. End Sub. @@ -334,6 +350,8 @@ have -> : Pf2 = (set_mem (sub_sfun_fimfun Pf)) by []. exact: Ksub. Qed. +Import HBSimple. + Lemma sfun_valP f (Pf : f \in sfun) : sfun_Sub Pf = f :> (_ -> _). Proof. by []. Qed. @@ -346,6 +364,10 @@ HB.instance Definition _ := [Choice of {sfun aT >-> rT} by <:]. (* TODO: BUG: HB *) (* HB.instance Definition _ (x : rT) := @cst_mfun_subproof aT rT x. *) + +(* NB: duplicate from cardinality.v *) +HB.instance Definition _ x := @cst_fimfun_subproof aT rT x. + Definition cst_sfun x := [the {sfun aT >-> rT} of cst x]. Lemma cst_sfunE x : @cst_sfun x =1 cst x. Proof. by []. Qed. @@ -380,6 +402,8 @@ HB.instance Definition _ := [SubChoice_isSubComRing of {sfun aT >-> rT} by <:]. Implicit Types (f g : {sfun aT >-> rT}). +Import HBSimple. + Lemma sfun0 : (0 : {sfun aT >-> rT}) =1 cst 0. Proof. by []. Qed. Lemma sfun1 : (1 : {sfun aT >-> rT}) =1 cst 1. Proof. by []. Qed. Lemma sfunN f : - f =1 \- f. Proof. by []. Qed. @@ -400,6 +424,11 @@ HB.instance Definition _ f g := MeasurableFun.copy (\- f) (- f). HB.instance Definition _ f g := MeasurableFun.copy (f \- g) (f - g). HB.instance Definition _ f g := MeasurableFun.copy (f \* g) (f * g). +Import HBSimple. +(* NB: duplicate from lebesgue_integral.v *) +HB.instance Definition _ (D : set aT) (mD : measurable D) : + @FImFun aT rT (mindic _ mD) := FImFun.on (mindic _ mD). + Definition indic_sfun (D : set aT) (mD : measurable D) := [the {sfun aT >-> rT} of mindic rT mD]. @@ -445,6 +474,8 @@ Qed. Section simple_bounded. Context d (T : sigmaRingType d) (R : realType). +Import HBSimple. + Lemma simple_bounded (f : {sfun T >-> R}) : bounded_fun f. Proof. have /finite_seqP[r fr] := fimfunP f. @@ -462,10 +493,18 @@ End simple_bounded. Section nnsfun_functions. Context d (T : measurableType d) (R : realType). +Import HBNNSimple. + Lemma cst_nnfun_subproof (x : {nonneg R}) : @isNonNegFun T R (cst x%:num). Proof. by split=> /=. Qed. HB.instance Definition _ x := @cst_nnfun_subproof x. +HB.instance Definition _ x := isMeasurableFun.Build d _ T R (cst x) + (@cst_mfun_subproof _ _ _ _ x). + +(* NB: duplicate from cardinality.v *) +HB.instance Definition _ x := @cst_fimfun_subproof T R x. + Definition cst_nnsfun (r : {nonneg R}) := [the {nnsfun T >-> R} of cst r%:num]. Definition nnsfun0 : {nnsfun T >-> R} := cst_nnsfun 0%R%:nng. @@ -501,6 +540,8 @@ Section nnsfun_bin. Context d (T : measurableType d) (R : realType). Variables f g : {nnsfun T >-> R}. +Import HBNNSimple. + HB.instance Definition _ := MeasurableFun.on (f \+ g). Definition add_nnsfun := [the {nnsfun T >-> R} of f \+ g]. @@ -523,6 +564,8 @@ Variable f : {nnsfun T >-> R}^nat. Definition sum_nnsfun n := \big[add_nnsfun/nnsfun0]_(i < n) f i. +Import HBNNSimple. + Lemma sum_nnsfunE n t : sum_nnsfun n t = \sum_(i < n) (f i t). Proof. by rewrite /sum_nnsfun; elim/big_ind2 : _ => [|x g y h <- <-|]. Qed. @@ -538,6 +581,8 @@ Local Open Scope ereal_scope. Context d (T : measurableType d) (R : realType). Variable f : {nnsfun T >-> R}. +Import HBNNSimple. + Lemma nnsfun_cover : \big[setU/set0]_(i \in range f) (f @^-1` [set i]) = setT. Proof. by rewrite fsbig_setU//= -subTset => x _; exists (f x). Qed. @@ -574,6 +619,8 @@ move=> Afin Fm Ft. by rewrite fsbig_finite// -measure_fin_bigcup// -bigsetU_fset_set. Qed. +Import HBNNSimple. + Lemma additive_nnsfunr (g f : {nnsfun T >-> R}) x : \sum_(i \in range g) m (f @^-1` [set x] `&` (g @^-1` [set i])) = m (f @^-1` [set x] `&` \big[setU/set0]_(i \in range g) (g @^-1` [set i])). @@ -617,6 +664,8 @@ by move=> xA; rewrite (@mulef_ge0 _ _ (mu \o _))//= => /xA ->; rewrite measure0. Qed. Global Arguments mulemu_ge0 {d T R mu x} A. +Import HBNNSimple. + Lemma nnsfun_mulemu_ge0 d (T : sigmaRingType d) (R : realType) (mu : {measure set T -> \bar R}) (f : {nnsfun T >-> R}) x : 0 <= x%:E * mu (f @^-1` [set x]). @@ -661,6 +710,8 @@ rewrite sintegralE fsbig1// => r _; rewrite preimage_cst. by case: ifPn => [/[!inE] <-|]; rewrite ?mul0e// measure0 mule0. Qed. +Import HBNNSimple. + Lemma sintegral_ge0 (f : {nnsfun T >-> R}) : 0 <= sintegral mu f. Proof. by rewrite sintegralE fsume_ge0// => r _; exact: nnsfun_mulemu_ge0. Qed. @@ -698,6 +749,8 @@ Local Open Scope ereal_scope. Context d (T : sigmaRingType d) (R : realType). Variables (m : {measure set T -> \bar R}) (r : R) (f : {nnsfun T >-> R}). +Import HBNNSimple. + Lemma sintegralrM : sintegral m (cst r \* f)%R = r%:E * sintegral m f. Proof. have [->|r0] := eqVneq r 0%R. @@ -720,6 +773,8 @@ Context d (T : measurableType d) (R : realType). Variables (m : {measure set T -> \bar R}). Variables (D : set T) (mD : measurable D) (f g : {nnsfun T >-> R}). +Import HBNNSimple. + Lemma sintegralD : sintegral m (f \+ g)%R = sintegral m f + sintegral m g. Proof. rewrite !sintegralE; set F := f @` _; set G := g @` _; set FG := _ @` _. @@ -752,6 +807,9 @@ End sintegralD. Section le_sintegral. Context d (T : measurableType d) (R : realType) (m : {measure set T -> \bar R}). Variables f g : {nnsfun T >-> R}. + +Import HBNNSimple. + Hypothesis fg : forall x, f x <= g x. Let fgnn : @isNonNegFun T R (g \- f). @@ -766,6 +824,9 @@ Qed. End le_sintegral. +Section tmp. +Import HBNNSimple. + Lemma is_cvg_sintegral d (T : measurableType d) (R : realType) (m : {measure set T -> \bar R}) (f : {nnsfun T >-> R}^nat) : (forall x, nondecreasing_seq (f ^~ x)) -> cvgn (sintegral m \o f). @@ -774,10 +835,15 @@ move=> nd_f; apply/cvg_ex; eexists; apply/ereal_nondecreasing_cvgn => a b ab. by apply: le_sintegral => // => x; exact/nd_f. Qed. +End tmp. + Definition proj_nnsfun d (T : measurableType d) (R : realType) (f : {nnsfun T >-> R}) (A : set T) (mA : measurable A) := mul_nnsfun f (indic_nnsfun R mA). +Section tmp. +Import HBNNSimple. + Definition mrestrict d (T : measurableType d) (R : realType) (f : {nnsfun T >-> R}) A (mA : measurable A) : f \_ A = proj_nnsfun f mA. Proof. @@ -785,6 +851,8 @@ apply/funext => x /=; rewrite /patch mindicE. by case: ifP; rewrite (mulr0, mulr1). Qed. +End tmp. + Definition scale_nnsfun d (T : measurableType d) (R : realType) (f : {nnsfun T >-> R}) (k : R) (k0 : 0 <= k) := mul_nnsfun (cst_nnsfun T (NngNum k0)) f. @@ -793,6 +861,9 @@ Section sintegral_nondecreasing_limit_lemma. Context d (T : measurableType d) (R : realType). Variable mu : {measure set T -> \bar R}. Variables (g : {nnsfun T >-> R}^nat) (f : {nnsfun T >-> R}). + +Import HBNNSimple. + Hypothesis nd_g : forall x, nondecreasing_seq (g^~ x). Hypothesis gf : forall x, cvgn (g^~ x) -> f x <= limn (g^~ x). @@ -908,6 +979,9 @@ Section sintegral_nondecreasing_limit. Context d (T : measurableType d) (R : realType). Variable mu : {measure set T -> \bar R}. Variables (g : {nnsfun T >-> R}^nat) (f : {nnsfun T >-> R}). + +Import HBNNSimple. + Hypothesis nd_g : forall x, nondecreasing_seq (g^~ x). Hypothesis gf : forall x, g ^~ x @ \oo --> f x. @@ -933,6 +1007,8 @@ Local Open Scope ereal_scope. Context d (T : measurableType d) (R : realType). Implicit Types (f g : T -> \bar R) (D : set T). +Import HBNNSimple. + Let nnintegral mu f := ereal_sup [set sintegral mu h | h in [set h : {nnsfun T >-> R} | forall x, (h x)%:E <= f x]]. @@ -1029,6 +1105,8 @@ Local Open Scope ereal_scope. Context d (T : measurableType d) (R : realType) (D : set T). Implicit Types m : {measure set T -> \bar R}. +Import HBNNSimple. + Let eq_measure_integral0 m2 m1 (f : T -> \bar R) : (forall A, measurable A -> A `<=` D -> m1 A = m2 A) -> [set sintegral m1 h | h in @@ -1066,6 +1144,8 @@ Context d (T : measurableType d) (R : realType). Let sintegral_measure_zero (f : T -> R) : sintegral mzero f = 0. Proof. by rewrite sintegralE big1// => r _ /=; rewrite /mzero mule0. Qed. +Import HBNNSimple. + Lemma integral_measure_zero (D : set T) (f : T -> \bar R) : \int[mzero]_(x in D) f x = 0. Proof. @@ -1089,6 +1169,8 @@ Variable mu : {measure set T -> \bar R}. Lemma integral_mkcond D f : \int[mu]_(x in D) f x = \int[mu]_x (f \_ D) x. Proof. by rewrite /integral patch_setT. Qed. +Import HBNNSimple. + Lemma integralT_nnsfun (h : {nnsfun T >-> R}) : \int[mu]_x (h x)%:E = sintegral mu h. Proof. by rewrite integral_nnsfun// patch_setT. Qed. @@ -1119,6 +1201,9 @@ Variables (mu : {measure set T -> \bar R}) (f : T -> \bar R) (g : {nnsfun T >-> R}^nat). Hypothesis f0 : forall x, 0 <= f x. Hypothesis mf : measurable_fun setT f. + +Import HBNNSimple. + Hypothesis nd_g : forall x, nondecreasing_seq (g^~x). Hypothesis gf : forall x, EFin \o g^~ x @ \oo --> f x. Local Open Scope ereal_scope. @@ -1511,6 +1596,8 @@ Definition nnsfun_approx : {nnsfun T >-> R}^nat := fun n => locked (add_nnsfun end) (n * 2 ^ n)%N) (scale_nnsfun (indic_nnsfun _ (mB n)) (ler0n _ n))). +Import HBNNSimple. + Lemma nnsfun_approxE n : nnsfun_approx n = approx n :> (T -> R). Proof. rewrite funeqE => t /=; rewrite /nnsfun_approx; unlock; rewrite /=. @@ -1548,6 +1635,8 @@ Variables f1 f2 : T -> \bar R. Hypothesis f10 : forall x, D x -> 0 <= f1 x. Hypothesis mf1 : measurable_fun D f1. +Import HBNNSimple. + Lemma ge0_integralZl_EFin k : (0 <= k)%R -> \int[mu]_(x in D) (k%:E * f1 x) = k%:E * \int[mu]_(x in D) f1 x. Proof. @@ -1586,6 +1675,8 @@ Hypothesis mf1 : measurable_fun D f1. Hypothesis f20 : forall x, D x -> 0 <= f2 x. Hypothesis mf2 : measurable_fun D f2. +Import HBNNSimple. + Lemma ge0_integralD : \int[mu]_(x in D) (f1 x + f2 x) = \int[mu]_(x in D) f1 x + \int[mu]_(x in D) f2 x. Proof. @@ -1657,13 +1748,27 @@ Section approximation_sfun. Context d (T : measurableType d) (R : realType) (f : T -> \bar R). Variables (D : set T) (mD : measurable D) (mf : measurable_fun D f). +Import HBSimple. +(* duplicate *) +HB.instance Definition _ x := @cst_fimfun_subproof T R x. +HB.instance Definition _ x := isMeasurableFun.Build d _ T R (cst x) + (@cst_mfun_subproof _ _ _ _ x). + Lemma approximation_sfun : - exists g : {sfun T >-> R}^nat, (forall x, D x -> EFin \o g^~ x @ \oo --> f x). + exists g : {sfun T >-> R}^nat, (forall x, D x -> EFin \o g ^~ x @ \oo --> f x). Proof. have [fp_ [fp_nd fp_cvg]] := approximation mD (measurable_funepos mf) (fun=> ltac:(by [])). have [fn_ [fn_nd fn_cvg]] := approximation mD (measurable_funeneg mf) (fun=> ltac:(by [])). + +Import HBNNSimple. +(* duplicate *) +HB.instance Definition _ x := @cst_fimfun_subproof T R x. +HB.instance Definition _ x := isMeasurableFun.Build d _ T R (cst x) + (@cst_mfun_subproof _ _ _ _ x). +HB.instance Definition _ x := @cst_nnfun_subproof _ T R x. + exists (fun n => [the {sfun T >-> R} of fp_ n \+ cst (-1) \* fn_ n]) => x /=. rewrite [X in X @ \oo --> _](_ : _ = EFin \o fp_^~ x \+ (-%E \o EFin \o fn_^~ x))%E; last first. @@ -1683,6 +1788,8 @@ Let R := [the measurableType _ of measurableTypeR rT]. Hypothesis mA : measurable A. Hypothesis finA : mu A < +oo. +Import HBSimple. + Let lusin_simple (f : {sfun R >-> rT}) (eps : rT) : (0 < eps)%R -> exists K, [/\ compact K, K `<=` A, mu (A `\` K) < eps%:E & {within K, continuous f}]. @@ -1800,6 +1907,8 @@ Local Open Scope ereal_scope. Context d (T : measurableType d) (R : realType). Implicit Types (D : set T) (f g : T -> \bar R). +Import HBSimple. + Lemma emeasurable_funD D f g : measurable_fun D f -> measurable_fun D g -> measurable_fun D (f \+ g). Proof. @@ -2065,6 +2174,8 @@ Local Definition max_g2' : (T -> R)^nat := Local Definition max_g2 : {nnsfun T >-> R}^nat := fun k => bigmax_nnsfun (g2^~ k) k. +Import HBNNSimple. + Let is_cvg_g2 n t : cvgn (EFin \o (g2 n ^~ t)). Proof. apply: ereal_nondecreasing_is_cvgn => a b ab. @@ -2291,6 +2402,8 @@ Local Open Scope ereal_scope. Context d (T : measurableType d) (R : realType) (mu : {measure set T -> \bar R}) (D : set T) (mD : measurable D). +Import HBNNSimple. + Lemma integral_indic (E : set T) : measurable E -> \int[mu]_(x in D) (\1_E x)%:E = mu (E `&` D). Proof. @@ -2318,6 +2431,8 @@ rewrite ge0_integralZl//; first exact/measurable_EFinP. by move=> y _; rewrite lee_fin. Qed. +Import HBNNSimple. + Lemma integralZl_indic_nnsfun (f : {nnsfun T >-> R}) (k : R) : \int[m]_(x in D) (k * \1_(f @^-1` [set k]) x)%:E = k%:E * \int[m]_(x in D) (\1_(f @^-1` [set k]) x)%:E. @@ -2344,6 +2459,8 @@ Let integral_mscale_indic E : measurable E -> k%:num%:E * \int[m]_(x in D) (\1_E x)%:E. Proof. by move=> ?; rewrite !integral_indic. Qed. +Import HBNNSimple. + Let integral_mscale_nnsfun (h : {nnsfun T >-> R}) : \int[mscale k m]_(x in D) (h x)%:E = k%:num%:E * \int[m]_(x in D) (h x)%:E. Proof. @@ -2484,6 +2601,8 @@ rewrite sintegralE (fsbig_widen _ [set 0%R; x%:num])/=. - by move=> y [_ /=/preimage10->]; rewrite measure0 mule0. Qed. +Import HBNNSimple. + Local Lemma integral_cstr r : \int[mu]_(x in D) r%:E = r%:E * mu D. Proof. wlog r0 : r / (0 <= r)%R. @@ -2532,6 +2651,8 @@ Context d1 d2 (X : measurableType d1) (Y : measurableType d2) (R : realType). Variables (phi : X -> Y) (mphi : measurable_fun setT phi). Variables (mu : {measure set X -> \bar R}). +Import HBNNSimple. + Lemma ge0_integral_pushforward (f : Y -> \bar R) : measurable_fun setT f -> (forall y, 0 <= f y) -> \int[pushforward mu mphi]_y f y = \int[mu]_x (f \o phi) x. @@ -2577,6 +2698,8 @@ Local Open Scope ereal_scope. Context d (T : measurableType d) (a : T) (R : realType). Variables (D : set T) (mD : measurable D). +Import HBNNSimple. + Let ge0_integral_dirac (f : T -> \bar R) (mf : measurable_fun D f) (f0 : forall x, D x -> 0 <= f x) : D a -> \int[\d_a]_(x in D) (f x) = f a. @@ -2632,6 +2755,8 @@ rewrite integral_indic//= /msum/=; apply: eq_bigr => i _. by rewrite integral_indic// setIT. Qed. +Import HBNNSimple. + Let integralT_measure_sum (f : {nnsfun T >-> R}) : \int[m]_x (f x)%:E = \sum_(n < N) \int[m_ n]_x (f x)%:E. Proof. @@ -2665,6 +2790,10 @@ Qed. End integral_measure_sum_nnsfun. +Section tmp. + +Import HBNNSimple. + Lemma integral_measure_add_nnsfun d (T : measurableType d) (R : realType) (m1 m2 : {measure set T -> \bar R}) (D : set T) (mD : measurable D) (f : {nnsfun T >-> R}) : @@ -2675,11 +2804,15 @@ rewrite /measureD integral_measure_sum_nnsfun// 2!big_ord_recl/= big_ord0. by rewrite adde0. Qed. +End tmp. + Section integral_mfun_measure_sum. Local Open Scope ereal_scope. Context d (T : measurableType d) (R : realType). Variable m_ : {measure set T -> \bar R}^nat. +Import HBNNSimple. + Lemma ge0_integral_measure_sum (D : set T) (mD : measurable D) (f : T -> \bar R) : (forall x, D x -> 0 <= f x) -> measurable_fun D f -> forall N, @@ -2741,6 +2874,8 @@ rewrite integral_indic// setIT /m/= /mseries; apply: eq_eseriesr => i _. by rewrite integral_indic// setIT. Qed. +Import HBNNSimple. + Lemma integral_measure_series_nnsfun (D : set T) (mD : measurable D) (f : {nnsfun T >-> R}) : \int[m]_x (f x)%:E = \sum_(n \bar R}^nat. Let m := mseries m_ O. +Import HBNNSimple. + Lemma ge0_integral_measure_series (D : set T) (mD : measurable D) (f : T -> \bar R) : (forall t, D t -> 0 <= f t) -> measurable_fun D f -> @@ -3687,6 +3824,20 @@ exists N; split => // t /= /not_implyP[_]. by rewrite patchE; case: ifPn => //; rewrite inE. Qed. +Import HBNNSimple. + +Lemma funID (N : set T) (mN : measurable N) (f : T -> \bar R) : + let oneCN := [the {nnsfun T >-> R} of mindic R (measurableC mN)] in + let oneN := [the {nnsfun T >-> R} of mindic R mN] in + f = (fun x => f x * (oneCN x)%:E) \+ (fun x => f x * (oneN x)%:E). +Proof. +move=> oneCN oneN; rewrite funeqE => x. +rewrite /oneCN /oneN/= /mindic !indicE. +have [xN|xN] := boolP (x \in N). + by rewrite mule1 in_setC xN mule0 add0e. +by rewrite in_setC xN mule0 adde0 mule1. +Qed. + Lemma negligible_integrable (D N : set T) (f : T -> \bar R) : measurable N -> measurable D -> measurable_fun D f -> mu N = 0 -> mu.-integrable D f <-> mu.-integrable (D `\` N) f. @@ -3709,7 +3860,7 @@ have h1 : mu.-integrable D f <-> mu.-integrable D (f \_ ~` N). rewrite -integral_mkcondr; case: intf => _; apply: le_lt_trans. by apply: ge0_subset_integral => //=; [exact:measurableI| exact:measurableT_comp]. - apply/integrableP; split => //; rewrite (funID N f). + apply/integrableP; split => //; rewrite (ereal.funID N f). have ? : measurable_fun D (f \_ ~` N). by apply/measurable_restrict => //; exact: measurable_funS mf. have ? : measurable_fun D (f \_ N). @@ -3747,7 +3898,7 @@ Lemma ge0_negligible_integral (D N : set T) (f : T -> \bar R) : mu N = 0 -> \int[mu]_(x in D) f x = \int[mu]_(x in D `\` N) f x. Proof. move=> mN mD mf f0 muN0. -rewrite {1}(funID N f) ge0_integralD//; last 4 first. +rewrite {1}(ereal.funID N f) ge0_integralD//; last 4 first. - by move=> x Dx; rewrite patchE; case: ifPn => // _; exact: f0. - apply/measurable_restrict => //; first exact/measurableC. exact: measurable_funS mf. @@ -4977,6 +5128,8 @@ have [M [_ mrt]] := bdA; apply: le_lt_trans. by rewrite lte_mul_pinfty. Qed. +Import HBSimple. + Let sfun_dense_L1_pos (f : T -> \bar R) : mu.-integrable E f -> (forall x, E x -> 0 <= f x) -> exists g_ : {sfun T >-> R}^nat, @@ -4986,6 +5139,9 @@ Let sfun_dense_L1_pos (f : T -> \bar R) : Proof. move=> intf fpos; case/integrableP: (intf) => mfE _. pose g_ n := nnsfun_approx mE mfE n. + +Import HBNNSimple. + have [] // := @dominated_convergence _ _ _ mu _ mE (fun n => EFin \o g_ n) f f. - by move=> ?; exact/measurable_EFinP/measurable_funTS. - apply: aeW => ? ?; under eq_fun => ? do rewrite /g_ nnsfun_approxE. @@ -5083,6 +5239,8 @@ move=> cptA ctsfA; apply: measurable_bounded_integrable. by exists M; split; rewrite ?num_real // => ? ? ? ?; exact: mrt. Qed. +Import HBSimple. + Lemma approximation_continuous_integrable (E : set _) (f : rT -> rT): measurable E -> mu E < +oo -> mu.-integrable E (EFin \o f) -> exists g_ : (rT -> rT)^nat, @@ -5251,6 +5409,8 @@ End indic_fubini_tonelli. Section sfun_fubini_tonelli. Variable f : {nnsfun [the measurableType _ of T1 * T2 : Type] >-> R}. +Import HBNNSimple. + Let F := fubini_F m2 (EFin \o f). Let G := fubini_G m1 (EFin \o f). @@ -5376,6 +5536,8 @@ Let T := [the measurableType _ of T1 * T2 : Type]. Let F := fubini_F m2 f. Let G := fubini_G m1 f. +Import HBNNSimple. + Let F_ (g : {nnsfun T >-> R}^nat) n x := \int[m2]_y (g n (x, y))%:E. Let G_ (g : {nnsfun T >-> R}^nat) n y := \int[m1]_x (g n (x, y))%:E. From ac6a5e6ccc224e8bbf9cc987d195b6cfe1d55b69 Mon Sep 17 00:00:00 2001 From: Reynald Affeldt Date: Tue, 24 Sep 2024 18:30:25 +0900 Subject: [PATCH 6/7] complete the fix - include rebase --- CHANGELOG_UNRELEASED.md | 19 ++++-- classical/cardinality.v | 6 +- theories/charge.v | 2 + theories/kernel.v | 11 ++++ theories/lebesgue_integral.v | 122 +++++++++++++++-------------------- theories/probability.v | 2 + 6 files changed, 83 insertions(+), 79 deletions(-) diff --git a/CHANGELOG_UNRELEASED.md b/CHANGELOG_UNRELEASED.md index c05d19213..2b9213098 100644 --- a/CHANGELOG_UNRELEASED.md +++ b/CHANGELOG_UNRELEASED.md @@ -90,21 +90,22 @@ into local `Let`'s - in `lebesgue_integral.v`: - + lemma `cst_mfun_subproof` now a `Let` + + structure `SimpleFun` now inside a module `HBSimple` + + structure `NonNegSimpleFun` now inside a module `HBNNSimple` + + lemma `cst_nnfun_subproof` has now a different statement + + lemma `indic_nnfun_subproof` has now a different statement + ### Renamed ### Generalized - in `lebesgue_integral.v`: - + generalized from `sigmaRingType`/`realType` to `sigmaRingType` + + generalized from `sigmaRingType`/`realType` to `sigmaRingType`/`sigmaRingType` * mixin `isMeasurableFun` * structure `MeasurableFun` * definition `mfun` * lemmas `mfun_rect`, `mfun_valP`, `mfuneqP` - + generalized from `measurableType`/`realType` to `sigmaRingType`/`realType` - * lemmas `cst_mfun_subproof`, `mfun_cst` - * definition `cst_mfun` ### Deprecated @@ -114,6 +115,14 @@ + definition `cst_mfun` + lemma `mfun_cst` +- in `cardinality.v`: + + lemma `cst_fimfun_subproof` + +- in `lebesgue_integral.v`: + + lemma `cst_mfun_subproof` (use lemma `measurable_cst` instead) + + lemma `cst_nnfun_subproof` (turned into a `Let`) + + lemma `indic_mfun_subproof` (use lemma `measurable_fun_indic` instead) + ### Infrastructure ### Misc diff --git a/classical/cardinality.v b/classical/cardinality.v index 6a68c128f..c84602f5f 100644 --- a/classical/cardinality.v +++ b/classical/cardinality.v @@ -1324,9 +1324,9 @@ suff -> : cst x @` [set: aT] = [set x] by apply: finite_set1. by apply/predeqP => y; split=> [[t' _ <-]//|->//] /=; exists point. Qed. -Lemma cst_fimfun_subproof aT rT x : @FiniteImage aT rT (cst x). -Proof. by split; exact: finite_image_cst. Qed. -HB.instance Definition _ aT rT x := @cst_fimfun_subproof aT rT x. +HB.instance Definition _ aT rT x := + FiniteImage.Build aT rT (cst x) (@finite_image_cst aT rT x). + Definition cst_fimfun {aT rT} x := [the {fimfun aT >-> rT} of cst x]. Lemma fimfun_cst aT rT x : @cst_fimfun aT rT x =1 cst x. Proof. by []. Qed. diff --git a/theories/charge.v b/theories/charge.v index 3ce46c005..498cc2228 100644 --- a/theories/charge.v +++ b/theories/charge.v @@ -1914,6 +1914,8 @@ Implicit Types f : T -> \bar R. Local Notation "'d nu '/d mu" := (f nu mu). +Import HBNNSimple. + Lemma change_of_variables f E : (forall x, 0 <= f x) -> measurable E -> measurable_fun E f -> \int[mu]_(x in E) (f x * ('d nu '/d mu) x) = \int[nu]_(x in E) f x. diff --git a/theories/kernel.v b/theories/kernel.v index 1c3e2cb2e..4d154d267 100644 --- a/theories/kernel.v +++ b/theories/kernel.v @@ -504,6 +504,8 @@ Section measurable_fun_integral_finite_sfinite. Context d d' (X : measurableType d) (Y : measurableType d') (R : realType). Variable k : X * Y -> \bar R. +Import HBNNSimple. + Lemma measurable_fun_xsection_integral (l : X -> {measure set Y -> \bar R}) (k_ : {nnsfun (X * Y) >-> R}^nat) @@ -949,6 +951,7 @@ HB.export KCOMP_SFINITE_KERNEL. Section measurable_fun_preimage_integral. Context d d' (X : measurableType d) (Y : measurableType d') (R : realType). +Import HBNNSimple. Variables (k : Y -> \bar R) (k_ : ({nnsfun Y >-> R}) ^nat) (ndk_ : nondecreasing_seq (k_ : (Y -> R)^nat)) @@ -992,6 +995,10 @@ Qed. End measurable_fun_preimage_integral. +Section measurable_fun_integral_kernel. + +Import HBNNSimple. + Lemma measurable_fun_integral_kernel d d' (X : measurableType d) (Y : measurableType d') (R : realType) (l : X -> {measure set Y -> \bar R}) @@ -1004,6 +1011,8 @@ have [k_ [ndk_ k_k]] := approximation measurableT mk (fun x _ => k0 x). by apply: (measurable_fun_preimage_integral ndk_ k_k) => n r; exact/ml. Qed. +End measurable_fun_integral_kernel. + Section integral_kcomp. Context d d2 d3 (X : measurableType d) (Y : measurableType d2) (Z : measurableType d3) (R : realType). @@ -1017,6 +1026,8 @@ rewrite integral_indic//= /kcomp. by apply: eq_integral => y _; rewrite integral_indic. Qed. +Import HBNNSimple. + Let integral_kcomp_nnsfun x (f : {nnsfun Z >-> R}) : \int[kcomp l k x]_z (f z)%:E = \int[l x]_y (\int[k (x, y)]_z (f z)%:E). Proof. diff --git a/theories/lebesgue_integral.v b/theories/lebesgue_integral.v index 5b42f3ad6..bcf78d03a 100644 --- a/theories/lebesgue_integral.v +++ b/theories/lebesgue_integral.v @@ -77,6 +77,19 @@ From mathcomp Require Import lebesgue_measure numfun realfun function_spaces. (* nicely_shrinking x E == the sequence of sets E is nicely shrinking to x *) (* ```` *) (* *) +(* About the use of simple functions: *) +(* Because of a limitation of HB <= 1.8.0, we need some care to be able to *) +(* use simple functions. *) +(* The structure SimpleFun (resp. NonNegSimpleFun) is located inside the *) +(* module HBSimple (resp. HBNNSimple). *) +(* As a consequence, we need to import HBSimple (resp. HBNNSimple) to use the *) +(* coercion from simple functions (resp. non-negative simple functions) to *) +(* Coq functions. *) +(* Also, assume that f (e.g., cst, indic) is equipped with the structure of *) +(* MeasurableFun. For f to be equipped with the structure of SimpleFun *) +(* (resp. NonNegSimpleFun), one need locallu to import HBSimple (resp. *) +(* HBNNSimple) and to instantiate FiniteImage (resp. NonNegFun) locally. *) +(* *) (******************************************************************************) Set Implicit Arguments. @@ -204,11 +217,8 @@ Proof. by split=> [->//|fg]; apply/val_inj/funext. Qed. HB.instance Definition _ := [Choice of {mfun aT >-> rT} by <:]. -Lemma cst_mfun_subproof x : @measurable_fun d _ aT rT [set: aT] (cst x). -Proof. by []. Qed. - HB.instance Definition _ x := isMeasurableFun.Build d _ aT rT (cst x) - (@cst_mfun_subproof x). + (@measurable_cst _ _ aT rT setT x). End mfun. @@ -245,8 +255,8 @@ split=> [|f g|f g]; rewrite !inE/=. - exact: measurable_funB. - exact: measurable_funM. Qed. -HB.instance Definition _ := GRing.isSubringClosed.Build _ (@mfun d default_measure_display aT rT) - mfun_subring_closed. +HB.instance Definition _ := GRing.isSubringClosed.Build _ + (@mfun d default_measure_display aT rT) mfun_subring_closed. HB.instance Definition _ := [SubChoice_isSubComRing of {mfun aT >-> rT} by <:]. Implicit Types (f g : {mfun aT >-> rT}). @@ -272,22 +282,13 @@ HB.instance Definition _ f g := MeasurableFun.copy (f \- g) (f - g). HB.instance Definition _ f g := MeasurableFun.copy (f \* g) (f * g). Definition mindic (D : set aT) of measurable D : aT -> rT := \1_D. + Lemma mindicE (D : set aT) (mD : measurable D) : mindic mD = (fun x => (x \in D)%:R). Proof. by rewrite /mindic funeqE => t; rewrite indicE. Qed. -HB.instance Definition _ (D : set aT) (mD : measurable D) : - @FImFun aT rT (mindic mD) := FImFun.on (mindic mD). -Lemma indic_mfun_subproof (D : set aT) (mD : measurable D) : - @isMeasurableFun d _ aT rT (mindic mD). -Proof. -split=> mA /= B mB; rewrite preimage_indic. -case: ifPn => B1; case: ifPn => B0 //. -- by rewrite setIT. -- exact: measurableI. -- by apply: measurableI => //; apply: measurableC. -- by rewrite setI0. -Qed. -HB.instance Definition _ D mD := @indic_mfun_subproof D mD. + +HB.instance Definition _ D mD := @isMeasurableFun.Build _ _ aT rT (mindic mD) + (@measurable_fun_indic _ aT rT setT D mD). Definition indic_mfun (D : set aT) (mD : measurable D) := [the {mfun aT >-> rT} of mindic mD]. @@ -297,7 +298,9 @@ Definition scale_mfun k f := [the {mfun aT >-> rT} of k \o* f]. Lemma max_mfun_subproof f g : @isMeasurableFun d _ aT rT (f \max g). Proof. by split; apply: measurable_maxr. Qed. + HB.instance Definition _ f g := max_mfun_subproof f g. + Definition max_mfun f g := [the {mfun aT >-> _} of f \max g]. End ring. @@ -362,11 +365,8 @@ Proof. by split=> [->//|fg]; apply/val_inj/funext. Qed. HB.instance Definition _ := [Choice of {sfun aT >-> rT} by <:]. -(* TODO: BUG: HB *) -(* HB.instance Definition _ (x : rT) := @cst_mfun_subproof aT rT x. *) - -(* NB: duplicate from cardinality.v *) -HB.instance Definition _ x := @cst_fimfun_subproof aT rT x. +(* NB: already instantiated in cardinality.v *) +HB.instance Definition _ x : @FImFun aT rT (cst x) := FImFun.on (cst x). Definition cst_sfun x := [the {sfun aT >-> rT} of cst x]. @@ -425,7 +425,7 @@ HB.instance Definition _ f g := MeasurableFun.copy (f \- g) (f - g). HB.instance Definition _ f g := MeasurableFun.copy (f \* g) (f * g). Import HBSimple. -(* NB: duplicate from lebesgue_integral.v *) +(* NB: already instantiated in lebesgue_integral.v *) HB.instance Definition _ (D : set aT) (mD : measurable D) : @FImFun aT rT (mindic _ mD) := FImFun.on (mindic _ mD). @@ -495,23 +495,23 @@ Context d (T : measurableType d) (R : realType). Import HBNNSimple. -Lemma cst_nnfun_subproof (x : {nonneg R}) : @isNonNegFun T R (cst x%:num). -Proof. by split=> /=. Qed. -HB.instance Definition _ x := @cst_nnfun_subproof x. - -HB.instance Definition _ x := isMeasurableFun.Build d _ T R (cst x) - (@cst_mfun_subproof _ _ _ _ x). +Lemma cst_nnfun_subproof (x : {nonneg R}) : forall t : T, 0 <= cst x%:num t. +Proof. by move=> /=. Qed. +HB.instance Definition _ x := @isNonNegFun.Build T R (cst x%:num) + (cst_nnfun_subproof x). -(* NB: duplicate from cardinality.v *) -HB.instance Definition _ x := @cst_fimfun_subproof T R x. +(* NB: already instantiated in cardinality.v *) +HB.instance Definition _ x : @FImFun T R (cst x) := FImFun.on (cst x). Definition cst_nnsfun (r : {nonneg R}) := [the {nnsfun T >-> R} of cst r%:num]. Definition nnsfun0 : {nnsfun T >-> R} := cst_nnsfun 0%R%:nng. -Lemma indic_nnfun_subproof (D : set T) : @isNonNegFun T R (\1_D). -Proof. by split=> //=; rewrite /indic. Qed. -HB.instance Definition _ D := @indic_nnfun_subproof D. +Lemma indic_nnfun_subproof (D : set T) : forall x, 0 <= (\1_D) x :> R. +Proof. by []. Qed. + +HB.instance Definition _ D := @isNonNegFun.Build T R \1_D + (indic_nnfun_subproof D). HB.instance Definition _ D (mD : measurable D) : @NonNegFun T R (mindic R mD) := NonNegFun.on (mindic R mD). @@ -824,7 +824,7 @@ Qed. End le_sintegral. -Section tmp. +Section is_cvg_sintegral. Import HBNNSimple. Lemma is_cvg_sintegral d (T : measurableType d) (R : realType) @@ -835,13 +835,13 @@ move=> nd_f; apply/cvg_ex; eexists; apply/ereal_nondecreasing_cvgn => a b ab. by apply: le_sintegral => // => x; exact/nd_f. Qed. -End tmp. +End is_cvg_sintegral. Definition proj_nnsfun d (T : measurableType d) (R : realType) (f : {nnsfun T >-> R}) (A : set T) (mA : measurable A) := mul_nnsfun f (indic_nnsfun R mA). -Section tmp. +Section mrestrict. Import HBNNSimple. Definition mrestrict d (T : measurableType d) (R : realType) (f : {nnsfun T >-> R}) @@ -851,7 +851,7 @@ apply/funext => x /=; rewrite /patch mindicE. by case: ifP; rewrite (mulr0, mulr1). Qed. -End tmp. +End mrestrict. Definition scale_nnsfun d (T : measurableType d) (R : realType) (f : {nnsfun T >-> R}) (k : R) (k0 : 0 <= k) := @@ -1749,10 +1749,13 @@ Context d (T : measurableType d) (R : realType) (f : T -> \bar R). Variables (D : set T) (mD : measurable D) (mf : measurable_fun D f). Import HBSimple. -(* duplicate *) -HB.instance Definition _ x := @cst_fimfun_subproof T R x. -HB.instance Definition _ x := isMeasurableFun.Build d _ T R (cst x) - (@cst_mfun_subproof _ _ _ _ x). +(* NB: already instantiated in cardinality.v *) +HB.instance Definition _ x : @FImFun T R (cst x) := FImFun.on (cst x). + +Import HBNNSimple. +(* NB: already instantiated in lebesgue_integral.v *) +HB.instance Definition _ x : @NonNegFun T R (cst x%:num) := + NonNegFun.on (cst x%:num). Lemma approximation_sfun : exists g : {sfun T >-> R}^nat, (forall x, D x -> EFin \o g ^~ x @ \oo --> f x). @@ -1761,14 +1764,6 @@ have [fp_ [fp_nd fp_cvg]] := approximation mD (measurable_funepos mf) (fun=> ltac:(by [])). have [fn_ [fn_nd fn_cvg]] := approximation mD (measurable_funeneg mf) (fun=> ltac:(by [])). - -Import HBNNSimple. -(* duplicate *) -HB.instance Definition _ x := @cst_fimfun_subproof T R x. -HB.instance Definition _ x := isMeasurableFun.Build d _ T R (cst x) - (@cst_mfun_subproof _ _ _ _ x). -HB.instance Definition _ x := @cst_nnfun_subproof _ T R x. - exists (fun n => [the {sfun T >-> R} of fp_ n \+ cst (-1) \* fn_ n]) => x /=. rewrite [X in X @ \oo --> _](_ : _ = EFin \o fp_^~ x \+ (-%E \o EFin \o fn_^~ x))%E; last first. @@ -2790,8 +2785,7 @@ Qed. End integral_measure_sum_nnsfun. -Section tmp. - +Section integral_measure_add_nnsfun. Import HBNNSimple. Lemma integral_measure_add_nnsfun d (T : measurableType d) (R : realType) @@ -2804,7 +2798,7 @@ rewrite /measureD integral_measure_sum_nnsfun// 2!big_ord_recl/= big_ord0. by rewrite adde0. Qed. -End tmp. +End integral_measure_add_nnsfun. Section integral_mfun_measure_sum. Local Open Scope ereal_scope. @@ -3824,20 +3818,6 @@ exists N; split => // t /= /not_implyP[_]. by rewrite patchE; case: ifPn => //; rewrite inE. Qed. -Import HBNNSimple. - -Lemma funID (N : set T) (mN : measurable N) (f : T -> \bar R) : - let oneCN := [the {nnsfun T >-> R} of mindic R (measurableC mN)] in - let oneN := [the {nnsfun T >-> R} of mindic R mN] in - f = (fun x => f x * (oneCN x)%:E) \+ (fun x => f x * (oneN x)%:E). -Proof. -move=> oneCN oneN; rewrite funeqE => x. -rewrite /oneCN /oneN/= /mindic !indicE. -have [xN|xN] := boolP (x \in N). - by rewrite mule1 in_setC xN mule0 add0e. -by rewrite in_setC xN mule0 adde0 mule1. -Qed. - Lemma negligible_integrable (D N : set T) (f : T -> \bar R) : measurable N -> measurable D -> measurable_fun D f -> mu N = 0 -> mu.-integrable D f <-> mu.-integrable (D `\` N) f. @@ -3860,7 +3840,7 @@ have h1 : mu.-integrable D f <-> mu.-integrable D (f \_ ~` N). rewrite -integral_mkcondr; case: intf => _; apply: le_lt_trans. by apply: ge0_subset_integral => //=; [exact:measurableI| exact:measurableT_comp]. - apply/integrableP; split => //; rewrite (ereal.funID N f). + apply/integrableP; split => //; rewrite (funID N f). have ? : measurable_fun D (f \_ ~` N). by apply/measurable_restrict => //; exact: measurable_funS mf. have ? : measurable_fun D (f \_ N). @@ -3898,7 +3878,7 @@ Lemma ge0_negligible_integral (D N : set T) (f : T -> \bar R) : mu N = 0 -> \int[mu]_(x in D) f x = \int[mu]_(x in D `\` N) f x. Proof. move=> mN mD mf f0 muN0. -rewrite {1}(ereal.funID N f) ge0_integralD//; last 4 first. +rewrite {1}(funID N f) ge0_integralD//; last 4 first. - by move=> x Dx; rewrite patchE; case: ifPn => // _; exact: f0. - apply/measurable_restrict => //; first exact/measurableC. exact: measurable_funS mf. diff --git a/theories/probability.v b/theories/probability.v index f6ac45d2c..c57cac324 100644 --- a/theories/probability.v +++ b/theories/probability.v @@ -1289,6 +1289,8 @@ move=> mE; rewrite integral_indic//= /uniform_prob setIT -ge0_integralZl//=. - by rewrite lee_fin invr_ge0// ltW// subr_gt0. Qed. +Import HBNNSimple. + Let integral_uniform_nnsfun (f : {nnsfun _ >-> R}) : (\int[uniform_prob ab]_x (f x)%:E = (b - a)^-1%:E * \int[mu]_(x in `[a, b]) (f x)%:E)%E. From 1c5523ed55d834ad5abef3c4a2b81a2973f90557 Mon Sep 17 00:00:00 2001 From: Reynald Affeldt Date: Sun, 27 Oct 2024 13:47:43 +0900 Subject: [PATCH 7/7] typo --- theories/lebesgue_integral.v | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/theories/lebesgue_integral.v b/theories/lebesgue_integral.v index bcf78d03a..b043af47c 100644 --- a/theories/lebesgue_integral.v +++ b/theories/lebesgue_integral.v @@ -87,7 +87,7 @@ From mathcomp Require Import lebesgue_measure numfun realfun function_spaces. (* Coq functions. *) (* Also, assume that f (e.g., cst, indic) is equipped with the structure of *) (* MeasurableFun. For f to be equipped with the structure of SimpleFun *) -(* (resp. NonNegSimpleFun), one need locallu to import HBSimple (resp. *) +(* (resp. NonNegSimpleFun), one need locally to import HBSimple (resp. *) (* HBNNSimple) and to instantiate FiniteImage (resp. NonNegFun) locally. *) (* *) (******************************************************************************)