Entropy-Based Inference Using R and The NP Package: A Primer
Entropy-Based Inference Using R and The NP Package: A Primer
Entropy-Based Inference Using R and The NP Package: A Primer
Package: A Primer
Jeffrey S. Racine
McMaster University
Abstract
We describe new functionality in the R (R Development Core Team (2010)) package
np (Hayfield and Racine (2008)) by providing a brief overview of each approach and its
implementation followed by brief illustrative examples. A simple demonstration outlining
how practitioners can implement their own entropy functions is also provided.
1. Overview
In versions 0.30-4 through 0.30-7 of the np package (Hayfield and Racine (2008)) we introduced
a range of new functions that may be of interest to those conducting applied research. The
five new functions are summarized in Table 1 below.
Function Description Reference
npdeneqtest Nonparametric Test for Equality of Densities Li, Maasoumi, and Racine (2009)
npdeptest Nonparametric Entropy Test for Pairwise De- Maasoumi and Racine (2002)
pendence
npsdeptest Nonparametric Entropy Test for Serial Non- Granger, Maasoumi, and Racine
linear Dependence (2004)
npsymtest Nonparametric Entropy Test for Asymmetry Racine and Maasoumi (2007),
Maasoumi and Racine (2009)
npunitest Nonparametric Entropy Test for Univariate Maasoumi and Racine (2002)
Density Equality
In what follows we briefly describe each new function listed in Table 1 and provide illustrative
examples of their use. Be aware that many of these functions rely on numerical integration
and can be computationally demanding. Though we provide moment-based versions of the
most computationally demanding functions, we advocate the use of the integral-based versions
which are the default. In the last section of this overview we describe in detail how the user
can implement their own custom entropy functions with minimal effort using the np package.
of continuous and categorical data. This test can be accessed via the npdeneqtest function.
Let X and Y be multivariate vectors of dimension q + r where q denotes the number of
continuous variables and r the number of discrete/categorical variables. A test statistic
R can
be constructed based on the integrated squared density difference given by I = [f (x) −
2
R
g(x)] dx = [f (x)dF (x) + g(x)dG(x) − f (x)dG(x) − g(x)dF (x)], where RF (·) and PG(·) are R the
cumulative distribution functions for X and Y , respectively, and where dx = xd ∈Sd dxc .
Replacing the first occurrences of f (·) and g(·) by their leave-one-out kernel estimates, and
replacing F (·) and G(·) by their empirical distribution functions, we obtain the following test
statistic,
n1 X
n1 n2 X
n2 n1 X
n2
1 X 1 X 2 X
In = Kγ,xi ,xj + Kγ,yi ,yj − Kγ,xi ,yj .
n1 (n1 − 1) n2 (n2 − 1) n1 n 2
i=1 j6=i i=1 j6=i i=1 j=i
where
n1 Xn1 n2 Xn2
1 X 1 X
σn2 = 2(n1 n2 h1 . . . hq ) (K γ,x ,x ) 2
+ (Kγ,yi ,yj )2
n21 (n1 − 1)2 i=1 i j
n22 (n2 − 1)2 i=1
j6=i j6=i
n1 Xn2
2 X
+ 2 2 (Kγ,xi ,yj )2 ,
n1 n2 i=1 j=1
which is a consistent estimator of σ02 = 2[δ −1 + δ + 2][E[f (Xi )]][ W 2 (v)dv], the asymptotic
R
variance of (n1 n2 h1 . . . hq )1/2 In , where δ = limmin{n1 ,n2 }→∞ (n1 /n2 ). Under the alternative the
statistic diverges to +∞, so the test is one-sided rejecting when the test statistic is sufficiently
large.
The test that uses critical values taken from the asymptotic distribution displays finite-sample
size distortions, so the npdeneqtest function employs bootstrap resampling to obtain the
finite-sample distribution of the statistic (this provides a test having correct size). The boot-
strap resamples are obtained by resampling from the empirical distribution of the pooled
data (i.e. are drawn from a common multivariate distribution under the null). Bandwidths
are obtained via likelihood cross-validation by default.
The following code snippet provides two simple examples using a mix of continuous and
discrete data. Note that the two samples must be data frames with identically named variables
(e.g., the variables ‘wages’ and ‘experience’ must be common to both data frames while sample
A could be that for females, sample B for males).
R> set.seed(1234)
R> n <- 250
R> ## Distributions are equal
R>
R> sample.A <- data.frame(a=rnorm(n),b=factor(rbinom(n,2,.5)))
R> sample.B <- data.frame(a=rnorm(n),b=factor(rbinom(n,2,.5)))
R> npdeneqtest(sample.A,sample.B,boot.num=99)
Jeffrey S. Racine 3
where f1 = f (x) and f2 = f (y) are the marginal densities of the random variables X and
Y . The second expression is in a moment form which is often replaced with a sample av-
erage, especially for theoretical developments. When X and Y are discrete/categorical, we
replace integration with the sum over all possible outcomes. The unknown density/probability
functions are replaced with nonparametric kernel estimates.
The bootstrap is conducted by resampling with replacement from the pooled empirical distri-
bution of X and Y (X only for the moment version). Default bandwidths are of the plug-in
variety (‘bw.SJ’ for continuous variables and direct plug-in for discrete variables).
The following code snippet provides three simple examples for both continuous and discrete
data.
4 Entropy-Based Inference using R and the np Package: A Primer
R> set.seed(1234)
R> n <- 1000
R> ## Compute the statistic only, different distributions
R>
R> x <- rchisq(n,df=10)
R> y <- rnorm(n,sd=10000,mean=-10000)
R> npunitest(x,y,bootstrap=FALSE)
The function npsymtest computes the nonparametric metric entropy (normalized Hellinger
of Granger et al. (2004)) outlined in Maasoumi and Racine (2009) for testing the null of
symmetry using the densities/probabilities of the data and the rotated data, f (y) and f (ỹ),
respectively, and in Racine and Maasoumi (2007). Y must be univariate and can be a time
series, continuous, or even categorical valued so long as the outcomes are not character strings.
For bootstrapping the null distribution of the statistic, ‘iid’ conducts simple random resam-
pling, while ‘geom’ conducts stationary bootstrapping using automatic block length selection
via the ‘b.star’ function in the ‘np’ package (Politis and Romano (1994), Politis and White
(2004), Patton, Politis, and White (2009)). Bootstrapping is conducted by resampling from
the empirical distribution of the pooled data and rotated data. Default bandwidths are of
the plug-in variety (‘bw.SJ’ for continuous variables and direct plug-in for discrete variables).
For continuous variables we use
1
Z
1/2 2
1/2
Sρ = f1 − f2 dx
2
!2
1/2
1 f2
Z
= 1− dF1 (x),
2 1/2
f1
where f1 and f2 are the marginal densities of the data and rotated data, respectively. The
second expression is in a moment form which is often replaced with a sample average, especially
for theoretical developments. When Y is discrete/categorical, we replace integration with the
sum over all possible outcomes.
6 Entropy-Based Inference using R and the np Package: A Primer
The following code snippet provides two simple examples for both continuous and discrete
data.
R> set.seed(1234)
R> n <- 100
R> ## Asymmetric discrete probability distribution
R>
R> x <- factor(rbinom(n,2,.8))
R> npsymtest(x,boot.num=99)
The bootstrap distribution is obtained by resampling with replacement from the empirical
distribution of X delivering {Xi , Yi } pairs under the null generated as {Xi∗ , Yi } where X ∗ is
the bootstrap resample (i.e. we ‘shuffle’ X leaving Y unchanged thereby breaking any pairwise
dependence to generate resamples under the null). Bandwidths are obtained via likelihood
cross-validation by default for the marginal and joint densities.
Examples include, (a) a measure/test of “fit”, for in-sample values of a variable y and its
fitted values, ŷ, and (b) a measure of “predictability” for a variable y and its predicted values
ŷ (from a user implemented model).
The following code snippet provides a simple example using the actual and fitted values from
a regression model. Note that we strongly advocate the use of the integration (default) version
of the statistic in applied settings but use the summation (i.e. moment) version below purely
by way of demonstration as it is computationally faster.
R> set.seed(123)
R> ## Test/measure lack of fit between y and its fitted value from a
R> ## regression model when x is relevant.
R> n <- 100
R> x <- rnorm(n)
R> y <- 1 + x + rnorm(n)
R> model <- lm(y~x)
R> y.fit <- fitted(model)
R> npdeptest(y,y.fit,boot.num=99,method="summation")
where f1 = f (yt , yt−k ) is the joint density and f2 = g(yt ) × h(yt−k ) is the product of the
marginal densities of the random variables Yt and Yt−k . The second expression is in a moment
8 Entropy-Based Inference using R and the np Package: A Primer
form which is often replaced with a sample average, especially for theoretical developments.
The unknown density/probability functions are replaced with nonparametric kernel estimates.
The bootstrap distribution is obtained by resampling with replacement from the empirical
distribution of Yt delivering Yt∗ under the null of nonlinear serial independence. Bandwidths
are obtained via likelihood cross-validation by default for the marginal and joint densities.
The following code snippet provides a simple example for a continuous time series. Note that
we strongly advocate the use of the integration (default) version of the statistic in applied
settings but use the summation (i.e. moment) version below purely by way of demonstration
as it is computationally faster.
R> set.seed(123)
R> ## A function to create a time series
R> ar.series <- function(phi,epsilon) {
+ n <- length(epsilon)
+ series <- numeric(n)
+ series[1] <- epsilon[1]/(1-phi)
+ for(i in 2:n) {
+ series[i] <- phi*series[i-1] + epsilon[i]
+ }
+ return(series)
+ }
R> n <- 100
R> ## Stationary persistent time-series
R> yt <- ar.series(0.95,rnorm(n))
R> npsdeptest(yt,lag.num=2,boot.num=99,method="summation")
In the following code snippet we construct a simple function in R that accomplishes this. You
could of course use nonparametric methods for both distributions or parametric methods for
both. The function npudens computes unconditional kernel density estimates, and fitted
computes the fitted density for the sample realizations. The function dnorm provides the
normal density function. The integrate function performs univariate numerical integration.
[1] 0.000871
[1] 0.858
8. Summary
The np package (Hayfield and Racine (2008)) contains new functionality introduced in versions
0.30-4 through 0.30-7 that implements a range of entropy-based inferential procedures. We
hope you find these to be easy to use. Please report any issues encountered to racinej@mcmaster.ca.
Any suggestions for improvements to this document would be greatly appreciated. As always,
if you use these functions for your work we would sincerely appreciate your citing both the
relevant published research papers and the np package (Hayfield and Racine (2008)).
Acknowledgments
We would like to gratefully acknowledge support from the Natural Sciences and Engineering
Research Council of Canada (http://www.nserc.ca), the Social Sciences and Humanities
Research Council of Canada (http://www.sshrc.ca), and the Shared Hierarchical Academic
Research Computing Network (http://www.sharcnet.ca).
References
Johnson SG, Narasimhan B (2009). cubature: Adaptive multivariate integration over hyper-
cubes. R package version 1.0, URL http://CRAN.R-project.org/package=cubature.
Maasoumi E, Racine JS (2002). “Entropy and Predictability of Stock Market Returns.” Jour-
nal of Econometrics, 107(2), 291–312.
Maasoumi E, Racine JS (2009). “A robust entropy-based test of asymmetry for discrete and
continuous processes.” Econometric Reviews, 28, 246–261.
Politis DN, Romano JP (1994). “Limit theorems for weakly dependent Hilbert space valued
random variables with applications to the stationary bootstrap.” Statistica Sinica, 4, 461–
476.
Politis DN, White H (2004). “Automatic block-length selection for the dependent bootstrap.”
Econometric Reviews, 23, 53–70.
Jeffrey S. Racine 11
R Development Core Team (2010). R: A Language and Environment for Statistical Comput-
ing. R Foundation for Statistical Computing, Vienna, Austria. ISBN 3-900051-07-0, URL
http://www.R-project.org.
Racine J, Maasoumi E (2007). “A Versatile and Robust Metric Entropy Test of Time Re-
versibility and Dependence.” Journal of Econometrics, 138, 547–567.
Affiliation:
Jeffrey S. Racine
Department of Economics
McMaster University
Hamilton, Ontario, Canada, L8S 4L8
E-mail: racinej@mcmaster.ca
URL: http://www.mcmaster.ca/economics/racine/