我正在尝试使用 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 轴的位置。
任何帮助或要求进一步澄清将不胜感激。