【Python】Gamma分布详解

news2024/11/27 10:24:15

文章目录

    • 初步介绍
    • 形状特征

初步介绍

在学习Gamma分布之前,有必要复习一下Poisson分布:泊松分布

Poisson分布指的是,单个事件在某一刻发生的概率。Gamma分布更进一步,指的是某个事件在某个时刻发生第 n n n次的概率。

p ( x ) = x k − 1 e − λ x λ k Γ ( k ) p(x)=x^{k-1}\frac{e^{-\lambda x}}{\lambda^k\Gamma(k)} p(x)=xk1λkΓ(k)eλx

其中, k k k为形状参数, λ \lambda λ为尺度参数,固定尺度参数 λ \lambda λ,给定不同的 k k k值,可得到不同型形状的 Γ \Gamma Γ分布的概率曲线

import numpy as np
import matplotlib.pyplot as plt
from numpy.random import gamma

for k in [0.8, 1.5, 3.5]:
    xs = gamma(k, size=20000)
    plt.hist(xs, 200, range=(0,10), 
        alpha=0.5, label=f"k={k}")

plt.legend()
plt.show()

其分布如下图所示

在这里插入图片描述

形状特征

一般来说,当 k < 1 k<1 k<1时, p ( x ) p(x) p(x)为单调递减函数,对应图中 k = 0.8 k=0.8 k=0.8时,概率密度逐渐下降的情况;当 k ∈ ( 1 , 2 ) k\in(1,2) k(1,2)时, p ( x ) p(x) p(x)先上凸,然后下凸,由于上图画的是随机点的直方图,所以对凹凸性的展现并不明显。当 k > 2 k>2 k>2时, p ( x ) p(x) p(x)在增函数区间,是先下凸然后上凸的。

特别地,当 k = 1 k=1 k=1时, Γ \Gamma Γ分布的概率密度变为

p ( x ) = e − λ x λ p(x)=\frac{e^{-\lambda x}}{\lambda} p(x)=λeλx

此为指数分布,有关指数分布,请看这里Pyhton威布尔分布

k = n 2 k=\frac n 2 k=2n λ = 1 2 \lambda=\frac12 λ=21,则其表达式变为

p ( x ) = x n 2 − 1 e − λ 2 2 n 2 Γ ( n 2 ) p(x)=\frac{x^{\frac{n}{2}-1}e^{-\frac{\lambda}{2}}}{2^{\frac{n}{2}}\Gamma(\frac{n}{2})} p(x)=22nΓ(2n)x2n1e2λ

此即具有 n n n个自由度的卡方分布,有关卡方分布请戳这里:Python卡方分布

尺度因子 k k k可以调整分布曲线的胖瘦,需要注意的是,在gamma函数中,输入的尺度因子是 λ \lambda λ的倒数。接下来对 λ = 2 , 1 , 0.5 \lambda=2, 1, 0.5 λ=2,1,0.5这三种情况进行仿真

ks = [0.8, 1.5, 3.5]
fig = plt.figure()
for i in range(3):
    ax = fig.add_subplot(1,3,i+1)
    ax.set_title(f"k={ks[i]}")
    for lam in [1/2, 1, 2]:
        xs = gamma(ks[i], lam, size=20000)
        ax.hist(xs, 200, range=(0,10), 
            alpha=0.5, label=f"lambda={1/lam}")
    plt.legend()

plt.show()

得到不同k值时的分布情况

在这里插入图片描述

可见, λ \lambda λ越小,则分布越矮胖。

最后,测试一下 Γ \Gamma Γ函数的期望与方差,根据其概率密度函数,可以求得其期望和方差分别为

E = k λ , σ 2 = k λ 2 E=\frac{k}{\lambda}, \sigma^2=\frac{k}{\lambda^2} E=λk,σ2=λ2k

接下来对其进行测试

k, lam = 1.5, 2
xs = gamma(k, 1/lam, size=20000)
print("理论期望", k/lam, "\t理论方差", k/lam**2)
print("实际期望", np.mean(xs), "\t实际方差", np.cov(xs))

得到输出

理论期望 0.75   理论方差 0.375
实际期望 0.7550140115027265     实际方差 0.3794021804397493

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/88579.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

PowerDesigner 模型类型介绍

目录 PowerDesigner 提供了两种方式组织模型 分别是Categories和Model types 1.Categories方式是从企业架构建模角度出发&#xff0c;主要包含业务层&#xff0c;信息层&#xff0c;应用层&#xff0c;技术层&#xff0c;需求与规划层 1.1 业务层主要用于业务流程&#xff0c…

python游戏开发的库你知道几个?

对这方面有兴趣的朋友可以去学习学习。 01 PyGame 官网&#xff1a; Pygame Front Page — pygame v2.1.4 documentation 概述&#xff1a; Pygame 是一组专为编写视频游戏而设计的 Python 模块。 它在优秀的 SDL 库之上添加了功能。这允许您使用 python 语言创建功能齐全…

MyBatisPlus框架:一文带你清晰整个MP框架逻辑

MyBatisPlus框架&#xff1a;一文带你清晰整个MP框架逻辑需求&#xff1a;如果搭建一个SpringBootMP的基本框架&#xff1f;并入门其API使用MP入门简介工程环境搭建数据库配置依赖Yaml框架流程简单介绍下MP的底层运行过程常用APIMP日志配置主键生成策略自动填充处理扩展插件MP乐…

allegro中添加logo (方法二)

allegro中添加logo &#xff08;方法二&#xff09;1、 先制作好bmp格式的文件2、 Allegro中新建一个format symbol文件3、 导入IPF文件4、 方法对比软件环境&#xff1a;cadence 16.6前言&#xff1a;很多时候我们在设计pcb的时候都会在pcb上添加自己产品的logo&#xff0c;现…

Python《字符,符号,函数,索引》

函数描述len()计算序列的长度max()找出序列中的最大元素min()找出序列中的最小元素list()将序列转换为列表str()将序列转换为字符串sum()计算元素的和sorted()对元素进行排序enumerate()将序列组合为一个索引序列&#xff0c;多用在 for 循环中 关键字 andexecnotassertfinall…

Linux网络编程(二)——socket通信基础

目录 一、socket 二、字节序 &#xff08;一&#xff09;字节序转换函数 三、Socket地址 &#xff08;一&#xff09;通用socket地址 &#xff08;二&#xff09;专用socket地址 四、IP地址转换 五、TCP通信流程 &#xff08;一&#xff09;TCP和UDP的区别 &#xff…

深入浅出RPC

什么是RPC 为什么要有RPC PRC架构组件 RPC框架需要解决的问题&#xff1f; 1、如何确定客户端和服务端之间的通信协议&#xff1f; 2、如何更高效地进行网络通信&#xff1f; 3、服务端提供的服务如何暴露给客户端&#xff1f; 4、客户端如何发现这些暴露的服务&#xff1f; 5…

云存储学习笔记--3

目录前言1. 原理2. 实验前言 那么&#xff0c;根据我们上一版块的解释&#xff0c;其实经过思考会发现&#xff0c;传统的分区格式化会有一些问题&#xff0c;比如说&#xff1a;当我数据的存储大小超过了所有单个磁盘的存储空间大小的时候&#xff0c;会发现即使剩余空间总和…

论文复现-1论文重读:Black-Box Tuning for Language-Model-as-a-Service

论文核心&#xff1a;使用PLM的API进而完成prompt learning&#xff0c;微调完成任务。 具体来说&#xff0c;是采用连续prompts拼接在input_text之后&#xff0c;然后&#xff0c;通过derivative-free的框架&#xff0c;完成任务。 一、背景&#xff08;Introduction&#x…

门店数字化管理|门店督导工作监管难?SpaceSight 来帮忙

在门店管理中&#xff0c;这些问题是否一直困扰着你&#xff1a; 哪家店员工作更细致高效&#xff1f;难评估&#xff01; 有哪些门店问题高频发生&#xff1f;难发现&#xff01; 不同门店运营差距有多大&#xff1f;难界定&#xff01; SpaceSight 系列第二篇&#xff0c;为…

看看阿里程序员是怎样讲限流的

限流算法很多,常见的有三类,分别是计数器算法、漏桶算法、令牌桶算法,下面逐一讲解。 计数器算法 简单粗暴,比如指定线程池大小&#xff0c;指定数据库连接池大小、nginx连接数等,这都属于计数器算法。 计数器算法是限流算法里最简单也是最容易实现的一种算法。举个例子,比如…

YOLO系列目标检测算法——PP-YOLOv2

YOLO系列目标检测算法目录 - 文章链接 YOLO系列目标检测算法总结对比- 文章链接 YOLOv1- 文章链接 YOLOv2- 文章链接 YOLOv3- 文章链接 YOLOv4- 文章链接 Scaled-YOLOv4- 文章链接 YOLOv5- 文章链接 YOLOv6- 文章链接 YOLOv7- 文章链接 PP-YOLO- 文章链接 …

>python可视化神器altair

python可视化神器一.些简单图形的绘制(一).柱状图1. 然后我们还可以设置高亮柱状图的某一根柱子&#xff0c;其他柱子设置为一样的颜色&#xff1a;2. 翻转图片&#xff0c;同时添加图片标注&#xff0c;在图上加上数据3.在图形上添加线条4. 组合图&#xff0c;柱状图折线图(二…

[R语言]手把手教你如何绘图(万字)

目录 概况 常用高级图形 条形图 csv文件导入 csv文件导出 R语言sep函数 seq函数 with函数 直方图和密度估计图 盒型图 boxplot() 正态QQ图 散点图 pairs()散点矩阵图 曲线图 curve() 三维图 动态三维图 低级图形函数 abline() lines() legand()增加图例 …

String类——字符序列类(1)

目录 前言 String类 1.该类的由来 2.String类对象的创建 &#xff08;1&#xff09;头文件 &#xff08;2&#xff09;类对象的创建 其他用法&#xff1a; &#xff08;3&#xff09;String类对象遍历 1&#xff1a;数组方式遍历 2.范围for遍历&#xff1a; …

【Python】【期末复习题】【2022秋】

文章目录一、单选题&#xff08;20分&#xff09;二、判断题&#xff08;10分&#xff09;三、填空题&#xff08;10分&#xff09;四、问答题&#xff08;共30分&#xff0c;6题&#xff0c;每题5分&#xff09;五、程序题&#xff08;3题&#xff0c;每题10分&#xff0c;共3…

React.js 简介以及一些基本概念

React 是什么 React 跟angular.js 和Vue.js 一样是构建用户界面的js库 2011 年 由Facebook 工程师Jordan Walke创建 在 2013 开源 React 的优势 原生js的痛点 原生的Javascript 操作DOM繁琐&#xff0c;效率低(DOM-API 操作UI&#xff09;使用Javascript 直接操作DOM&#xf…

scala语法(三)(有java基础速学)

面向对象编程&#xff08;中&#xff09; scala的包 Scala中包名和源码所在的系统文件目录结构要可以不一致&#xff0c;但是编译后的字节码文件路径和包名会保持一致 scala 自动引入的包 Scala中&#xff0c;以下三个包的内容会隐式引用到每个程序上。 import java.lang._…

[附源码]Python计算机毕业设计二手交易平台Django(程序+LW)

该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程 项目运行 环境配置&#xff1a; Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术&#xff1a; django python Vue 等等组成&#xff0c;B/S模式 pychram管理等…

如何管理客商主数据,附要点和QA

客商主数据&#xff08;客户、供应商、既是客户也是供应商&#xff09;是企业最常用的主数据类型之一。要实现上下游的打通&#xff0c;方便企业内部相关业务的运转以及信息流通&#xff0c;做好客商主数据的管理至关重要。 什么是客商主数据 客商主数据是一类复杂的主数据&a…