MPCS 53120 Applied Data Analysis (Spring 2026)

Section 1
Instructor(s) Singh Sahota, Davender (dsahota)
Location None
Meeting Times
Fulfills Elective Specialization - High Performance Computing (HPC-2)

Syllabus

This course provides a self-contained introduction to computational data analysis from an applied perspective. It is intended as a standalone course for students who are not pursuing the full data analysis sequence in the MPCS. As such, students who have taken MPCS 53110 Foundations of Computational Data Analysis and received a grade of B or higher should take MPCS 53111 Machine Learning. Students that have taken or are currently enrolled in MPCS 53111 Machine Learning cannot register for this class. 


The course will cover topics in basic probability theory, statistical inference, and basic machine learning models typically used in data analysis. Each topic will be accompanied by example illustrations using Python. Many of the topics covered form the basis of almost all algorithms and machine learning methods used in data analysis. As an applied course, the emphasis will be on the use of these tools to solve problems. 

Textbook: An Introduction to Statistical Learning

Optional: The Elements of Statistical Learning; Python for Data Analysis: Data Wrangling with Pandas, NumPy, and IPython; Deep Learning with Python

Course Contents:

  • Elementary Probability and Statistics
    • Probability Theory
    • Random Variables
    • Distributions and Densities
  • Software Platforms
    • Variables, objects, and functions in Python
    • Working with data frames
    • Data pre-processing and visualization
  • Linear Models/Statistical Inference
    • Least-squares regression
    • Logistic regression
    • Hypothesis testing
  • Model Assessment and Selection
  • Machine Learning Models
    • Perceptron classifier
    • Neural networks
    • Decision trees/Random forests
    • Support vector machines
  • Clustering 
    • Unsupervised clustering
    • Recommender systems
  • Introduction to Deep Learning
    • Computer Vision
    • Natural Language Processing

Evaluation:

  • Homework Assignments (12-14)
  • Course Project

Course Prerequisites

Core Programming completed or Core Waiver for Programming. MPCS 50103 Discrete Mathematics completed.

Other Prerequisites

Knowledge of Python is required for this class.

This course requires competency in Unix, Linux, and GitHub. If you attended the MPCS Unix Bootcamp you covered the required material. If you did not, please review the UChicago CS Student Resource Guide here: https://uchicago-cs.github.io/student-resource-guide/.

Course request information for non-MPCS students: https://masters.cs.uchicago.edu/student-resources/non-mpcs-student-course-requests/

Overlapping Classes

This class is scheduled at a time that does not conflict with any other classes this quarter.

Eligible Programs

MA in Computational Social Science (Year 2) Bx/MS in Computer Science (Option 1: Research-Oriented) Bx/MS in Computer Science (Option 2: Professionally-oriented - CS Majors) Bx/MS in Computer Science (Option 3: Profesionally-oriented - Non-CS Majors) Masters Program in Computer Science