RandomExtensions.cs 1.1 KB

12345678910111213141516171819202122232425262728293031323334
  1. using System;
  2. using System.Diagnostics;
  3. namespace Masuit.Tools
  4. {
  5. public static class RandomExtensions
  6. {
  7. /// <summary>
  8. /// 生成真正的随机数
  9. /// </summary>
  10. /// <param name="r"></param>
  11. /// <param name="seed"></param>
  12. /// <returns></returns>
  13. public static int StrictNext(this Random r, int seed = int.MaxValue)
  14. {
  15. return new Random((int)Stopwatch.GetTimestamp()).Next(seed);
  16. }
  17. /// <summary>
  18. /// 产生正态分布的随机数
  19. /// </summary>
  20. /// <param name="rand"></param>
  21. /// <param name="mean">均值</param>
  22. /// <param name="stdDev">方差</param>
  23. /// <returns></returns>
  24. public static double NextGauss(this Random rand, double mean, double stdDev)
  25. {
  26. double u1 = 1.0 - rand.NextDouble();
  27. double u2 = 1.0 - rand.NextDouble();
  28. double randStdNormal = Math.Sqrt(-2.0 * Math.Log(u1)) * Math.Sin(2.0 * Math.PI * u2);
  29. return mean + stdDev * randStdNormal;
  30. }
  31. }
  32. }