Class TTest
- java.lang.Object
- 
- org.apache.commons.statistics.inference.TTest
 
- 
 public final class TTest extends Object Implements Student's t-test statistics.Tests can be: - One-sample or two-sample
- One-sided or two-sided
- Paired or unpaired (for two-sample tests)
- Homoscedastic (equal variance assumption) or heteroscedastic (for two sample tests)
 Input to tests can be either double[]arrays or the mean, variance, and size of the sample.- Since:
- 1.1
- See Also:
- Student's t-test (Wikipedia)
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classTTest.ResultResult for the t-test.
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description doublepairedStatistic(double[] x, double[] y)Computes a paired two-sample t-statistic on related samples comparing the mean difference between the samples tomu.TTest.ResultpairedTest(double[] x, double[] y)Performs a paired two-sample t-test on related samples comparing the mean difference between the samples tomu.doublestatistic(double[] x)Computes a one-sample t statistic comparing the mean of the sample tomu.doublestatistic(double[] x, double[] y)Computes a two-sample t statistic on independent samples comparing the difference in means of the samples tomu.doublestatistic(double m, double v, long n)Computes a one-sample t statistic comparing the mean of the dataset tomu.doublestatistic(double m1, double v1, long n1, double m2, double v2, long n2)Computes a two-sample t statistic on independent samples comparing the difference in means of the datasets tomu.TTest.Resulttest(double[] sample)Performs a one-sample t-test comparing the mean of the sample tomu.TTest.Resulttest(double[] x, double[] y)Performs a two-sample t-test on independent samples comparing the difference in means of the samples tomu.TTest.Resulttest(double m, double v, long n)Perform a one-sample t-test comparing the mean of the dataset tomu.TTest.Resulttest(double m1, double v1, long n1, double m2, double v2, long n2)Performs a two-sample t-test on independent samples comparing the difference in means of the datasets tomu.TTestwith(AlternativeHypothesis v)Return an instance with the configured alternative hypothesis.TTestwith(DataDispersion v)Return an instance with the configured assumption on the data dispersion.static TTestwithDefaults()Return an instance using the default options.TTestwithMu(double v)Return an instance with the configuredmu.
 
- 
- 
- 
Method Detail- 
withDefaultspublic static TTest withDefaults() Return an instance using the default options.- Returns:
- default instance
 
 - 
withpublic TTest with(AlternativeHypothesis v) Return an instance with the configured alternative hypothesis.- Parameters:
- v- Value.
- Returns:
- an instance
 
 - 
withpublic TTest with(DataDispersion v) Return an instance with the configured assumption on the data dispersion.Applies to the two-sample independent t-test. The statistic can compare the means without the assumption of equal sub-population variances (heteroscedastic); otherwise the means are compared under the assumption of equal sub-population variances (homoscedastic). - Parameters:
- v- Value.
- Returns:
- an instance
- See Also:
- test(double[], double[]),- test(double, double, long, double, double, long)
 
 - 
withMupublic TTest withMu(double v) Return an instance with the configuredmu.For the one-sample test this is the expected mean. For the two-sample test this is the expected difference between the means. - Parameters:
- v- Value.
- Returns:
- an instance
- Throws:
- IllegalArgumentException- if the value is not finite
 
 - 
statisticpublic double statistic(double m, double v, long n) Computes a one-sample t statistic comparing the mean of the dataset tomu.The returned t-statistic is: \[ t = \frac{m - \mu}{ \sqrt{ \frac{v}{n} } } \] - Parameters:
- m- Sample mean.
- v- Sample variance.
- n- Sample size.
- Returns:
- t statistic
- Throws:
- IllegalArgumentException- if the number of samples is- < 2; or the variance is negative
- See Also:
- withMu(double)
 
 - 
statisticpublic double statistic(double[] x) Computes a one-sample t statistic comparing the mean of the sample tomu.- Parameters:
- x- Sample values.
- Returns:
- t statistic
- Throws:
- IllegalArgumentException- if the number of samples is- < 2
- See Also:
- statistic(double, double, long),- withMu(double)
 
 - 
pairedStatisticpublic double pairedStatistic(double[] x, double[] y) Computes a paired two-sample t-statistic on related samples comparing the mean difference between the samples tomu.The t-statistic returned is functionally equivalent to what would be returned by computing the one-sample t-statistic statistic(double[]), with the sample array consisting of the (signed) differences between corresponding entries inxandy.- Parameters:
- x- First sample values.
- y- Second sample values.
- Returns:
- t statistic
- Throws:
- IllegalArgumentException- if the number of samples is- < 2; or the the size of the samples is not equal
- See Also:
- withMu(double)
 
 - 
statisticpublic double statistic(double m1, double v1, long n1, double m2, double v2, long n2) Computes a two-sample t statistic on independent samples comparing the difference in means of the datasets tomu.Use the DataDispersionto control the computation of the variance.The heteroscedastic t-statistic is: \[ t = \frac{m1 - m2 - \mu}{ \sqrt{ \frac{v_1}{n_1} + \frac{v_2}{n_2} } } \] The homoscedastic t-statistic is: \[ t = \frac{m1 - m2 - \mu}{ \sqrt{ v (\frac{1}{n_1} + \frac{1}{n_2}) } } \] where \( v \) is the pooled variance estimate: \[ v = \frac{(n_1-1)v_1 + (n_2-1)v_2}{n_1 + n_2 - 2} \] - Parameters:
- m1- First sample mean.
- v1- First sample variance.
- n1- First sample size.
- m2- Second sample mean.
- v2- Second sample variance.
- n2- Second sample size.
- Returns:
- t statistic
- Throws:
- IllegalArgumentException- if the number of samples in either dataset is- < 2; or the variances are negative.
- See Also:
- withMu(double),- with(DataDispersion)
 
 - 
statisticpublic double statistic(double[] x, double[] y) Computes a two-sample t statistic on independent samples comparing the difference in means of the samples tomu.Use the DataDispersionto control the computation of the variance.- Parameters:
- x- First sample values.
- y- Second sample values.
- Returns:
- t statistic
- Throws:
- IllegalArgumentException- if the number of samples in either dataset is- < 2
- See Also:
- withMu(double),- with(DataDispersion)
 
 - 
testpublic TTest.Result test(double m, double v, long n) Perform a one-sample t-test comparing the mean of the dataset tomu.Degrees of freedom are \( v = n - 1 \). - Parameters:
- m- Sample mean.
- v- Sample variance.
- n- Sample size.
- Returns:
- test result
- Throws:
- IllegalArgumentException- if the number of samples is- < 2; or the variance is negative
- See Also:
- statistic(double, double, long)
 
 - 
testpublic TTest.Result test(double[] sample) Performs a one-sample t-test comparing the mean of the sample tomu.Degrees of freedom are \( v = n - 1 \). - Parameters:
- sample- Sample values.
- Returns:
- the test result
- Throws:
- IllegalArgumentException- if the number of samples is- < 2; or the the size of the samples is not equal
- See Also:
- statistic(double[])
 
 - 
pairedTestpublic TTest.Result pairedTest(double[] x, double[] y) Performs a paired two-sample t-test on related samples comparing the mean difference between the samples tomu.The test is functionally equivalent to what would be returned by computing the one-sample t-test test(double[]), with the sample array consisting of the (signed) differences between corresponding entries inxandy.- Parameters:
- x- First sample values.
- y- Second sample values.
- Returns:
- the test result
- Throws:
- IllegalArgumentException- if the number of samples is- < 2; or the the size of the samples is not equal
- See Also:
- pairedStatistic(double[], double[])
 
 - 
testpublic TTest.Result test(double m1, double v1, long n1, double m2, double v2, long n2) Performs a two-sample t-test on independent samples comparing the difference in means of the datasets tomu.Use the DataDispersionto control the computation of the variance.The heteroscedastic degrees of freedom are estimated using the Welch-Satterthwaite approximation: \[ v = \frac{ (\frac{v_1}{n_1} + \frac{v_2}{n_2})^2 } { \frac{(v_1/n_1)^2}{n_1-1} + \frac{(v_2/n_2)^2}{n_2-1} } \] The homoscedastic degrees of freedom are \( v = n_1 + n_2 - 2 \). - Parameters:
- m1- First sample mean.
- v1- First sample variance.
- n1- First sample size.
- m2- Second sample mean.
- v2- Second sample variance.
- n2- Second sample size.
- Returns:
- test result
- Throws:
- IllegalArgumentException- if the number of samples in either dataset is- < 2; or the variances are negative.
- See Also:
- statistic(double, double, long, double, double, long)
 
 - 
testpublic TTest.Result test(double[] x, double[] y) Performs a two-sample t-test on independent samples comparing the difference in means of the samples tomu.Use the DataDispersionto control the computation of the variance.- Parameters:
- x- First sample values.
- y- Second sample values.
- Returns:
- the test result
- Throws:
- IllegalArgumentException- if the number of samples in either dataset is- < 2
- See Also:
- statistic(double[], double[]),- test(double, double, long, double, double, long)
 
 
- 
 
-