Measures of Shape: Skewness and Kurtosis
Copyright © 2008–2015 by Stan Brown, Oak Road Systems
Copyright © 2008–2015 by Stan Brown, Oak Road Systems
Why do we care? One application is testing for normality: many statistics inferences require that a distribution be normal or nearly normal. A normal distribution has skewness and excess kurtosis of 0, so if your distribution is close to those values then it is probably close to normal.
The first thing you usually notice about a distribution’s shape is whether it has one mode (peak) or more than one. If it’s unimodal (has just one peak), like most data sets, the next thing you notice is whether it’s symmetric or skewed to one side. If the bulk of the data is at the left and the right tail is longer, we say that the distribution is skewed right or positively skewed; if the peak is toward the right and the left tail is longer, we say that the distribution is skewed left or negatively skewed.
Look at the two graphs below. They both have μ = 0.6923 and σ = 0.1685, but their shapes are different.
Beta(α=4.5, β=2)

1.3846 − Beta(α=4.5, β=2)

The first one is moderately skewed left: the left tail is longer and most of the distribution is at the right. By contrast, the second distribution is moderately skewed right: its right tail is longer and most of the distribution is at the left.
You can get a general impression of skewness by drawing a histogram (MATH200A part 1), but there are also some common numerical measures of skewness. Some authors favor one, some favor another. This Web page presents one of them. In fact, these are the same formulas that Excel uses in its “Descriptive Statistics” tool in Analysis Toolpak.
You may remember that the mean and standard deviation have the same units as the original data, and the variance has the square of those units. However, the skewness has no units: it’s a pure number, like a zscore.
The moment coefficient of skewness of a data set is
skewness: g_{1} = m_{3} / m_{2}^{3/2}
(1) where
m_{3} = ∑(x−x̅)^{3} / n and m_{2} = ∑(x−x̅)^{2} / n
x̅ is the mean and n is the sample size, as usual. m_{3} is called the third moment of the data set. m_{2} is the variance, the square of the standard deviation.
You’ll remember that you have to choose one of two different measures of standard deviation, depending on whether you have data for the whole population or just a sample. The same is true of skewness. If you have the whole population, then g_{1} above is the measure of skewness. But if you have just a sample, you need the sample skewness:
(2) sample skewness:
(The formula comes from Joanes and Gill 1998 [full citation at http://www.tc3.edu/instruct/sbrown/swt/sources.htm#so_Joanes1998].)
Excel doesn’t concern itself with whether you have a sample or a population: its measure of skewness is always G_{1}.
Height (inches)  Class Mark, x  Frequ ency, f 

59.5–62.5  61  5 
62.5–65.5  64  18 
65.5–68.5  67  42 
68.5–71.5  70  27 
71.5–74.5  73  8 
Here are grouped data for heights of 100 randomly selected male students, adapted from Spiegel and Stephens (1999, 68) [full citation at http://www.tc3.edu/instruct/sbrown/swt/sources.htm#so_Spiegel1999].
A histogram shows that the data are skewed left, not symmetric.
But how highly skewed are they, compared to other data sets? To answer this question, you have to compute the skewness.
Begin with the sample size and sample mean. (The sample size was given, but it never hurts to check.)
n = 5+18+42+27+8 = 100
x̅ = (61×5 + 64×18 + 67×42 + 70×27 + 73×8) ÷ 100
x̅ = 9305 + 1152 + 2814 + 1890 + 584) ÷ 100
x̅ = 6745÷100 = 67.45
Now, with the mean in hand, you can compute the skewness. (Of course in real life you’d probably use Excel or a statistics package, but it’s good to know where the numbers come from.)
Class Mark, x  Frequency, f  xf  (x−x̅)  (x−x̅)²f  (x−x̅)³f 

61  5  305  6.45  208.01  1341.68 
64  18  1152  3.45  214.25  739.15 
67  42  2814  0.45  8.51  3.83 
70  27  1890  2.55  175.57  447.70 
73  8  584  5.55  246.42  1367.63 
∑  6745  n/a  852.75  −269.33  
x̅, m_{2}, m_{3}  67.45  n/a  8.5275  −2.6933 
Finally, the skewness is
g_{1} = m_{3} / m_{2}^{3/2} = −2.6933 / 8.5275^{3/2} = −0.1082
But wait, there’s more! That would be the skewness if the you had data for the whole population. But obviously there are more than 100 male students in the world, or even in almost any school, so what you have here is a sample, not the population. You must compute the sample skewness:
= [√(100×99) / 98] [−2.6933 / 8.5275^{3/2}] = −0.1098
If skewness is positive, the data are positively skewed or skewed right, meaning that the right tail of the distribution is longer than the left. If skewness is negative, the data are negatively skewed or skewed left, meaning that the left tail is longer.
If skewness = 0, the data are perfectly symmetrical. But a skewness of exactly zero is quite unlikely for realworld data, so how can you interpret the skewness number? Bulmer (1979) [full citation at http://www.tc3.edu/instruct/sbrown/swt/sources.htm#so_Bulmer1979] — a classic — suggests this rule of thumb:
With a skewness of −0.1098, the sample data for student heights are approximately symmetric.
Caution: This is an interpretation of the data you actually have. When you have data for the whole population, that’s fine. But when you have a sample, the sample skewness doesn’t necessarily apply to the whole population. In that case the question is, from the sample skewness, can you conclude anything about the population skewness? To answer that question, see the next section.
Your data set is just one sample drawn from a population. Maybe, from ordinary sample variability, your sample is skewed even though the population is symmetric. But if the sample is skewed too much for random chance to be the explanation, then you can conclude that there is skewness in the population.
But what do I mean by “too much for random chance to be the explanation”? To answer that, you need to divide the sample skewness G_{1} by the standard error of skewness (SES) to get the test statistic, which measures how many standard errors separate the sample skewness from zero:
(3) test statistic: Z_{g1} = G_{1}/SES where
This formula is adapted from page 85 of Cramer (1997) [full citation at http://www.tc3.edu/instruct/sbrown/swt/sources.htm#so_Cramer1997]. (Some authors suggest √(6/n), but for small samples that’s a poor approximation. And anyway, we’ve all got calculators, so you may as well do it right.)
The critical value of Z_{g1} is approximately 2. (This is a twotailed test of skewness ≠ 0 at roughly the 0.05 significance level.)
Don’t mix up the meanings of this test statistic and the amount of skewness. The amount of skewness tells you how highly skewed your sample is: the bigger the number, the bigger the skew. The test statistic tells you whether the whole population is probably skewed, but not by how much: the bigger the number, the higher the probability.
GraphPad suggests a confidence interval for skewness:
(4) 95% confidence interval of population skewness = G_{1} ± 2 SES
I’m not so sure about that. Joanes and Gill [full citation at http://www.tc3.edu/instruct/sbrown/swt/sources.htm#so_Joanes1998] point out that sample skewness is an unbiased estimator of population skewness for normal distributions, but not others. So I would say, compute that confidence interval, but take it with several grains of salt — and the further the sample skewness is from zero, the more skeptical you should be.
For the college men’s heights, recall that the sample skewness was G_{1} = −0.1098. The sample size was n = 100 and therefore the standard error of skewness is
SES = √[ (600×99) / (98×101×103) ] = 0.2414
The test statistic is
Z_{g1} = G_{1}/SES = −0.1098 / 0.2414 = −0.45
This is quite small, so it’s impossible to say whether the population is symmetric or skewed. Since the sample skewness is small, a confidence interval is probably reasonable:
G_{1} ± 2 SES = −.1098 ± 2×.2414 = −.1098±.4828 = −0.5926 to +0.3730.
You can give a 95% confidence interval of skewness as about −0.59 to +0.37, more or less.
If a distribution is symmetric, the next question is about the central peak: is it high and sharp, or short and broad? You can get some idea of this from the histogram, but a numerical measure is more precise.
The height and sharpness of the peak relative to the rest of the data are measured by a number called kurtosis. Higher values indicate a higher, sharper peak; lower values indicate a lower, less distinct peak. This occurs because, as Wikipedia’s article on kurtosis explains, higher kurtosis means more of the variability is due to a few extreme differences from the mean, rather than a lot of modest differences from the mean.
Balanda and MacGillivray (1988) [full citation at http://www.tc3.edu/instruct/sbrown/swt/sources.htm#so_Balanda1988] say the same thing in another way: increasing kurtosis is associated with the “movement of probability mass from the shoulders of a distribution into its center and tails.”
You may remember that the mean and standard deviation have the same units as the original data, and the variance has the square of those units. However, the kurtosis has no units: it’s a pure number, like a zscore.
The reference standard is a normal distribution, which has a kurtosis of 3. In token of this, often the excess kurtosis is presented: excess kurtosis is simply kurtosis−3. For example, the “kurtosis” reported by Excel is actually the excess kurtosis.
Kurtosis is unfortunately harder to picture than skewness, but these illustrations, suggested by Wikipedia, should help. All three of these distributions have mean of 0, standard deviation of 1, and skewness of 0, and all are plotted on the same horizontal and vertical scale. Look at the progression from left to right, as kurtosis increases.
Uniform(min=−√3, max=√3)

Normal(μ=0, σ=1)

Logistic(α=0, β=0.55153)

Moving from the illustrated uniform distribution to a normal distribution, you see that the “shoulders” have transferred some of their mass to the center and the tails. In other words, the intermediate values have become less likely and the central and extreme values have become more likely. The kurtosis increases while the standard deviation stays the same, because more of the variation is due to extreme values.
Moving from the normal distribution to the illustrated logistic distribution, the trend continues. There is even less in the shoulders and even more in the tails, and the central peak is higher and narrower.
How far can this go? What are the smallest and largest possible values of kurtosis? The smallest possible kurtosis is 1 (excess kurtosis −2), and the largest is ∞, as shown here:
Discrete: equally likely values

Student’s t (df=4)

A discrete distribution with two equally likely outcomes, such as winning or losing on the flip of a coin, has the lowest possible kurtosis. It has no central peak and no real tails, and you could say that it’s “all shoulder” — it’s as platykurtic as a distribution can be. At the other extreme, Student’s t distribution with four degrees of freedom has infinite kurtosis. A distribution can’t be any more leptokurtic than this.
The moment coefficient of kurtosis of a data set is computed almost the same way as the coefficient of skewness: just change the exponent 3 to 4 in the formulas:
kurtosis: a_{4} = m_{4} / m_{2}^{2} and excess kurtosis: g_{2} = a_{4}−3
(5) where
m_{4} = ∑(x−x̅)^{4} / n and m_{2} = ∑(x−x̅)^{2} / n
Again, the excess kurtosis is generally used because the excess kurtosis of a normal distribution is 0. x̅ is the mean and n is the sample size, as usual. m_{4} is called the fourth moment of the data set. m_{2} is the variance, the square of the standard deviation.
Just as with variance, standard deviation, and kurtosis, the above is the final computation if you have data for the whole population. But if you have data for only a sample, you have to compute the sample excess kurtosis using this formula, which comes from Joanes and Gill [full citation at http://www.tc3.edu/instruct/sbrown/swt/sources.htm#so_Joanes1998]:
(6) sample excess kurtosis:
Excel doesn’t concern itself with whether you have a sample or a population: its measure of kurtosis is always G_{2}.
Example: Let’s continue with the example of the college men’s heights, and compute the kurtosis of the data set. n = 100, x̅ = 67.45 inches, and the variance m_{2} = 8.5275 in² were computed earlier.
Class Mark, x  Frequency, f  x−x̅  (x−x̅)^{4}f 

61  5  6.45  8653.84 
64  18  3.45  2550.05 
67  42  0.45  1.72 
70  27  2.55  1141.63 
73  8  5.55  7590.35 
∑  n/a  19937.60  
m_{4}  n/a  199.3760 
Finally, the kurtosis is
a_{4} = m_{4} / m_{2}² = 199.3760/8.5275² = 2.7418
and the excess kurtosis is
g_{2} = 2.7418−3 = −0.2582
But this is a sample, not the population, so you have to compute the sample excess kurtosis:
G_{2} = [99/(98×97)] [101×(−0.2582)+6)] = −0.2091
This sample is slightly platykurtic: its peak is just a bit shallower than the peak of a normal distribution.
Your data set is just one sample drawn from a population. How far must the excess kurtosis be from 0, before you can say that the population also has nonzero excess kurtosis?
The question is similar to the question about skewness, and the answers are similar too. You divide the sample excess kurtosis by the standard error of kurtosis (SEK) to get the test statistic, which tells you how many standard errors the sample excess kurtosis is from zero:
(7) test statistic: Z_{g2} = G_{2} / SEK where
The formula is adapted from page 89 of Cramer (1979) [full citation at http://www.tc3.edu/instruct/sbrown/swt/sources.htm#so_Cramer1997]. (Some authors suggest √(24/n), but for small samples that’s a poor approximation. And anyway, we’ve all got calculators, so you may as well do it right.)
The critical value of Z_{g2} is approximately 2. (This is a twotailed test of excess kurtosis ≠ 0 at approximately the 0.05 significance level.)
For the sample college men’s heights (n=100), you found excess kurtosis of G_{2} = −0.2091. The sample is platykurtic, but is this enough to let you say that the whole population is platykurtic (has lower kurtosis than the bell curve)?
First compute the standard error of kurtosis:
SEK = 2 × SES × √[ (n²−1) / ((n−3)(n+5)) ]
n = 100, and the SES was previously computed as 0.2414.
SEK = 2 × 0.2414 × √[ (100²−1) / (97×105) ] = 0.4784
The test statistic is
Z_{g2} = G_{2}/SEK = −0.2091 / 0.4784 = −0.44
You can’t say whether the kurtosis of the population is the same as or different from the kurtosis of a normal distribution.
There are many ways to assess normality, and unfortunately none of them are without problems.
One test is the D'AgostinoPearson omnibus test (D’Agostino and Stephens [full citation at http://www.tc3.edu/instruct/sbrown/swt/sources.htm#so_Dagostino1986], 390–391; for an online source see Öztuna, Elhan, Tüccar [full citation at http://www.tc3.edu/instruct/sbrown/swt/sources.htm#so_Oztuna2006]). It’s called an omnibus test because it uses the test statistics for both skewness and kurtosis to come up with a single pvalue assessing whether this data set’s shape is too different from normal. The test statistic is
(8) DP = Z_{g1}² + Z_{g2}² follows χ² with df=2
You can look up the pvalue in a table, or use
χ²cdf
on a TI83 or TI84.
χ²cdf(2, 5.991464546) = 0.95, so if the test statistic is bigger than about 6 you would reject the hypothesis of normality at the .05 level.
Caution: The D’AgostinoPearson test has a tendency to err on the side of rejecting normality, particularly with small sample sizes. David Moriarty, in his StatCat utility, recommends that you don’t use D’AgostinoPearson for sample sizes below 20.
For college students’ heights you had test statistics Z_{g1} = −0.45 for skewness and Z_{g2} = 0.44 for kurtosis. The omnibus test statistic is
DP = Z_{g1}² + Z_{g2}² = 0.45² + 0.44² = 0.3961
and the pvalue for χ²(2 df) > 0.3961, from a table or a statistics calculator, is 0.8203. You cannot reject the assumption of normality. (Remember, you never accept the null hypothesis, so you can’t say from this test that the distribution is normal.) The histogram suggests normality, and this test gives you no reason to reject that impression.
There’s no One Right Way to test for normality. One of many alternatives to the D’AgostinoPearson test is making a normal probability plot; the accompanying workbook does this. (See Technology near the top of this page.)
TI83/84/89 calculator owners can use Normality Check on TI83/84 or Normality Check on TI89.
See also: The University of Surrey has a good survey of problems with normality tests, at How do I test the normality of a variable’s distribution? (You have to scroll down about 2/3 of the page to get to the relevant section, headed YOU THOUGHT THIS WAS GOING TO BE QUICK AND SIMPLE BUT…) That page recommends using the test statistics Z_{g1} and Z_{g2} individually.
For a second illustration of inferences about skewness and kurtosis of a population, I’ll use an example from Bulmer [full citation at http://www.tc3.edu/instruct/sbrown/swt/sources.htm#so_Bulmer1979]:
Frequency distribution of litter size in rats, n=815  

Litter size  1  2  3  4  5  6  7  8  9  10  11  12  
Frequency  7  33  58  116  125  126  121  107  56  37  25  4 
I’ll spare you the detailed calculations, but you should be able to verify them by following equation (1) and equation (2):
n = 815, x̅ = 6.1252, m_{2} = 5.1721, m_{3} = 2.0316
skewness g_{1} = 0.1727 and sample skewness G_{1} = 0.1730
The sample is roughly symmetric but slightly skewed right, which looks about right from the histogram. The standard error of skewness is
SES = √[ (6×815×814) / (813×816×818) ] = 0.0856
Dividing the skewness by the SES, you get the test statistic
Z_{g1} = 0.1730 / 0.0856 = 2.02
Since this is greater than 2, you can say that there is some positive skewness in the population. Again, “some positive skewness” just means a figure greater than zero; it doesn’t tell us anything more about the magnitude of the skewness.
If you go on to compute a 95% confidence interval of skewness from equation (4), you get 0.1730±2×0.0856 = 0.00 to 0.34.
What about the kurtosis? You should be able to follow equation (5) and compute a fourth moment of m_{4} = 67.3948. You already have m_{2} = 5.1721, and therefore
kurtosis a_{4} = m_{4} / m_{2}² = 67.3948 / 5.1721² = 2.5194
excess kurtosis g_{2} = 2.5194−3 = −0.4806
sample excess kurtosis G_{2} = [814/(813×812)] [816×(−0.4806+6) = −0.4762
So the sample is moderately less peaked than a normal distribution. Again, this matches the histogram, where you can see the higher “shoulders”.
What if anything can you say about the population? For this you need equation (7). Begin by computing the standard error of kurtosis, using n = 815 and the previously computed SES of 0.0.0856:
SEK = 2 × SES × √[ (n²−1) / ((n−3)(n+5)) ]
SEK = 2 × 0.0856 × √[ (815²−1) / (812×820) ] = 0.1711
and divide:
Z_{g2} = G_{2}/SEK = −0.4762 / 0.1711 = −2.78
Since Z_{g2} is comfortably below −2, you can say that the distribution of all litter sizes is platykurtic, less sharply peaked than the normal distribution. But be careful: you know that it is platykurtic, but you don’t know by how much.
You already know the population is not normal, but let’s apply the D’AgostinoPearson test anyway:
DP = 2.02² + 2.78² = 11.8088
pvalue = P( χ²(2) > 11.8088 ) = 0.0027
The test agrees with the separate tests of skewness and kurtosis: sizes of rat litters, for the entire population of rats, is not normally distributed.
This page is used in instruction at Tompkins Cortland Community College in Dryden, New York; it’s not an official statement of the College. Please visit www.tc3.edu/instruct/sbrown/ to report errors or ask to copy it.
For updates and new info, go to http://www.tc3.edu/instruct/sbrown/stat/