Генерация случайного числа на основе бета-распределения с использованием Boost

Я пытаюсь использовать Boost для генерации случайных чисел в соответствии с бета-дистрибутивом с использованием C++. В Интернете я видел много примеров генерации случайных чисел в соответствии с распределениями в random.hpp (например, в этой книге). Тем не менее, я не вижу, чтобы перевести их для использования бета-дистрибутива, найденного в beta.hpp.

Благодарю.

2 ответа

Решение

Сначала вы захотите нарисовать случайное число равномерно из диапазона (0,1). Для любого распределения вы можете затем вставить это число в "квантильную функцию" распределения, и в результате вы получите случайное значение из распределения. Отсюда:

Общий метод генерации случайных чисел из произвольного распределения, в котором есть cdf без переходов, заключается в использовании обратной функции для cdf: G(y)=F^{-1}(y). Если u(1), ..., u(n) - случайные числа из равномерного распределения (0,1), то G(u(1)), ..., G(u(n)) - случайное число образец из дистрибутива с cdf F(x).

Так как же получить квантильную функцию для бета-распределения? Документация для beta.hpp находится здесь. Вы должны быть в состоянии использовать что-то вроде этого:

#include <boost/math/distributions.hpp>
using namespace boost::math;

double alpha, beta, randFromUnif; 
//parameters and the random value on (0,1) you drew

beta_distribution<> dist(alpha, beta);
double randFromDist = quantile(dist, randFromUnif);

Согласно демонстрации Boost для библиотеки случайных чисел Random_demo.cpp и Генерация целых чисел с различными вероятностями

Что вы должны сделать, это использовать класс "variate_generator", чтобы связать ваш генератор случайных чисел и распределение.

Пример может выглядеть так

#include <iostream>
#include "boost/random.hpp"

int main(int argc, char *argv[])
{
    int seed = 2018;
    typedef boost::random::mt19937 RandomNumberGenerator;
    typedef boost::random::beta_distribution<> BetaDistribution;
    typedef boost::variate_generator<RandomNumberGenerator&, BetaDistribution> 
    Generator;
    RandomNumberGenerator Rng(seed);
    BetaDistribution distribution(2,5);
    Generator getRandomNumber(Rng,distribution);
    for (int idx = 0 ; idx < 1000 ; ++idx) 
    {
        std::cout << getRandomNumber() << std::endl;
    }
return 0;
}

Тем не менее, в более позднем документе введите здесь описание ссылки, кажется, что boost рекомендует напрямую передавать генератор объекту распределения. Результат из кода ниже идентичен.

#include <iostream>
#include "boost/random.hpp"

int main(int argc, char *argv[])
{
    int seed = 2018;
    typedef boost::random::mt19937 RandomNumberGenerator;
    typedef boost::random::beta_distribution<> BetaDistribution;
    RandomNumberGenerator Rng(seed);
    BetaDistribution distribution(2,5);
    for (int idx = 0 ; idx < 1000 ; ++idx) 
    {
        std::cout << distribution(Rng) << std::endl;
    }
return 0;
}
Другие вопросы по тегам