9

我正在尝试使用 Numpy 的随机指数分布创建一个随机数数组。我的工作正常,但是我的项目有一个额外的要求,那就是能够精确指定有多少数组元素具有特定值。

让我解释一下(代码在下面,但我会在这里解释一下):我生成我的随机指数分布并绘制数据的直方图,生成一条漂亮的指数曲线。我真正想做的是使用一个变量来指定这条曲线的 y 轴截距(曲线与 y 轴相交的点)。我可以通过更改直方图中的 bin 数量以基本方式实现这一点,但这只会改变绘图而不是原始数据。

我在这里插入了我的代码的骨架。为了给出一些背景信息,我正在尝试创建星系的指数圆盘,因此我想要生成的随机数组是半径数组,而我想要指定的变量是星系中心的数字密度:

import numpy as N
import matplotlib.pyplot as P

n = 1000    
scale_radius = 2
central_surface_density = 100 #I would like this to be the controlling variable, even if it's specification had knock on effects on n.

radius_array = N.random.exponential(scale_radius,(n,1))     

P.figure()    
nbins = 100
number_density, radii = N.histogram(radius_array, bins=nbins,normed=False)
P.plot(radii[0:-1], number_density)
P.xlabel('$R$')
P.ylabel(r'$\Sigma$')
P.ylim(0, central_surface_density)
P.legend()      
P.show()

此代码创建以下直方图:

在此处输入图像描述

因此,总而言之,我希望能够通过控制生成数据的方式而不是通过更改直方图的绘制方式来指定此图在 y 轴的位置。

任何帮助或要求进一步澄清将不胜感激。

4

1 回答 1

12

根据文档numpy.random.exponential,输入参数 beta 是 1/lambda,用于定义wikipedia 中描述的指数

你想要的是这个函数在f(x=0)=lambda=1/beta. 因此,在规范分布中,您的 y 截距应该是 numpy 函数的倒数:

import numpy as np
import pylab as plt

target = 250
beta = 1.0/target

Y = np.random.exponential(beta, 5000)
plt.hist(Y, normed=True, bins=200,lw=0,alpha=.8)
plt.plot([0,max(Y)],[target,target],'r--')
plt.ylim(0,target*1.1)
plt.show()

在此处输入图像描述

是的,直方图的 y 截距会随着不同的 bin 大小而变化,但这并不意味着什么。您可以在这里合理谈论的唯一事情是潜在的概率分布(因此normed=true

于 2013-02-26T15:00:27.190 回答