本文整理汇总了C#中Sample.PopulationMomentAboutMean方法的典型用法代码示例。如果您正苦于以下问题:C# Sample.PopulationMomentAboutMean方法的具体用法?C# Sample.PopulationMomentAboutMean怎么用?C# Sample.PopulationMomentAboutMean使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Sample
的用法示例。
在下文中一共展示了Sample.PopulationMomentAboutMean方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: SignTestDistribution
public void SignTestDistribution()
{
// start with a non-normally distributed population
Distribution xDistribution = new ExponentialDistribution();
Random rng = new Random(1);
// draw 100 samples from it and compute the t statistic for each
Sample wSample = new Sample();
for (int i = 0; i < 100; i++) {
// each sample has 8 observations
Sample xSample = new Sample();
for (int j = 0; j < 8; j++) { xSample.Add(xDistribution.GetRandomValue(rng)); }
//Sample xSample = CreateSample(xDistribution, 8, i);
TestResult wResult = xSample.SignTest(xDistribution.Median);
double W = wResult.Statistic;
//Console.WriteLine("W = {0}", W);
wSample.Add(W);
}
// sanity check our sample of t's
Assert.IsTrue(wSample.Count == 100);
// check that the t statistics are distributed as expected
DiscreteDistribution wDistribution = new BinomialDistribution(0.5, 8);
// check on the mean
Console.WriteLine("m = {0} vs. {1}", wSample.PopulationMean, wDistribution.Mean);
Assert.IsTrue(wSample.PopulationMean.ConfidenceInterval(0.95).ClosedContains(wDistribution.Mean));
// check on the standard deviation
Console.WriteLine("s = {0} vs. {1}", wSample.PopulationStandardDeviation, wDistribution.StandardDeviation);
Assert.IsTrue(wSample.PopulationStandardDeviation.ConfidenceInterval(0.95).ClosedContains(wDistribution.StandardDeviation));
// check on the skew
Console.WriteLine("t = {0} vs. {1}", wSample.PopulationMomentAboutMean(3), wDistribution.MomentAboutMean(3));
Assert.IsTrue(wSample.PopulationMomentAboutMean(3).ConfidenceInterval(0.95).ClosedContains(wDistribution.MomentAboutMean(3)));
// check on the kuritosis
Console.WriteLine("u = {0} vs. {1}", wSample.PopulationMomentAboutMean(4), wDistribution.MomentAboutMean(4));
Assert.IsTrue(wSample.PopulationMomentAboutMean(4).ConfidenceInterval(0.95).ClosedContains(wDistribution.MomentAboutMean(4)));
// KS tests are only for continuous distributions
}
示例2: TwoSampleKolmogorovNullDistributionTest
public void TwoSampleKolmogorovNullDistributionTest()
{
Distribution population = new ExponentialDistribution();
int[] sizes = new int[] { 23, 30, 175 };
foreach (int na in sizes) {
foreach (int nb in sizes) {
Console.WriteLine("{0} {1}", na, nb);
Sample d = new Sample();
Distribution nullDistribution = null;
for (int i = 0; i < 128; i++) {
Sample a = TestUtilities.CreateSample(population, na, 31415 + na + i);
Sample b = TestUtilities.CreateSample(population, nb, 27182 + nb + i);
TestResult r = Sample.KolmogorovSmirnovTest(a, b);
d.Add(r.Statistic);
nullDistribution = r.Distribution;
}
// Only do full KS test if the number of bins is larger than the sample size, otherwise we are going to fail
// because the KS test detects the granularity of the distribution
TestResult mr = d.KolmogorovSmirnovTest(nullDistribution);
Console.WriteLine(mr.LeftProbability);
if (AdvancedIntegerMath.LCM(na, nb) > d.Count) Assert.IsTrue(mr.LeftProbability < 0.99);
// But always test that mean and standard deviation are as expected
Console.WriteLine("{0} {1}", nullDistribution.Mean, d.PopulationMean.ConfidenceInterval(0.99));
Assert.IsTrue(d.PopulationMean.ConfidenceInterval(0.99).ClosedContains(nullDistribution.Mean));
Console.WriteLine("{0} {1}", nullDistribution.StandardDeviation, d.PopulationStandardDeviation.ConfidenceInterval(0.99));
Assert.IsTrue(d.PopulationStandardDeviation.ConfidenceInterval(0.99).ClosedContains(nullDistribution.StandardDeviation));
Console.WriteLine("{0} {1}", nullDistribution.MomentAboutMean(3), d.PopulationMomentAboutMean(3).ConfidenceInterval(0.99));
//Assert.IsTrue(d.PopulationMomentAboutMean(3).ConfidenceInterval(0.99).ClosedContains(nullDistribution.MomentAboutMean(3)));
//Console.WriteLine("m {0} {1}", nullDistribution.Mean, d.PopulationMean);
}
}
}