blob: 0270f60b0e48b42e22d8bc7db54c0d5950a1c369 (
plain)
1
2
3
4
5
6
7
8
9
|
export const normalRandom = (mean: number, stdDev: number, maxStdDevs = 2) => {
const [u, v] = [0, 0].map(() => Math.random() + 1e-12);
const normal =
mean + stdDev * Math.sqrt(-2.0 * Math.log(u)) * Math.cos(2.0 * Math.PI * v);
return Math.min(
mean + maxStdDevs * stdDev,
Math.max(mean - maxStdDevs * stdDev, normal)
);
};
|