std:: gamma_distribution
|
Определено в заголовке
<random>
|
||
|
template
<
class
RealType
=
double
>
class gamma_distribution ; |
(начиная с C++11) | |
Генерирует случайные положительные значения с плавающей точкой x , распределенные в соответствии с функцией плотности вероятности:
-
P(x|α,β) =
· x α-1e -x/β
β α
· Γ(α)
где α известен как параметр формы , а β известен как параметр масштаба . Параметр формы иногда обозначается буквой k , а параметр масштаба иногда обозначается буквой θ .
Для вещественного числа α полученное значение представляет собой сумму α независимых экспоненциально распределенных случайных величин, каждая из которых имеет среднее значение β .
std::gamma_distribution
удовлетворяет
RandomNumberDistribution
.
Содержание |
Параметры шаблона
| RealType | - | Тип результата, генерируемый генератором. Поведение не определено, если это не один из float , double , или long double . |
Типы членов
| Тип члена | Определение |
result_type
(C++11)
|
RealType |
param_type
(C++11)
|
тип набора параметров, см. RandomNumberDistribution . |
Функции-члены
|
(C++11)
|
создает новое распределение
(public member function) |
|
(C++11)
|
сбрасывает внутреннее состояние распределения
(public member function) |
Генерация |
|
|
(C++11)
|
генерирует следующее случайное число в распределении
(public member function) |
Характеристики |
|
|
(C++11)
|
возвращает параметры распределения
(public member function) |
|
(C++11)
|
получает или устанавливает объект параметров распределения
(public member function) |
|
(C++11)
|
возвращает минимальное потенциально генерируемое значение
(public member function) |
|
(C++11)
|
возвращает максимальное потенциально генерируемое значение
(public member function) |
Функции, не являющиеся членами класса
|
(C++11)
(C++11)
(removed in C++20)
|
сравнивает объекты распределения
(функция) |
|
(C++11)
|
выполняет потоковый ввод и вывод для псевдослучайного распределения чисел
(шаблон функции) |
Пример
#include <iomanip> #include <iostream> #include <map> #include <random> #include <string> int main() { std::random_device rd; std::mt19937 gen(rd()); // Гамма-распределение с alpha = 1 и beta = 2 // аппроксимирует экспоненциальное распределение. std::gamma_distribution<> d(1, 2); std::map<int, int> hist; for (int n = 0; n != 10000; ++n) ++hist[2 * d(gen)]; for (auto const& [x, y] : hist) if (y / 100.0 > 0.5) std::cout << std::fixed << std::setprecision(1) << x / 2.0 << '-' << (x + 1) / 2.0 << ' ' << std::string(y / 100, '*') << '\n'; }
Возможный вывод:
0.0-0.5 ********************** 0.5-1.0 **************** 1.0-1.5 ************* 1.5-2.0 ********** 2.0-2.5 ******** 2.5-3.0 ****** 3.0-3.5 ***** 3.5-4.0 **** 4.0-4.5 *** 4.5-5.0 ** 5.0-5.5 ** 5.5-6.0 * 6.0-6.5 * 6.5-7.0 7.0-7.5 7.5-8.0
Внешние ссылки
| Вайсштейн, Эрик В. "Гамма-распределение." Из MathWorld — веб-ресурс Wolfram. |