numpy.random.gamma#
- random.gamma(shape, scale=1.0, размер=None)#
Извлечение выборок из гамма-распределения.
Выборки берутся из гамма-распределения с заданными параметрами,
shape(иногда обозначается как «k») и scale (иногда обозначается как "theta"), где оба параметра > 0.Примечание
Новый код должен использовать
gammaметодGeneratorэкземпляр вместо; пожалуйста, смотрите Быстрый старт.- Параметры:
- shapefloat или array_like из float
Форма гамма-распределения. Должна быть неотрицательной.
- scalefloat или array_like из floats, необязательный
Масштаб гамма-распределения. Должен быть неотрицательным. По умолчанию равен 1.
- размерint или кортеж ints, опционально
Форма вывода. Если заданная форма, например,
(m, n, k), затемm * n * kобразцы извлекаются. Если size равенNone(по умолчанию), возвращается единственное значение, еслиshapeиscaleоба являются скалярами. В противном случае,np.broadcast(shape, scale).sizeвыбираются образцы.
- Возвращает:
- выходndarray или скаляр
Выбранные образцы из параметризованного гамма-распределения.
Смотрите также
scipy.stats.gammaфункция плотности вероятности, распределение или интегральная функция распределения и т.д.
random.Generator.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., 2. # mean=4, std=2*sqrt(2) >>> s = np.random.gamma(shape, scale, 1000)
Отображение гистограммы выборок вместе с функцией плотности вероятности:
>>> 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()