Skip to content

Commit

Permalink
a sampling theorem
Browse files Browse the repository at this point in the history
Co-authored-by: @affeldt-aist
Co-authored-by: @t6s
  • Loading branch information
hoheinzollern authored and affeldt-aist committed Dec 4, 2024
1 parent b48e208 commit 6274362
Show file tree
Hide file tree
Showing 9 changed files with 1,643 additions and 29 deletions.
8 changes: 8 additions & 0 deletions CHANGELOG_UNRELEASED.md
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,14 @@
`independent_RVs2_funrpospos`
+ lemma `expectationM_ge0`, `integrable_expectationM`, `independent_integrableM`,
` expectation_prod`
- in `lebesgue_integral.v`:
+ lemma `abse_integralP`
- in `signed.v`:
+ definition `onem_NngNum`
- in `measure.v`:
+ definition `bernoulli`, declared as a probability measure instance
- in `itv.v`:
+ canonical `onem_itv01`

### Changed

Expand Down
1 change: 1 addition & 0 deletions _CoqProject
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,7 @@ theories/ftc.v
theories/hoelder.v
theories/probability.v
theories/independence.v
theories/sampling.v
theories/convex.v
theories/charge.v
theories/kernel.v
Expand Down
5 changes: 3 additions & 2 deletions reals/itv.v
Original file line number Diff line number Diff line change
Expand Up @@ -850,6 +850,9 @@ Lemma inum_lt : {mono inum : x y / (x < y)%O}. Proof. by []. Qed.

End Morph.

Canonical onem_itv01 {R : realDomainType} (p : {i01 R}) : {i01 R} :=
@Itv.mk _ _ (onem p%:inum) [itv of 1 - p%:inum].

Section Test1.

Variable R : numDomainType.
Expand Down Expand Up @@ -890,8 +893,6 @@ Definition s_of_pq (p q : {i01 R}) : {i01 R} :=
Lemma s_of_p0 (p : {i01 R}) : s_of_pq p 0%:i01 = p.
Proof. by apply/val_inj; rewrite /= subr0 mulr1 subKr. Qed.

Canonical onem_itv01 (p : {i01 R}) : {i01 R} :=
@Itv.mk _ _ (onem p%:inum) [itv of 1 - p%:inum].

Definition s_of_pq' (p q : {i01 R}) : {i01 R} :=
(`1- (`1-(p%:inum) * `1-(q%:inum)))%:i01.
Expand Down
1 change: 1 addition & 0 deletions reals/signed.v
Original file line number Diff line number Diff line change
Expand Up @@ -123,6 +123,7 @@ From mathcomp Require Import mathcomp_extra.
(* Canonical instances are also provided according to types, as a *)
(* fallback when no known operator appears in the expression. Look to *)
(* nat_snum below for an example on how to add your favorite type. *)
(* *)
(******************************************************************************)

Reserved Notation "{ 'compare' x0 & nz & cond }"
Expand Down
1 change: 1 addition & 0 deletions theories/Make
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,7 @@ ftc.v
hoelder.v
probability.v
independence.v
sampling.v
lebesgue_stieltjes_measure.v
convex.v
charge.v
Expand Down
4 changes: 2 additions & 2 deletions theories/independence.v
Original file line number Diff line number Diff line change
Expand Up @@ -788,7 +788,7 @@ rewrite [ltLHS](_ : _ =
\int[distribution P X \x distribution P Y]_x `|x.1 * x.2|%:E); last first.
apply: eq_measure_integral => // A mA _.
apply/esym.
apply: product_measure_unique => //= A1 A2 mA1 mA2.
(* apply: product_measure_unique => //= A1 A2 mA1 mA2.
rewrite /pushforward/=.
rewrite -tmp1//.
by rewrite tmp0//.
Expand All @@ -812,7 +812,7 @@ rewrite lte_mul_pinfty//.
by move/integrable_abse : iX => //.
apply: integral_fune_lt_pinfty => //.
by move/integrable_abse : iY => //.
Qed.
Qed.*) Abort. (* TODO: urgent, why is that broken now?*)

End product_expectation.

Expand Down
12 changes: 4 additions & 8 deletions theories/lebesgue_integral.v
Original file line number Diff line number Diff line change
Expand Up @@ -4956,19 +4956,16 @@ Variable m2 : {sigma_finite_measure set T2 -> \bar R}.
Implicit Types A : set (T1 * T2).

Let pm10 : (m1 \x m2) set0 = 0.
Proof. by rewrite [LHS]integral0_eq// => x/= _; rewrite xsection0 measure0. Qed.
Proof. by rewrite [LHS]integral0_eq// => x/= _; rewrite xsection0. Qed.

Let pm1_ge0 A : 0 <= (m1 \x m2) A.
Proof.
by apply: integral_ge0 => // *; exact/measure_ge0/measurable_xsection.
Qed.
Proof. by apply: integral_ge0 => // *. Qed.

Let pm1_sigma_additive : semi_sigma_additive (m1 \x m2).
Proof.
move=> F mF tF mUF.
rewrite [X in _ --> X](_ : _ = \sum_(n <oo) (m1 \x m2) (F n)).
apply/cvg_closeP; split; last by rewrite closeE.
by apply: is_cvg_nneseries => *; exact: integral_ge0.
by apply/cvg_closeP; split; [exact: is_cvg_nneseries|rewrite closeE].
rewrite -integral_nneseries//; last by move=> n; exact: measurable_fun_xsection.
apply: eq_integral => x _; apply/esym/cvg_lim => //=; rewrite xsection_bigcup.
apply: (measure_sigma_additive _ (trivIset_xsection tF)) => ?.
Expand Down Expand Up @@ -5027,8 +5024,7 @@ HB.instance Definition _ := Measure_isSigmaFinite.Build _ _ _ (m1 \x m2)

Lemma product_measure_unique
(m' : {measure set [the semiRingOfSetsType _ of T1 * T2] -> \bar R}) :
(forall A1 A2, measurable A1 -> measurable A2 ->
m' (A1 `*` A2) = m1 A1 * m2 A2) ->
(forall A B, measurable A -> measurable B -> m' (A `*` B) = m1 A * m2 B) ->
forall X : set (T1 * T2), measurable X -> (m1 \x m2) X = m' X.
Proof.
move=> m'E.
Expand Down
Loading

0 comments on commit 6274362

Please sign in to comment.