Unity 机器学习代理工具包 (ML-Agents) 是一个开源项目,它使游戏和模拟能够作为训练智能代理的环境。
您最多选择25个主题 主题必须以中文或者字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符
 
 
 
 
 

55 行
1.6 KiB

using System;
namespace MLAgents.InferenceBrain.Utils
{
/// <summary>
/// RandomNormal - A random number generator that produces normally distributed random
/// numbers using the Marsaglia polar method:
/// https://en.wikipedia.org/wiki/Marsaglia_polar_method
/// TODO: worth overriding System.Random instead of aggregating?
/// </summary>
public class RandomNormal
{
private readonly double _mean;
private readonly double _stddev;
private readonly Random _random;
public RandomNormal(int seed, float mean = 0.0f, float stddev = 1.0f)
{
_mean = mean;
_stddev = stddev;
_random = new Random(seed);
}
// Each iteration produces two numbers. Hold one here for next call
private bool _hasSpare;
private double _spareUnscaled;
/// <summary>
/// Return the next random double number
/// </summary>
/// <returns>Next random double number</returns>
public double NextDouble()
{
if (_hasSpare)
{
_hasSpare = false;
return _spareUnscaled * _stddev + _mean;
}
double u, v, s;
do
{
u = _random.NextDouble() * 2.0 - 1.0;
v = _random.NextDouble() * 2.0 - 1.0;
s = u * u + v * v;
} while (s >= 1.0 || Math.Abs(s) < double.Epsilon);
s = Math.Sqrt(-2.0 * Math.Log(s) / s);
_spareUnscaled = u * s;
_hasSpare = true;
return v * s * _stddev + _mean;
}
}
}