Skip to content

A Python 3 implementation of the nested fixed point algorithm for BLP demand estimation.

License

Notifications You must be signed in to change notification settings

yuminliut/pyblp

 
 

Repository files navigation

pyblp

docs-badge pypi-badge python-badge license-badge

An overview of the model, examples, and other documentation can be found on Read the Docs.

The pyblp package is a Python 3 implementation of the nested fixed point algorithm for BLP demand estimation. The author of this package is Jeff Gortmaker. At the moment, the only other contributer is Chris Conlon. Development of the package has been guided by the BLP code made publicly available by many researchers and practitioners. Views expressed in the documentation of this package are those of the contributers and do not necessarily reflect the views of any institution to which they belong.

Installation

The pyblp package has been tested on Python 3.6. The SciPy instructions for installing related packages is a good guide for how to install a scientific Python environment. A good choice is the Anaconda Distribution, since, along with many other packages that are useful for scientific computing, it comes packaged with pyblp's only required dependencies: NumPy and SciPy.

You can install the current release of pyblp with pip:

pip install pyblp

You can upgrade to a newer release with the --upgrade flag:

pip install --upgrade pyblp

If you lack permissions, you can install pyblp in your user directory with the --user flag:

pip install --user pyblp

Alternatively, you can download a wheel or source archive from PyPI. You can find the latest development code on GitHub and the latest development documentation here.

Features

  • Straightforward interface for configuring and solving BLP problems.
  • Support for demographics and supply-side moments.
  • Customizable parameter matrices and bounds.
  • Post-estimation functions for computing elasticities, diversion ratios, marginal costs, markups, profits, HHI, and consumer surplus.
  • Post-estimation merger simulation.
  • Flexible interface for simulating synthetic data under Bertrand-Nash competition.
  • Optimization with Artleys Knitro, SciPy, or custom routines.
  • Fixed point iteration with SQUAREM acceleration or custom routines.
  • Integration with Monte Carlo, Gauss-Hermite/Kronrod-Patterson product rules, sparse grids, or custom specifications.
  • One-step, two-step, or iterated GMM.
  • Control over weighting matrix and standard error computation.
  • Linear or log-linear marginal cost specifications.
  • Functions for building indicators and BLP instruments.
  • Support for market-by-market parallelization.
  • Support for extended floating point precision.
  • Robust handling of computational errors.
  • Informative and configurable progress updates.

Features Slated for Future Versions

In no particular order, listed below are major features that will hopefully be added to the package in future versions:

  • Solving with logit and nested logit.
  • Tests for identification and overidentifying restrictions.
  • Clustered standard errors.
  • Fixed effect absorption.
  • Parametric bootstrap computation of post-estimation standard errors.
  • Built-in IPOPT support.
  • Built-in support for more fixed point routines.
  • Nonlinear optimization alternatives to fixed point iteration when simulation synthetic data or mergers.
  • Hessian computation and tests for local minima.
  • Mathematical Program with Equilibrium Constraints (MPEC) formulation of the GMM objective function.
  • Generalized Empirical Likelihood (GEL) formulation of the problem.

Bugs and Requests

Please use the GitHub issue tracker to submit bugs or to request features.

About

A Python 3 implementation of the nested fixed point algorithm for BLP demand estimation.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 100.0%