中心极限定理与Python图解

中心极限定理与Python图解

方差与z-score标准化

方差公式V[X]=E((XE(X))2)V[X]=E\left((X-E(X))^{2}\right),也表示为σ2=(Xμ)2N\sigma^{2}=\frac{\sum(X-\mu)^{2}}{N}

方差描述的是分布的离散程度,方差为0时则X=E(X)X=E(X),即分布不含有任何随机的成分。

由于数据加常量后其方差σ2\sigma^2不变,乘以nn后则变为n2σ2n^2\sigma^2,所以对任何分布的数据都可以做一个标准化(z-score),使得方差σ2=1\sigma^2=1,期望μ=0\mu=0。具体做法为:

W=XμσW=\frac{X-\mu}{\sigma}

import numpy as np
import matplotlib.pyplot as plt

X = np.random.rand(1000)

fig, (axs1, axs2) = plt.subplots(1, 2, figsize=(9, 4))

axs1.plot(X, '.')
axs1.set_ylim(-2, 2)

axs2.hist(X, edgecolor='k', alpha=0.8)
plt.show()

print("mean:", np.round(X.mean(), 2), "std:", np.round(X.std(), 2))

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-WlwuPYyG-1592485360789)(https://static01.imgkr.com/temp/bf9cd8999ba24d929380bee8f5e8835c.png)]

mean: 0.5 std: 0.29

进行z-score标准化z=xμσz=\frac{x-\mu}{\sigma}操作(证明过程见下一小节)

W = (X - X.mean())/X.std()

mean = W.mean()
std_var = W.std()

fig, (axs1, axs2) = plt.subplots(1, 2, figsize=(9, 4))

axs1.plot(W, '.')
axs1.set_ylim(-2, 2)

axs2.hist(W, edgecolor='k', alpha=0.8)
plt.show()

print("mean:", np.round(W.mean(), 2), "std:", np.round(W.std(), 2))

mean: -0.0 std: 1.0

打印的信息显示新的数据均值为0,方差为1,但是histgram显示出每个bin(默认10个)的数据数量没有变化。

z-score证明

假设一组数据{X:x1,x2...xn}\{X: x_1,x_2...x_n\}的均值为μ=inxin\mu=\sum_i^n\frac{x_i}{n},方差为σ=in(xiμ)2n\sigma=\sum_i^n \frac{(x_i-\mu)^2}{n},经过z-score标准化的数据{Z:zi=xiμσ}\{Z: z_i=\frac{x_i-\mu}{\sigma}\}

ZZ的均值
E(Z)=inxiμσn=inxinσinμnσ=μσμσ=0\begin{aligned}E(Z) &= \sum_i^n\frac{\frac{x_i-\mu}{\sigma}}{n}\\ &= \sum_i^n\frac{x_i}{n\sigma} - \frac{\sum_i^n\mu}{n\sigma}\\ &= \frac{\mu}{\sigma} - \frac{\mu}{\sigma}\\ &= 0\end{aligned}

ZZ的方差(已经得知μz=0\mu_z=0
V(Z)=in((xiμ)σμz)2n=1σ2in(xiμ)2n=σ2σ2=1\begin{aligned}V(Z) &= \sum_i^n \frac{\left(\frac{(x_i-\mu)}{\sigma} - \mu_z\right)^2}{n}\\ &= \frac{1}{\sigma^2}\sum_i^n\frac{(x_i-\mu)^2}{n}\\ &= \frac{\sigma^2}{\sigma^2} = 1 \end{aligned}

标准正态分布

对于正态分布xN(μ,σ2)x \sim N\left(\mu, \sigma^{2}\right),其概率密度函数如下:

f(x)=12πσexp((xμ)22σ2)f(x)=\frac{1}{\sqrt{2 \pi} \sigma} \exp \left(-\frac{(x-\mu)^{2}}{2 \sigma^{2}}\right)

如果μ=0,σ=1\mu=0, \sigma=1,则称为标准正态分布xN(μ,σ2)x \sim N\left(\mu, \sigma^{2}\right),概率密度函数简化为:

f(x)=12πexp(x22)f(x)=\frac{1}{\sqrt{2 \pi}} \exp \left(-\frac{x^2}{2}\right)

def NormDist(x, mean=0, sigma=1):
    assert(sigma != 0)
    return np.exp(-(x-mean)**2/2)/(np.sqrt(2*np.pi)*sigma)

plt.figure(figsize=(8, 6))

xs = np.linspace(-5, 5, 100)
X = [NormDist(i) for i in xs]
plt.plot(xs, X, '-', label=r'$\frac{1}{\sqrt{2\pi}\sigma}exp(\frac{-x^2}{2})$')

X = [np.exp(-i**2/2) for i in xs]
plt.plot(xs, X, '--', label=r'$exp(\frac{-x^2}{2})$')

X = [np.exp(-i**2) for i in xs]
plt.plot(xs, X, '--', label=r'$exp(-x^2)$')

plt.legend(fontsize=14)
plt.show()

从上图可以看出:1. 由于x2-x^2的存在使得在0点处左右对称,并且xx越接近于0越大;2. 而12π\frac{1}{\sqrt{2\pi}}ee的指数除以1/21/2使得其面积(在x轴上积分)为1,满足了概率密度函数积分为1的性质。

z-score变换为标准正态分布

正态分布xN(μ,σ2)x \sim N\left(\mu, \sigma^{2}\right)经过z-score标准化后会变成标准正态分布。证明过程如下

正态分布概率密度函数
f(x)=12πσexp((xμ)22σ2)f(x)=\frac{1}{\sqrt{2 \pi} \sigma} \exp \left(-\frac{(x-\mu)^{2}}{2 \sigma^{2}}\right)

其精髓和意义就是通过对f(x)f(x)积分,可以得到xx在任意区间的概率,例如x<kx \lt k的概率:

P(x<k)=k12πσexp((xμ)22σ2)dxP(x \lt k)=\int_{-\infty}^{k} \frac{1}{\sqrt{2 \pi} \sigma} \exp \left(-\frac{(x-\mu)^{2}}{2 \sigma^{2}}\right) \mathrm{d} x

经过z-score标准化的新数据为z=xμσz=\frac{x-\mu}{\sigma},那么z<kz \lt k的概率:

P(z<k)=P(xμσ<k)=P(x<kσ+μ)P(z \lt k) = P\left(\frac{x-\mu}{\sigma} \lt k\right) = P(x \lt k\sigma + \mu)

kσ+μk\sigma + \mu代入积分公式,替换上限kk

P(x<kσ+μ)=kσ+μ12πσexp((xμ)22σ2)dxP(x \lt k\sigma + \mu) = \int_{-\infty}^{k\sigma + \mu} \frac{1}{\sqrt{2 \pi} \sigma} \exp \left(-\frac{(x-\mu)^{2}}{2 \sigma^{2}}\right) \mathrm{d} x

可是我们要求的是z<kz < k的概率P(z<k)P(z < k),由于P(z<k)=P(x<kσ+μ)P(z\lt k) = P(x \lt k\sigma + \mu),只需要将x=zσ+μx = z\sigma + \mu只要代入积分公式替换掉xx即可:

P(z<k)=k12πσexp((zσ+μμ)22σ2)σdz=k12πexp(z22)dz\begin{aligned} P(z\lt k) &=\int_{-\infty}^{k} \frac{1}{\sqrt{2 \pi} \sigma} \exp \left(-\frac{(z \sigma+\mu-\mu)^{2}}{2 \sigma^{2}}\right) \sigma \mathrm{d} z \\ &=\int_{\infty}^{k} \frac{1}{\sqrt{2 \pi}} \exp \left(-\frac{z^{2}}{2}\right) \mathrm{d} z \end{aligned}

注意两点:

  1. 积分xx的上限为x=kσ+μx^*=k\sigma + \mu,新变量zz的上限为xμσ=kσ+μμσ=k\frac{x^*-\mu}{\sigma} = \frac{k\sigma + \mu - \mu}{\sigma} = k
  2. x=zσ+μx=z\sigma + \mu两边求导,得到dx=σdzdx=\sigma dz

至此,证明得到z-score变化后的数据服从标准正态分布zN(0,1)z \sim N(0, 1)

中心极限定理

The central limit theorem in statistics states that, given a sufficiently large sample size, the sampling distribution of the mean for a variable will approximate a normal distribution regardless of that variable’s distribution in the population.

名词解释

在统计学中,有一些专用名词不能弄混淆,特别是我们平时说的“样本”在这里并不是指单个数据,参见Central Limit Theorem Explained

  • 总体(population):研究对象的整个群体(the complete set of all objects or people of interest)
  • 样本(sample):从总体中选取的一部分数据(a subset of the entire population)
  • 样本数量(the number of samples):有多少个样本。
  • 样本大小/样本容量(sample size):每个样本里包含多少个数据。
  • 抽样分布(sampling distribution):将样本平均值的分布可视化。

定义

对于独立同分布的变量X1,X2,X3...XnX_1, X_2, X_3 ... X_n,其中E(Xi)=μ, V(Xi)=σ2<E(X_i)=\mu,\ V(X_i)=\sigma^2 < \infty,这组样本的均值表示为:

Xˉn:=X1++Xnn\bar{X}_{n}:=\frac{X_{1}+\cdots+X_{n}}{n}

中心极限定理研究的就是这个Xnˉ\bar{X_n}的分布情况,而不是XX的分布情况,因为现实中很多数据我们是无法获得其总体(population)分布情况的,而中心极限定理可以帮助我们分析其均值位置。

不同的nn或者不同的样本都会影响Xnˉ\bar{X_n},直觉上Xnˉ\bar{X_n}是和E(Xi)E(X_i)有关的,而且是围绕着E(Xi)E(X_i)的。如果对这组数据做z-score标准化得到Yn=(Xiμ)/σY_n = (X_i-\mu)/\sigma,标准化后的样本均值

Yˉn=in(Xiμσ)n=inxinσμσ\bar{Y}_n = \frac{\sum_i^n(\frac{X_i - \mu}{\sigma})}{n} = \sum_i^n{\frac{x_i}{n\sigma}} - \frac{\mu}{\sigma}

由大数定律(大数定律、中心极限定理与格里文科定理)可知,当n+n\rightarrow+\infty时,{Xi,i=1,2,...,n}\{X_i, i=1,2,...,n\}以概率1收敛于期望μ\mu,因此得到

limnYˉn0\lim_{n\rightarrow\infty} \bar{Y}_n \rightarrow 0

现在给出中心极限定理的定义:

limn+P{Xnˉμσ/nx}=12πxet22dt\lim _{n \rightarrow+\infty} P\left\{\frac{\bar{X_n}-\mu}{\sigma / \sqrt{n}} \leqslant x\right\}=\frac{1}{\sqrt{2 \pi}} \int_{-\infty}^{x} e^{\frac{-t^{2}}{2}} d t

公式左边相当于对Xˉn\bar{X}_n做了类似z-score的处理,减去总体均值μ\mu,并除以σ/n\sigma/\sqrt{n},右边就是标准正态分布N(0,1)N(0,1)的概率密度函数的积分,也就是说当样本容量极大时,样本均值的抽样分布趋近于期望为μ\mu,标准差为σn\frac{\sigma}{\sqrt{n}}的正态分布。如果将分子分母同乘以nn,那么可以得到XiX_i和的表示形式

i=1nXinμσnN(0,1)\frac{\sum_{i=1}^{n} X_{i}-n \mu}{\sigma \sqrt{n}} \sim N(0,1)

证明过程将Xˉnorm\bar{X}_{norm}特征函数在0点泰勒展开,得到了和标准正态分布N(0,1)N(0, 1)一样的特征函函数et22e^{-\frac{t^2}{2}}

单次采样

均匀分布

以均匀分布np.random.rand()为例,一次采样1000个值,可以看到样本均值接近0.5,并且histgram(默认10个bin)中每个bin的值都接近1000/10=100

sample_size = 1000 # 采样个数
number_of_sample = 1 # 采样次数

np.random.seed(0)
X = np.random.rand(number_of_sample, sample_size)

mean = X.mean(axis=1)

fig, axs = plt.subplots(1, 2, figsize=(9, 4))

# sample values
axs[0].plot(X[0], '.')
axs[0].set_ylim(-1, 2)
axs[0].set_title('sample values')

# histgram of X
axs[1].hist(X[0], edgecolor='k', alpha=0.8)
axs[1].set_title('histgram of $X$')

plt.show()
print('mean:', mean)

mean: [0.49592153]

偏正态分布

如果用正态分布实验,结果可能不能很好的展示中心极限定理。我们直接用SciPy里的skewnorm偏正态分布,概率密度函数为skewnorm.pdf(x, a) = 2 * norm.pdf(x) * norm.cdf(a*x)

from scipy.stats import skewnorm
import matplotlib.pyplot as plt

a = 4
fig, ax = plt.subplots(1, 1)
mean, var, skew, kurt = skewnorm.stats(a, moments='mvsk')

x = np.linspace(skewnorm.ppf(0.01, a), skewnorm.ppf(0.99, a), 100)
ax.plot(x, skewnorm.pdf(x, a), 'r-', lw=5, alpha=0.6, label='skewnorm pdf')

print('E(X) =', mean)
E(X) = 0.7740617226446519

打印的结果显示这个分布均值约等于0.774,我们采样1000个值看看其分布情况。

r = skewnorm.rvs(a, size=1000)

fig, axs = plt.subplots(1, 2, figsize=(9, 4))

# sample values
axs[0].plot(r, '.')
axs[0].set_ylim(-2, 5)
axs[0].set_title('sample values')

# histgram of X
axs[1].hist(r, edgecolor='k', alpha=0.8)
axs[1].set_title('histgram of $X$')

print('mean:', r.mean())
mean: 0.7426786528215207

多次采样

均匀分布

我们分别测试n={3,10,30,100}n=\{3, 10, 30, 100\}的情况,每种情况都采集100000次,并画出每种情况下均值的分布图(已归一化)。从图中可以看出,虽然样本容量n=3n=3很小,但是其均值的分布图已经是正态分布,这和均匀分布本身对称有关系。当n=30n=30时候已经很好了。

sample_size = [3, 10, 30, 100] # 每次采样个数
number_of_sample = 100000 # 采样次数

plt.figure(figsize=(8,6))

for i, ss in enumerate(sample_size):
    Xs = np.random.rand(number_of_sample, ss)    
    h, b = np.histogram(Xs.mean(axis=1), bins=50, density=True)
    b = (b[:-1] + b[1:]) / 2.
    plt.plot(b, h, '-', label=f'sample size = {ss}')

plt.legend()

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Iw3aDmtH-1592485360810)(https://static01.imgkr.com/temp/455608657cea4ca8867401ab1e077261.png)]

偏正态分布

同均匀分布一样,仍然测试n={3,10,30,100}n=\{3, 10, 30, 100\}的情况,但是注意,由于样本容量n=3n=3太小,其均值分布类似于总体数据的偏正态分布,而n=10n=10就好了很多。

sample_size = [3, 10, 30, 100] # 每次采样个数
number_of_sample = 100000 # 采样次数


plt.figure(figsize=(8,6))

for i, ss in enumerate(sample_size):
    Xs = skewnorm.rvs(4, size=(number_of_sample, ss))
    h, b = np.histogram(Xs.mean(axis=1), bins=50, density=True)
    b = (b[:-1] + b[1:]) / 2.
    plt.plot(b, h, '-', label=f'sample size = {ss}')

plt.legend()

练习题

e.g.1 某炮兵阵地对敌人的防御地段进行100次射击,每次射击中炮弹的命中数是一个随机变量,其期望为2,方差为1.69,求在100次射击中有180颗到220颗炮弹命中目标的概率。

解:设XiX_i表示第ii次设计命中的炮弹数,则E(Xi)=2, D(Xi)=1.69E(X_i)=2,\ D(X_i)=1.69,因为100很大,所以根据中心极限定理可以认为(S100100μ)100σ\frac{(S_{100}-100\mu)}{\sqrt{100}\sigma}近似服从N(0,1)N(0,1)100μ=200 σ=1.3100\mu=200\ \sigma=1.3,所以

P(180Sn220)=P(18020013Sn2001322020013)(2013)(2013)=2(1.54)1=0.8764P\left(180 \leq S_{n} \leq 220\right) = P\left(\frac{180-200}{13} \leq \frac{S_{n}-200}{13} \leq \frac{220-200}{13}\right)\\ \approx \varnothing\left(\frac{20}{13}\right)-\varnothing\left(-\frac{20}{13}\right)\\ = 2\varnothing(1.54) - 1 = 0.8764

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章