Misplaced Pages

Jarque–Bera test

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
Normality test

In statistics, the Jarque–Bera test is a goodness-of-fit test of whether sample data have the skewness and kurtosis matching a normal distribution. The test is named after Carlos Jarque and Anil K. Bera. The test statistic is always nonnegative. If it is far from zero, it signals the data do not have a normal distribution.

The test statistic JB is defined as

J B = n 6 ( S 2 + 1 4 ( K 3 ) 2 ) {\displaystyle {\mathit {JB}}={\frac {n}{6}}\left(S^{2}+{\frac {1}{4}}(K-3)^{2}\right)}

where n is the number of observations (or degrees of freedom in general); S is the sample skewness, K is the sample kurtosis :

S = μ ^ 3 σ ^ 3 = 1 n i = 1 n ( x i x ¯ ) 3 ( 1 n i = 1 n ( x i x ¯ ) 2 ) 3 / 2 , {\displaystyle S={\frac {{\hat {\mu }}_{3}}{{\hat {\sigma }}^{3}}}={\frac {{\frac {1}{n}}\sum _{i=1}^{n}(x_{i}-{\bar {x}})^{3}}{\left({\frac {1}{n}}\sum _{i=1}^{n}(x_{i}-{\bar {x}})^{2}\right)^{3/2}}},}
K = μ ^ 4 σ ^ 4 = 1 n i = 1 n ( x i x ¯ ) 4 ( 1 n i = 1 n ( x i x ¯ ) 2 ) 2 , {\displaystyle K={\frac {{\hat {\mu }}_{4}}{{\hat {\sigma }}^{4}}}={\frac {{\frac {1}{n}}\sum _{i=1}^{n}(x_{i}-{\bar {x}})^{4}}{\left({\frac {1}{n}}\sum _{i=1}^{n}(x_{i}-{\bar {x}})^{2}\right)^{2}}},}

where μ ^ 3 {\displaystyle {\hat {\mu }}_{3}} and μ ^ 4 {\displaystyle {\hat {\mu }}_{4}} are the estimates of third and fourth central moments, respectively, x ¯ {\displaystyle {\bar {x}}} is the sample mean, and σ ^ 2 {\displaystyle {\hat {\sigma }}^{2}} is the estimate of the second central moment, the variance.

If the data comes from a normal distribution, the JB statistic asymptotically has a chi-squared distribution with two degrees of freedom, so the statistic can be used to test the hypothesis that the data are from a normal distribution. The null hypothesis is a joint hypothesis of the skewness being zero and the excess kurtosis being zero. Samples from a normal distribution have an expected skewness of 0 and an expected excess kurtosis of 0 (which is the same as a kurtosis of 3). As the definition of JB shows, any deviation from this increases the JB statistic.

For small samples the chi-squared approximation is overly sensitive, often rejecting the null hypothesis when it is true. Furthermore, the distribution of p-values departs from a uniform distribution and becomes a right-skewed unimodal distribution, especially for small p-values. This leads to a large Type I error rate. The table below shows some p-values approximated by a chi-squared distribution that differ from their true alpha levels for small samples.

Calculated p-values equivalents to true alpha levels at given sample sizes
True α level 20 30 50 70 100
0.1 0.307 0.252 0.201 0.183 0.1560
0.05 0.1461 0.109 0.079 0.067 0.062
0.025 0.051 0.0303 0.020 0.016 0.0168
0.01 0.0064 0.0033 0.0015 0.0012 0.002

(These values have been approximated using Monte Carlo simulation in Matlab)

In MATLAB's implementation, the chi-squared approximation for the JB statistic's distribution is only used for large sample sizes (> 2000). For smaller samples, it uses a table derived from Monte Carlo simulations in order to interpolate p-values.

History

The statistic was derived by Carlos M. Jarque and Anil K. Bera while working on their Ph.D. Thesis at the Australian National University.

Jarque–Bera test in regression analysis

According to Robert Hall, David Lilien, et al. (1995) when using this test along with multiple regression analysis the right estimate is:

J B = n k 6 ( S 2 + 1 4 ( K 3 ) 2 ) {\displaystyle {\mathit {JB}}={\frac {n-k}{6}}\left(S^{2}+{\frac {1}{4}}(K-3)^{2}\right)}

where n is the number of observations and k is the number of regressors when examining residuals to an equation.

Implementations

  • ALGLIB includes an implementation of the Jarque–Bera test in C++, C#, Delphi, Visual Basic, etc.
  • gretl includes an implementation of the Jarque–Bera test
  • Julia includes an implementation of the Jarque-Bera test JarqueBeraTest in the HypothesisTests package.
  • MATLAB includes an implementation of the Jarque–Bera test, the function "jbtest".
  • Python statsmodels includes an implementation of the Jarque–Bera test, "statsmodels.stats.stattools.py".
  • R includes implementations of the Jarque–Bera test: jarque.bera.test in the package tseries, for example, and jarque.test in the package moments.
  • Wolfram includes a built in function called, JarqueBeraALMTest and is not limited to testing against a Gaussian distribution.

See also

References

  1. "Analysis of the JB-Test in MATLAB". MathWorks. Retrieved May 24, 2009.
  2. "Time series tests". juliastats.org. Retrieved 2020-02-04.
  3. "tseries: Time Series Analysis and Computational Finance". R Project.
  4. "moments: Moments, cumulants, skewness, kurtosis and related tests". R Project.
  5. "JarqueBeraALMTest—Wolfram Language Documentation". reference.wolfram.com. Retrieved 2017-10-26.

Further reading

  • Jarque, Carlos M.; Bera, Anil K. (1980). "Efficient tests for normality, homoscedasticity and serial independence of regression residuals". Economics Letters. 6 (3): 255–259. doi:10.1016/0165-1765(80)90024-5.
  • Jarque, Carlos M.; Bera, Anil K. (1981). "Efficient tests for normality, homoscedasticity and serial independence of regression residuals: Monte Carlo evidence". Economics Letters. 7 (4): 313–318. doi:10.1016/0165-1765(81)90035-5.
  • Jarque, Carlos M.; Bera, Anil K. (1987). "A test for normality of observations and regression residuals". International Statistical Review. 55 (2): 163–172. doi:10.2307/1403192. JSTOR 1403192.
  • Judge; et al. (1988). Introduction and the theory and practice of econometrics (3rd ed.). pp. 890–892.
  • Hall, Robert E.; Lilien, David M.; et al. (1995). EViews User Guide. p. 141.
Statistics
Descriptive statistics
Continuous data
Center
Dispersion
Shape
Count data
Summary tables
Dependence
Graphics
Data collection
Study design
Survey methodology
Controlled experiments
Adaptive designs
Observational studies
Statistical inference
Statistical theory
Frequentist inference
Point estimation
Interval estimation
Testing hypotheses
Parametric tests
Specific tests
Goodness of fit
Rank statistics
Bayesian inference
Correlation
Regression analysis
Linear regression
Non-standard predictors
Generalized linear model
Partition of variance
Categorical / Multivariate / Time-series / Survival analysis
Categorical
Multivariate
Time-series
General
Specific tests
Time domain
Frequency domain
Survival
Survival function
Hazard function
Test
Applications
Biostatistics
Engineering statistics
Social statistics
Spatial statistics
Category: