Non-parametric statistical tests
Contents
3. Non-parametric statistical tests#
3.1. Parametric vs. non-parametric statistical tests#
Parametric test#
Based on parameters that summarize a distribution, such as mean and standard deviation
For example, t-tests and ANOVA assume a normal distribution of samples
Non-parametric test#
Advantage: No assumptions about parent population (more robust)
Disadvantage: Less power in situations where parametric assumptions are satisfied (more samples needed to draw conclusions at same confidence level)
3.2. Testing for normality#
The following figures come from a notebook on the central limit theorem and testing for normality of a distribution:
https://github.com/tompc35/oceanography-notebooks/blob/master/central_limit_theorem.ipynb
Blue: Sample distribution (\(O_i\))
Red: Normal distribution with same mean and standard deviation, expected value (\(E_i\))
Chi squared test for normality#
Tests for goodness of fit
Compare this test statistic to the Chi-Squared distribution \(\chi_{\nu, 1-\alpha}^2\), where \(\nu = k-1\) is the degrees of freedom.
If test statistic is larger than the Chi-square value, can reject the Null Hypothesis that they are from the same distribution. Note that this test is sensitive to bin size.
Probability Plot#
The corresponding probability plot for this distribution is shown below:
The x-axis is the quantiles of the normal. If a normal distribution is split up into some discrete number of pieces, the quantiles are the z-scores at the edges of each piece. The quantiles are tightly clustered near zero.
The y-axis is the ordered values in the sample distribution.
If values are normally distributed, the quantiles should plot linearly with the ordered values. That is, most values are clustered around the mean. Note that this test is qualitative and the \(R^2\) statistic does not have much meaning in this case. As we will see later, correlation statistics are only meaningful of the variables are normally distributed.
Example for a non-normal distribution:#
Kolmogorov-Smirnov test#
Can be used to compare two sample distributions, or a sample distribution and a reference distribution (normal, exponential, etc.)
Null Hypothesis: Samples are drawn from the same distribution (in the two-sample case)
An oceanographic example#
The following two examples use the K-S test to determine if there is significant difference in fluorescence intensity between an experimental treatment (black) and control (gray).
Source: Durkin et al (2009), Chitin in diatoms and its association with the cell wall, Eukaryotic Cell
The graph below illustrates the K-S test statistic for a two-sample test. It is the maximum difference between two the cumulative probability distributions.
Source: https://en.wikipedia.org/wiki/Kolmogorov–Smirnov_test
Illustration of the two-sample Kolmogorov–Smirnov statistic. Red and blue lines each correspond to an empirical distribution function, and the black arrow is the two-sample KS statistic.
This is a very sensitive test, therefore with lots of samples it is very easy to reject the null hypothesis. i.e. low power
from scipy import stats
help(stats.kstest)
Other tests for normality#
Shapiro-Wilk#
High Power
Biased at large sample size (may indicate non-normality for very subtle deviations from normality)
from scipy import stats
help(stats.shapiro)
Anderson-Darling#
from scipy import stats
help(stats.anderson)
These tests, along with the K-S test and probability plots are included in the Python stats library.
Geometric mean#
If you were to log-transform data and then do a T-test, you’d be testing for a differences between geometric means.
Will amplify the large values
Non-parametric tests: univariate data#
Wilcoxan signed-rank test#
\(H_0\): the median difference between pairs of observations is zero
Like a paired t-test on ranks of the differences
Rank the absolute values of the differences (smallest = 1)
Sum the ranks of the positive values, and sum the ranks the negative values separately
The smaller of the two sums is the test statistic T
Low values of T required for significance
Use Mann-Whitney test for unpaired data
from scipy import stats
stats.wilcoxon
Mann- Whitney test#
ranked test
analaogue of t-test for independent samples
from scipy import stats
stats.mannwhitneyu
Kruskal-Wallis ANOVA#
\(H_0\): Means of ranks of groups are the same
\(H_0 (II)\): Medians of groups are the same (assuming they come from distributions with the same shape)
Related to the Mann-Whitney rank-sum test (two groups)
Does not assume normality, but…
According to McDonald, the Fisher’s classic ANOVA is not actually very sensitive to non-normal distributions
Like Fisher’s classic ANOVA, testing \(H_0 (II)\) does not assume difference groups have same variance( homoscedasticity)
Welch’s ANOVA is another alternative to Fisher’s ANOVA that does not assume homoscedasticity (like Welch’s t-test)
from scipy import stats
stats.kruskal
https://docs.scipy.org/doc/scipy-0.14.0/reference/stats.html
Spearman’s correlation coefficient, \(\rho\)#
Non-parametric test for rank-ordered correlation.
Test for a relationship between the rank-ordered data (lowest variable in x corresponds to lowest variable in y, highest variable in x corresponds to highest variable in y, etc.)
\(\rho\) = 1 if y increases monotonically with x
import numpy as np
from scipy import stats
import matplotlib.pyplot as plt
x = np.arange(0,20,0.5)
y1 = np.arctan(x)
y2 = np.arctan(x)+np.random.normal(0,0.1,len(x))
y3 = -np.arctan(x)+np.random.normal(0,0.6,len(x))
rho1,p1 = stats.spearmanr(x,y1)
rho2,p2 = stats.spearmanr(x,y2)
rho3,p3 = stats.spearmanr(x,y3)
plt.figure()
plt.subplot(1,3,1)
plt.plot(x,y1,'.')
plt.title('rho = '+str(round(rho1,3))+'\n p = '+str(round(p1,3)))
plt.subplot(1,3,2)
plt.plot(x,y2,'.')
plt.title('rho = '+str(round(rho2,3))+'\n p = '+str(round(p2,4)))
plt.subplot(1,3,3)
plt.plot(x,y3,'.')
plt.title('rho = '+str(round(rho3,3))+'\n p = '+str(round(p3,4)));
Spearman’s correlation coefficient is not useful for relationships like those below because they are not monotonic relationships.
3.3. A guide to common statistical tests#
3.4. Caution on using non-parametric tests#
What hypothesis is being tested?#
Make sure that if you are using a non-parametric test, that you know what the hypothesis is. If performing a t-test on log transformed data, the null hypothesis is no difference between geometric means (G.M.)
What are the new assumptions?#
For example, Mann-Whitney and Kruskal-Wallis test for differences between medians, not means. Also, these tests still have the very restrictive that the distributions of each group have the same shape. This means that there is an implicity assumption of homoscedasticity, or equal variances between the groups. As discussed in detail by McDonald (2014), the Welch’s ANOVA is robust to deviations from normality and is often a better choice than the Kruskal-Wallis ANOVA for non-normal data.
https://www.biostathandbook.com/kruskalwallis.html
McDonald, J.H. 2014. Handbook of Biological Statistics (3rd ed.). Sparky House Publishing, Baltimore, Maryland. Freely available online at www.biostathandbook.com