/matelike

Empirical Likelihood for Matlab

Primary LanguageMatlab

MatELike (version 0.1.4)
John Zedlewski (jzedlewski@hbs.edu)

DESCRIPTION:

MatELike is a Matlab package to estimate Empirical Likelihood (EL)
models by direct maximization. It includes tools to formulate problems
easily and use automatic differentiation to efficiently estimate
models with nonlinear moment conditions. It can use the robust
optimization code Ipopt (which must be installed separately) or the
included ZIPsolver interior-point optimization method to solve the
very large maximization problems that arise in EL.

INSTALLATION:

To install MatELike, unzip the matelike archive and place the
resulting melroot directory wherever you like to store your Matlab
code. Add the subdirectory "melroot/matelike" to your Matlab
path with a command like:

   addpath c:/matlab/melroot/matelike

where c:/matlab is replaced with the base directory in which matelike
is stored. Edit the file matelike/elLoad.m so that the variable
BASEPATH points to the directory where MatELike is installed. Now the
package is installed, but you must load it into Matlab's memory in
each session before you can use it. Load the package with the command:

   elLoad

you should see some output and then "Loaded matElike verson 0.1.4
package successfully". To avoid repeating these steps every time you
run Matlab, you can add those commands to your 'startup.m' file
(search the Matlab help docs for startup.m for information on how to
do this).

Usage:

More documentation coming soon! Individual functions have usage
documentation, so look at the source or type 'help elSetup' and
'help elSolve' in Matlab to view the docs.

For now, look at 'simpleDemoEL.m' (under 'matelike/demos') to see a
trivial usage. (Currently, simpleDemo makes little sense as a model,
but it illustrates the code usage.) testDP.m is a more complicated
dynamic panel data model, based on Imbens 2002 JBES.

The only real steps are:

- write a function that computes the moment conditions for each observation
- call 'elike = elSetup(...)', specifying the number of observations, etc.
- call 'res = elSolve(elike, ...)' to solve the model

For linear two-stage-least-squares models, the 'elLinearIV' function
is much more efficient than using 'elSolve' directly. To use
'elLinearIV' you can skip the 'elSetup' step: just put your
instruments (Z) and structural variables (X) in to matrices and pass
them into 'elLinearIV'. The moment condition is that 'y - X*theta' is
orthogonal to 'Z'.


REQUIREMENTS:

Tested on Matlab 7.4 and 7.6. For large models, a 64-bit platform is
very helpful. The Ipopt code is tested with Ipopt 3.3.4 with the
Matlab mex bridge.

LICENSE:

MatELike includes Intlab, which is copyright by Siegfried Rump @
TUHH. That package's license states that:

"INTLAB is free for private use and for purely academic purposes
provided proper reference is given acknowledging that the software
package INTLAB has been developed by Siegfried M. Rump at Hamburg
University of Technology, Germany. For any other use of INTLAB a
license is required." (See also: http://www.ti3.tu-harburg.de/rump/intlab/)

All other components are copyright 2008 by John Zedlewski and are
distributed under the same license: Free use for academic and/or
personal purposes is permitted as long as this authorship is
acknowledged.