For years I’ve kept an extremely long list of resources, from online and offline, of various forms, for machine learning, statistics, programming, video game production and many more. Since many people asked me what to take at Columbia to advance their career in data science, let me begin with one tiny fraction of that: Great Columbia courses that teach you theory, practice, implementation and thought-process on doing the pro way. If you’re Β starting at Columbia with some basic knowledge of statistics and probability, this is the list of road-to-pro I’ve came up with (most of these I’ve taken or audited, some listed with old course numbers before they swapped to the GR ones):

Ph.D. level courses:

- Bayesian Data Analysis (Andrew Gelman, STAT G6103) (Applied Bayesian statistics, social studies, hierarchical regression models, PPC, Bayesian inference, Stan, etc.)
- Computational Statistics (Liam Paninski, STAT G6104)
- Gaussian Process & Kernel Methods (John Cunningham, STAT G8325) (RKHS, kernels, advanced approximate Bayesian inference, GP, etc.)
- Bayesian Nonparametrics (John Paisley, ELEN 9801) (Beta process, Poisson process, DP, IBP, etc.)
- Statistical Communication (Andrew Gelman)
- Causal Inference (Jose Zubizarreta, DROM B9124)
- Foundations of Graphical Models (David Blei, STAT G6509)
- Applied Causality (David Blei, STAT GR8101)
- Probabilistic Models with Discrete Data (David Blei, COMS 6998)
- Probability Theory I (Marcel Nutz, STAT GR6301) (Probability, measure, expectations, LLN, CLT, etc.)
- Probability Theory II (Peter Orbanz, STAT G6106) (Topology, filtrations, measure theory, Martingales, etc.)
- Probability Theory III (Marcel Nutz, STAT GR6303) (semi-Martingales, stochastic process, Weiner process, SDE, etc.)
- Statistical Inference II (Sumit Mukherjee, STAT GR6202) (Statistical testing, nonparametric inference, etc.)
- Statistical Inference III (Zhiliang Ying, STAT GR6203) (Semiparametric inference, etc.)
- Bayesian Nonparametrics (Peter Orbanz, STAT GR8201) (DP, IBP, GP, PP, random measures, approximate inference)
- Neural Networks and Deep Learning (Aurel Lazar, COMS 6998)
- Seminar in Theoretical Statistics (STAT GR9201)
- High Dimensional Data Analysis (Aleksandr Aravkin & Aurelie Lozano, COMS 6998)
- Optimization I (Donald Goldfarb, IEOR 6613) (LP, convex optimization, newton methods, quasi-newton methods, etc.)
- Optimization II (Clifford Stein, IEOR 6614) (Graph theory)

non-Ph.D. level courses:

- Natural Language Processing (Michael Collins, COMS W4705)
- Design and Analysis on Sample Surveys (Andrew Gelman, POLS GU4764)
- Advanced Machine Learning (Tony Jebara, COMS W4772)
- Advanced Machine Learning (Daniel Hsu, COMS W4772)
- Nonlinear Optimization (Donald Goldfarb, IEOR E4009)

You might now wonder:

- Where are the distributed systems courses?
- Where are the MapReduce courses?
- Where are the SAAS courses?
- Where are the low-latency courses?
- Where are the data visualization courses?
- Where are the data mining courses?
- Where are the mathematical finance courses?
- Where are the data structure courses?
- Where are the algorithm courses?
- Where are the learning theory courses?

My answer: Although they take prime roles in modern implementations of machine learning systems, it’s really difficult to get the right (and better) extrapolations from data, and easy to sink and get buried within the implementation of real-world application systems. These aforementioned courses in my list concentrates on how to get your insights deeper via the underlying history of math and statistics development that made how these tools came about, and what limitations they have. Courses for those questions, on the other hand, can easily be found on Columbia’s own data science master’s degree roadmaps, rather standard and gives you more industrial preps as an engineer specified in data science rather than preps you’ll need for complicated real-world analysis on non-trivial problems.