numpy.random.standard_gamma#
- random.standard_gamma(shape, размер=None)#
Извлечь выборки из стандартного гамма-распределения.
Выборки извлекаются из гамма-распределения с заданными параметрами: формой (иногда обозначаемой как «k») и масштабом=1.
Примечание
Новый код должен использовать
standard_gammaметодGeneratorэкземпляр вместо; пожалуйста, смотрите Быстрый старт.- Параметры:
- shapefloat или array_like из float
Параметр должен быть неотрицательным.
- размерint или кортеж ints, опционально
Форма вывода. Если заданная форма, например,
(m, n, k), затемm * n * kобразцы извлекаются. Если size равенNone(по умолчанию), возвращается единственное значение, еслиshapeявляется скаляром. В противном случае,np.array(shape).sizeвыбираются образцы.
- Возвращает:
- выходndarray или скаляр
Выбранные выборки из параметризованного стандартного гамма-распределения.
Смотрите также
scipy.stats.gammaфункция плотности вероятности, распределение или интегральная функция распределения и т.д.
random.Generator.standard_gammaкоторый следует использовать для нового кода.
Примечания
Функция плотности вероятности для гамма-распределения равна
\[p(x) = x^{k-1}\frac{e^{-x/\theta}}{\theta^k\Gamma(k)},\]где \(k\) является формой и \(\theta\) масштаб, и \(\Gamma\) является гамма-функцией.
Гамма-распределение часто используется для моделирования времени до отказа электронных компонентов и возникает естественным образом в процессах, для которых время ожидания между событиями, распределёнными по Пуассону, является значимым.
Ссылки
[1]Вайсштейн, Эрик В. «Гамма-распределение». Из MathWorld – веб-ресурс Wolfram. https://mathworld.wolfram.com/GammaDistribution.html
[2]Википедия, "Гамма-распределение", https://en.wikipedia.org/wiki/Gamma_distribution
Примеры
Извлечь выборки из распределения:
>>> shape, scale = 2., 1. # mean and width >>> s = np.random.standard_gamma(shape, 1000000)
Отображение гистограммы выборок вместе с функцией плотности вероятности:
>>> import matplotlib.pyplot as plt >>> import scipy.special as sps >>> count, bins, ignored = plt.hist(s, 50, density=True) >>> y = bins**(shape-1) * ((np.exp(-bins/scale))/ ... (sps.gamma(shape) * scale**shape)) >>> plt.plot(bins, y, linewidth=2, color='r') >>> plt.show()