Skip to main content

Solve nonlinear perfect foresight models with heterogeneous agents

Project description

Solve nonlinear heterogeneous agent models using automatic differentiation

https://img.shields.io/badge/GitHub-gboehl%2Feconpizza-blue.svg?style=flat https://github.com/dfm/emcee/workflows/Tests/badge.svg https://readthedocs.org/projects/econpizza/badge/?version=latest https://badge.fury.io/py/econpizza.svg

Econpizza is a framework to solve and simulate fully nonlinear perfect foresight models, with or without heterogeneous agents. A parser allows to express economic models in a simple, high-level fashion as yaml-files. Generic and robust routines for steady state search are provided.

The package can solve nonlinear models with heterogeneous agents, such as HANK models with one or two assets and portfolio choice. Steady state and nonlinear impulse responses (including, e.g., the ELB) can typically be found within a few seconds. The approach to deal with heterogeneity extends the Sequence-Space Jacobian method (Auclert et al., 2022, ECMA) to fully nonlinear models by iteratively using jacobian-vector producs to construct the inverse jacobian during each Newton iteration. This not only allows to study the dynamics of aggregate variables, but also the complete nonlinear transition dynamics of the distribution of assets across agents.

To solve models with representative agent the shooting methods of Laffargue (1990), Boucekkine (1995) and Juillard (1996) is implemented. It is faster and more reliable than the extended path method in dynare due to the use of automatic differentiation for the efficient jacobian decompositions during each Newton-step. Nonlinear perfect-foresight transition dynamics can - even for large-scale nonlinear models with several occassionally binding constraints - be computed in less than a second.

The package builds heavily on automatic differentiation via JAX.

A central philosophy of this package is to consequently separate the low-level routines for model solution (which is what happens under the hood) from model specification (via a yaml file) and the high-level interface for model simulation and analysis (what the user does with the model).

A model parser allows for the simple and generic specification of models (with or without heterogeneity) in yaml format.

Documentation

The documentation and some tutorials can be found here.

Installation

Installing the repository version from PyPi is as simple as typing

pip install econpizza

in your terminal or Anaconda Prompt.

Installation on Windows

Econpizza needs JAX to be installed. This is not a problem for MacOS and Linux, but the time for JAX to fully support Windows has not yet come. Fortunately, there is help out there (see this link for the somewhat cryptic original reference). To install JAX, run

pip install "jax[cpu]===0.3.25" -f https://whls.blob.core.windows.net/unstable/index.html --use-deprecated legacy-resolver

prior to installing Econpizza. Econpizza should then run just fine (proof).

In case you run into an error with ptxas (like in this case), a workaround is to disable CUDA by running the following before importing econpizza or JAX:

import os; os.environ["CUDA_VISIBLE_DEVICES"] = "-1"

References

econpizza is developed by Gregor Boehl to simulate nonlinear perfect foresight models. Please cite it with

@Misc{boehl2022pizza,
title         = {Econpizza: solving nonlinear heterogeneous agents models using machine learning techniques},
author        = {Boehl, Gregor},
howpublished  = {\url{https://econpizza.readthedocs.io/_/downloads/en/latest/pdf/}},
year = {2022}
}

For the Boehl-Hommes method: Boehl and Hommes (2021). Rational vs. Irrational Beliefs in a Complex World. IMFS Working papers

@techreport{boehl2021rational,
title         = {Rational vs. Irrational Beliefs in a Complex World},
author        = {Boehl, Gregor and Hommes, Cars},
year          = 2021,
institution   = {IMFS Working Paper Series}
}

I appreciate citations for econpizza because it helps me to find out how people have been using the package and it motivates further work.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

econpizza-0.4.8.tar.gz (744.1 kB view details)

Uploaded Source

Built Distribution

econpizza-0.4.8-py3-none-any.whl (165.2 kB view details)

Uploaded Python 3

File details

Details for the file econpizza-0.4.8.tar.gz.

File metadata

  • Download URL: econpizza-0.4.8.tar.gz
  • Upload date:
  • Size: 744.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.9

File hashes

Hashes for econpizza-0.4.8.tar.gz
Algorithm Hash digest
SHA256 2818d0ab726147689619fee4563641dfbd439903de24584a2fed9f3536e4071e
MD5 ce80e724930e25633847869f5252f1f9
BLAKE2b-256 b8d5720175763fcdff653122bcfe799ad7b4ddcfcf70529baab375aa5b3ebda5

See more details on using hashes here.

Provenance

File details

Details for the file econpizza-0.4.8-py3-none-any.whl.

File metadata

  • Download URL: econpizza-0.4.8-py3-none-any.whl
  • Upload date:
  • Size: 165.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.9

File hashes

Hashes for econpizza-0.4.8-py3-none-any.whl
Algorithm Hash digest
SHA256 8d7effde041f00076b3097ca2d2fed235e15b901f1a5254c9da8165abf595939
MD5 7ded3bedadfe0bd17196be820ab66ef1
BLAKE2b-256 4bb641894f6e2ea85947986c3b90218f351e1d297d6d51c2cb9d7ba2dde41608

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page