numpy.random.Generator.weibull#

метод

random.Generator.weibull(a, размер=None)#

Извлечь выборки из распределения Вейбулла.

Генерирует выборки из распределения Вейбулла с одним параметром и заданным параметром формы a.

\[X = (-ln(U))^{1/a}\]

Здесь U выбирается из равномерного распределения на интервале (0,1].

Более распространённое 2-параметрическое распределение Вейбулла, включая параметр масштаба \(\lambda\) это просто \(X = \lambda(-ln(U))^{1/a}\).

Параметры:
afloat или array_like из float

Параметр формы распределения. Должен быть неотрицательным.

размерint или кортеж ints, опционально

Форма вывода. Если заданная форма, например, (m, n, k), затем m * n * k образцы извлекаются. Если size равен None (по умолчанию), возвращается единственное значение, если a является скаляром. В противном случае, np.array(a).size выбираются образцы.

Возвращает:
выходndarray или скаляр

Выбранные выборки из параметризованного распределения Вейбулла.

Примечания

Распределение Вейбулла (или асимптотическое распределение экстремальных значений типа III для наименьших значений, SEV типа III, или распределение Розина-Раммлера) является одним из класса обобщённых распределений экстремальных значений (GEV), используемых при моделировании задач экстремальных значений. Этот класс включает распределения Гумбеля и Фреше.

Функция плотности вероятности распределения Вейбулла равна

\[p(x) = \frac{a} {\lambda}(\frac{x}{\lambda})^{a-1}e^{-(x/\lambda)^a},\]

где \(a\) является формой и \(\lambda\) масштаб.

Функция имеет пик (моду) в \(\lambda(\frac{a-1}{a})^{1/a}\).

Когда a = 1, распределение Вейбулла сводится к экспоненциальному распределению.

Ссылки

[1]

Валодди Вейбулл, Королевский технический университет, Стокгольм, 1939 «Статистическая теория прочности материалов», Ingeniorsvetenskapsakademiens Handlingar Nr 151, 1939, Generalstabens Litografiska Anstalts Forlag, Стокгольм.

[2]

Вальодди Вейбулл, "Статистическая функция распределения широкой применимости", Journal Of Applied Mechanics ASME Paper 1951.

[3]

Википедия, "Распределение Вейбулла", https://en.wikipedia.org/wiki/Weibull_distribution

Примеры

Извлечь выборки из распределения:

>>> rng = np.random.default_rng()
>>> a = 5. # shape
>>> s = rng.weibull(a, 1000)

Отображение гистограммы выборок вместе с функцией плотности вероятности:

>>> import matplotlib.pyplot as plt
>>> def weibull(x, n, a):
...     return (a / n) * (x / n)**(a - 1) * np.exp(-(x / n)**a)
>>> count, bins, _ = plt.hist(rng.weibull(5., 1000))
>>> x = np.linspace(0, 2, 1000)
>>> bin_spacing = np.mean(np.diff(bins))
>>> plt.plot(x, weibull(x, 1., 5.) * bin_spacing * s.size, label='Weibull PDF')
>>> plt.legend()
>>> plt.show()
../../../_images/numpy-random-Generator-weibull-1.png