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

常见分布

总结统计工作中几个常用用法在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分布
fF分布
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概率分布大全(含可视化)

  • 4
    点赞
  • 39
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
### 回答1: 我了解Scipy.stats,它是一个用于统计计算的Python模块。 你好!Scipy.stats 是一个 Python 库,提供了大量用于数据分析、概率计算和统计分布的函数和类。Python Scipy.stats 是一个用于科学计算和统计分析的 Python 库。它提供了大量用于数据探索、描述性统计、概率分布和假设检验等的函数。 Scipy.stats 中包含了多种概率分布函数,包括连续型分布(如正态分布、指数分布和威布尔分布等)和离散型分布(如泊松分布和二项分布等)。此外,它还提供了许多统计函数,如假设检验、相关分析、方差分析等。 下面是一些 Scipy.stats 常用函数的示例: 1. 正态分布 ```python from scipy.stats import norm # 计算正态分布概率密度函数在 x=1 处的取值 norm.pdf(1) # 计算正态分布累积分布函数在 x=1 处的取值 norm.cdf(1) # 计算给定正态分布的均值和标准差时,从 -1 到 1 区间的概率密度函数值 norm.interval(0.68, loc=0, scale=1) ``` 2. t 分布 ```python from scipy.stats import t # 计算给定 t 分布的自由度,从 -1 到 1 区间的概率密度函数值 t.interval(0.68, df=10, loc=0, scale=1) # 计算两个样本的 t 统计值和 p 值,用于假设检验 ttest_ind(sample1, sample2) ``` 3. 卡方分布 ```python from scipy.stats import chi2 # 计算给定卡方分布的自由度,从 0 到 2 区间的概率密度函数值 chi2.interval(0.68, df=5, loc=0, scale=1) # 计算卡方分布的 p 值,用于假设检验 chisquare(observed, expected) ``` 以上是 Scipy.stats 库的一些常用函数。你可以通过调用这些函数和查看其文档来进一步了解该库的使用。 ### 回答2: Python是一种广泛使用的编程语言,而Python scipy.stats是Python中的一个统计学模块。它是一个极其强大的模块,用于执行各种统计和概率分布操作。这个模块是SciPy库的一部分,SciPy是一个Python库,专门用于数学、科学和工程计算。 Python scipy.stats可以用于在Python中生成各种概率分布,如正态分布泊松分布、二项分布、t分布等等。使用它可以计算每个概率分布的概率密度、累积分布函数和逆累积分布函数。 除了概率分布之外,Python scipy.stats还提供了各种统计测量功能,例如Kendall的Tau系数、Spearman的等级相关系数、Pearson的相关系数、均值、中位数、标准差等。还可以使用Python scipy.stats来进行假设检验,例如单样本和双样本t检验、卡方检验等等。 Python scipy.stats还提供了一些有用的函数,如峰度(kurtosis)、偏态(skewness)、最大值、最小值和极差。将这些函数与概率分布和统计测量相关函数相结合,可以在Python中快速完成高级统计分析操作。 总的来说,Python scipy.stats对于希望利用Python进行统计分析的科学家和工程师来说是非常有用的。它提供了方便、快速和高效的数据分析工具,使得研究人员可以更简单、更迅速地实现各种复杂的统计分析操作。 ### 回答3: PythonScipy库提供了许多统计函数,其中最重要的是scipy.stats模块。在统计学和数据科学中,scipy.stats被广泛用于概率分布的计算、分位数的计算、假设检验、线性回归、方差分析等。 该模块提供了多种分布概率密度函数的计算。例如,正态分布(norm)、t分布(t)、卡方分布(chi2)、F分布(f)、伽马分布(gamma)等。对于每种分布,该模块提供了一个或多个方法计算概率密度函数、累积分布函数、分位数等。除此之外,还有如半正态分布、冈分布、三角分布等其它分布概率密度函数的计算。 与此同时,该模块还可用于执行假设检验。例如,在从正态分布中取样时,可以使用t检验测试样本和总体的均值是否不同。还可以使用方差分析(ANOVA)来比较不同组的平均值是否有差异。 scipy.stats模块还提供了一些关于线性回归的函数,例如pearsonr和spearmanr方法可以计算线性相关系数和斯皮尔曼等级相关系数。还可以使用linregress方法进行回归分析,包括计算斜率、截距、标准错误、t值和p值。 总的来说,scipy.stats是Python科学计算的重要组成部分,对于数据科学家、研究人员等人员来说非常有用,可以方便地计算和分析各种数据分布和假设检验,并且提供了一些常见的统计函数来解决数据问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

现实、狠残酷

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值