GrubbsTest Class

Represents a Grubbs test for detecting a single outlier.

DefinitionPermalink

Namespace: Numerics.NET.Statistics.Tests
Assembly: Numerics.NET (in Numerics.NET.dll) Version: 9.1.0
C#
public sealed class GrubbsTest : OneSampleTest
Inheritance
Object  →  HypothesisTest  →  OneSampleTest<Double>  →  OneSampleTest  →  GrubbsTest

RemarksPermalink

The Grubbs test is used to detect a single outlier in a normally distributed sample. The null hypothesis is that there are no outliers in the data. The test statistic is the maximum absolute deviation from the mean, divided by the standard deviation. This statistic follows a Student's t distribution.

The test has two-sided and one-sided versions. In the one-sided version, the null hypothesis is that the smallest (one-tailed lower) or largest (one-tailed upper) value in the sample is not an outlier. In the two-sided version, the null hypothesis is that neither the smallest nor the largest value are outliers.

This test assumes that the sample is drawn from a normal distribution. It can only test for a single outlier. If you suspect there is more than one outlier, the GeneralizedEsdTest is the test of choice.

ExamplePermalink

The following example demonstrates how to use the GrubbsTest class to detect a single outlier in a sample.

C#
using Numerics.NET;  
using Numerics.NET.Statistics.Tests;  
using System;  

Vector<double> data = [ 1.0, 2.0, 3.0, 4.0, 100.0 ];  
GrubbsTest test = new GrubbsTest(data);  
double statistic = test.CalculateStatistic();  
bool isOutlier = test.Reject();  
Console.WriteLine($"Test Statistic: {statistic}");  
Console.WriteLine($"Is Outlier: {isOutlier}");

The following example demonstrates how to use the GrubbsTest class with a one-tailed upper hypothesis.

C#
using Numerics.NET;  
using Numerics.NET.Statistics.Tests;  
using System;  

Vector<double> data = [ 1.0, 2.0, 3.0, 4.0, 100.0 ];  
GrubbsTest test = new GrubbsTest(data, HypothesisType.OneTailedUpper);  
double statistic = test.CalculateStatistic();  
bool isOutlier = test.Reject();  
Console.WriteLine($"Test Statistic: {statistic}");  
Console.WriteLine($"Is Outlier: {isOutlier}");

ConstructorsPermalink

GrubbsTest() Constructs a new Grubbs test for a single outlier.
GrubbsTest(Vector<Double>) Constructs a new Grubbs test for a single outlier.
GrubbsTest(Vector<Double>, HypothesisType) Constructs a new Grubbs test for a single outlier.

PropertiesPermalink

Distribution Gets the probability distribution used in the hypothesis test.
(Inherited from HypothesisTest)
HypothesisType Gets or sets whether the test is one or two-tailed.
(Inherited from HypothesisTest)
Name Gets the name of the hypothesis test.
(Overrides HypothesisTest.Name)
PValue Gets the probability that the test statistic would take on the calculated value under the alternate hypothesis.
(Inherited from HypothesisTest)
Sample Gets or sets the variable the test is to be applied to.
(Inherited from OneSampleTest<T>)
SignificanceLevel Gets the significance level used to test the null hypothesis.
(Inherited from HypothesisTest)
Statistic Gets the value of the test statistic.
(Inherited from HypothesisTest)

MethodsPermalink

EqualsDetermines whether the specified object is equal to the current object.
(Inherited from Object)
GetConfidenceInterval() Returns the confidence interval for the test parameter for the default confidence level.
(Inherited from HypothesisTest)
GetConfidenceInterval(Double) Returns the confidence interval for the test parameter for the specified confidence level.
(Inherited from HypothesisTest)
GetHashCodeServes as the default hash function.
(Inherited from Object)
GetLowerCriticalValue() Gets the lower critical value for the hypothesis test's current significance level.
(Inherited from HypothesisTest)
GetLowerCriticalValue(Double) Gets the lower critical value for the hypothesis test at the specified significance level.
(Inherited from HypothesisTest)
GetPValue Gets the probability that the test statistic would take on the calculated value under the specified alternate hypothesis.
(Inherited from HypothesisTest)
GetTypeGets the Type of the current instance.
(Inherited from Object)
GetUpperCriticalValue() Gets the upper critical value for the test statistic at the hypothesis test's current significance level.
(Inherited from HypothesisTest)
GetUpperCriticalValue(Double) Gets the upper critical value for the test statistic at the specified significance level.
(Inherited from HypothesisTest)
Reject() Returns whether the null hypothesis is rejected using the default significance level.
(Inherited from HypothesisTest)
Reject(Double) Returns whether the null hypothesis is rejected using the specified significance level.
(Inherited from HypothesisTest)
Summarize() Returns a string containing a human-readable summary of the object.
(Inherited from HypothesisTest)
Summarize(SummaryOptions) Returns a string containing a human-readable summary of the object using the specified options.
(Inherited from OneSampleTest<T>)
ToStringReturns a string that represents the current object.
(Inherited from HypothesisTest)

See AlsoPermalink