Перетворення Бокса-Мюллера
Матеріал з Вікіпедії — вільної енциклопедії.
Перетвóрення Боксу — Мюллера — метод моделювання стандартних нормально розподілених випадкових величин. Має два варіанти. Метод є точним, на відміну, наприклад, від методів що ґрунтуються на центральній граничній теоремі.
Метод був опублікований в 1958 році Джорджем Боксом і Мервіном Мюллером.
[ред.] Перший варіант
Хай r і φ — незалежні випадкові величини, рівномірно розподілені на інтервалі (0, 1]. Обчислимо z0 і z1 за формулами:
Тоді z0 і z1 будуть незалежні і розподілені нормально з математичним сподіванням 0 і дисперсією 1. При реалізації на комп'ютері зазвичай швидше не обчислювати обидві тригонометричні функції — и — а розрахувати одну з них через іншу. Ще краще скористатися натомість другим варіантом перетворення Боксу — Мюллера.
[ред.] Другий варіант
Нехай x і y — незалежні випадкові величини, рівномірно розподілені на відрізку [−1, 1]. Обчислимо R = x2 + y2. Якщо виявиться, що R > 1 чи R = 0, то значення x і y слід «викинути» і згенерувати наново. Як тільки виконається умова за формулами
і
слід розрахувати z0 и z1, які, як і в першому випадку, будуть незалежними величинами, що задовольняють стандартному нормальному розподілу.
Коефіцієнт використовування базових випадкових величин для першого варіанту, очевидно, рівний одиниці. Для другого варіанту це відношення площі кола одиничного радіусу до площі квадрата із стороною два, тобто . Проте, на практиці другий варіант звичайно виявляється швидше, за рахунок того, що в ньому використовується тільки одна трансцендентна функція . Ця перевага для більшості реалізацій переважує необхідність генерації більшого числа рівномірно розподілених випадкових величин.
[ред.] Перехід до загального нормального розподілу
Після отримання стандартної нормальної випадкової величини z, можна легко перейти до величини , що є нормально розподіленою з математичним очікуванням μ і стандартним відхиленням μ за формулою:
- ξ = μ + σz.
Це вже не є частиною перетворення Боксу — Мюллера, але дозволяє завершити генерацію нормальної випадкової величини.