我们的代码库中有一个伪随机数生成器,我们认为它在产生符合给定正态分布的数字的方法上存在错误。
是否有C#实现的正态性测试可以在我的单元测试套件中使用,以确保该模块的行为符合预期?
我更喜欢具有以下签名的东西:
bool NormalityTest.IsNormal(IEnumerable<int> samples)
我们的代码库中有一个伪随机数生成器,我们认为它在产生符合给定正态分布的数字的方法上存在错误。
是否有C#实现的正态性测试可以在我的单元测试套件中使用,以确保该模块的行为符合预期?
我更喜欢具有以下签名的东西:
bool NormalityTest.IsNormal(IEnumerable<int> samples)
// Let's say we would like to determine whether a set
// of observations come from a normal distribution:
double[] samples =
{
0.11, 7.87, 4.61, 10.14, 7.95, 3.14, 0.46, 4.43,
0.21, 4.75, 0.71, 1.52, 3.24, 0.93, 0.42, 4.97,
9.53, 4.55, 0.47, 6.66
};
// For this, we can use the Shapiro-Wilk test. This test tests the null hypothesis
// that samples come from a Normal distribution, vs. the alternative hypothesis that
// the samples do not come from such distribution. In other words, should this test
// come out significant, it means our samples do not come from a Normal distribution.
// Create a new Shapiro-Wilk test:
var sw = new ShapiroWilkTest(samples);
double W = sw.Statistic; // should be 0.90050
double p = sw.PValue; // should be 0.04209
bool significant = sw.Significant; // should be true
// The test is significant, therefore we should reject the null
// hypothesis that the samples come from a Normal distribution.
Math.Net拥有分布函数和随机数生成功能。它可能是最广泛使用的数学库,非常稳定。
Random
类? - EkoostikMartinMathNet.Numerics.Distributions
命名空间中的许多类需要随机数生成器来执行此操作。同时,在.Net自定义RNG中,这是最佳实践。 - EkoostikMartin我不知道有任何关于正态性测试数据的c-implementation。我曾经遇到过同样的问题,然后自己编写了一个程序。这个网页对我帮助很大。它是为在Excel中执行测试而编写的,但它提供了所有必要的系数(Royston)和逻辑。