Spearman's rank correlation coefficient

From testwiki
Jump to navigation Jump to search

Template:Short description

A Spearman correlation of 1 results when the two variables being compared are monotonically related, even if their relationship is not linear. This means that all data points with greater x values than that of a given data point will have greater y values as well. In contrast, this does not give a perfect Pearson correlation.
When the data are roughly elliptically distributed and there are no prominent outliers, the Spearman correlation and Pearson correlation give similar values.
The Spearman correlation is less sensitive than the Pearson correlation to strong outliers that are in the tails of both samples. That is because Spearman's ρ limits the outlier to the value of its rank.

In statistics, Spearman's rank correlation coefficient or Spearman's ρ, named after Charles Spearman[1] and often denoted by the Greek letter ρ (rho) or as rs, is a nonparametric measure of rank correlation (statistical dependence between the rankings of two variables). It assesses how well the relationship between two variables can be described using a monotonic function.

The Spearman correlation between two variables is equal to the Pearson correlation between the rank values of those two variables; while Pearson's correlation assesses linear relationships, Spearman's correlation assesses monotonic relationships (whether linear or not). If there are no repeated data values, a perfect Spearman correlation of +1 or −1 occurs when each of the variables is a perfect monotone function of the other.

Intuitively, the Spearman correlation between two variables will be high when observations have a similar (or identical for a correlation of 1) rank (i.e. relative position label of the observations within the variable: 1st, 2nd, 3rd, etc.) between the two variables, and low when observations have a dissimilar (or fully opposed for a correlation of −1) rank between the two variables.

Spearman's coefficient is appropriate for both continuous and discrete ordinal variables.[2][3] Both Spearman's ρ and Kendall's τ can be formulated as special cases of a more general correlation coefficient.

Applications

The coefficient can be used to determine how well data fits a model,[4] like when determining the similarity of text documents.[5]

Definition and calculation

The Spearman correlation coefficient is defined as the Pearson correlation coefficient between the rank variables.[6]

For a sample of size  n , the  n  pairs of raw scores  (Xi,Yi)  are converted to ranks  R[Xi],R[Yi] , and  rs  is computed as

rs=ρ[ R[X],R[Y] ]= 𝖼𝗈𝗏[ R[X],R[Y] ]  σR[X] σR[Y] ,

where

ρ  denotes the conventional Pearson correlation coefficient operator, but applied to the rank variables,
𝖼𝗈𝗏[ R[X],R[Y] ]  is the covariance of the rank variables,
σR[X]  and  σR[Y]  are the standard deviations of the rank variables.

Only when all  n  ranks are distinct integers (no ties), it can be computed using the popular formula

rs=16di2 n(n21)  ,

where

diR[Xi]R[Yi]  is the difference between the two ranks of each observation,
 n  is the number of observations.

Template:Clear right Template:Hidden begin Consider a bivariate sample  (Xi,Yi) , i=1, n  with corresponding rank pairs  (R[Xi],R[Yi])=(Ri,Si). Then the Spearman correlation coefficient of  (X,Y)  is

rs= 1 n i=1nRi SiR SσRσS ,

where, as usual,

R= 1 n i=1nRi ,
S= 1 n i=1nSi ,
σR2= 1 n i=1n(RiR)2 ,

and

σS2= 1 n i=1n(SiS)2.

We shall show that  rs  can be expressed purely in terms of  diRiSi , provided we assume that there be no ties within each sample.

Under this assumption, we have that  R,S  can be viewed as random variables distributed like a uniformly distributed discrete random variable,  U , on  { 1,2, , n }. Hence  R=S=𝔼[ U ]  and  σR2=σS2=𝖵𝖺𝗋[ U ]=𝔼[ U2 ]𝔼[ U ]2 , where

𝔼[ U ]= 1 n i=1ni= n+1 2 ,
𝔼[ U2 ]= 1 n i=1ni2= (n+1)(2n+1) 6 ,

and thus

𝗏𝖺𝗋[ U]= (n+1) (2n+1) 6( n+1 2)2= n21 12.

(These sums can be computed using the formulas for the triangular numbers and square pyramidal numbers, or basic summation results from umbral calculus.)

Observe now that

 1 n i=1nRiSiRS= 1 n i=1n 1 2(Ri2+Si2di2)R2= 1 2 1 n i=1nRi2+ 1 2 1 n i=1nSi2 1 2n i=1ndi2R2=( 1 n i=1nRi2R2) 1 2n i=1ndi2=σR2 1 2n i=1ndi2=σR σS 1 2n i=1ndi2

Putting this all together thus yields

rs= σR σS 1 2n i=1ndi2 σR σS=1 i=1ndi2 2n n21 12=1 6 i=1ndi2 n(n21) .

Template:Hidden end

Identical values are usually[7] each assigned fractional ranks equal to the average of their positions in the ascending order of the values, which is equivalent to averaging over all possible permutations.

If ties are present in the data set, the simplified formula above yields incorrect results: Only if in both variables all ranks are distinct, then  σR[X] σR[Y]= 𝗏ar[ R[X] ]= 𝗏ar[ R[Y] ]=  1 12(n21)  (calculated according to biased variance). The first equation — normalizing by the standard deviation — may be used even when ranks are normalized to [0, 1] ("relative ranks") because it is insensitive both to translation and linear scaling.

The simplified method should also not be used in cases where the data set is truncated; that is, when the Spearman's correlation coefficient is desired for the top X records (whether by pre-change rank or post-change rank, or both), the user should use the Pearson correlation coefficient formula given above.[8]

Template:Main

There are several other numerical measures that quantify the extent of statistical dependence between pairs of observations. The most common of these is the Pearson product-moment correlation coefficient, which is a similar correlation method to Spearman's rank, that measures the “linear” relationships between the raw numbers rather than between their ranks.

An alternative name for the Spearman rank correlation is the “grade correlation”;[9] in this, the “rank” of an observation is replaced by the “grade”. In continuous distributions, the grade of an observation is, by convention, always one half less than the rank, and hence the grade and rank correlations are the same in this case. More generally, the “grade” of an observation is proportional to an estimate of the fraction of a population less than a given value, with the half-observation adjustment at observed values. Thus this corresponds to one possible treatment of tied ranks. While unusual, the term “grade correlation” is still in use.[10]

Interpretation

Template:Multiple image

The sign of the Spearman correlation indicates the direction of association between X (the independent variable) and Y (the dependent variable). If Y tends to increase when X increases, the Spearman correlation coefficient is positive. If Y tends to decrease when X increases, the Spearman correlation coefficient is negative. A Spearman correlation of zero indicates that there is no tendency for Y to either increase or decrease when X increases. The Spearman correlation increases in magnitude as X and Y become closer to being perfectly monotonic functions of each other. When X and Y are perfectly monotonically related, the Spearman correlation coefficient becomes 1. A perfectly monotonic increasing relationship implies that for any two pairs of data values Template:Math and Template:Math, that Template:Math and Template:Math always have the same sign. A perfectly monotonic decreasing relationship implies that these differences always have opposite signs.

The Spearman correlation coefficient is often described as being "nonparametric". This can have two meanings. First, a perfect Spearman correlation results when X and Y are related by any monotonic function. Contrast this with the Pearson correlation, which only gives a perfect value when X and Y are related by a linear function. The other sense in which the Spearman correlation is nonparametric is that its exact sampling distribution can be obtained without requiring knowledge (i.e., knowing the parameters) of the joint probability distribution of X and Y.

Example

In this example, the arbitrary raw data in the table below is used to calculate the correlation between the IQ of a person with the number of hours spent in front of TV per week [fictitious values used].

IQ, Xi Hours of TV per week, Yi
106 7
100 27
86 2
101 50
99 28
103 29
97 20
113 12
112 6
110 17

Firstly, evaluate di2. To do so use the following steps, reflected in the table below.

  1. Sort the data by the first column (Xi). Create a new column xi and assign it the ranked values 1, 2, 3, ..., n.
  2. Next, sort the augmented (with xi) data by the second column (Yi). Create a fourth column yi and similarly assign it the ranked values 1, 2, 3, ..., n.
  3. Create a fifth column di to hold the differences between the two rank columns (xi and yi).
  4. Create one final column di2 to hold the value of column di squared.
IQ, Xi Hours of TV per week, Yi rank xi rank yi di di2
86 2 1 1 0 0
97 20 2 6 −4 16
99 28 3 8 −5 25
100 27 4 7 −3 9
101 50 5 10 −5 25
103 29 6 9 −3 9
106 7 7 3 4 16
110 17 8 5 3 9
112 6 9 2 7 49
113 12 10 4 6 36

With di2 found, add them to find di2=194. The value of n is 10. These values can now be substituted back into the equation

ρ=16di2n(n21)

to give

ρ=16×19410(1021),

which evaluates to Template:Math with a p-value = 0.627188 (using the t-distribution).

Chart of the data presented. It can be seen that there might be a negative correlation, but that the relationship does not appear definitive.

That the value is close to zero shows that the correlation between IQ and hours spent watching TV is very low, although the negative value suggests that the longer the time spent watching television the lower the IQ. In the case of ties in the original values, this formula should not be used; instead, the Pearson correlation coefficient should be calculated on the ranks (where ties are given ranks, as described above).

Confidence intervals

Confidence intervals for Spearman's ρ can be easily obtained using the Jackknife Euclidean likelihood approach in de Carvalho and Marques (2012).[11] The confidence interval with level α is based on a Wilks' theorem given in the latter paper, and is given by

{θ:{i=1n(Ziθ)}2i=1n(Ziθ)2χ1,α2},

where χ1,α2 is the α quantile of a chi-square distribution with one degree of freedom, and the Zi are jackknife pseudo-values. This approach is implemented in the R package spearmanCI.

Determining significance

One approach to test whether an observed value of ρ is significantly different from zero (r will always maintain Template:Nowrap) is to calculate the probability that it would be greater than or equal to the observed r, given the null hypothesis, by using a permutation test. An advantage of this approach is that it automatically takes into account the number of tied data values in the sample and the way they are treated in computing the rank correlation.

Another approach parallels the use of the Fisher transformation in the case of the Pearson product-moment correlation coefficient. That is, confidence intervals and hypothesis tests relating to the population value ρ can be carried out using the Fisher transformation:

F(r)=12ln1+r1r=arctanhr.

If F(r) is the Fisher transformation of r, the sample Spearman rank correlation coefficient, and n is the sample size, then

z=n31.06F(r)

is a z-score for r, which approximately follows a standard normal distribution under the null hypothesis of statistical independence (Template:Math).[12][13]

One can also test for significance using

t=rn21r2,

which is distributed approximately as Student's t-distribution with Template:Math degrees of freedom under the null hypothesis.[14] A justification for this result relies on a permutation argument.[15]

A generalization of the Spearman coefficient is useful in the situation where there are three or more conditions, a number of subjects are all observed in each of them, and it is predicted that the observations will have a particular order. For example, a number of subjects might each be given three trials at the same task, and it is predicted that performance will improve from trial to trial. A test of the significance of the trend between conditions in this situation was developed by E. B. Page[16] and is usually referred to as Page's trend test for ordered alternatives.

Correspondence analysis based on Spearman's ρ

Classic correspondence analysis is a statistical method that gives a score to every value of two nominal variables. In this way the Pearson correlation coefficient between them is maximized.

There exists an equivalent of this method, called grade correspondence analysis, which maximizes Spearman's ρ or Kendall's τ.[17]

Approximating Spearman's ρ from a stream

There are two existing approaches to approximating the Spearman's rank correlation coefficient from streaming data.[18][19] The first approach[18] involves coarsening the joint distribution of (X,Y). For continuous X,Y values: m1,m2 cutpoints are selected for X and Y respectively, discretizing these random variables. Default cutpoints are added at and . A count matrix of size (m1+1)×(m2+1), denoted M, is then constructed where M[i,j] stores the number of observations that fall into the two-dimensional cell indexed by (i,j). For streaming data, when a new observation arrives, the appropriate M[i,j] element is incremented. The Spearman's rank correlation can then be computed, based on the count matrix M, using linear algebra operations (Algorithm 2[18]). Note that for discrete random variables, no discretization procedure is necessary. This method is applicable to stationary streaming data as well as large data sets. For non-stationary streaming data, where the Spearman's rank correlation coefficient may change over time, the same procedure can be applied, but to a moving window of observations. When using a moving window, memory requirements grow linearly with chosen window size.

The second approach to approximating the Spearman's rank correlation coefficient from streaming data involves the use of Hermite series based estimators.[19] These estimators, based on Hermite polynomials, allow sequential estimation of the probability density function and cumulative distribution function in univariate and bivariate cases. Bivariate Hermite series density estimators and univariate Hermite series based cumulative distribution function estimators are plugged into a large sample version of the Spearman's rank correlation coefficient estimator, to give a sequential Spearman's correlation estimator. This estimator is phrased in terms of linear algebra operations for computational efficiency (equation (8) and algorithm 1 and 2[19]). These algorithms are only applicable to continuous random variable data, but have certain advantages over the count matrix approach in this setting. The first advantage is improved accuracy when applied to large numbers of observations. The second advantage is that the Spearman's rank correlation coefficient can be computed on non-stationary streams without relying on a moving window. Instead, the Hermite series based estimator uses an exponential weighting scheme to track time-varying Spearman's rank correlation from streaming data, which has constant memory requirements with respect to "effective" moving window size. A software implementation of these Hermite series based algorithms exists [20] and is discussed in Software implementations.

Software implementations

  • R's statistics base-package implements the test cor.test(x, y, method = "spearman") in its "stats" package (also cor(x, y, method = "spearman") will work. The package spearmanCI computes confidence intervals. The package hermiter[20] computes fast batch estimates of the Spearman correlation along with sequential estimates (i.e. estimates that are updated in an online/incremental manner as new observations are incorporated).
  • Stata implementation: spearman varlist calculates all pairwise correlation coefficients for all variables in varlist.
  • MATLAB implementation: [r,p] = corr(x,y,'Type','Spearman') where r is the Spearman's rank correlation coefficient, p is the p-value, and x and y are vectors.[21]
  • Python has many different implementations of the spearman correlation statistic: it can be computed with the spearmanr function of the scipy.stats module, as well as with the DataFrame.corr(method='spearman') method from the pandas library, and the corr(x, y, method='spearman') function from the statistical package pingouin.

See also

Template:Portal

References

Template:Reflist

Further reading

Template:Wikiversity

Template:Statistics