/Syllabus

Syllabus for CompEcon Course

Primary LanguageMakefile

ScPo-CompEcon Syllabus

  • Course: Computational Economics for PhDs
  • Teacher: Florian Oswald, florian.oswald@sciencespo.fr
  • Class Times: Weekly Friday 14:45-16:45 starting 27 of January
  • Class Location: Salle : 911 - 9, rue de la chaise
  • Chatroom: Join the chat at https://gitter.im/ScPo-CompEcon/Syllabus

Course Description

This is a course for PhD students at the Department of Economics at Sciences Po in Computational Economics.

Course Overview

In this course you will learn about some commonly used methods in Computational Economics. These methods are being used in all fields of Economics. The course has a clear focus on applying what you learn. We will cover the theoretical concepts that underlie each topic, but you should expect a fair amount of hands on action required on your behalf. In the words of the great Che-Lin Su:

Doing Computation is the only way to learn Computation. Doing Computation is the only way to learn Computation. Doing Computation is the only way to learn Computation.

True to that motto, there will be homeworks for you to try out what you learned in class. There will also be a term paper. It will be helpful to bring a laptop to the sessions if you have one.

Topics will be demonstrated through live-code examples/slides, available at ScPo-CompEcon.github.io/slides.

Prerequisites

  1. We will be using Julia for this course. Please download the latest stable release here (v0.5.0). Please read in full the following short pieces after you installed the program:
  2. Some experience with the Unix Shell and the verion control system Git would be very useful - for this course, and for the rest of your life as a scientist. I do therefore recommend that you spend some time with the following excellent tutorials:
    1. Software Carpentry: The Unix Shell: If you have never heard of unix, please go over the first three (very short) chapters:
    2. What is Version Control? 5 minute video.

Homeworks

There will be homeworks. They will be listed within the Course Outline.

Term paper

You are expected to produce a term paper over the course of the semester. This could be:

  • A replication of a paper that uses computational methods.
  • Computing additional things that another (maybe theoretical) paper does not compute.
  • Ideally, it would be your own research project.

Textbooks

There are some excellent references for computational methods out there. This course will use material from

  • Fackler and Miranda (2002), Applied Computational Economics and Finance, MIT Press
  • Kenneth Judd (1998), Numerical Methods in Economics, MIT Press
  • Nocedal, Jorge, and Stephen J. Wright (2006): Numerical Optimization, Springer-Verlag

(recommended ones in bold face)

Course Outline

Introduction, Logistics and Intro to Julia

  1. Setup
    • How many people are comfortable with Git/GitHub?
    • Install GitHub Desktop
      • If you are comfortable with Git already, you can skip this.
    • Sign up for GitHub
  2. GitHub workflow
  3. Explain how slides work
  4. Talk through homework requirements
  5. Talk through term paper requirements
  6. Talk through weapon of choice

Talk about Computation!

  1. Basic Computing concepts
    • The fundamental tradeoff: Speed vs Accuracy
    • Some numerical gotchas
    • Computer Basics
    • Intro to Julia

Reading


Session: Integration and Function Approximation

  1. Numerical Integration and Derivation
    • Monte-Carlo integration
    • Gaussian Quadrature
    • Multidimensional Quadrature
      • Quadrature with correlated shocks
    • Numerical Differentiation
  2. Function Approximation
    • Polynomial Interpolation
      • Basis functions and Coefficients
    • Regression as Approximation
    • Colocation Methods
    • Multidimensional Approximation
      • The Smolyak Grid

Homework

  • Fork the homework at github.com/ScPo-CompEcon/HW-integration
    • Follow steps detailed there.
  • Create a new repository on github for your term paper.
    • Choose a name, whether public of private and select the option to create a README.md file. clone.
    • In the README.md file detail your project idea in a few words (more than 100 but less than 500). If you need math, include an IJulia notebook.
    • If you decide to make this a private repository, you need to add me as a collaborator.
    • push to github.
    • email me the URL of the repo by the homework deadline (24h prior to next class.)

Session: Optimisation

  1. Unconstrained Optimisation
    • Comparison Methods
    • Newton's Method
    • Line Search, Trust Region, and other Methods
    • Application: Maximum Likelihood
    • Introduce http://www.juliaopt.org
  2. Constrained Optimization
    • Theory
    • Some Numerical Methods for Constrained Optimization

Session: Constrained Optimisation Applications

  1. MPEC on John Rust's Bus Engine Replacement
  2. The Berry-Levinsohn-Pakes (BLP) paper as constrainted optimization problems

Homework


Session: Numerical Dynamic Programming

  • Review of DP theory
  • Different Solution methods for different cases

Homework


Session: Sky's the Limit - Parallel Computing in the Cloud

Homework


Session: More MPEC Applications

  • BLP as an MPEC as in Fox, Dube and Su

Session: Application to Discrete/Continuous Choice in Dynamic models

  • Ishkakov, Jorgensen, Rust and Schjerning

Grading

50% homeworks, 50% paper

Statements on Plagiarism

We will try to honour Science Po's anti-plagiarism policy:

Plagiarism occurs when a student submits work that does not allow one to distinguish the student's own thoughts from those of other authors: it can be characterised by the absence of citation of a group of consecutive words (five or more), by reformulation or translation, or by copying directly." (article on intellectual honesty)

Related to Plagiarism

Reuse and building upon ideas or code are major parts of modern software development. As an economist writing code, you will (hopefully) never write anything from scratch. This class is structured such that all solutions are public. You are encouraged to learn from the work of your peers. As I said above, I won't hunt down people who are simply copying-and-pasting solutions, because without challenging themselves, they are simply wasting their time and money taking this class.

Please respect the terms of use and/or license of any code you find, and if you reimplement or duplicate an algorithm or code from elsewhere, credit the original source with an inline comment.

License

In setting up this course I was heavily influenced - and shamelessly copied entire parts of - https://github.com/advanced-js taught by Aidan Feldman and team at NYU, and I would like to thankfully acknowledge making the materials useable to other teachers. The same license applies (below). The license allows you to copy and use everything here, under the condition that you attribute the work (details in the license). The copyright notice to be included in any such copies and other derivative work is:

Copyright 2017 Florian Oswald, Sciences Po Paris, florian.oswald@gmail.com

Thank you.

Creative Commons License
This work and all other materials under https://github.com/ScPo-CompEcon are licensed under a Creative Commons Attribution 4.0 International License.