scipy.stats常见概率分布-正态分布与泊松分布

  • Post author:
  • Post category:其他




常见分布

总结统计工作中几个常用用法在python统计函数库scipy.stats的使用范例



常见术语


  • pdf

    ,概率密度函数(Probability Density Function),连续型随机变量的概率。

  • cdf

    ,累积分布函数(Cumulative Distribution Function),pdf的积分。

  • ppf

    ,百分点函数(Percent Point Function),cdf的逆函数。

  • pmf

    ,概率质量函数(Probability Mass Function),离散型随机变量的概率。
  • sf,残存函数(Survival function),它的值为(1-CDF)
  • isf,逆残存函数(Inverse survival function),sf的逆函数


常见随机分布

名称 含义
uniform 均匀分布
norm 正态分布
t 学生T分布
f F分布
poisson 泊松分布
bernoulli 伯努利分布
binom 二项分布
expon 指数分布
chi2 卡方分布


下面我们以正态分布(Norm)和泊松分布(Poisson)为例做详细的介绍



1.正态分布(Norm)

norm = scipy.stats.norm(loc=0, scale=1)

正态分布,属于连续性概率分布函数,

loc

表示均值,

scale

表示标准差。其概率密度函数为:

在这里插入图片描述

x = np.linspace(-1.5, 1.5, 100)
labels = []
f_list = [stats.norm.pdf, stats.norm.cdf, stats.norm.ppf]
plt.figure(dpi=150)
for f in f_list:
    labels.append(f)
    y = f(x, loc=0, scale=0.5)  #标准正态分布,均值0,标准差0.5
    plt.tick_params(axis='both', labelsize=14)
    plt.plot(x, y)
plt.legend(labels=['pdf', 'cdf', 'ppf'], loc='best')
plt.title("Normal distribution")

在这里插入图片描述

import matplotlib.pyplot as plt
import scipy.stats as stats
import numpy as np
import math

x = np.linspace(-5, 5, 1000)
labels = []
mu_list = [0, 0, 0, -2]
sigma_list = [0.2, 1.0, 5.0, 0.5]
plt.figure(dpi=150)
for mu, sigma in zip(mu_list, sigma_list):
    labels.append('μ={}, σ²={}'.format(mu, sigma))
    y = stats.norm.pdf(x, loc=mu, scale=math.sqrt(sigma))
    plt.axis([-5, 5, 0, 1.0])
    plt.tick_params(axis='both', labelsize=14)
    plt.plot(x, y)
plt.legend(labels=labels, loc='best')
plt.show()

在这里插入图片描述



连续随机变量对象的方法


rvs:产生服从这种分布的一个样本,对随机变量进行随机取值,可以通过size参数指定输出的数组大小。

from scipy import stats
rv_norm=stats.norm.rvs(loc = 5,scale = 1,size =(2,2))
# array([[4.75695311, 5.71218072], [6.05233184, 5.56499171]])
rv_norm=stats.norm.rvs(loc = 5,scale = 1,size =6)
# array([3.39791064, 5.18353263, 2.38873254, 5.00970607, 4.36979662, 4.16425798])


pdf:随机变量的概率密度函数。产生对应x的这种分布的y值

# 比如我们想知道标准正态分布得到0的概率。
st.norm.pdf(x=0,loc=0,scale=1)
0.3989422804014327


cdf:随机变量的累积分布函数,它是概率密度函数的积分(也就是x时p(X<x)的概率)。产生对应x的这种分布的累积分布函数的值。

x=st.norm.cdf(0.842,loc=0,scale=1)
y=st.norm.cdf(1.6449,loc=0,scale=1)
z=st.norm.cdf(2.33,loc=0,scale=1)
print(x,y,z)
0.8001060232739432 0.9500047825316537 0.9900969244408357

问题:正态分布的3σ原则为:数值分布在(μ-σ,μ+σ)中的概率为0.6827;数值分布在(μ-2σ,μ+2σ)中的概率为0.9545;数值分布在(μ-3σ,μ+3σ)中的概率为0.9973,可以认为,Y的取值几乎全部集中在(μ-3σ,μ+3σ)区间内,超出这个范围的可能性仅占不到0.3%。

证明如下:

x=st.norm.cdf(1,loc=0,scale=1)
y=st.norm.cdf(2,loc=0,scale=1)
z=st.norm.cdf(3,loc=0,scale=1)
print(x-(1-x),y-(1-y),z-(1-z))
0.6826894921370859 0.9544997361036416 0.9973002039367398


ppf:累积分布函数的反函数。q=0.01时,ppf就是p(X<x)=0.01时的x值。

inv_z095=st.norm.ppf(0.95)
inv_z099=st.norm.ppf(0.99)
inv_z080=st.norm.ppf(0.80)
print(inv_z080,inv_z095,inv_z099)
0.8416212335729143 1.6448536269514722 2.3263478740408408


interval:中位数周围面积相等的置信区间

# 证明数值分布在(μ-2σ,μ+2σ)中的概率为0.9545
interval=st.norm.interval(0.9544997361036416,loc=0,scale=1)
interval
Out[56]: (-2.0000000000000004, 2.0000000000000004)
st.norm.interval(0.95,loc=0,scale=1)
Out[57]: (-1.959963984540054, 1.959963984540054) # 1.96


fit:对一组随机取样进行拟合,找出最适合取样数据的概率密度函数的系数。如stats.norm.fit(x)就是将x看成是某个norm分布的抽样,求出其最好的拟合参数(mean, std)连续分布函数特有方法

import numpy as np
from scipy import stats

data = stats.norm.rvs(size=1000, random_state=3)  # 生成随机数
print(np.mean(data), np.std(data))
print(stats.norm.fit(data))
0.017284332980834295 1.0084018990512724
(0.017284332980834295, 1.0084018990512724)



泊松分布(Poisson)

首先要清楚,泊松分布是离散的,也就是说我接到骚扰电话次数必须是整数,要么就是15次,要么就是16次…,而不会是15.5次。

在这里插入图片描述


均值方差:泊松分布的均值和方差都是 λ。


使用poisson.rvs(mu, size) 函数生成服从泊松分布数据,给定均值和样本大小:

from scipy import stats
data = stats.poisson.rvs(mu=2, size=10, random_state=5343)
# data
# array([2, 0, 3, 1, 1, 2, 3, 3, 4, 1], dtype=int64)


泊松分布属于离散型概率分布函数, 其概率质量函数为poisson.pmf(k, mu)


上述概率质量函数以“标准化”形式定义。要移动分布,请使用loc参数。具体来说,就是泊松pmf(k,mu,loc)等同于泊松。pmf(k-loc,mu)

# 某商店每天平均有三位顾客,某天恰好有5人的概率:
from scipy.stats import poisson
poisson.pmf(k=5, mu=3)
# 结果为 0.100819


使用poisson.cdf(k, mu)及计算泊松分布的累积分布函数值

# 某商店平均每天卖7个足球,那么某天卖出足球数量小于5的概率:
from scipy.stats import poisson
# 计算累积概率
poisson.cdf(k=4, mu=7)
# 结果为 0.172992

# 某商店平均每天卖15个罐头,则某天卖出罐头超过20听的概率:
# 1减去累积概率
1-poisson.cdf(k=20, mu=15)
# 结果为 0.082971


poisson.ppf(q, mu, loc=0)累积分布函数的反函数

stats.poisson.ppf(q=0.95, mu=3, loc=0)
Out[58]: 6.0
stats.poisson.ppf(q=0.95, mu=5, loc=0)
Out[59]: 9.0



泊松分布图像绘制

# IMPORTS
import numpy as np
import scipy.stats as stats
import matplotlib.pyplot as plt
import matplotlib.style as style
from IPython.core.display import HTML

# PLOTTING CONFIG
style.use('fivethirtyeight')
plt.rcParams["figure.figsize"] = (14, 7)

plt.figure(dpi=100)
# PDF
plt.bar(x=np.arange(20),
        height=(stats.poisson.pmf(np.arange(20), mu=5)),
        width=.75,
        alpha=0.75
        )
# CDF
plt.plot(np.arange(20),
         stats.poisson.cdf(np.arange(20), mu=5),
         color="#fc4f30",
         )
# LEGEND
plt.text(x=8, y=.45, s="pmf (normed)", alpha=.75, weight="bold", color="#008fd5")
plt.text(x=8.5, y=.9, s="cdf", alpha=.75, weight="bold", color="#fc4f30")

# TICKS
plt.xticks(range(21)[::2])
plt.tick_params(axis='both', which='major', labelsize=18)
plt.axhline(y=0.005, color='black', linewidth=1.3, alpha=.7)

# TITLE, SUBTITLE & FOOTER
plt.text(x=-2.5, y=1.25, s="Poisson Distribution - Overview",
         fontsize=26, weight='bold', alpha=.75)
plt.text(x=-2.5, y=1.1,
         s='Depicted below are the normed probability mass function (pmf) and the cumulative density\nfunction (cdf) of a Poisson distributed random variable $ y \sim Poi(\lambda) $, given $ \lambda = 5 $.',
         fontsize=19, alpha=.85)
# 调整空白
plt.subplots_adjust(left=0.1, bottom=0.2, right=0.9, top=0.8, wspace=0.5, hspace=0.5)
plt.show()

在这里插入图片描述

x = np.arange(20)
mu_list = [1, 5, 10]
plt.figure(dpi=150)
for mu in mu_list:
    y = stats.poisson.pmf(x, mu=mu)
    plt.axis([0, 20, 0, 0.4])
    plt.tick_params(axis='both', labelsize=14)
    plt.scatter(x, y)
    plt.plot(x, y,label='μ={}'.format(mu))
plt.legend(loc='best')
plt.show()

在这里插入图片描述



参考连接


Scipy教程 – 统计函数库scipy.stats



Python概率分布大全(含可视化)



版权声明:本文为qq_34184505原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。