diff --git a/Documentation/conf.py b/Documentation/conf.py index 3edbc487e..7a3b8c6d0 100644 --- a/Documentation/conf.py +++ b/Documentation/conf.py @@ -98,8 +98,29 @@ "attributes": {"target": "_blank"}, }, ], + "secondary_sidebar_items": { + "**": ["page-toc", "sourcelink"], + "index": ["page-toc"], + }, } +nbsphinx_prolog = r""" +{% set docname = 'Documentation/' + env.doc2path(env.docname, base=None) %} + +.. raw:: html + +
+ This page was generated from + {{ docname|e }}. +
+ Interactive online version: + Binder badge. + Download notebook. +
+""" +myst_enable_extensions = [ + "colon_fence", +] # Point to Econ-ARK repo for edit buttons html_context = { "github_url": "https://github.com", diff --git a/Documentation/guides/installation.md b/Documentation/guides/installation.md index 5c4bd00de..439a54ee0 100644 --- a/Documentation/guides/installation.md +++ b/Documentation/guides/installation.md @@ -1,13 +1,12 @@ # HARK installation guide -HARK is an open source project written in Python. It's compatible with both Python -2 and 3, and with the Anaconda distributions of python 2 and 3. +HARK is an open source project written in Python. It's supported for Python versions 3.10 and up. ## Instructions for a new user -In order to use HARK, you firstly need to download Python and add Python to the PATH. We recommend to install python 3, as eventually support for python 2 will end. If you are not confident about the installation process you can use this step-by-step guide https://realpython.com/installing-python/ . +In order to use HARK, you firstly need to download Python and add Python to the PATH. If you are not confident about the installation process you can use [this step-by-step guide](https://realpython.com/installing-python/). -Next, install a text editor for Python. If you do not use the Anaconda Python distribution (see below), we recommend [Atom](https://atom.io/). To use Atom for Python, first install it (you can use this [manual](https://flight-manual.atom.io/getting-started/sections/installing-atom/)). Next, install the [packages](https://flight-manual.atom.io/using-atom/sections/atom-packages/) for Python, we recommend to install at least [autocomplete-python](https://atom.io/packages/autocomplete-python) and [atom-ide-debugger-python](https://flight-manual.atom.io/using-atom/sections/atom-packages/). The last enables debugging the Python scripts, that is to set breakpoints and call variables in certain spot of your code (with increase in your codes' sophistication you will find this tools very helpful in finding bugs). +Next, you'll want a text editor for Python. If you do not use the Anaconda Python distribution (see below), we recommend [VSCode](https://code.visualstudio.com/) or [PyCharm](https://www.jetbrains.com/pycharm/). After installing Python and the text editor, you can install HARK package. The simplest way is to use [pip](https://pip.pypa.io/en/stable/installing/). @@ -44,9 +43,9 @@ Next, install `econ-ark` into your new virtual environment via pip: pip install econ-ark ``` ---- -**!NOTE** + +:::{note} If you install econ-ark into the virtual environment, your HARK scripts will not compile unless it is activated. @@ -71,22 +70,21 @@ cd [directory where you located your script] python YourScript.py ``` -For using the text editor, you also need to configure the environment. If you use [Atom](https://atom.io/), simply type `atom` at a command prompt after activating the environment. Atom text editor will open and you will be able to compile your codes which use HARK. - +For using the text editor, you also need to configure the environment. +::: --- ### Using HARK with Anaconda Installing HARK with pip does not give you full access to HARK's many graphical capabilities. One way to access these capabilities is by using [Anaconda](https://anaconda.com/why-anaconda), which is a distribution of python along with many packages that are frequently used in scientific computing. -1. Download Anaconda for your operating system and follow the installation instructions [at Anaconda.com](https://www.anaconda.com/distribution/#download-section). +1. Download Anaconda for your operating system and follow the installation instructions [at Anaconda.com](https://www.anaconda.com/download/success). --- +:::{note} -**!NOTE** - -You can have the default python distribution from python.org and from anaconda, as they do not interfere. However, be careful with setting the PATH. To avoid problems you can eg. set the environment variables path to the default distribution and access anaconda distribution via anaconda prompt. - +You can have the default python distribution from python.org and from anaconda, as they do not interfere. However, be careful with setting the PATH. To avoid problems you can set the environment variables path to the default distribution and access anaconda distribution via anaconda prompt. +::: --- 2. Anaconda includes its own virtual environment system called `conda` which stores environments in a preset location (so you don't have to choose). So in order to create and activate an econ-ark virtual environment: @@ -201,8 +199,7 @@ pip install -e . --- -**!NOTE** - +:::{note} To check the package performance with your local changes, use the same command from the command line (after navigating to your HARK directory): ``` @@ -215,3 +212,4 @@ If for some reason you want to switch back to the PyPI version: pip uninstall econ-ark pip install econ-ark (options) ``` +::: diff --git a/Documentation/guides/quick_start.md b/Documentation/guides/quick_start.md index f808f0c7f..bddb07ace 100644 --- a/Documentation/guides/quick_start.md +++ b/Documentation/guides/quick_start.md @@ -2,9 +2,9 @@ ## Installing HARK -HARK is an open source project that is compatible with Python 3. Currently, we recommend using version 3.10 or lower. +HARK is an open source project that is compatible with Python 3. Currently, we recommend using version 3.10 or higher. -The simplest way to install HARK is to use [pip](https://pip.pypa.io/en/stable/installation/). +The simplest way to install HARK is to use [pip](https://pip.pypa.io/en/stable/installation/) by running `pip install econ-ark` in your command line. Before installing HARK, we recommend creating a new virtual environment, which isolates the installation of `econ-ark` from the installations of any other Python tools and packages, thus avoiding conflicts. @@ -18,31 +18,53 @@ pip install econ-ark ## Learning HARK -We have a set of 30-second [Elevator Spiels](https://github.com/econ-ark/PARK/blob/master/Elevator-Spiels.md#capsule-summaries-of-what-the-econ-ark-project-is) describing the project, tailored to people with several different kinds of background. +We've prepared a set of 30-second Elevator Spiels describing the project, tailored to people with several different kinds of background. -The most broadly applicable advice is to go to [Econ-ARK](https://econ-ark.org) and click on "Notebooks", and choose [A Gentle Introduction to HARK](https://docs.econ-ark.org/example_notebooks/Gentle-Intro-To-HARK.html) which will launch as a [jupyter notebook](https://jupyter.org/). +To start learning HARK we recommend working through the [Overview and Examples](https://docs.econ-ark.org/overview/index.html) section starting with [A Gentle Introduction to HARK](https://docs.econ-ark.org/example_notebooks/Gentle-Intro-To-HARK.html). -### [For people with a technical/scientific/computing background but little economics background](https://github.com/econ-ark/PARK/blob/master/Elevator-Spiels.md#for-people-with-a-technicalscientificcomputing-background-but-no-economics-background) +:::{dropdown} For people without a technical/scientific/computing background +:color: secondary +:icon: info +Recent years have seen major advances in the ability of computational tools to explain the economic behavior of households, firms, and whole economies. But a major impediment to the widespread adoption of these techniques among economists has been the extent to which the advances are the culmination of years of development of intricate and hand-crafted (but mutually incomprehensible) computational tools by a few pioneering scholars and their students. The aim of the Econ-ARK project is to make it much easier for new scholars to begin using these techniques, by providing a modern, robust, open-source set of high-quality computational tools with components that can be mixed, matched, and extended to address the wide variety of problems across all fields of economics that can be effectively studied using such tools. +::: -- A good starting point is [A Gentle Introduction to HARK](https://docs.econ-ark.org/example_notebooks/Gentle-Intro-To-HARK.html) which provides a light economic intuition. +:::{dropdown} For people with a technical/scientific/computing background but little economics background +:color: secondary +:icon: info -### [For economists who have done some structural modeling](https://github.com/econ-ark/PARK/blob/master/Elevator-Spiels.md#for-economists-who-have-done-some-structural-modeling) +Most of what economists have done so far with 'big data' has been like what Kepler did with astronomical data: Organizing the data, and finding patterns and regularities and interconnections. An alternative approach called 'structural modeling' aims to do, for economic data, what Newton did for astronomical data: Provide a deep and rigorous mathematical (or computational) framework that distills the essence of the underlying behavior that produces the 'big data.' But structural techniques are so novel and computationally difficult that few economists have mastered them. The aim of the Econ-ARK project is to make it much, much easier for new scholars to do structural modeling, by providing a well-documented, open source codebase that contains the core techniques and can be relatively easily adapted to address many different questions. +::: +:::{dropdown} For economists who have done some structural modeling +:color: secondary +:icon: info + +The Econ-ARK project is motivated by a sense that quantitative structural modeling of economic agents' behavior (consumers; firms), at present, is roughly like econometric modeling in the 1960s: Lots of theoretical results are available and a great deal can be done in principle, but actually using such tools for any specific research question requires an enormous investment of a scholar's time and attention to learn techniques that are fundamentally not related to economics but instead are algorithmic/computational (in the 1960s, e.g., inverting matrices; now, e.g., solving dynamic stochastic optimization problems). The toolkit is built using the suite of open source, transparent tools for collaborative software development that have become ubiquitous in other fields in the last few years: Github, object-oriented coding, and methods that make it much easier to produce plug-and-play software modules that can be (relatively) easily combined, enhanced and adapted to address new problems. + +After working through the [Overview and Examples](https://docs.econ-ark.org/overview/index.html) section: - A full replication of the [Iskhakov, Jørgensen, Rust, and Schjerning](https://onlinelibrary.wiley.com/doi/abs/10.3982/QE643) paper for solving the discrete-continuous retirement saving problem - An informal discussion of the issues involved is [here](https://github.com/econ-ark/DemARK/blob/master/notebooks/DCEGM-Upper-Envelope.ipynb) (part of the [DemARK](https://github.com/econ-ark/DemARK) repo) - [Structural-Estimates-From-Empirical-MPCs](https://github.com/econ-ark/DemARK/blob/master/notebooks/Structural-Estimates-From-Empirical-MPCs-Fagereng-et-al.ipynb) is an example of the use of the toolkit in a discussion of a well known paper. (Yes, it is easy enough to use that you can estimate a structural model on somebody else's data in the limited time available for writing a discussion) +::: -### [For economists who have not yet done any structural modeling but might be persuadable to start](https://github.com/econ-ark/PARK/blob/master/Elevator-Spiels.md#for-economists-who-have-not-yet-done-any-structural-modeling-but-might-be-persuadable-to-start) +:::{dropdown} For economists who have not yet done any structural modeling but might be persuadable to start +:color: secondary +:icon: info -- Start with [A Gentle Introduction to HARK](https://docs.econ-ark.org/example_notebooks/Gentle-Intro-To-HARK.html) to get your feet wet +Dissatisfaction with the ability of Representative Agent models to answer important questions raised by the Great Recession has led to a strong movement in the macroeconomics literature toward 'Heterogeneous Agent' models, in which microeconomic agents (consumers; firms) solve a structural problem calibrated to match microeconomic data; aggregate outcomes are derived by explicitly simulating the equilibrium behavior of populations solving such models. The same kinds of modeling techniques are also gaining popularity among microeconomists, in areas ranging from labor economics to industrial organization. In both macroeconomics and structural micro, the chief barrier to the wide adoption of these techniques has been that programming a structural model has, until now, required a great deal of specialized knowledge and custom software development. The aim of the Econ-ARK project is to provide a robust, well-designed, open-source infrastructure for building such models much more efficiently than has been possible in the past. +After working through the [Overview and Examples](https://docs.econ-ark.org/overview/index.html) section: - A simple indirect inference/simulated method of moments structural estimation along the lines of Gourinchas and Parker's 2002 Econometrica paper or Cagetti's 2003 paper is performed by the [SolvingMicroDSOPs](https://github.com/econ-ark/SolvingMicroDSOPs/) [REMARK](https://github.com/econ-ark/REMARK); this code implements the solution methods described in the corresponding section of [these lecture notes](https://llorracc.github.io/SolvingMicroDSOPs/). +::: -### [For Other Developers of Software for Computational Economics](https://github.com/econ-ark/PARK/blob/master/Elevator-Spiels.md#for-other-developers-of-software-for-computational-economics) +:::{dropdown} For Other Developers of Software for Computational Economics +:icon: info +:color: secondary -- Our workhorse module is [ConsIndShockModel.py](https://github.com/econ-ark/HARK/blob/master/HARK/ConsumptionSaving/ConsIndShockModel.py) which includes the IndShockConsumerType. A short explanation about the Agent Type can be found [here](https://docs.econ-ark.org/example_notebooks/IndShockConsumerType.html) and an introduction how it is solved [here](https://docs.econ-ark.org/example_notebooks/HowWeSolveIndShockConsumerType.html). +The Econ-ARK project's aim is to create a modular and extensible open-source toolkit for solving heterogeneous-agent partial-and general-equilibrium structural models. The code for such models has always been handcrafted, idiosyncratic, poorly documented, and sometimes not generously shared from leading researchers to outsiders. The result that it can take years for a new researcher to become proficient. Building an integrated system from the bottom up using object-oriented programming techniques and other tools (GitHub, open source licensing, unit testing, etc), we aim to provide a platform that will become a focal point for people using such models. At present, the project contains: A set of general purpose tools for solving such models; a number of tutorials and examples of how to use the tools; and complete archives of several papers whose main contribution is structural modeling results, and whose modeling work has been done using the toolkit. +::: ### Demonstrations on using HARK diff --git a/Documentation/index.rst b/Documentation/index.rst index 75f93ad49..9a495ab5b 100644 --- a/Documentation/index.rst +++ b/Documentation/index.rst @@ -5,9 +5,9 @@ Econ-ARK documentation -- HARK :maxdepth: 1 :hidden: + Guides Overview & Examples Reference - Guides **Useful links**: @@ -56,40 +56,40 @@ you might want to look at the `DemARK :padding: 2 :text-align: center - **API reference** - ^^^^^^^^^^^^^^^^^ + **Overview and Examples** + ^^^^^^^^^^^^^^^^^^^^^^^^^ - The reference guide contains a detailed description of the HARK API, - and assumes an understanding of HARK's key concepts. + To learn how HARK works and what it's capable of, see the Overview and Examples. +++ - .. button-ref:: reference/index + .. button-ref:: overview/index :ref-type: doc :color: info :click-parent: :expand: - Tools & Models Reference Guide + Overview and Examples .. grid-item-card:: :padding: 2 :text-align: center - **ARKitecture** - ^^^^^^^^^^^^^^^ + **API reference** + ^^^^^^^^^^^^^^^^^ - For a high-level overview of Econ-ARK's structure and design, see the ARKitecture. + The reference guide contains a detailed description of the HARK API, + and assumes an understanding of HARK's key concepts. +++ - .. button-ref:: overview/ARKitecture + .. button-ref:: reference/index :ref-type: doc :color: info :click-parent: :expand: - The ARKitecture + Tools & Models Reference Guide .. grid-item-card:: :padding: 2 diff --git a/Documentation/overview/ARKitecture.md b/Documentation/overview/ARKitecture.md index ca458c6ed..0857d4ffb 100644 --- a/Documentation/overview/ARKitecture.md +++ b/Documentation/overview/ARKitecture.md @@ -42,7 +42,7 @@ Python modules in HARK can generally be categorized into three types: tools, mod ## HARK -After you [installed](https://docs.econ-ark.org/guides/quick_start.html) and [cloned the repository of](https://github.com/econ-ark/HARK) HARK, you can explore the content of it. In the subfolder HARK, you can find a range of [general purpose tools](#general-purpose-tools), as well as the next subfolder ConsumptionSaving which has [AgentType Classes](#agenttype-class) and [Market Classes](#market-class). +After you [installed](https://docs.econ-ark.org/guides/installation.html) and [cloned the repository of](https://github.com/econ-ark/HARK) HARK, you can explore the content of it. In the subfolder HARK, you can find a range of [general purpose tools](#general-purpose-tools), as well as the next subfolder ConsumptionSaving which has [AgentType Classes](#agenttype-class) and [Market Classes](#market-class). ### General Purpose Tools diff --git a/README.md b/README.md index 601635963..1a79ff846 100644 --- a/README.md +++ b/README.md @@ -13,7 +13,7 @@ [![DOI](https://zenodo.org/badge/50448254.svg)](https://zenodo.org/badge/latestdoi/50448254) [![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](https://opensource.org/licenses/Apache-2.0) [![Powered by NumFOCUS](https://img.shields.io/badge/powered%20by-NumFOCUS-orange.svg?style=flat&colorA=E1523D&colorB=007D8A)](https://numfocus.org/) -[![Donate](https://img.shields.io/badge/donate-$2-brightgreen.svg)](https://numfocus.salsalabs.org/donate-to-econ-ark/index.html) +[![Donate](https://img.shields.io/badge/donate-$2-brightgreen.svg)](https://numfocus.org/donate-to-econ-ark) [![Actions Status](https://github.com/econ-ark/hark/workflows/HARK%20build%20on%20MacOS%2C%20Ubuntu%20and%20Windows/badge.svg)](https://github.com/econ-ark/hark/actions) [![badge](https://img.shields.io/badge/HARK-DemARK-579ACA.svg?logo=)](https://mybinder.org/v2/gh/econ-ark/DemARK/master?filepath=notebooks) [![badge](https://img.shields.io/badge/HARK-examples-579ACA.svg?logo=)](https://mybinder.org/v2/gh/econ-ark/HARK/master?filepath=examples) @@ -35,7 +35,7 @@ HARK is a toolkit for the structural modeling of economic choices of optimizing and non-optimizing heterogeneous agents. For more information on using HARK, see the [Econ-ARK Website](https://econ-ark.org). -The Econ-ARK project uses an [open governance model](https://github.com/econ-ark/governance) and is fiscally sponsored by [NumFOCUS](https://numfocus.org/). Consider making a [tax-deductible donation](https://numfocus.salsalabs.org/donate-to-econ-ark/index.html) to help the project pay for developer time, professional services, travel, workshops, and a variety of other needs. +The Econ-ARK project is fiscally sponsored by [NumFOCUS](https://numfocus.org/). Consider making a [tax-deductible donation](https://numfocus.org/donate-to-econ-ark) to help the project pay for developer time, professional services, travel, workshops, and a variety of other needs.
@@ -63,12 +63,6 @@ We have a [Gitter](https://gitter.im) Econ-ARK [community](https://gitter.im/eco - [For Economists: Structural Modeling with Hark](#for-economists-structural-modeling-with-hark) - [For Computational Economics Developers](#for-computational-economics-developers) - [Contributing to HARK](#contributing-to-hark) -- [Current Project Team Members](#current-project-team-members) - - [Founders](#founders) - - [TSC (Technical Steering Commitee)](#tsc-technical-steering-committee) - - [Collaborators](#collaborators) - - [Release Team](#release-team) -- [Contributors](#contributors) - [Disclaimer](#disclaimer) ## Install @@ -144,7 +138,7 @@ Or you can retrieve the solved value for human wealth normalized by permanent in PFexample.solution[0].hNrm ``` -For a detailed explanation of the above example please see the demo notebook [_A Gentle Introduction to HARK_](https://mybinder.org/v2/gh/econ-ark/DemARK/master?filepath=notebooks/Gentle-Intro-To-HARK-PerfForesightCRRA.ipynb). +For a detailed explanation of the above example please see the demo notebook [_A Gentle Introduction to HARK_](https://mybinder.org/v2/gh/econ-ark/HARK/master?filepath=examples/Gentle-Intro/Gentle-Intro-To-HARK.ipynb). For more examples please visit the [econ-ark/DemARK](https://github.com/econ-ark/DemARK) repository. @@ -174,7 +168,7 @@ For more on acknowledging Econ-ARK [visit our website](https://econ-ark.org/ackn ## Support -Looking for help? Please open a [GitHub issue](https://github.com/econ-ark/HARK/issues/new) or reach out to the [TSC](#tsc-technical-steering-committee). +Looking for help? Please open a [GitHub issue](https://github.com/econ-ark/HARK/issues/new) or reach out to us through the gitter [community](https://gitter.im/econ-ark/community). ## Release Types @@ -215,7 +209,7 @@ HARK provides a modular and extensible open-source toolkit for solving heterogen HARK is written in Python, making significant use of libraries such as numpy and scipy which offer a wide array of mathematical and statistical functions and tools. Our modules are generally categorized into Tools (mathematical functions and techniques), Models (particular economic models and solvers) and Applications (use of tools to simulate an economic phenomenon). -For more information on how you can create your own Models or use Tools and Model to create Applications please see the [HARK Manual](./_static/HARKmanual.pdf). +For more information on how you can create your own Models or use Tools and Model to create Applications please see the [documentation](https://docs.econ-ark.org/guides/quick_start.html#for-other-developers-of-software-for-computational-economics) ### Contributing to HARK @@ -234,11 +228,9 @@ Contributions go far beyond pull requests and commits. Although we love giving y - Blogging, speaking about, or creating tutorials about HARK - Helping others in our mailing list -If you are worried or don’t know how to start, you can always reach out to the [TSC](#tsc-technical-steering-committee) or simply submit [an issue](https://github.com/econ-ark/HARK/issues/new) and a member can help give you guidance! +If you are worried or don’t know how to start, you can always reach out to us through the gitter [community](https://gitter.im/econ-ark/community)(#tsc-technical-steering-committee) or simply submit [an issue](https://github.com/econ-ark/HARK/issues/new) and a member can help give you guidance! -**After your first contribution please let us know and we will add you to the Contributors list below!** - -To install for development see the [Quickstart Guide](https://docs.econ-ark.org/guides/quick_start.html). +To install for development see the [Quickstart Guide](https://docs.econ-ark.org/guides/installation.html). For more information on contributing to HARK please see [the contributing guide](https://docs.econ-ark.org/guides/contributing.html). This is the guide that collaborators follow in maintaining the Econ-ARK project.