最近参与翻译的一本书,以下是我翻译的其中一章,其余可以阅读
https://github.com/apachecn/prob140-textbook-zh
英文原文:https://nbviewer.jupyter.org/github/prob140/textbook/tree/gh-pages/notebooks/
17. 联合密度
我们现在开始研究两个连续随机变量的联合概率密度。这些方法使用单个随机变量的密度来扩展我们的计算,并且类似于在离散情况下涉及联合分布表的方法。
# HIDDEN
from datascience import *
from prob140 import *
import numpy as np
import matplotlib.pyplot as plt
plt.style.use('fivethirtyeight')
%matplotlib inline
import math
from scipy import stats
from sympy import *
init_printing()
17.1 概率和期望
# HIDDEN
from datascience import *
from prob140 import *
import numpy as np
import matplotlib.pyplot as plt
plt.style.use('fivethirtyeight')
%matplotlib inline
import math
from scipy import stats
from sympy import *
init_printing()
一个位于二维平面能够被称为联合密度的函数 f f 定义如下:
- ,对于任意的
x,y
x
,
y
- ∫x∫yf(x,y)dxdy=1 ∫ x ∫ y f ( x , y ) d x d y = 1
如果你把 f f 作为一个表面,那么第一个条件就意味着这个表面位于或者位于这个二维平面之上。第二个条件则表示在表面之下的总体积为1。
将概率视为表面下的体积,定义为随机变量 X,Y X , Y 的联合密度,
P((X,Y)∈A)=∬Af(x,y),forallA P ( ( X , Y ) ∈ A ) = ∬ A f ( x , y ) , f o r a l l A这也意味着,随机点 (X,Y) ( X , Y ) 位于区域 A A 的可能性被表示为二维区域下的体积。
这是一个二维随机变量的类比,即涉及单个连续随机变量的概率可以被认为是密度曲线下的区域。
微元
同样类似的是联合密度的解释,作为计算无穷小区域概率的一部分。
无穷小区域是在点 (x,y) ( x , y ) 周围的平面中的一个小矩形。它的长和宽分别为 dy d y 和 dx d x 。相对应的体积是该矩形框对应的体积,其底部是极小的举行,同时这个立方体的高是 f(x,y) f ( x , y ) 。
因此,对于所有的 x x 和,
P(X∈dx,Y∈dy)∼f(x,y)dxdy P ( X ∈ d x , Y ∈ d y ) ∼ f ( x , y ) d x d y
由此,联合分布的密度表示为单位面积上的概率,
f(x,y)∼P(X∈dx,Y∈dy)dxdy f ( x , y ) ∼ P ( X ∈ d x , Y ∈ d y ) d x d y一个例子可以帮助我们可视化地理解。函数 f f 被定义为
现在,假设这是一个联合分布函数,事实上,它确实是(它的积分为1)。现在让我们看看这个表面看上去是怎样的。表面绘制
为了绘制这个函数的表面,我们会使用三维绘图程序。首先,我们定义联合分布的密度函数。这个函数将 x x 和作为输入,然后返回上面定义的 f(x,y) f ( x , y ) 。
def joint(x,y): if y < x: return 0 else: return 120 * x * (y-x) * (1-y)
现在我们可以调用
plot_3d
来绘制出这个图形。调用函数的参数被限制在 x x 轴和轴,绘制函数的名字,以及两个可选参数rstride
和cstride
用于决定绘制需要使用网格线的数量。较大的数字表示越不频繁的网格线。Plot_3d(x_limits=(0,1), y_limits=(0,1), f=joint, cstride=4, rstride=4)
曲面在右下角的三角形的值为0,因为点 (X,Y) ( X , Y ) 不可能在那个区域。
对于 (X,Y) ( X , Y ) 可能的值显示如下图的蓝色区域。为了手算,我们通常仅仅绘制可能值对应的平面区域而不是立体的曲面。
# NO CODE plt.plot([0, 0], [0, 1], color='k', lw=2) plt.plot([0, 1], [0, 1], color='k', lw=2) plt.plot([0, 1], [1, 1], color='k', lw=2) xx = np.arange(0, 1.11, 0.1) yy = np.ones(len(xx)) plt.fill_between(xx, xx, yy, alpha=0.3) plt.xlim(-0.05, 1) plt.ylim(0, 1.05) plt.axes().set_aspect('equal') plt.xticks(np.arange(0, 1.1, 0.25)) plt.yticks(np.arange(0, 1.1, 0.25)) plt.xlabel('$x$') plt.ylabel('$y$', rotation=0) plt.title('Possible Values of $(X, Y)$');
表面下的总体积
函数 f f 看起来有点乱但是可以很清楚地看出它是非负的。检查表面下的总概率是否等于1是个好主意。
在整个可能值的区域上计算双重积分,需要注意的是,对于固定的值, x x 的值从0增长到,而 y y 的值从0增长到。
我们首先固定 y y 并对于积分,然后我们对于 y y 进行积分。因此,整个积分可以如下计算,
使用SymPy
为了使用
SymPy
,我们首先在单位间隔上声明两个变量,然后定义一个函数f
。以上声明并没有表示 x<y x < y ,我们需要在进行积分时加入这个条件。declare('x', interval=(0, 1)) declare('y', interval=(0, 1)) f = 120*x*(y-x)*(1-y)
双重积分则需要调用
Integral
并在参数中声明内部积分和外部积分。这个调用形式表示,- 被积分的函数是 f f
- 内部积分针对变量,其从0增长至 y y
- 外部积分针对变量,其从0增长至1
Integral(f, (x, 0, y), (y, 0, 1))
∫10∫y0120x(−x+y)(−y+1)dxdy ∫ 0 1 ∫ 0 y 120 x ( − x + y ) ( − y + 1 ) d x d y为了计算这个积分,需要用到
doit()
Integral(f, (x, 0, y), (y, 0, 1)).doit()
作为体积的概率
概率被作为联合分布密度函数曲面下的体积。换言之,它就是函数 f f 的双重积分。对于每一个概率,我们必须首先定义积分的区域,一般使用几何学和检查事件空间来检查该区域是否正确。一旦我们建立了这个积分公式,我们就可以通过来自动计算这个积分。
例子1
假设你想知道 P(Y>4X) P ( Y > 4 X ) 。那么这个事件就如下图的蓝色区域所示。
# NO CODE plt.plot([0, 0], [0, 1], color='k', lw=2) plt.plot([0, 1], [0, 1], color='k', lw=2) plt.plot([0, 1], [1, 1], color='k', lw=2) xx = np.arange(0, 0.251, 0.05) yy = np.ones(len(xx)) plt.fill_between(xx, 4*xx, yy, alpha=0.3) plt.xlim(-0.05, 1) plt.ylim(0, 1.05) plt.axes().set_aspect('equal') plt.xticks(np.arange(0, 1.1, 0.25)) plt.yticks(np.arange(0, 1.1, 0.25)) plt.xlabel('$x$') plt.ylabel('$y$', rotation=0) plt.title('$Y > 4X$');
为了找到积分的区域,首先还是需要固定 y y ,的值从0增长至 y/4 y / 4 。因此
P(Y>4X) = ∫10∫y/40120x(y−x)(1−y)dxdy= 120∫10(1−y)(∫y/40(xy−x2)dx)dy= 120(132−1192)∫10(1−y)y3dy= 120(132−1192)⋅120 = 0.15625 P ( Y > 4 X ) = ∫ 0 1 ∫ 0 y / 4 120 x ( y − x ) ( 1 − y ) d x d y = 120 ∫ 0 1 ( 1 − y ) ( ∫ 0 y / 4 ( x y − x 2 ) d x ) d y = 120 ( 1 32 − 1 192 ) ∫ 0 1 ( 1 − y ) y 3 d y = 120 ( 1 32 − 1 192 ) ⋅ 1 20 = 0.15625
使用SymPy
Integral(f, (x, 0, y/4), (y, 0, 1))
∫10∫y40120x(−x+y)(−y+1)dxdy ∫ 0 1 ∫ 0 y 4 120 x ( − x + y ) ( − y + 1 ) d x d yIntegral(f, (x, 0, y/4), (y, 0, 1)).doit()
最终积分结果得到,
532∼0.15625 5 32 ∼ 0.15625
例子2假设你想要知道 P(X>0.25,Y>0.5) P ( X > 0.25 , Y > 0.5 ) 。这个事件依旧如下图的着色区域所示。
# HIDDEN plt.plot([0, 0], [0, 1], color='k', lw=2) plt.plot([0, 1], [0, 1], color='k', lw=2) plt.plot([0, 1], [1, 1], color='k', lw=2) xx = np.arange(0.25, .52, 0.05) yy1 = 0.5*np.ones(len(xx)) yy2 = np.ones(len(xx)) plt.fill_between(xx, yy1, yy2, alpha=0.3) xx = np.arange(0.5, 1.1, 0.1) yy1 = 0.5*np.ones(len(xx)) yy2 = np.ones(len(xx)) plt.fill_between(xx, xx, yy2, alpha=0.3) plt.xlim(-0.05, 1) plt.ylim(0, 1.05) plt.axes().set_aspect('equal') plt.xticks(np.arange(0, 1.1, 0.25)) plt.yticks(np.arange(0, 1.1, 0.25)) plt.xlabel('$x$') plt.ylabel('$y$', rotation=0) plt.title('$X > 0.25, Y > 0.5$');
现在 P(X>0.25,Y>0.5) P ( X > 0.25 , Y > 0.5 ) 就是该区域的联合概率密度函数的积分。选择 y>0.5 y > 0.5 中的某个值并固定,该事件 x x 的值从增长至 y y 。然后先积分再积分 y y ,整个积分表示如下
依旧使用 SymPy S y m P y
Integral(f, (x, 0.25, y), (y, 0.5, 1))
∫10.5∫y0.25120x(−x+y)(−y+1)dxdy ∫ 0.5 1 ∫ 0.25 y 120 x ( − x + y ) ( − y + 1 ) d x d yIntegral(f, (x, 0.25, y), (y, 0.5, 1)).doit()
最终得到结果,
0.578125 0.578125
期望设定 g g 是平面上的一个函数,于是
如果存在积分,那么可以按任意顺序进行积分:先 x x 后,或者相反的顺序。这是期望的非线性函数规则的应用,应用于具有联合密度的两个随机变量。
举一个例子,针对上面提出的具有联合密度函数 f f 的变量和 Y Y ,让我们计算出。在这里 g(x,y)=yx g ( x , y ) = y x ,因此
E(YX) = ∫y∫xg(x,y)f(x,y)dxdy= ∫10∫y0yx120x(y−x)(1−y)dxdy= 120∫10y(1−y)(∫y0(y−x)dx)dy= 60∫10y3(1−y)dy = 60⋅120 = 3 E ( Y X ) = ∫ y ∫ x g ( x , y ) f ( x , y ) d x d y = ∫ 0 1 ∫ 0 y y x 120 x ( y − x ) ( 1 − y ) d x d y = 120 ∫ 0 1 y ( 1 − y ) ( ∫ 0 y ( y − x ) d x ) d y = 60 ∫ 0 1 y 3 ( 1 − y ) d y = 60 ⋅ 1 20 = 3
使用SymPy
ev_y_over_x = Integral((y/x)*f, (x, 0, y), (y, 0, 1))
∫10∫y0120y(−x+y)(−y+1)dxdy ∫ 0 1 ∫ 0 y 120 y ( − x + y ) ( − y + 1 ) d x d yev_y_over_x.doit()
得到结果,
3 317.2 独立性
# HIDDEN from datascience import * from prob140 import * import numpy as np import matplotlib.pyplot as plt plt.style.use('fivethirtyeight') %matplotlib inline import math from scipy import stats from sympy import * init_printing()
联合分布的随机变量 X X 和是独立的,当且仅当
P(X∈A,Y∈B)=P(X∈A)P(Y∈B),∀X,Y P ( X ∈ A , Y ∈ B ) = P ( X ∈ A ) P ( Y ∈ B ) , ∀ X , Y
变量 X X 的概率密度为, Y Y 的概率密度为,现在假定 X X 与相互独立,那么作为 X X 与的联合概率密度函数 f f ,
因此,如果 X X 和独立,那么他们的联合密度
f(x,y)=fX(x)fY(y) f ( x , y ) = f X ( x ) f Y ( y )
这是密度的乘积规则:两个独立随机变量的联合密度是它们密度的乘积。独立标准正态随机变量
假设 X X 和是独立同分布的标准正态随机变量(i.i.d.),因此他们的联合概率密度表示为
f(x,y)=12π−−√e−12x2⋅12π−−√e−12y2, −∞<x,y<∞ f ( x , y ) = 1 2 π e − 1 2 x 2 ⋅ 1 2 π e − 1 2 y 2 , − ∞ < x , y < ∞
等价于,
f(x,y)=12πe−12(x2+y2), −∞<x,y<∞ f ( x , y ) = 1 2 π e − 1 2 ( x 2 + y 2 ) , − ∞ < x , y < ∞
下面尝试绘制出联合概率密度的曲面图,def indep_standard_normals(x,y): return 1/(2*math.pi) * np.exp(-0.5*(x**2 + y**2)) Plot_3d((-4, 4), (-4, 4), indep_standard_normals, rstride=4, cstride=4)
需要注意该曲面整体的对称性,这是由于联合密度的式子中包含的的随机变量对 (x,y) ( x , y ) 关于 x2+y2 x 2 + y 2 对称。
同时需要注意的是 P(X=Y)=0 P ( X = Y ) = 0 ,因为概率是直线上的体积。所有具有联合密度的独立随机变量对都是如此: P(X=Y)=0 P ( X = Y ) = 0 。因此 P(X>Y)=P(X≥Y) P ( X > Y ) = P ( X ≥ Y ) 。你不必担心不等号是否应该严格。
两个服从指数分布的随机变量中较大的一个
假定 X X 和是独立随机变量,且 X∼E(λ) X ∼ E ( λ ) (服从参数为 λ λ 的指数分布), Y∼E(μ) Y ∼ E ( μ ) (服从参数为 μ μ 的指数分布)。我们这里的目标是得出 P(Y>X) P ( Y > X ) 。
由乘积规则可知, X X 和的联合概率密度函数为
f(x,y) = λe−λxμe−μy, x>0, y>0 f ( x , y ) = λ e − λ x μ e − μ y , x > 0 , y > 0
下图绘制的是 λ=0.5,μ=0.25 λ = 0.5 , μ = 0.25 的情况,因此 E(X)=2,E(Y)=4 E ( X ) = 2 , E ( Y ) = 4 。def independent_exp(x, y): return 0.5 * 0.25 * np.e**(-0.5*x - 0.25*y) Plot_3d((0, 10), (0, 10), independent_exp)
为了得出 P(Y>X) P ( Y > X ) ,我们必须上第一象限中的上三角部分对联合密度函数进行积分,该部分显示如下。
# NO CODE xx = np.arange(0, 10.1, 0.1) yy = 10*np.ones(len(xx)) plt.fill_between(xx, xx, yy, alpha=0.3) plt.axes().set_aspect('equal') plt.xlabel('$x$') plt.ylabel('$y$', rotation=0) plt.title('$Y > X$ (portion of infinite region)');
因此,这个概率等于
P(Y>X) = ∫∞0∫∞xλe−λxμe−μydydx P ( Y > X ) = ∫ 0 ∞ ∫ x ∞ λ e − λ x μ e − μ y d y d x
我们可以通过使用概率事实来计算这个双重积分而不需要很多微积分知识。
P(Y>X)=∫∞0∫∞xλe−λxμe−μydydx=∫∞0λe−λx(∫∞xμe−μydy)dx=∫∞0λe−λxe−μxdx (survival function of Y, evaluated at x)=λλ+μ∫∞0(λ+μ)e−(λ+μ)xdx=λλ+μ (total integral of exponential (λ+μ) density is 1) P ( Y > X ) = ∫ 0 ∞ ∫ x ∞ λ e − λ x μ e − μ y d y d x = ∫ 0 ∞ λ e − λ x ( ∫ x ∞ μ e − μ y d y ) d x = ∫ 0 ∞ λ e − λ x e − μ x d x (survival function of Y , evaluated at x ) = λ λ + μ ∫ 0 ∞ ( λ + μ ) e − ( λ + μ ) x d x = λ λ + μ (total integral of exponential ( λ + μ ) density is 1)
因此,
P(Y>X) = λλ+μ P ( Y > X ) = λ λ + μ
类似的是,
P(X>Y) = μλ+μ P ( X > Y ) = μ λ + μ需要注意的是以上两个值与参数( λ、μ λ 、 μ )成正比。如果你将 X X 和当作两个生命周期,那么这与直觉是一致的。如果 λ λ 偏大,相应的 X X 的生命周期就偏小,因此这个式子表明更有可能比 X X 大。
如果,那么 P(Y>X)=1/2 P ( Y > X ) = 1 / 2 ,同时对称的也是相等的值,因为 P(X=Y)=0 P ( X = Y ) = 0 。
如果我们尝试以另外一个顺序进行双重积分——先 X X 后,那么我们需要做更多的事情。
∫∞0∫y0λe−λxμe−μydxdy ∫ 0 ∞ ∫ 0 y λ e − λ x μ e − μ y d x d y
现在使用SymPy
来检查是否是相等的答案。需要注意的是
SymPy
不能使用负指数,所以我们需要改变一些函数的形式。declare('x', 'y', 'lamda', 'mu', positive=True) f_X = lamda * exp(-lamda * x) f_Y = mu * exp(-mu * y) jt_density = f_X * f_Y jt_density
λμeλxeμy λ μ e λ x e μ yp_Y_greater_than_X = Integral(jt_density, (x, 0, y), (y, 0, oo)) p_Y_greater_than_X
∫∞0∫y0λμeλxeμydxdy ∫ 0 ∞ ∫ 0 y λ μ e λ x e μ y d x d yp_Y_greater_than_X.doit()
1−μλ(1+μλ) 1 − μ λ ( 1 + μ λ )上面这个式子看起来十分奇怪,但是它其实等价于
1−μλ+μ = λλ+μ 1 − μ λ + μ = λ λ + μ
这样就和我们早先得到的答案一样。17.3 边际密度和条件密度
# HIDDEN from datascience import * from prob140 import * import numpy as np import matplotlib.pyplot as plt plt.style.use('fivethirtyeight') %matplotlib inline import math from scipy import stats from sympy import * init_printing()
假定随机变量 X X 和的联合概率密度如下,
f(x,y) = {30(y−x)4, 0<x<y<10 otherwise f ( x , y ) = { 30 ( y − x ) 4 , 0 < x < y < 1 0 otherwisedef jt_dens(x,y): if y < x: return 0 else: return 30 * (y-x)**4 Plot_3d(x_limits=(0,1), y_limits=(0,1), f=jt_dens, cstride=4, rstride=4)
然后 (X,Y) ( X , Y ) 可能的值就位于左上角三角形,
# NO CODE plt.plot([0, 0], [0, 1], color='k', lw=2) plt.plot([0, 1], [0, 1], color='k', lw=2) plt.plot([0, 1], [1, 1], color='k', lw=2) plt.xlim(-0.05, 1) plt.ylim(0, 1.05) plt.axes().set_aspect('equal') plt.xticks(np.arange(0, 1.1, 0.25)) plt.yticks(np.arange(0, 1.1, 0.25)) plt.xlabel('$x$') plt.ylabel('$y$', rotation=0) plt.title('Possible Values of $(X, Y)$');
这里使用
SymPy
快速检查保证函数 f f 是一个联合概率密度,declare('x', interval=(0, 1)) declare('y', interval=(0, 1)) joint_density = 30*(y-x)**4
Integral(joint_density, (y, x, 1), (x, 0, 1)).doit()
的密度
我们可以使用联合分布 f f 来得到的边缘分布,记为 fX f X 。我们知道
fX(x)dx∼P(X∈dx)=∫yP(X∈dx,Y∈dy)=∫yf(x,y)dxdy=(∫yf(x,y)dy)dx f X ( x ) d x ∼ P ( X ∈ d x ) = ∫ y P ( X ∈ d x , Y ∈ d y ) = ∫ y f ( x , y ) d x d y = ( ∫ y f ( x , y ) d y ) d x
在下面这副图,你可以看到这样计算的推论。蓝线表示事件 X∈dx X ∈ d x 非常靠近0.25。为了得出 P(X∈dx) P ( X ∈ d x ) 所对应的体积,我们固定 x x 然后加上所有的。# NO CODE plt.plot([0, 0], [0, 1], color='k', lw=2) plt.plot([0, 1], [0, 1], color='k', lw=2) plt.plot([0, 1], [1, 1], color='k', lw=2) plt.plot([0.25, 0.25], [0.25, 1], color='blue', lw=3, alpha=0.3) plt.xlim(-0.05, 1) plt.ylim(0, 1.05) plt.axes().set_aspect('equal') plt.xticks(np.arange(0, 1.1, 0.25)) plt.yticks(np.arange(0, 1.1, 0.25)) plt.xlabel('$x$') plt.ylabel('$y$', rotation=0) plt.title('$X \in dx$');
因此 X X 的分布密度函数可以由下式得到,
通过与离散情况类比, fX f X 也被称为 X X 的边缘密度。
在我们这里举的例子中,可能的值是左上角的三角形。因此,对于每个固定的 x x ,可能的值是从 x x 至1。
所以,例子中的密度可以如下计算,
fX(x)=∫1x30(y−x)4dy=30⋅15(y−x)5∣∣1x=6(1−x)5 f X ( x ) = ∫ x 1 30 ( y − x ) 4 d y = 30 ⋅ 1 5 ( y − x ) 5 | x 1 = 6 ( 1 − x ) 5
这里再次出现了联合分布密度函数的曲面图形,可以从图中看到 X X 相较于1更靠近0。Plot_3d(x_limits=(0,1), y_limits=(0,1), f=jt_dens, cstride=4, rstride=4)
通过的边缘密度分布可以看到类似的图形,
# NO CODE x_vals = np.arange(0, 1.01, 0.01) f_X = 6*(1-x_vals)**5 plt.plot(x_vals, f_X, color='darkblue', lw=2) plt.xlabel('$x$') plt.ylabel('$f_X(x)$', rotation=0) plt.title('$f_X$: Density of $X$');
Y Y 的密度
相应地,的密度函数可以通过固定 y y 并对进行积分得到,
fY(y)=∫xf(x,y)dx for all y f Y ( y ) = ∫ x f ( x , y ) d x for all y
在我们的例子中,联合分布的密度函数曲面表明 Y Y 更接近于1,这也能通过计算证明。需要牢记的是,因此对于每个固定的 y y 值,的值从0增长至 y y 。对于,
fY(y) = ∫y030(y−x)4dx = 6y5 f Y ( y ) = ∫ 0 y 30 ( y − x ) 4 d x = 6 y 5# NO CODE y_vals = np.arange(0, 1.01, 0.01) f_Y = 6*y_vals**5 plt.plot(y_vals, f_Y, color='darkblue', lw=2) plt.xlabel('$y$') plt.ylabel('$f_Y(y)$', rotation=0) plt.title('$f_Y$: Density of $Y$');
条件密度
考虑到条件概率 P(Y∈dy∣X∈dx) P ( Y ∈ d y ∣ X ∈ d x ) 。依据除法法则,
P(Y∈dy∣X∈dx) = P(X∈dx,Y∈dy)P(X∈dx) = f(x,y)dxdyfX(x)dx = f(x,y)fX(x)dy P ( Y ∈ d y ∣ X ∈ d x ) = P ( X ∈ d x , Y ∈ d y ) P ( X ∈ d x ) = f ( x , y ) d x d y f X ( x ) d x = f ( x , y ) f X ( x ) d y
这同样暗示了一个对于概率密度的除法法则。给定值 x x ,的条件概率是
fY∣X=x(y) = f(x,y)fX(x) for all y f Y ∣ X = x ( y ) = f ( x , y ) f X ( x ) for all y
因为变量 X X 也有一个边缘概率密度函数,我们知道对于任意的, P(X=x)=0 P ( X = x ) = 0 。但是上面的比率 fY|X=x(y) f Y | X = x ( y ) 并不是一个概率。可能赋予更多的直觉“给定 X=x X = x ”意味着“给定的 X X 位于附近”。可以看出,条件分布密度的形状就是联合分布密度图中位于 x x 点的垂直截面。式子中的分子决定了形状,分母是常数部分保证了这个密度分布积分结果为1。
需要谨记的是,在这个公式中是常数,所以分母 fX(x) f X ( x ) 对于所有的 y y 都是相等的。
为了确认条件概率密度真的是积分为1,让我们完成这个这个积分计算。
在我们这个例子中,假定 x=0.2 x = 0.2 ,然后考虑计算 Y Y 的条件密度(给定)。在这个条件下, Y Y 可能的值从0.4到1,因此,
这是就是在 (0.4,1) ( 0.4 , 1 ) 区间的条件概率密度declare('y', interval=(0.4, 1)) cond_density = (5/(0.6**5)) * (y - 0.4)**4 Integral(cond_density, (y, 0.4, 1)).doit()
得到结果
0.999999999999999 0.999999999999999下面的图就展示了 Y Y 的边缘密度与给定时 Y Y 的条件概率,可以看到条件概率更多集中在较大的值。
# NO CODE plt.plot(y_vals, f_Y, color='darkblue', lw=2, label='Density of $Y$') new_y = np.arange(0.4, 1.01, 0.01) dens = (5/(0.6**5)) * (new_y - 0.4)**4 plt.plot(new_y, dens, color='gold', lw=2, label='Density of $Y$ given $X=0.4$') plt.legend() plt.xlim(0, 1) plt.xlabel('$y$');
使用条件概率
我们通过使用条件概率来计算得到概率和期望,就像我们使用普通的分布密度。下面会举多个计算示例,在每个例子中我们建立积分公式然后使用
SymPy
。
P(Y>0.9∣X=0.4)=∫10.950.65(y−0.4)4dy P ( Y > 0.9 ∣ X = 0.4 ) = ∫ 0.9 1 5 0.6 5 ( y − 0.4 ) 4 d y
上面的示例结果是 60% 60 % 。declare('y', interval=(0, 1)) cond_density = (5/(0.6**5))*(y - 0.4)**4 Integral(cond_density, (y, 0.9, 1)).doit()
0.598122427983537 0.598122427983537现在我们使用条件概率计算条件期望。记住,在我们的例子中,给定 X=0.4 X = 0.4 时 Y Y 可能的值从至1。
E(Y∣X=0.4) = ∫10.4y50.65(y−0.4)4dy = 0.9 E ( Y ∣ X = 0.4 ) = ∫ 0.4 1 y 5 0.6 5 ( y − 0.4 ) 4 d y = 0.9Integral(y*cond_density, (y, 0.4, 1)).doit()
0.899999999999998 0.899999999999998对于任意固定的 y y 值,给定值时 X X 的条件概率是
在这一节的所有例子同时与前一节的都开始于一个突然出现的联合密度函数。在下一节里,我们将开始研究它们出现的情况。17.4 具有整数参数的Beta密度
# HIDDEN from datascience import * from prob140 import * import numpy as np import matplotlib.pyplot as plt plt.style.use('fivethirtyeight') %matplotlib inline import math from scipy import stats from sympy import * init_printing()
在上一节我们学会了如何使用联合分布的密度函数,但是许多的联合分布密度都像是无中生有。举一个例子,我们检查函数
f(x,y)=120x(y−x)(1−y), 0<x<y<1 f ( x , y ) = 120 x ( y − x ) ( 1 − y ) , 0 < x < y < 1
是否时一个联合密度,但是并没有展示这个是从何而来。在这一节,我们将追溯源头同时尝试在单位间隔上拓展出一个重要的分布密度函数族。独立均匀分布 (0,1) ( 0 , 1 ) 变量的次序统计量
假定 U1,U2,...,Un U 1 , U 2 , . . . , U n 是在 (0,1) ( 0 , 1 ) 均匀分布上的独立变量。想象每一个 Ui U i 就是一个飞镖扔向单位间隔的具体位置,下图展示了5支飞镖(星号)的位置。
# NO CODE plt.plot([0, 1], [0, 0], color='k', lw=2) y = 1 - np.ones(5) x = stats.uniform.rvs(size=5) order_stats = np.sort(x) plt.scatter(x, y, marker='*', color='r', s=100) plt.text(0, -0.0007, r'0', size=16) plt.text(0.98, -0.0007, r'1', size=16) plt.xlim(0, 1) plt.yticks([]) plt.xticks([]) plt.title('Five IID Uniform (0, 1) Variables');
基于上面的图,你能指出哪个星号代表 U1 U 1 。不,你不能,因为 U1 U 1 可能是五个位置中的任意一个。所以你也不饿能分辨出 U1,U2,U3,U4,U5 U 1 , U 2 , U 3 , U 4 , U 5 五个变量。
你能看到的只是 Ui U i 的增长序列。你可以看到最小值,排序后的第二大的值,以及第三大、第四大和第五大的值。
这些值被称作 U1,U2,U3,U4,U5 U 1 , U 2 , U 3 , U 4 , U 5 的次序统计量,并被记为 U(1),U(2),U(3),U(4),U(5) U ( 1 ) , U ( 2 ) , U ( 3 ) , U ( 4 ) , U ( 5 ) 。
请记住,因为 Ui U i 是具有密度的独立随机变量,所以它们之间不存在联系:两个变量相等的概率为0。
# NO CODE plt.plot([0, 1], [0, 0], color='k', lw=2) order_stats = np.sort(x) plt.scatter(x, y, marker='*', color='r', s=100) u_labels = make_array('$U_{(1)}$', '$U_{(2)}$', '$U_{(3)}$', '$U_{(4)}$', '$U_{(5)}$') for i in range(5): plt.text(order_stats[i], -0.0007, u_labels[i], size=16) plt.text(0, -0.0007, r'0', size=16) plt.text(0.98, -0.0007, r'1', size=16) plt.xlim(0, 1) plt.yticks([]) plt.xticks([]) plt.title('Order Statistics of the Five IID Uniform (0, 1) Variables');
总之对于 1≤k≤n 1 ≤ k ≤ n ,当 Ui U i 以升序排列时, U1,U2,U3,U4,U5 U 1 , U 2 , U 3 , U 4 , U 5 中的第 k k 个次序统计量是第大的值。
两个次序统计量的联合分布密度
假定 n=5 n = 5 ,同时在这里我们尝试计算 U(2) U ( 2 ) 和 U(4) U ( 4 ) 的联合分布,这代表第二大和第四大的联合分布。
下面这幅图展示了事件 {U(2)∈dx,U(4)∈dy} { U ( 2 ) ∈ d x , U ( 4 ) ∈ d y } 对于所有的 x x 、值,其中 0<x<y<1 0 < x < y < 1 。
# NO CODE plt.plot([0, 1], [0, 0], color='k', lw=2) y = 1 - np.ones(5) x = make_array(0.1, 0.3, 0.45, 0.7, 0.9) plt.scatter(x, y, marker='*', color='r', s=100) plt.plot([0.28, 0.32], [0, 0], color='gold', lw=2) plt.text(0.28, -0.0007, r'$dx$', size=16) plt.plot([0.68, 0.72], [0, 0], color='gold', lw=2) plt.text(0.68, -0.0007, r'$dy$', size=16) plt.text(0, -0.0007, r'0', size=16) plt.text(0.98, -0.0007, r'1', size=16) plt.xlim(0, 1) plt.yticks([]) plt.xticks([]) plt.title('$n = 5$; $\{ U_{(2)} \in dx, U_{(4)} \in dy \}$');
为了得出 P(U(2)∈dx,U(4)∈dy) P ( U ( 2 ) ∈ d x , U ( 4 ) ∈ d y ) ,首先可以看出:
- U1,U2,U3,U4,U5 U 1 , U 2 , U 3 , U 4 , U 5 中的一个必定是 dx d x ,这里共有5种情况。
- 剩下的4个变量,其中一个必定是 dy d y ,这里共有4种情况。
- 剩下的3个变量中,其中一个必定在 (0,x) ( 0 , x ) 。
- 剩下的2个变量中,其中一个必定在 (x,y) ( x , y ) 。
- 最后一个变量则必定在 (x,y) ( x , y ) 。
那么,
P(U(2)∈dx,U(4)∈dy) ∼ 5(1dx)⋅4(1dy)⋅3x⋅2(y−x)⋅1(1−y) = 120x(y−x)(1−y)dxdy P ( U ( 2 ) ∈ d x , U ( 4 ) ∈ d y ) ∼ 5 ( 1 d x ) ⋅ 4 ( 1 d y ) ⋅ 3 x ⋅ 2 ( y − x ) ⋅ 1 ( 1 − y ) = 120 x ( y − x ) ( 1 − y ) d x d y
因此 U(2) U ( 2 ) 与 U(4) U ( 4 ) 的条件概率为,
f(x,y)=120x(y−x)(1−y), 0<x<y<1 f ( x , y ) = 120 x ( y − x ) ( 1 − y ) , 0 < x < y < 1
这个也就解释了这个式子是如何出现的。但是它能体现更多的东西。服从 (0,1) ( 0 , 1 ) 均匀分布的独立次序统计量的边缘密度构成了在数据科学中非常重要的一类分布函数族。
U(k) U ( k ) 的密度
假定 U(k) U ( k ) 是 U1,U2,…,Un U 1 , U 2 , … , U n 的第 k k 大的次序统计量。我们这次通过与以前一样的手法得出的密度函数。
下面这幅图展示了事件 {U(k)∈dx} { U ( k ) ∈ d x } 。当这个事件发生时,
- dx d x 必定是 U1,U2,…,Un U 1 , U 2 , … , U n 其中一个。
- 剩下的 n−1 n − 1 个变量中,必定有 k−1 k − 1 个位于 (0,x) ( 0 , x ) ,其余的位于 (x,1) ( x , 1 ) 。
# NO CODE plt.plot([0, 1], [0, 0], color='k', lw=2) plt.scatter(0.4, 0, marker='*', color='r', s=100) plt.plot([0.38, 0.42], [0, 0], color='gold', lw=2) plt.text(0.38, -0.0007, r'$dx$', size=16) plt.text(0.1, 0.001, '$k-1$ stars', size=16) plt.text(0.1, 0.0005, 'in $(0, x)$', size=16) plt.text(0.6, 0.001, '$n-k$ stars', size=16) plt.text(0.6, 0.0005, 'in $(x, 1)$', size=16) plt.text(0, -0.0007, r'0', size=16) plt.text(0.98, -0.0007, r'1', size=16) plt.xlim(0, 1) plt.yticks([]) plt.xticks([]) plt.title('$\{ U_{(k)} \in dx \}$');
这里共有 n n 种方法来选择的位置,一旦选定,剩下的 n−1 n − 1 个变量种 k−1 k − 1 个位于 (0,x) ( 0 , x ) 。那么,
P(U(k)∈dx)∼n⋅1dx⋅(n−1k−1)xk−1(1−x)n−k P ( U ( k ) ∈ d x ) ∼ n ⋅ 1 d x ⋅ ( n − 1 k − 1 ) x k − 1 ( 1 − x ) n − k
因此 U(k) U ( k ) 的密度函数为
fU(k)(x)=n!(k−1)!(n−k)!xk−1(1−x)n−k, 0<x<1 f U ( k ) ( x ) = n ! ( k − 1 ) ! ( n − k ) ! x k − 1 ( 1 − x ) n − k , 0 < x < 1
让我们重写一下上面这个公式,
fU(k)(x)=n!(k−1)!((n−k+1)−1)!xk−1(1−x)(n−k+1)−1, 0<x<1 f U ( k ) ( x ) = n ! ( k − 1 ) ! ( ( n − k + 1 ) − 1 ) ! x k − 1 ( 1 − x ) ( n − k + 1 ) − 1 , 0 < x < 1
因为 1≤k≤n 1 ≤ k ≤ n ,我们知道 n−k+1 n − k + 1 是一个正整数。同时由于 n n 是一个任意正整数,所以也一样。Beta密度
我们已经展示了如果 s s 和是任意两个正整数,那么函数
f(x) = (r+s−1)!(r−1)!(s−1)!xr−1(1−x)s−1, 0<x<1 f ( x ) = ( r + s − 1 ) ! ( r − 1 ) ! ( s − 1 ) ! x r − 1 ( 1 − x ) s − 1 , 0 < x < 1
就是一个概率密度函数。这个函数被称为参数为 r r 和的beta密度函数。次序统计量 U(k) U ( k ) 就是一个参数为 k k 和的beta密度函数。
密度的形状由 x x 和决定。所有的阶乘只是常数的部分以确保密度函数积分为1。
有趣的是, (0,1) ( 0 , 1 ) 均匀分布同样属于beta密度函数(参数 r=1 r = 1 与 s=1 s = 1 ),也就是说, (0,1) ( 0 , 1 ) 均匀分布同样是beta函数族的一员。
下图展示了某些beta密度函数曲线。正如你期望的,参数为 (3,3) ( 3 , 3 ) 的beta密度函数曲线关于0.5对称。
x = np.arange(0, 1.01, 0.01) for i in np.arange(1, 7, 1): plt.plot(x, stats.beta.pdf(x, i, 6-i), lw=2) plt.title('Beta $(i, 6-i)$ densities for $1 \leq i \leq 5$');
通过选择合适的参数,你可以创造一个beta密度函数并且使得它的重量(期望)趋近于一个预定的值。这是beta密度函数常常被用于建模随机比率的原因之一。例如,如果你想垃圾邮件的概率更趋近于 60% 60 % 至 90% 90 % 之间,也许更低,你可以通过选择密度使其尖峰在 0.75 0.75 附近来表示这一个先验倾向。
Beta函数积分
将beta密度函数积分至1,那么对于任意的正整数 r r 和,我们有
∫10xr−1(1−x)s−1dx = (r−1)!(s−1)!(r+s−1)! ∫ 0 1 x r − 1 ( 1 − x ) s − 1 d x = ( r − 1 ) ! ( s − 1 ) ! ( r + s − 1 ) !
因此概率论简化了其他方面的工作。同时,我们可以计算出服从beta分布的随机变量的期望。让 X X 服从分布,那么
E(X)=∫10x(r+s−1)!(r−1)!(s−1)!xr−1(1−x)s−1dx=(r+s−1)!(r−1)!(s−1)!∫10xr(1−x)s−1dx=(r+s−1)!(r−1)!(s−1)!⋅r!(s−1)!(r+s)! (beta integral for parameters r+1and s)=rr+s E ( X ) = ∫ 0 1 x ( r + s − 1 ) ! ( r − 1 ) ! ( s − 1 ) ! x r − 1 ( 1 − x ) s − 1 d x = ( r + s − 1 ) ! ( r − 1 ) ! ( s − 1 ) ! ∫ 0 1 x r ( 1 − x ) s − 1 d x = ( r + s − 1 ) ! ( r − 1 ) ! ( s − 1 ) ! ⋅ r ! ( s − 1 ) ! ( r + s ) ! (beta integral for parameters r + 1 and s ) = r r + s
你可以使用同样的方法计算出 E(X2) E ( X 2 ) 与 Var(X) V a r ( X ) 。期望的公式同样允许你依据先验知识选择参数。例如,如果你想要这个比率在 0.4 0.4 附近,你可以尝试参数 r=2 r = 2 和 s=3 s = 3 的bata函数。
也许你会注意到beta密度函数的形式十分二项式。事实上,我们使用二项式来推导出beta密度函数。接下来的教程里面你会看到beta密度与二项式之间另一个更近的联系。这些特性使得beta函数族成为机器学习中使用最广泛的密度系列之一。
本作品采用知识共享署名-非商业性使用-禁止演绎 4.0 国际许可协议进行许可。