• Python威布尔分布


    威布尔分布及其性质

    威布尔分布,即Weibull distribution,又被译为韦伯分布、韦布尔分布等,是仅分布在正半轴的连续分布。

    numpy.random中,提供了按照威布尔分布生成的随机数生成器,并且提供了与威布尔分布关系密切的瑞利分布、指数分布以及拉普拉斯分布,列表如下

    函数概率密度表达式
    weibull(a[,scale])威布尔分布 p ( x ) = a λ ( x λ ) a − 1 e − ( x / λ ) a p(x)=\frac{a}{\lambda}(\frac{x}{\lambda})^{a-1}e^{-(x/\lambda)^a} p(x)=λa(λx)a1e(x/λ)a
    rayleigh([scale])瑞利分布 p ( x ) = x λ 2 exp ⁡ [ − x 2 2 λ 2 ] p(x)=\frac{x}{\lambda^2}\exp[\frac{-x^2}{2\lambda^2}] p(x)=λ2xexp[2λ2x2]
    exponential([scale])指数分布 f ( x ) = 1 λ exp ⁡ − x λ f(x)=\frac{1}{\lambda}\exp{-\frac{x}{\lambda}} f(x)=λ1expλx
    laplace([loc, scale])拉普拉斯分布 f ( x ) = 1 2 λ exp ⁡ [ − ∣ x − μ ∣ λ ] f(x)=\frac{1}{2\lambda}\exp[-\frac{\vert x-\mu\vert}{\lambda}] f(x)=2λ1exp[λxμ]

    上表中,概率密度表达式中的 λ \lambda λ即为函数中的scale μ \mu μ对应函数参数中的loc

    根据概率密度表达式,可以发现,当 a = 2 a=2 a=2时,威布尔分布变为瑞利分布;当 a = 1 a=1 a=1时,变为指数分布。

    若将指数分布的中心移动到 μ \mu μ,同时延展到整个坐标轴,那么就会变成Laplace分布。

    威布尔分布具有如下性质:

    其均值为

    E = λ Γ ( 1 + 1 a ) E=\lambda\Gamma(1+\frac{1}{a}) E=λΓ(1+a1)

    方差为

    S 2 = λ 2 [ Γ ( 1 + 2 a ) − Γ ( 1 + 1 a ) 2 ] S^2=\lambda^2[\Gamma(1+\frac{2}{a})-\Gamma(1+\frac{1}{a})^2] S2=λ2[Γ(1+a2)Γ(1+a1)2]

    偏度为

    2 Γ ( 1 + 1 a ) 3 − 3 Γ ( 1 + 2 a ) Γ ( 1 + 1 a ) + Γ ( 1 + 3 a i = ) [ Γ ( 1 + 2 a ) − Γ ( 1 + 1 a ) 2 ] 3 / 2 \frac{2\Gamma(1+\frac{1}{a})^3-3\Gamma(1+\frac{2}{a})\Gamma(1+\frac{1}{a})+\Gamma(1+\frac{3}{ai=})}{[\Gamma(1+\frac{2}{a})-\Gamma(1+\frac{1}{a})^2]^{3/2}} [Γ(1+a2)Γ(1+a1)2]3/22Γ(1+a1)33Γ(1+a2)Γ(1+a1)+Γ(1+ai=3)

    峰度为

    − 3 Γ ( 1 + 1 a ) 4 + 6 Γ ( 1 + 2 a ) Γ ( 1 + 1 a ) 2 − 4 Γ ( 1 + 3 a ) Γ ( 1 + 1 a ) + Γ ( 1 + 4 a ) [ Γ ( 1 + 2 a ) − Γ ( 1 + 1 a ) 2 ] 2 \frac{-3\Gamma(1+\frac{1}{a})^4+6\Gamma(1+\frac{2}{a})\Gamma(1+\frac{1}{a})^2-4\Gamma(1+\frac{3}{a})\Gamma(1+\frac{1}{a})+\Gamma(1+\frac{4}{a})}{[\Gamma(1+\frac{2}{a})-\Gamma(1+\frac{1}{a})^2]^2} [Γ(1+a2)Γ(1+a1)2]23Γ(1+a1)4+6Γ(1+a2)Γ(1+a1)24Γ(1+a3)Γ(1+a1)+Γ(1+a4)

    在Python中生成威布尔分布的随机数

    接下来生成不同a值时的威布尔分布,

    import numpy as np
    import matplotlib.pyplot as plt
    
    fig = plt.figure("Weibull Distribution")
    for i in range(1,5):
        ax = fig.add_subplot(2,2,i)
        xs = np.random.weibull(i,size=1000)
        ax.set_title(f"a={i}")
        plt.hist(xs,100)
    
    plt.show()
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    在这里插入图片描述

    可以看到,随着 a a a不断变大,威布尔分布逐渐向右移动。

    指数分布和拉普拉斯分布的对比

    接下来对比一下指数分布和拉普拉斯分布

    fig = plt.figure()
    
    xs1 = np.random.exponential(1, size=1000)
    xs2 = np.random.laplace(0, 1, size=1000)
    ax1 = fig.add_subplot(1,2,1)
    ax1.hist(xs1, 100)
    ax1.set_title("exponential")
    
    ax2 = fig.add_subplot(1,2,2)
    ax2.hist(xs2, 100)
    ax2.set_title("laplace")
    plt.show()
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    效果为

    在这里插入图片描述

  • 相关阅读:
    基于java的大学教室管理系统——计算机毕业设计
    intellij debug模式提示 : Method breakpoints may dramatically slow down debugging
    有监督学习神经网络的回归拟合——基于红外光谱的汽油辛烷值预测(Matlab代码实现)
    组态软件和人机界面与plc之间Profinet无线通讯
    数字信号处理MATLAB作业
    霸道的 AliPaladin64.sys
    笔试题/面试题——数组去重--9种方法
    IC验证覆盖率
    【React 源码】(八)fiber 树构造(基础准备)
    舆情监控系统有哪些功能,行者AI告诉你
  • 原文地址:https://blog.csdn.net/m0_37816922/article/details/127993251