가우스 분포를 따르는 임의의 고품질 난수 생성

가우스 분포를 따르는 임의의 고품질 난수 생성

1. C # 버전

1.1. 다음 코드 사용 (MathNet.Numerics 사용)

double[] createRandom(double mean, double stdDev, int sumCount)
        {
            Random rand = new Random();
            MathNet.Numerics.Distributions.Normal normalDist = new Normal(mean, stdDev);
            List<double> resultList = new List<double>();
            for (int index = 0; index < sumCount; index++)
                resultList.Add(normalDist.Sample());
            return resultList.ToArray();
        }

1.2. 사용자 정의 구현은 ( https://www.itranslater.com/qa/details/2325740528148677632 ) 를 참조하십시오.

Random rand = new Random(); //reuse this if you are generating many
double u1 = 1.0-rand.NextDouble(); //uniform(0,1] random doubles
double u2 = 1.0-rand.NextDouble();
double randStdNormal = Math.Sqrt(-2.0 * Math.Log(u1)) *Math.Sin(2.0 * Math.PI * u2); //random normal(0,1)
double randNormal = mean + stdDev * randStdNormal; //random normal(mean,stdDev^2)

2. C ++ 버전

2.1, boost_1_75_0 라이브러리 사용

boost::normal_distribution<> nd(dAverage, dVariance);

 

추천

출처blog.csdn.net/fuweiping/article/details/114383946