微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Python中的二元泊松分布

如何解决Python中的二元泊松分布

我想从二元 Possion 分布中抽取 N 次。 是否有类似于 R 中的包 bivpois 的 Python 模块?

在 Python 中,我只知道 scipy.stats.poissonnumpy.random.possion 库,它们允许我根据单个参数 lambda 从单变量泊松分布进行绘制,但不知道从双变量或多变量。

解决方法

你可以很容易地自己完成,因为我没有看到任何内置方法:

https://en.wikipedia.org/wiki/Poisson_distribution#Bivariate_Poisson_distribution

步骤:

  1. 使用参数 lambda_i 生成 3 个独立的泊松变量 Z_i
  2. 生成两个 P_i = Z_i + Z_3 for i = 1,2 跟随 Poi(lambda_i + lambda_3)

代码:

import numpy
lam1 = 1
lam2 = 2
lam3 = 3
#wrap next part in a loop to generate more than 1 sample
a = np.random.poisson(lam1)
b = np.random.poisson(lam2)
c = np.random.poisson(lam3)
bivariate1 = a + c #follows Poi(lam1+lam3)
bivariate2 = b + c #follows Poi(lam2+lam3)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。