numpy.random.RandomState.triangular#

方法

random.RandomState.triangular(left, mode, right, size=None)#

从区间 [left, right] 上的三角分布中抽取样本。

三角分布是一种连续概率分布,其下限为 left,峰值为 mode,上限为 right。与其他分布不同,这些参数直接定义了 pdf 的形状。

注意

新代码应使用 triangular 方法,该方法属于 Generator 实例;请参阅 快速入门

参数:
left浮点数或浮点数组

下限。

mode浮点数或浮点数组

分布峰值出现的值。该值必须满足条件 left <= mode <= right

right浮点数或浮点数组

上限,必须大于 left

size整数或整数元组,可选

输出形状。如果给定的形状为,例如 (m, n, k),则抽取 m * n * k 个样本。如果 size 为 None(默认),则如果 leftmoderight 均为标量,则返回单个值。否则,抽取 np.broadcast(left, mode, right).size 个样本。

返回:
outndarray 或标量

从参数化的三角分布中抽取的样本。

另请参阅

random.Generator.triangular

新代码应使用它。

注释

三角分布的概率密度函数为

\[\begin{split}P(x;l, m, r) = \begin{cases} \frac{2(x-l)}{(r-l)(m-l)}& \text{对于 $l \leq x \leq m$},\\ \frac{2(r-x)}{(r-l)(r-m)}& \text{对于 $m \leq x \leq r$},\\ 0& \text{其他情况}. \end{cases}\end{split}\]

三角分布通常用于未明确定义的问题,在这些问题中,基础分布未知,但存在关于极限和模式的一些知识。它通常用于模拟中。

参考

[1]

维基百科,“三角分布” https://en.wikipedia.org/wiki/Triangular_distribution

示例

从分布中抽取值并绘制直方图

>>> import matplotlib.pyplot as plt
>>> h = plt.hist(np.random.triangular(-3, 0, 8, 100000), bins=200,
...              density=True)
>>> plt.show()
../../../_images/numpy-random-RandomState-triangular-1.png