Преобразование Бокса – Мюллера - Box–Muller transform
В Преобразование Бокса – Мюллера, от Коробка Джорджа Эдварда Пелхэма и Мервин Эдгар Мюллер,[1] это выборка случайных чисел метод генерации пар независимый, стандарт, нормально распределенный (нуль ожидание, единица измерения отклонение ) случайные числа, учитывая источник равномерно распределены случайные числа. Фактически, этот метод был впервые явно упомянут в Раймонд Э. А. С. Пейли и Норберт Винер в 1934 г.[2]
Преобразование Бокса – Мюллера обычно выражается в двух формах. Основная форма, данная Боксом и Мюллером, берет две выборки из равномерного распределения на интервале [0, 1] и отображает их в две стандартные, нормально распределенные выборки. Полярная форма берет две выборки из другого интервала, [-1, +1], и отображает их в две нормально распределенные выборки без использования функций синуса или косинуса.
Преобразование Бокса – Маллера было разработано как более эффективная с вычислительной точки зрения альтернатива преобразованию метод выборки с обратным преобразованием.[3] В алгоритм зиккурата дает более эффективный метод для скалярных процессоров (например, старых процессоров), в то время как преобразование Бокса – Мюллера лучше для процессоров с векторными модулями (например, графических процессоров или современных процессоров).[4]
Основная форма
Предположим U1 и U2 независимые выборки, выбранные из равномерного распределения на единичный интервал (0, 1). Позволять
и
потом Z0 и Z1 находятся независимый случайные величины с стандартное нормальное распределение.
Вывод[5] основан на свойстве двумерного Декартова система, где координаты X и Y описываются двумя независимыми и нормально распределенными случайными величинами, случайные величины для р2 и Θ (показано выше) в соответствующих полярных координатах также независимы и могут быть выражены как
и
Потому что р2 квадрат нормы стандарта двумерный нормальный переменная (Икс, Y), он имеет распределение хи-квадрат с двумя степенями свободы. В частном случае двух степеней свободы распределение хи-квадрат совпадает с экспоненциальное распределение, а уравнение для р2 выше - простой способ создания требуемой экспоненциальной переменной.
Полярная форма
Полярная форма была впервые предложена Дж. Беллом.[6] а затем модифицирован Р. Кнопом.[7] Хотя было описано несколько различных версий полярного метода, версия Р. Кнопа будет описана здесь, потому что она наиболее широко используется, отчасти из-за ее включения в Числовые рецепты.
Данный ты и v, независимые и равномерно распределенные на отрезке [−1, +1], положим s = р2 = ты2 + v2. Если s = 0 или s ≥ 1, отказаться ты и v, и попробуйте другую пару (ты, v). Потому что ты и v равномерно распределены, и поскольку допускаются только точки внутри единичного круга, значения s будут равномерно распределены и в открытом интервале (0, 1). Последнее можно увидеть, вычислив кумулятивную функцию распределения для s в интервале (0, 1). Это площадь круга радиусом , деленное на . Отсюда мы находим, что функция плотности вероятности имеет постоянное значение 1 на интервале (0, 1). Точно так же угол θ, деленный на равномерно распределена в интервале [0, 1) и не зависит от s.
Теперь мы определяем ценность s с этим из U1 и с этим из U2 в основной форме. Как показано на рисунке, значения и в основном виде можно заменить на коэффициенты и соответственно. Преимущество состоит в том, что можно избежать прямого вычисления тригонометрических функций. Это полезно, когда вычисление тригонометрических функций обходится дороже, чем одно деление, заменяющее каждую из них.
Подобно тому, как базовая форма дает два стандартных нормальных отклонения, так и этот альтернативный расчет.
и
Противопоставление двух форм
Полярный метод отличается от базового метода тем, что является разновидностью отбраковка. Он отбрасывает некоторые сгенерированные случайные числа, но может быть быстрее, чем базовый метод, потому что его проще вычислять (при условии, что генератор случайных чисел относительно быстр) и он более устойчив в числовом отношении.[8] Избегание использования дорогих тригонометрических функций увеличивает скорость по сравнению с базовой формой.[6] Он отбрасывает 1 − π/4 ≈ 21.46% от общего входа сгенерированы равномерно распределенные пары случайных чисел, т. е. отбрасывает 4/π − 1 ≈ 27.32% равномерно распределенные пары случайных чисел на Гауссовский сгенерирована пара случайных чисел, требующая 4/π ≈ 1.2732 входные случайные числа на выходное случайное число.
Базовая форма требует двух умножений, 1/2 логарифма, 1/2 квадратного корня и одной тригонометрической функции для каждой нормальной переменной.[9] На некоторых процессорах косинус и синус одного и того же аргумента могут быть вычислены параллельно с помощью одной инструкции. В частности, для машин на базе Intel можно использовать инструкцию ассемблера fsincos или инструкцию expi (обычно доступную из C как внутренняя функция ), для расчета сложных
и просто разделите реальную и мнимую части.
Заметка: Чтобы явно вычислить комплексно-полярную форму, используйте следующие подстановки в общем виде:
Позволять и потом
Полярная форма требует 3/2 умножения, 1/2 логарифма, 1/2 квадратного корня и 1/2 деления для каждой нормальной вариации. Эффект состоит в том, чтобы заменить одно умножение и одну тригонометрическую функцию одним делением и условным циклом.
Усечение хвостов
Когда компьютер используется для создания однородной случайной величины, он неизбежно будет иметь некоторые неточности, потому что существует нижняя граница того, насколько близки числа к 0. Если генератор использует 32 бита на выходное значение, наименьшее ненулевое число, которое может быть сгенерирован . Когда и равны этому, преобразование Бокса – Маллера дает нормальное случайное отклонение, равное . Это означает, что алгоритм не будет генерировать случайные величины более чем на 6,660 стандартных отклонений от среднего. Это соответствует пропорции потеряно из-за усечения, где - стандартное кумулятивное нормальное распределение. С 64 битами предел сдвигается до стандартные отклонения, для которых .
Реализация
Стандартное преобразование Бокса – Мюллера генерирует значения из стандартного нормального распределения (т.е. стандартные нормальные отклонения ) со средним 0 и стандартное отклонение 1. Реализация ниже в стандарте C ++ генерирует значения из любого нормального распределения со средним и дисперсия . Если стандартное нормальное отклонение, то будет иметь нормальное распределение со средним и стандартное отклонение . Обратите внимание, что генератор случайных чисел был засеянный чтобы гарантировать, что новые псевдослучайные значения будут возвращены из последовательных вызовов generateGaussianNoise
функция.
#включают <cmath>#включают <limits>#включают <random>#включают <utility>стандартное::пара<двойной, двойной> generateGaussianNoise(двойной му, двойной сигма){ constexpr двойной эпсилон = стандартное::numeric_limits<двойной>::эпсилон(); constexpr двойной two_pi = 2.0 * M_PI; статический стандартное::mt19937 rng(стандартное::random_device{}()); // Стандартный mersenne_twister_engine, засеянный с помощью rd () статический стандартное::uniform_real_distribution<> руниф(0.0, 1.0); двойной u1, u2; делать { u1 = руниф(rng); u2 = руниф(rng); } в то время как (u1 <= эпсилон); авто mag = сигма * sqrt(-2.0 * журнал(u1)); авто z0 = mag * потому что(two_pi * u2) + му; авто z1 = mag * грех(two_pi * u2) + му; вернуть стандартное::make_pair(z0, z1);}
Смотрите также
- Выборка с обратным преобразованием
- Полярный метод Марсальи, аналогичное преобразованию Бокса – Мюллера, которое использует декартовы координаты вместо полярных координат.
использованная литература
- Хоуз, Ли; Томас, Дэвид (2008). GPU Gems 3 - эффективная генерация случайных чисел и приложение с использованием CUDA. Pearson Education, Inc. ISBN 978-0-321-51526-1.CS1 maint: ref = harv (ссылка на сайт)
- ^ Box, G.E.P .; Мюллер, Мервин Э. (1958). «Заметка о генерации случайных нормальных отклонений». Анналы математической статистики. 29 (2): 610–611. Дои:10.1214 / aoms / 1177706645. JSTOR 2237361.
- ^ Раймонд Э. А. К. Пейли и Норберт Винер Преобразования Фурье в комплексной области, Нью-Йорк: Американское математическое общество (1934) §37.
- ^ Клёден и Платен, Численные решения стохастических дифференциальных уравнений., стр. 11–12
- ^ Хоус и Томас 2008.
- ^ Шелдон Росс, Первый курс вероятности, (2002), стр. 279–281
- ^ а б Белл, Джеймс Р. (1968). «Алгоритм 334: нормальные случайные отклонения». Коммуникации ACM. 11 (7): 498. Дои:10.1145/363397.363547.
- ^ Кноп, Р. (1969). «Замечание по алгоритму 334 [G5]: нормальные случайные отклонения». Коммуникации ACM. 12 (5): 281. Дои:10.1145/362946.362996.
- ^ Эверетт Ф. Картер-младший, Генерация и применение случайных чисел, Четвертые измерения (1994), т. 16, № 1 и 2.
- ^ Обратите внимание, что оценка 2πU1 считается как одно умножение, потому что значение 2π можно рассчитать заранее и использовать повторно.