Namespaces
Variants

std:: lognormal_distribution

From cppreference.net
Определено в заголовке <random>
template < class RealType = double >
class lognormal_distribution ;
(начиная с C++11)

Распределение случайных чисел lognormal_distribution генерирует случайные числа x > 0 в соответствии с логнормальным распределением :

f(x; m,s) =
1
sx 2 π
exp

-
(ln x - m) 2
2s 2


Параметры m и s являются, соответственно, математическим ожиданием и стандартным отклонением натурального логарифма x .

std::lognormal_distribution удовлетворяет всем требованиям RandomNumberDistribution .

Содержание

Параметры шаблона

RealType - Тип результата, генерируемый генератором. Поведение не определено, если это не один из float , double , или long double .

Типы членов

Тип члена Определение
result_type (C++11) RealType
param_type (C++11) тип набора параметров, см. RandomNumberDistribution .

Функции-члены

создает новое распределение
(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)
сравнивает объекты распределения
(функция)
выполняет потоковый ввод и вывод для псевдослучайного распределения чисел
(шаблон функции)

Пример

#include <cmath>
#include <iomanip>
#include <iostream>
#include <map>
#include <random>
#include <string>
int main()
{
    std::random_device rd;
    std::mt19937 gen(rd());
    std::lognormal_distribution<> d(1.6, 0.25);
    std::map<int, int> hist;
    for (int n = 0; n < 1e4; ++n)
        ++hist[std::round(d(gen))];
    for (std::cout << std::fixed << std::setprecision(1); auto [x, y] : hist)
        std::cout << std::hex << x << ' ' << std::string(y / 200, '*') << '\n';
}

Возможный вывод:

2
3 ***
4 *************
5 ***************
6 *********
7 ****
8 *
9
a
b
c

Внешние ссылки

Вайсштейн, Эрик В. "Логнормальное распределение." Из MathWorld — веб-ресурс Wolfram.