Module mathcomp.experimental_reals.distr
From mathcomp Require Import all_ssreflect_compat all_algebra.
From mathcomp.classical Require Import boolp classical_sets mathcomp_extra.
From mathcomp Require Import xfinmap constructive_ereal reals discrete.
From mathcomp Require Import realseq realsum.
Set Implicit Arguments.
Unset Strict Implicit.
Unset Printing Implicit Defensive.
Unset SsrOldRewriteGoalsOrder.
Import Order.TTheory GRing.Theory Num.Theory.
Local Open Scope ring_scope.
Local Notation simpm := Monoid.simpm.
Reserved Notation "\dlet_ ( i <- d ) E"
(at level 36, E at level 36, i, d at level 50,
format "'[' \dlet_ ( i <- d ) '/ ' E ']'").
Reserved Notation "\dlim_ ( n ) E"
(at level 36, E at level 36, n at level 50,
format "'[' \dlim_ ( n ) '/ ' E ']'").
Reserved Notation "\P_[ mu ] E" (at level 2, format "\P_[ mu ] E").
Reserved Notation "\P_[ mu , A ] E" (at level 2, format "\P_[ mu , A ] E").
Reserved Notation "\E?_[ mu ] f" (at level 2, format "\E?_[ mu ] f").
Reserved Notation "\E_[ mu ] f" (at level 2, format "\E_[ mu ] f").
Reserved Notation "\E_[ mu , A ] f" (at level 2, format "\E_[ mu , A ] f").
Local Notation "\`| f |" := (fun x => `|f x|) (at level 2).
Section Distribution.
Variables (R : realType) (T : choiceType).
Structure distr := Distr {
mu :> T -> R;
_ : forall x, 0 <= mu x;
_ : summable mu;
_ : psum mu <= 1
}.
Definition
distr_of : forall [R : realType] [T : choiceType], phant R -> phant T -> Type distr_of is not universe polymorphic Arguments distr_of [R T] _ _ distr_of is transparent Expands to: Constant mathcomp.experimental_reals.distr.distr_of Declared in library mathcomp.experimental_reals.distr, line 52, characters 11-19
End Distribution.
Notation "{ 'distr' T / R }" := (distr_of (Phant R) (Phant T))
(at level 0, T at level 2, format "{ 'distr' T / R }")
: type_scope.
Section DistrCoreTh.
Context {R : realType} (T : choiceType) (mu : {distr T / R}).
Lemma ge0_mu : forall x, 0 <= mu x.
Proof.
Lemma le1_mu : psum mu <= 1.
Proof.
Lemma summable_mu : summable mu.
Proof.
#[global] Hint Extern 0 (is_true (0 <= _)) => solve [apply: ge0_mu] : core.
#[global] Hint Resolve le1_mu summable_mu : core.
Section Clamp.
Context {R : realType}.
Definition
clamp : forall {R : realType}, R -> R clamp is not universe polymorphic Arguments clamp {R} x%_ring_scope clamp is transparent Expands to: Constant mathcomp.experimental_reals.distr.clamp Declared in library mathcomp.experimental_reals.distr, line 80, characters 11-16
Num.max (Num.min x 1) 0.
Lemma ge0_clamp x : 0 <= clamp x.
Lemma le1_clamp x : clamp x <= 1.
Definition
cp01_clamp : forall {R : realType}, (forall x : R, (0 <= clamp x)%R) * (forall x : R, (clamp x <= 1)%R) cp01_clamp is not universe polymorphic Arguments cp01_clamp {R} cp01_clamp is transparent Expands to: Constant mathcomp.experimental_reals.distr.cp01_clamp Declared in library mathcomp.experimental_reals.distr, line 89, characters 11-21
Lemma clamp_in01 x : 0 <= x <= 1 -> clamp x = x.
Lemma clamp_id x : clamp (clamp x) = clamp x.
Proof.
Lemma clamp0 : clamp 0 = 0.
Proof.
Lemma clamp1 : clamp 1 = 1.
Proof.
Section StdDefs.
Context {R : realType} (T : choiceType).
Implicit Types (mu : {distr T / R}) (A B E : pred T) (f : T -> R).
Definition
dinsupp : forall {R : realType} [T : choiceType], {distr T / R} -> T -> bool dinsupp is not universe polymorphic Arguments dinsupp {R} [T] mu x dinsupp is transparent Expands to: Constant mathcomp.experimental_reals.distr.dinsupp Declared in library mathcomp.experimental_reals.distr, line 110, characters 11-18
Lemma in_dinsupp x (mu : {distr T / R}) :
(x \in dinsupp mu) = (mu x != 0).
Proof.
Lemma dinsuppP mu x : reflect (mu x <> 0) (x \in dinsupp mu).
Lemma dinsuppPn mu x : reflect (mu x = 0) (x \notin dinsupp mu).
Definition
pr : forall {R : realType} [T : choiceType], {distr T / R} -> pred T -> R pr is not universe polymorphic Arguments pr {R} [T] mu E pr is transparent Expands to: Constant mathcomp.experimental_reals.distr.pr Declared in library mathcomp.experimental_reals.distr, line 122, characters 11-13
Definition
prc : forall {R : realType} [T : choiceType], {distr T / R} -> pred T -> pred T -> R prc is not universe polymorphic Arguments prc {R} [T] mu E A prc is transparent Expands to: Constant mathcomp.experimental_reals.distr.prc Declared in library mathcomp.experimental_reals.distr, line 123, characters 11-14
Definition
esp : forall {R : realType} [T : choiceType], {distr T / R} -> (T -> R) -> R esp is not universe polymorphic Arguments esp {R} [T] mu f%_function_scope esp is transparent Expands to: Constant mathcomp.experimental_reals.distr.esp Declared in library mathcomp.experimental_reals.distr, line 124, characters 11-14
Definition
espc : forall {R : realType} [T : choiceType], {distr T / R} -> (T -> R) -> pred T -> R espc is not universe polymorphic Arguments espc {R} [T] mu f%_function_scope A espc is transparent Expands to: Constant mathcomp.experimental_reals.distr.espc Declared in library mathcomp.experimental_reals.distr, line 125, characters 11-15
Definition
has_esp : forall {R : realType} [T : choiceType], {distr T / R} -> (T -> R) -> Prop has_esp is not universe polymorphic Arguments has_esp {R} [T] mu f%_function_scope has_esp is transparent Expands to: Constant mathcomp.experimental_reals.distr.has_esp Declared in library mathcomp.experimental_reals.distr, line 127, characters 11-18
End StdDefs.
Notation "\P_[ mu ] E" := (pr mu E).
Notation "\P_[ mu , A ] E" := (prc mu E A).
Notation "\E_[ mu ] f" := (esp mu f).
Notation "\E_[ mu , A ] f" := (espc mu f A).
Notation "\E?_[ mu ] f" := (has_esp mu f).
Notation dweight mu := (\P_[mu] predT).
Section DistrTheory.
Context {R : realType} {T : choiceType} (mu : T -> R).
Definition
isdistr : forall {R : realType} {T : choiceType}, (T -> R) -> Prop isdistr is not universe polymorphic Arguments isdistr {R T} mu%_function_scope isdistr is transparent Expands to: Constant mathcomp.experimental_reals.distr.isdistr Declared in library mathcomp.experimental_reals.distr, line 141, characters 11-18
(forall x, 0 <= mu x) /\ (forall J, uniq J -> \sum_(j <- J) mu j <= 1).
Hypothesis isd : isdistr.
Local Lemma isd1 : forall x, 0 <= mu x.
Proof.
Local Lemma isd2 : summable mu.
Proof.
Local Lemma isd3 : psum mu <= 1.
Proof.
by exists 0, fset0; rewrite big_fset0.
apply/ubP=> y [x ->]; rewrite big_fset_seq /=.
by case: isd => _; apply; case: x => x /= /canonical_uniq.
Qed.
Definition
mkdistr : forall {R : realType} {T : choiceType} [mu : T -> R], isdistr mu -> distr R T mkdistr is not universe polymorphic Arguments mkdistr {R T} [mu]%_function_scope isd mkdistr is transparent Expands to: Constant mathcomp.experimental_reals.distr.mkdistr Declared in library mathcomp.experimental_reals.distr, line 164, characters 11-18
Lemma mkdistrE : mkdistr =1 mu.
Proof.
Definition
ispredistr : forall {R : realType} {T : choiceType}, (T -> R) -> Prop ispredistr is not universe polymorphic Arguments ispredistr {R T} mu%_function_scope ispredistr is transparent Expands to: Constant mathcomp.experimental_reals.distr.ispredistr Declared in library mathcomp.experimental_reals.distr, line 169, characters 11-21
[/\ forall x, 0 <= mu x & summable mu].
End DistrTheory.
Lemma isdistr_finP {R : realType} {I : finType} (mu : I -> R) :
(isdistr mu) <-> (forall x, 0 <= mu x) /\ (\sum_j mu j <= 1).
Proof.
Lemma le1_mu1
{R : realType} {T : choiceType} (mu : {distr T / R}) x : mu x <= 1.
Section DistrD.
Context {R : realType} {T : choiceType} (mu : T -> R).
Definition
mnull : forall {R : realType} {T : choiceType}, T -> R mnull is not universe polymorphic Arguments mnull {R T} x mnull is transparent Expands to: Constant mathcomp.experimental_reals.distr.mnull Declared in library mathcomp.experimental_reals.distr, line 192, characters 11-16
Lemma isd_mnull : isdistr mnull.
Definition
dnull : forall {R : realType} {T : choiceType}, distr R T dnull is not universe polymorphic Arguments dnull {R T} dnull is transparent Expands to: Constant mathcomp.experimental_reals.distr.dnull Declared in library mathcomp.experimental_reals.distr, line 197, characters 11-16
Lemma dnullE x : dnull x = 0.
Proof.
Definition
mkdistrd : forall {R : realType} {T : choiceType}, (T -> R) -> {distr T / R} mkdistrd is not universe polymorphic Arguments mkdistrd {R T} mu%_function_scope mkdistrd is transparent Expands to: Constant mathcomp.experimental_reals.distr.mkdistrd Declared in library mathcomp.experimental_reals.distr, line 202, characters 11-19
if @idP `[< isdistr mu >] is ReflectT Px then
mkdistr (asboolW Px)
else dnull.
End DistrD.
Lemma lef_dnull {R : realType} {T : choiceType} (mu : {distr T / R}) :
dnull <=1 mu.
Section Restr.
Context {R : realType} {T : choiceType} (p : pred T).
Definition
mrestr : forall {R : realType} {T : choiceType}, pred T -> {distr T / R} -> T -> R mrestr is not universe polymorphic Arguments mrestr {R T} p mu x mrestr is transparent Expands to: Constant mathcomp.experimental_reals.distr.mrestr Declared in library mathcomp.experimental_reals.distr, line 217, characters 11-17
fun x => if p x then mu x else 0.
Lemma isd_mrestr (mu : {distr T / R}) : isdistr (mrestr mu).
Proof.
Definition
drestr : forall {R : realType} {T : choiceType}, pred T -> {distr T / R} -> distr R T drestr is not universe polymorphic Arguments drestr {R T} p mu drestr is transparent Expands to: Constant mathcomp.experimental_reals.distr.drestr Declared in library mathcomp.experimental_reals.distr, line 229, characters 11-17
Lemma drestrE (mu : {distr T / R}) x :
drestr mu x = if p x then mu x else 0.
Proof.
Section RestrTheory.
Context {R : realType} {T : choiceType}.
Lemma drestrD (mu : {distr T / R}) (p : pred T) x :
mu x = drestr p mu x + drestr (predC p) mu x.
Lemma dinsupp_restr (mu : {distr T / R}) (p : pred T) x :
(x \in dinsupp (drestr p mu)) = (x \in dinsupp mu) && p x.
Proof.
Section DRat.
Context {R : realType} (T : choiceType).
Local Notation distr := {distr T / R}.
Implicit Types (s : seq T).
Definition
mrat : forall {R : realType} [T : choiceType], seq T -> T -> R mrat is not universe polymorphic Arguments mrat {R} [T] s%_seq_scope _ mrat is transparent Expands to: Constant mathcomp.experimental_reals.distr.mrat Declared in library mathcomp.experimental_reals.distr, line 261, characters 11-15
fun x : T => (count (pred1 x) s)%:R / (size s)%:R.
Lemma ge0_mrat s : forall x, 0 <= mrat s x.
Local Lemma has_sup_mrat s J : uniq J -> \sum_(i <- J) mrat s i <= 1.
Proof.
by move=> ->; rewrite invr0 mulr0 ler01.
move=> /eqP nz_s; rewrite ler_pdivrMr ?ltr0n ?lt0n // mul1r.
rewrite ler_nat (bigID (mem s)) /= [X in (_+X)%N]big1 ?addn0.
by move=> i /count_memPn.
have ->: (size s = \sum_(i <- undup s) count_mem i s)%N.
rewrite -sum1_size -big_undup_iterop_count; apply: eq_bigr => i _.
by rewrite Monoid.iteropE iter_addn addn0 mul1n.
rewrite [X in (_<=X)%N](bigID (mem J)) /= -ltnS -addSn.
rewrite ltn_addr //= ltnS -big_filter -[X in (_<=X)%N]big_filter.
rewrite leq_eqVlt; apply/orP; left; apply/eqP/perm_big.
apply/uniq_perm; rewrite ?filter_uniq ?undup_uniq //.
by move=> x; rewrite !mem_filter mem_undup andbC.
Qed.
Local Lemma mrat_sup s : (0 < size s)%N ->
\sum_(i <- undup s) mrat s i = 1.
Proof.
Local Lemma summable_mrat s: summable (mrat s).
Proof.
by move=> j _; rewrite ger0_norm ?ge0_mrat.
by apply/has_sup_mrat.
Qed.
Lemma isd_mrat s : isdistr (mrat s).
Proof.
Definition
drat : forall {R : realType} [T : choiceType], seq T -> distr R T drat is not universe polymorphic Arguments drat {R} [T] s%_seq_scope drat is transparent Expands to: Constant mathcomp.experimental_reals.distr.drat Declared in library mathcomp.experimental_reals.distr, line 304, characters 11-15
Lemma drat1E s x :
drat s x = (count_mem x s)%:R / (size s)%:R.
Definition
dunit : forall {R : realType} [T : choiceType], T -> distr R T dunit is not universe polymorphic Arguments dunit {R} [T] x dunit is transparent Expands to: Constant mathcomp.experimental_reals.distr.dunit Declared in library mathcomp.experimental_reals.distr, line 310, characters 11-16
Definition
duni : forall {R : realType} [T : choiceType], seq T -> distr R T duni is not universe polymorphic Arguments duni {R} [T] s%_seq_scope duni is transparent Expands to: Constant mathcomp.experimental_reals.distr.duni Declared in library mathcomp.experimental_reals.distr, line 311, characters 11-15
Lemma dunit1E x y : (dunit x) y = (x == y)%:R.
Lemma duni1E s x : (duni s) x = (x \in s)%:R / (size (undup s))%:R.
Proof.
Lemma in_dunit t t' :
t' \in dinsupp (dunit t) -> t' = t :> T.
End DRat.
Section Flip.
Context {R : realType}.
Definition
mflip : forall {R : realType}, R -> bool -> R mflip is not universe polymorphic Arguments mflip {R} xt%_ring_scope b%_bool_scope mflip is transparent Expands to: Constant mathcomp.experimental_reals.distr.mflip Declared in library mathcomp.experimental_reals.distr, line 332, characters 11-16
fun b => if b then clamp xt else 1 - clamp xt.
Lemma isd_mflip xt : isdistr (mflip xt).
Proof.
+ by case: b; rewrite ?subr_ge0 cp01_clamp.
+ by rewrite /index_enum !unlock /= addr0 addrC subrK.
Qed.
Definition
dflip : forall {R : realType}, R -> distr R Datatypes_bool__canonical__choice_Choice dflip is not universe polymorphic Arguments dflip {R} xt%_ring_scope dflip is transparent Expands to: Constant mathcomp.experimental_reals.distr.dflip Declared in library mathcomp.experimental_reals.distr, line 341, characters 11-16
Lemma dflip1E xt : dflip xt =1 mflip xt.
End Flip.
Section Std.
Context {R : realType}.
Local Notation distr T := {distr T / R}.
Implicit Types (T U : choiceType).
Section Bind.
Context {T U : choiceType} (f : T -> distr U) (mu : distr T).
Definition
mlet : forall {R : realType} {T U : choiceType}, (T -> {distr U / R}) -> {distr T / R} -> U -> R mlet is not universe polymorphic Arguments mlet {R T U} f%_function_scope mu y mlet is transparent Expands to: Constant mathcomp.experimental_reals.distr.mlet Declared in library mathcomp.experimental_reals.distr, line 359, characters 11-15
Lemma isd_mlet : isdistr mlet.
Proof.
rewrite /mlet psum_bigop; first by move=> y x; rewrite mulr_ge0.
move=> u; apply/(le_summable (F2 := mu)) => //.
by move=> x; rewrite mulr_ge0 //= ler_piMr ?le1_mu1.
apply/(le_trans _ (le1_mu mu))/le_psum => //.
move=> x; rewrite sumr_ge0 /= => [y _|]; first by rewrite mulr_ge0.
rewrite -mulr_sumr ler_piMr //; apply/(le_trans _ (le1_mu (f x))).
have := summable_mu (f x) => /gerfinseq_psum => /(_ _ uqJ).
by apply/(le_trans _)/ler_sum=> y _; apply/ler_norm.
Qed.
Definition
dlet : forall {R : realType} {T U : choiceType}, (T -> {distr U / R}) -> {distr T / R} -> distr R U dlet is not universe polymorphic Arguments dlet {R T U} f%_function_scope mu dlet is transparent Expands to: Constant mathcomp.experimental_reals.distr.dlet Declared in library mathcomp.experimental_reals.distr, line 374, characters 11-15
Lemma dletE y : dlet y = psum (fun x => mu x * f x y).
Proof.
Notation "\dlet_ ( i <- d ) E" := (dlet (fun i => E) d).
Definition
dlift : forall {R : realType} {A : choiceType}, (A -> {distr A / R}) -> {distr A / R} -> distr R A dlift is not universe polymorphic Arguments dlift {R A} f%_function_scope d dlift is transparent Expands to: Constant mathcomp.experimental_reals.distr.dlift Declared in library mathcomp.experimental_reals.distr, line 382, characters 11-16
fun d => \dlet_(x <- d) f x.
Definition
diter : forall {R : realType} {A : choiceType}, nat -> (A -> {distr A / R}) -> A -> {distr A / R} diter is not universe polymorphic Arguments diter {R A} n%_nat_scope f%_function_scope a diter is transparent Expands to: Constant mathcomp.experimental_reals.distr.diter Declared in library mathcomp.experimental_reals.distr, line 385, characters 11-16
fun a => (iter n (dlift f) (dunit a)).
Section BindTheory.
Variables (T U : choiceType).
Implicit Types (f g : T -> distr U) (mu nu : distr T).
Lemma dlet_null f : dlet f dnull =1 dnull.
Lemma dlet_unit f v : \dlet_(y <- dunit v) f y =1 f v.
Proof.
Lemma dlet_dunit_id mu : \dlet_(t <- mu) (dunit t) =1 mu.
Proof.
Lemma eq_in_dlet f g mu nu : {in dinsupp mu, f =2 g} -> mu =1 nu ->
dlet f mu =1 dlet g nu.
Proof.
Lemma summable_mu_wgtd (f : T -> R) mu :
(forall x, 0 <= f x <= 1) -> summable (fun x => mu x * f x).
Proof.
exists 1 => x; case/andP: (in01_f x) => ge0_fx le1_fx.
by rewrite ger0_norm.
Qed.
Lemma summable_mlet f mu y : summable (fun x : T => mu x * (f x) y).
Proof.
Lemma le_in_dlet f g mu : {in dinsupp mu, f <=2 g} ->
dlet f mu <=1 dlet g mu.
Proof.
Lemma le_mu_dlet f mu nu : mu <=1 nu -> dlet f mu <=1 dlet f nu.
Proof.
Lemma le_dlet f g mu nu :
mu <=1 nu
-> {in dinsupp mu, forall x, f x <=1 g x}
-> \dlet_(x <- mu) f x <=1 \dlet_(x <- nu) g x.
Proof.
Lemma dletC (mu : {distr T / R}) (nu : {distr U / R}) y :
(\dlet_(_ <- mu) nu) y = (dweight mu) * (nu y).
Proof.
Lemma dinsupp_dlet f mu y :
y \in dinsupp (\dlet_(x <- mu) f x) ->
exists2 x, x \in dinsupp mu & f x y != 0.
Proof.
Lemma dlet_dinsupp f mu x y :
x \in dinsupp mu -> f x y != 0 -> y \in dinsupp (dlet f mu).
Proof.
Lemma dlet_eq0 (f : T -> U) mu y :
{in dinsupp mu, forall x, f x != y} -> (\dlet_(x <- mu) dunit (f x)) y = 0.
Proof.
Lemma eq0_dlet (mu : {distr T / R}) (F : T -> {distr U / R}) y :
(\dlet_(x <- mu) F x) y = 0 -> forall x, x \in dinsupp mu -> F x y = 0.
Proof.
Section DLetDLet.
Context {T U V : choiceType} (f1 : T -> distr U) (f2 : U -> distr V).
Lemma __deprecated__dlet_dlet (mu : {distr T / R}) :
\dlet_(x <- \dlet_(y <- mu) f1 y) f2 x
=1 \dlet_(y <- mu) (\dlet_(x <- f1 y) f2 x).
Proof.
pose S y x := mu x * (f1 x y * f2 y z).
rewrite (eq_psum (F2 := fun y => psum (S^~ y))) => [x|].
by rewrite -psumZ //; apply/eq_psum => y /=.
rewrite __admitted__interchange_psum.
+ by move=> x; apply/summableZ/summable_mlet.
+ rewrite {}/S; apply/(le_summable (F2 := mu)) => //.
move=> x; rewrite ge0_psum /= psumZ ?ler_piMr //.
apply/(le_trans _ (le1_mu (f1 x)))/le_psum => //.
by move=> y; rewrite mulr_ge0 //= ler_piMr ?le1_mu1.
apply/eq_psum=> y /=; rewrite -psumZr //.
by apply/eq_psum=> x /=; rewrite {}/S mulrA.
Qed.
Section DLetAlg.
Context {T U : choiceType} (mu mu1 mu2 : {distr T / R}).
Lemma dlet_additive (f : T -> {distr U / R}) z :
(forall x, mu x = mu1 x + mu2 x) -> (\dlet_(x <- mu) f x) z =
(\dlet_(x <- mu1) f x) z + (\dlet_(x <- mu2) f x) z.
Proof.
by move=> x; rewrite mulr_ge0. by move=> x; rewrite mulr_ge0.
by apply/summable_mlet. by apply/summable_mlet.
by apply/eq_psum=> x /=; rewrite -mulrDl -muD.
Qed.
Definition
mlim : forall {R : realType} [T : choiceType], (nat -> {distr T / R}) -> T -> R mlim is not universe polymorphic Arguments mlim {R} [T] f%_function_scope _ mlim is transparent Expands to: Constant mathcomp.experimental_reals.distr.mlim Declared in library mathcomp.experimental_reals.distr, line 543, characters 11-15
fun x => fine (nlim (fun n => f n x)).
Lemma isd_mlim T (f : nat -> distr T) : isdistr (mlim f).
Proof.
case: nlimP=> // l cvSl; apply/fine_ge0/(ncvg_geC _ cvSl).
by move=> n; apply/ge0_mu.
move=> uqJ; pose F j :=
if `[< iscvg (fun n => f n j) >] then fun n => f n j else 0%:S.
apply/(@le_trans _ _ (\sum_(j <- J) (fine (nlim (F j) (*: R*))))).
apply/ler_sum=> j _; rewrite /F; case/boolP: `[< _ >] => //.
move/asboolPn=> h; rewrite nlimC; case: nlimP=> //.
by case=> // l cf; case: h; exists l.
rewrite -lee_fin -nlim_sumR => [i _|].
rewrite /F; case/boolP: `[< _ >] => [/asboolP //|].
by move=> _; apply/iscvgC.
rewrite leNgt; apply/negP; pose s n := \sum_(j <- J) F j n.
move/ncvg_gt=> -/(_ s (nlim_ncvg _)) [].
suff: iscvg s by case=> l cs; exists l%:E.
apply/iscvg_sum=> j _; rewrite /F; case/boolP: `[< _ >].
by move/asboolP. by move=> _; apply/iscvgC.
move=> K /(_ _ (leqnn K)) /=; apply/negP; rewrite -leNgt.
apply/(@le_trans _ _ (\sum_(j <- J) f K j)); last first.
have /(gerfinseq_psum uqJ) := summable_mu (f K).
move/le_trans=> -/(_ _ (le1_mu (f K)))=> h.
by apply/(le_trans _ h)/ler_sum=> i _; apply/ler_norm.
by apply/ler_sum=> j _; rewrite /F; case/boolP: `[< _ >].
Qed.
Definition
dlim : forall {R : realType} [T : choiceType], (nat -> {distr T / R}) -> distr R T dlim is not universe polymorphic Arguments dlim {R} [T] f%_function_scope dlim is transparent Expands to: Constant mathcomp.experimental_reals.distr.dlim Declared in library mathcomp.experimental_reals.distr, line 573, characters 11-15
locked (mkdistr (isd_mlim f)).
Notation "\dlim_ ( n ) E" := (dlim (fun n => E)).
Lemma dlimE T (f : nat -> distr T) x :
(\dlim_(n) f n) x = fine (nlim (fun n => f n x)).
Proof.
Section DLimTheory.
Variables (T U : choiceType).
Implicit Types (f g : nat -> distr T) (h : T -> {distr U / R}).
Implicit Types (mu : {distr T / R}).
Lemma dlimC mu : \dlim_(n) mu =1 mu.
Lemma eq_dlim f g : f =2 g -> dlim f =1 dlim g.
Proof.
Lemma eq_from_dlim K f g :
(forall n, (K <= n)%N -> f n =1 g n) -> dlim f =1 dlim g.
Proof.
by apply/(eq_from_nlim (K := K)); move=> n /eq_fg /(_ x).
Qed.
Definition
dlim_bump : forall {R : realType} [T : choiceType] (mu0 : nat -> {distr T / R}), \dlim_(n) mu0 n.+1 =1 \dlim_(n) mu0 n dlim_bump is not universe polymorphic Arguments dlim_bump {R} [T] mu%_function_scope x dlim_bump is opaque Expands to: Constant mathcomp.experimental_reals.distr.dlim_bump Declared in library mathcomp.experimental_reals.distr, line 605, characters 11-20
dlim (fun n => mu n.+1) =1 dlim mu.
Definition
dlim_lift : forall {R : realType} [T : choiceType] (mu0 : nat -> {distr T / R}) (p : nat), \dlim_(n) mu0 (n + p) =1 \dlim_(n) mu0 n dlim_lift is not universe polymorphic Arguments dlim_lift {R} [T] mu%_function_scope p%_nat_scope x dlim_lift is opaque Expands to: Constant mathcomp.experimental_reals.distr.dlim_lift Declared in library mathcomp.experimental_reals.distr, line 609, characters 11-20
dlim (fun n => mu (n + p)%N) =1 dlim mu.
Definition
dcvg : forall {R : realType} {T : choiceType}, (nat -> {distr T / R}) -> Prop dcvg is not universe polymorphic Arguments dcvg {R T} f%_function_scope dcvg is transparent Expands to: Constant mathcomp.experimental_reals.distr.dcvg Declared in library mathcomp.experimental_reals.distr, line 613, characters 11-15
forall x, exists l, ncvg (fun n => f n x) l.
Definition
ducvg : forall {R : realType} {T : choiceType}, (nat -> {distr T / R}) -> Prop ducvg is not universe polymorphic Arguments ducvg {R T} f%_function_scope ducvg is transparent Expands to: Constant mathcomp.experimental_reals.distr.ducvg Declared in library mathcomp.experimental_reals.distr, line 616, characters 11-16
exists l, forall x, ncvg (fun n => f n x) l.
CoInductive dlim_spec f (x : T) : R -> Type :=
| DLimCvg : forall l : R, 0 <= l -> l <= 1 ->
ncvg (fun n => f n x) l%:E -> dlim_spec f x l
| DLimOut : ~ (exists l : \bar R, ncvg (fun n => f n x) l) ->
dlim_spec f x 0.
Lemma dlimP f x : dlim_spec f x (dlim f x).
Proof.
Lemma dcvgP f : dcvg f -> forall x,
exists2 l, (0 <= l <= 1) & ncvg (f^~ x) l%:E.
Proof.
Lemma dcvg_homo f :
(forall n m, (n <= m)%N -> f n <=1 f m) -> dcvg f.
Proof.
Lemma ge0_dlim f : forall x, 0 <= dlim f x.
Proof.
Lemma le1_dlim f : forall x, dlim f x <= 1.
Lemma le_dlim f g :
(forall n, f n <=1 g n) -> dcvg g -> dlim f <=1 dlim g.
Proof.
Lemma leub_dlim f mu : (forall n, f n <=1 mu) -> dlim f <=1 mu.
Proof.
Lemma dlim_ub f k :
(forall n m, (n <= m)%N -> f n <=1 f m) -> f k <=1 dlim f.
Proof.
Lemma __admitted__dlet_lim f h : (forall n m, (n <= m)%N -> f n <=1 f m) ->
\dlet_(x <- dlim f) h x =1 \dlim_(n) \dlet_(x <- f n) h x.
Proof.
Lemma __admitted__dlim_let (f : nat -> T -> {distr U / R}) (mu : {distr T / R}) :
(forall x n m, (n <= m)%N -> f n x <=1 f m x) ->
\dlim_(n) \dlet_(x <- mu) (f n x) =1
\dlet_(x <- mu) \dlim_(n) (f n x).
Proof using Type. End DLimTheory.
#[deprecated(since="mathcomp-analysis 0.6.2",
note="lacks proof, use __admitted__dlet_lim explicitly if you really want to use this lemma")]
Notation dlet_lim := __admitted__dlet_lim.
#[deprecated(since="mathcomp-analysis 0.6.2",
note="lacks proof, use __admitted__dlim_let explicitly if you really want to use this lemma")]
Notation dlim_let := __admitted__dlim_let.
Section Marginals.
Variable (T U : choiceType) (h : T -> U) (mu : distr T).
Definition
dmargin : forall {R : realType} [T U : choiceType], (T -> U) -> {distr T / R} -> distr R U dmargin is not universe polymorphic Arguments dmargin {R} [T U] h%_function_scope mu dmargin is transparent Expands to: Constant mathcomp.experimental_reals.distr.dmargin Declared in library mathcomp.experimental_reals.distr, line 705, characters 11-18
Lemma dmarginE : dmargin = \dlet_(y <- mu) (dunit (h y)).
Proof.
Section MarginalsTh.
Variable (T U V : choiceType).
Lemma dmargin_psumE (mu : {distr T / R}) (f : T -> U) y :
(dmargin f mu) y = psum (fun x => (f x == y)%:R * mu x).
Lemma __deprecated__dlet_dmargin (mu : {distr T / R}) (f : T -> U) (g : U -> {distr V / R}):
\dlet_(u <- dmargin f mu) g u =1 \dlet_(t <- mu) (g (f t)).
Proof.
by move=> y _ z; rewrite dlet_unit.
Qed.
Lemma __deprecated__dmargin_dlet (mu : {distr T / R}) (f : U -> V) (g : T -> {distr U / R}):
dmargin f (\dlet_(t <- mu) g t) =1 \dlet_(t <- mu) (dmargin f (g t)).
Proof.
Lemma dmargin_dunit (t : T) (f : T -> U):
dmargin f (dunit t) =1 dunit (f t) :> {distr U / R}.
Proof.
End Std.
#[deprecated(since="mathcomp-analysis 0.6.2",
note="relies on admitted, use __deprecated__dlet_dlet explicitly if you really want to use this lemma")]
Notation dlet_dlet := __deprecated__dlet_dlet.
#[deprecated(since="mathcomp-analysis 0.6.2",
note="relies on admitted, use __deprecated__dmargin_dlet explicitly if you really want to use this lemma")]
Notation dmargin_dlet := __deprecated__dmargin_dlet.
#[deprecated(since="mathcomp-analysis 0.6.2",
note="relies on admitted, use __deprecated__dlet_dmargin explicitly if you really want to use this lemma")]
Notation dlet_dmargin := __deprecated__dlet_dmargin.
Notation dfst mu := (dmargin fst mu).
Notation dsnd mu := (dmargin snd mu).
Notation "\dlet_ ( i <- d ) E" := (dlet (fun i => E) d).
Notation "\dlim_ ( n ) E" := (dlim (fun n => E)).
Section DSwap.
Context {R : realType} {A B : choiceType} (mu : {distr (A * B) / R}).
Definition
dswap : forall {R : realType} {A B : choiceType}, {distr (A * B) / R} -> {distr (B * A) / R} dswap is not universe polymorphic Arguments dswap {R A B} mu dswap is transparent Expands to: Constant mathcomp.experimental_reals.distr.dswap Declared in library mathcomp.experimental_reals.distr, line 760, characters 11-16
dmargin (fun xy => (xy.2, xy.1)) mu.
End DSwap.
Section DSwapCoreTheory.
Context {R : realType} {A B : choiceType} (mu : {distr (A * B) / R}).
Lemma dswapE xy : dswap mu xy = mu (xy.2, xy.1).
Proof.
Section DSwapTheory.
Context {R : realType} {A B : choiceType} (mu : {distr (A * B) / R}).
Lemma dswapK : dswap (dswap mu) =1 mu.
Proof.
Lemma dinsupp_swap xy : (xy.2, xy.1) \in dinsupp mu ->
xy \in dinsupp (dswap mu).
Lemma __deprecated__dfst_dswap : dfst (dswap mu) =1 dsnd mu.
Proof.
by move=> _ t /=; rewrite dlet_unit /=.
Qed.
Lemma __deprecated__dsnd_dswap : dsnd (dswap mu) =1 dfst mu.
Proof.
by move=> _ t /=; rewrite dlet_unit /=.
Qed.
#[deprecated(since="mathcomp-analysis 0.6.2",
note="relies on admitted, use __deprecated__dfst_dswap explicitly if you really want to use this lemma")]
Notation dfst_dswap := __deprecated__dfst_dswap.
#[deprecated(since="mathcomp-analysis 0.6.2",
note="relies on admitted, use __deprecated__dsnd_dswap explicitly if you really want to use this lemma")]
Notation dsnd_dswap := __deprecated__dsnd_dswap.
Section DFst.
Context {R : realType} {T U : choiceType}.
Lemma dfstE (mu : {distr (T * U) / R}) x :
dfst mu x = psum (fun y => mu (x, y)).
Proof.
rewrite (reindex_psum (P := [pred z | z.1 == x]) (h := h)) /=.
+ case=> a b; rewrite !inE/= mulf_eq0 => /norP[].
by rewrite pnatr_eq0 eqb0 negbK.
+ by exists snd => [z|[z1 z2]]; rewrite !inE //= => /eqP ->.
by apply/eq_psum => y; rewrite eqxx mul1r.
Qed.
Lemma summable_fst (mu : {distr (T * U) / R}) x :
summable (fun y => mu (x, y)).
Proof.
apply/summable_seqP; exists M => // J uqJ; pose X := [seq (x, y) | y <- J].
apply/(le_trans _ (h X _)); last by rewrite map_inj_uniq // => y1 y2 [].
by rewrite le_eqVlt big_map eqxx.
Qed.
Section DSnd.
Context {R : realType} {T U : choiceType}.
Lemma __deprecated__dsndE (mu : {distr (T * U) / R}) y :
dsnd mu y = psum (fun x => mu (x, y)).
Proof.
Lemma summable_snd (mu : {distr (T * U) / R}) y :
summable (fun x => mu (x, y)).
Proof.
#[deprecated(since="mathcomp-analysis 0.6.2",
note="relies on admitted, use __deprecated__dsndE explicitly if you really want to use this lemma")]
Notation dsndE := __deprecated__dsndE.
Section PrCoreTheory.
Context {R : realType} {T : choiceType}.
Implicit Types (mu : {distr T / R}) (A B E : pred T).
Lemma summable_pr E mu : summable (fun x => (E x)%:R * mu x).
Proof.
by rewrite mulr_ge0 ?ler0n //= ler_piMl // lern1 leq_b1.
Qed.
Lemma pr_pred0 mu : \P_[mu] pred0 = 0.
Lemma pr_pred1 mu x : mu x = \P_[mu] (pred1 x).
Proof.
Lemma pr_exp mu (E : pred T) : \P_[mu] E = \E_[mu] (fun m => (E m)%:R).
Lemma pr_predT mu : \P_[mu] predT = psum mu.
Lemma pr_dunit E x : \P_[dunit x] E = (E x)%:R :> R.
Proof.
Lemma exp_dunit (f : T -> R) (x : T) : \E_[dunit x] f = f x.
Proof.
Lemma exp_cst mu r : \E_[mu] (fun _ => r) = \P_[mu] predT * r.
Lemma exp0 mu : \E_[mu] (fun _ => 0) = 0.
Lemma has_expC mu c : \E?_[mu] (fun _ => c).
Proof.
Lemma has_exp0 mu : \E?_[mu] (fun _ => 0).
Proof.
Lemma has_exp1 mu : \E?_[mu] (fun _ => 1).
Proof.
Lemma has_expZ mu c F : \E?_[mu] F -> \E?_[mu] (c \*o F).
Proof.
Lemma expZ mu F c : \E_[mu] (c \*o F) = c * \E_[mu] F.
Lemma ge0_pr A mu : 0 <= \P_[mu] A.
Proof.
Lemma ge0_prc A B mu : 0 <= \P_[mu, B] A.
Lemma eq_in_pr A B mu :
{in dinsupp mu, A =i B} -> \P_[mu] A = \P_[mu] B.
Proof.
Lemma eq_pr A B mu : A =i B -> \P_[mu] A = \P_[mu] B.
Proof.
Lemma eq_exp mu (f1 f2 : T -> R):
{in dinsupp mu, f1 =1 f2} -> \E_[mu] f1 = \E_[mu] f2.
Proof.
Lemma pr_pred0_eq (mu : {distr T / R}) (E : pred T) :
E =1 pred0 -> \P_[mu] E = 0.
End PrCoreTheory.
Section PrTheory.
Context {R : realType} {T U : choiceType} {I : eqType}.
Implicit Types (mu : {distr T / R}) (A B E : pred T).
Lemma __deprecated__pr_dlet E f (mu : {distr U / R}) :
\P_[dlet f mu] E = \E_[mu] (fun x => \P_[f x] E).
Proof.
rewrite /pr; unlock dlet => /=; rewrite /mlet /=.
pose F x y := (E x)%:R * (mu y * f y x).
transitivity (psum (fun x => psum (fun y => F x y))); rewrite {}/F.
by apply/eq_psum => x; rewrite -psumZ ?ler0n.
rewrite __admitted__interchange_psum /=; last first.
apply/eq_psum=> y /=; rewrite mulrC -psumZ //.
by apply/eq_psum=> x /=; rewrite mulrCA.
+ have := summable_pr E (dlet f mu); apply/eq_summable.
by move=> x; rewrite dletE psumZ ?ler0n.
+ by move=> y; apply/summable_condl/summable_mlet.
Qed.
Lemma pr_dmargin E f (mu : {distr U / R}) :
\P_[dmargin f mu] E = \P_[mu] [pred x | f x \in E].
Proof.
Lemma eq0_pr A mu :
(forall x, x \in dinsupp mu -> x \notin A) -> \P_[mu] A = 0.
Proof.
Lemma eq0_prc A B mu :
(forall x, x \in dinsupp mu -> x \in B -> x \notin A)
-> \P_[mu, B] A = 0.
Proof.
Lemma subset_pr A B mu : {subset B <= A} -> \P_[mu] B <= \P_[mu] A.
Proof.
Lemma le1_pr A mu : \P_[mu] A <= 1.
Lemma le_exp mu f1 f2: \E?_[mu] f1 -> \E?_[mu] f2 ->
f1 <=1 f2 -> \E_[mu] f1 <= \E_[mu] f2.
Lemma le_in_pr E1 E2 mu :
(forall x, x \in dinsupp mu -> x \in E1 -> x \in E2) ->
\P_[mu] E1 <= \P_[mu] E2.
Proof.
Lemma le_mu_pr A mu nu :
(forall x, x \in dinsupp nu -> x \in A -> nu x <= mu x)
-> \P_[nu] A <= \P_[mu] A.
Proof.
Lemma le1_prc A B mu : \P_[mu, B] A <= 1.
Proof.
Lemma prc_sum A mu : 0 < \P_[mu] A ->
psum (fun x => \P_[mu, A] (pred1 x)) = 1.
Proof.
rewrite (eq_psum (F2 := (fun x => (A x)%:R * mu x))); last first.
by rewrite divff // gt_eqF.
move=> x /=; rewrite /pr (psum_finseq (r := [:: x])) ?big_seq1 //=.
move=> y; rewrite !inE; case: (y == x) => //=.
by rewrite mul0r eqxx.
by rewrite !inE eqxx -topredE ger0_norm ?mulr_ge0 ?ler0n.
Qed.
Lemma pr_eq0 mu E : \P_[mu] E = 0 -> forall x, x \in E -> mu x = 0.
Proof.
by move: xE; rewrite -topredE /= => ->; rewrite mul1r.
Qed.
Lemma prID A B mu :
\P_[mu] A = \P_[mu] [predI A & B] + \P_[mu] [predI A & predC B].
Proof.
Lemma pr_or_indep (A B : pred T) (mu : {distr T / R}) :
(forall x, x \in A -> x \notin B) ->
\P_[mu] [predU A & B] = \P_[mu] A + \P_[mu] B.
Proof.
Lemma pr_mem_map f mu (r : seq U) : uniq r ->
\P_[mu] [pred x | f x \in r]
= \sum_(y <- r) \P_[mu] [pred x | f x == y].
Proof.
case/andP=> yNr /ih {ih}h; rewrite big_cons -h -pr_or_indep.
by move=> x; rewrite !inE => /eqP->. by apply/eq_pr.
Qed.
Lemma pr_mem mu (r : seq T) : uniq r ->
\P_[mu] [pred x | x \in r] = \sum_(x <- r) mu x.
Proof.
case/andP=> yNr /ih {ih}h; rewrite big_cons /= pr_pred1.
by rewrite -h -pr_or_indep // => x /eqP ->.
Qed.
Lemma pr_bigor_indep mu (P : I -> pred T) (r : seq I) :
uniq r
-> (forall p1 p2 x, p1 != p2 -> p1 \in r -> p2 \in r -> x \in P p1 -> x \notin P p2)
-> \P_[mu] [pred x | has [pred p | x \in P p] r]
= \sum_(p <- r) \P_[mu] (P p).
Proof.
rewrite (eq_pr (B := S)) => [x|]; first by rewrite !inE -big_has.
rewrite {}/S; elim: r uq_r dj => [_|p r ih /andP[pNr /ih {ih}h]] dj.
by rewrite big_nil pr_pred0_eq // => x; rewrite big_nil.
rewrite big_cons -h => [p1 p2 x ne_p p1r p2r|].
by apply/dj=> //; rewrite in_cons (p1r, p2r) orbT.
rewrite -pr_or_indep => [x xNPp|].
rewrite -topredE /= big_has; apply/hasPn => y y_in_r.
apply/(dj p); rewrite ?in_cons ?(eqxx, y_in_r, orbT) //.
by apply/contra: pNr=> /eqP->.
by apply/eq_pr=> x; rewrite -!topredE /= big_cons.
Qed.
Lemma pr_or A B mu : \P_[mu] [predU A & B] =
\P_[mu] A + \P_[mu] B - \P_[mu] [predI A & B].
Proof.
Lemma pr_and A B mu : \P_[mu] [predI A & B] =
\P_[mu] A + \P_[mu] B - \P_[mu] [predU A & B].
Lemma ler_pr_or A B mu :
\P_[mu] [predU A & B] <= \P_[mu] A + \P_[mu] B.
Lemma ler_pr_and A B mu :
\P_[mu] [predI A & B] <= \P_[mu] A + \P_[mu] B.
Lemma pr_predC E mu: \P_[mu](predC E) = \P_[mu] predT - \P_[mu] E.
Proof.
Lemma pr_split B A mu : \P_[mu] A =
\P_[mu] B * \P_[mu, B] A
+ \P_[mu] (predC B) * \P_[mu, predC B] A.
Proof.
by rewrite (prID _ B); congr (_ + _); apply/h.
rewrite /prc mulrCA; have [] := eqVneq (\P_[mu] B') 0; last first.
by move=> nzPB'; rewrite divff // mulr1.
move=> zPB'; rewrite zPB' invr0 !mulr0; apply/eq0_pr.
move=> x mux; move/pr_eq0: zPB' => /(_ x) h; rewrite !inE.
by apply/negP=> /andP[_ /h] /dinsuppP.
Qed.
Lemma __admitted__exp_split A f mu : \E?_[mu] f -> \E_[mu] f =
\P_[mu] A * \E_[mu, A] f
+ \P_[mu] (predC A) * \E_[mu, predC A] f.
Proof using Type.
Lemma has_esp_bounded f mu :
(exists M, forall x, `|f x| < M) -> \E?_[mu] f.
Proof.
case=> M ltM; rewrite /has_esp; apply/summable_seqP.
exists (Num.max M 0); first by rewrite le_max lexx orbT.
move=> J uqJ; apply/(@le_trans _ _ (\sum_(j <- J) M * mu j)).
apply/ler_sum=> j _; rewrite normrM [X in _*X]ger0_norm //.
by apply/ler_wpM2r=> //; apply/ltW.
case: (ltrP M 0) => [lt0_M|ge0_M].
rewrite ?(ltW lt0_M) // -mulr_sumr.
by rewrite nmulr_rle0 //; apply/sumr_ge0.
by rewrite -mulr_sumr ler_piMr // -pr_mem ?le1_pr.
Qed.
Lemma bounded_has_exp mu F :
(exists M, forall x, `|F x| <= M) -> \E?_[mu] F.
Proof.
Lemma summable_has_exp mu F : summable F -> \E?_[mu] F.
Proof.
Lemma exp_le_bd mu F (M : R) :
0 <= M -> (forall x, `|F x| <= M) -> \E_[mu] F <= M.
Proof.
Lemma __admitted__exp_dlet mu (nu : T -> {distr U / R}) F :
(forall eta, \E?_[eta] F) ->
\E_[dlet nu mu] F = \E_[mu] (fun x => \E_[nu x] F).
Proof using Type*. End PrTheory.
#[deprecated(since="mathcomp-analysis 0.6.2",
note="relies on admitted, use __deprecated__pr_dlet explicitly if you really want to use this lemma")]
Notation pr_dlet := __deprecated__pr_dlet.
#[deprecated(since="mathcomp-analysis 0.6.2",
note="lacks proof, use __admitted__exp_split explicitly if you really want to use this lemma")]
Notation exp_split := __admitted__exp_split.
#[deprecated(since="mathcomp-analysis 0.6.2",
note="lacks proof, use __admitted__exp_dlet explicitly is you really want to use this lemma")]
Notation exp_dlet := __admitted__exp_dlet.
Section Jensen.
Context {R : realType} {I : finType}.
Definition
convexon : forall {R : realType}, \bar R -> \bar R -> (R -> R) -> Prop convexon is not universe polymorphic Arguments convexon {R} (a b)%_ereal_scope f%_function_scope convexon is transparent Expands to: Constant mathcomp.experimental_reals.distr.convexon Declared in library mathcomp.experimental_reals.distr, line 1225, characters 11-19
forall x y, (a <= x%:E <= b)%E -> (a <= y%:E <= b)%E ->
forall t, 0 <= t <= 1 ->
f (t * x + (1 - t) * y) <= t * (f x) + (1 - t) * (f y).
Notation convex f := (convexon -oo +oo f).
Section Jensen.
Context (f : R -> R) (x l : I -> R).
Hypothesis cvx_f : convex f.
Hypothesis ge0_l : forall x, 0 <= l x.
Hypothesis eq1_l : \sum_i (l i) = 1.
Lemma Jensen : f (\sum_i (l i * x i)) <= \sum_i (l i * f (x i)).
Proof.
by move/esym/eqP; rewrite oner_eq0.
elim: {i} s (l i) (ge0_l i) (x i) => [|j s ih] li ge0_li xi.
by rewrite !big_nil !addr0 => ->; rewrite !mul1r.
rewrite !big_cons; have := ge0_l j; rewrite le_eqVlt.
case/orP => [/eqP<-|gt0_lj].
by rewrite !Monoid.simpm /= !Monoid.simpm; apply/ih.
rewrite !addrA => eq1; pose z := (li * xi + l j * x j) / (li + l j).
have nz_lij: li + l j != 0 by rewrite gt_eqF ?ltr_wpDl.
have/ih := eq1 => -/(_ _ z); rewrite [_ * (_ / _)]mulrC.
rewrite mulfVK // => {}ih; apply/(le_trans (ih _)).
by rewrite addr_ge0 ?ge0_l.
rewrite lerD2r {ih}/z [_ / _]mulrDl ![_*_/_]mulrAC.
set c1 : R := _ / _; set c2 : R := _ / _; have eqc2: c2 = 1 - c1.
apply/(mulfI nz_lij); rewrite mulrBr mulr1 ![(li + l j)*_]mulrC.
by apply/eqP; rewrite !mulfVK // eq_sym subr_eq addrC.
set c := (li + l j); pose z := (c * c1 * f xi + c * c2 * f (x j)).
apply/(@le_trans _ _ z); last by rewrite /z ![_*(_/_)]mulrC !mulfVK.
rewrite {}/z -![c * _ * _]mulrA -mulrDr ler_wpM2l ?addr_ge0 //.
rewrite eqc2 cvx_f // ?leNye ?leey // divr_ge0 ?addr_ge0 //=.
by rewrite ler_pdivrMr ?mul1r ?lerDl ?ltr_wpDl.
Qed.
End Jensen.
Notation convex f := (convexon \-inf \+inf f).