# Teaching

## Winter 2019

- EECS 336: Design & Analysis of Algorithms
- EECS 396/496: Computational Geometry
- EECS 496: Graduate Algorithms
- EECS 496: Computational Learning Theory

## Fall 2018

- EECS 212: Mathematical Foundations of Computer Science
- EECS 335: Introduction to the Theory of Computation
- EECS 496: Mechanism Design

## Spring 2018

- EECS 212: Mathematical Foundations of Computer Science
- EECS 336: Design & Analysis of Algorithms
- EECS 395/495: Computational Learning Theory
- EECS 495: Topics in Beyond Worst-Case Analysis

## Winter 2018

## Fall 2017

- EECS 335: Introduction to the Theory of Computation
- EECS 336: Design & Analysis of Algorithms
- EECS 495: Analytical Methods in Theoretical Computer Science
- EECS 495: Mechanism Design

## Spring 2017

- EECS 495: Approximation Algorithms

## Winter 2017

- EECS 395/495: Bioinformatics

## Spring 2016

## Winter 2016

- EECS 212 : Mathematical Foundations of Computer Science.
- EECS 335: Introduction to the Theory of Computation
- EECS 495 : Graduate Algorithms

## Fall 2015

- EECS 212 : Mathematical Foundations of Computer Science.
- EECS 336: Design & Analysis of Algorithms
- EECS 395/495: Bioinformatics

## Here are a list of theory courses that have been offered in previous years and that are likely to be offered regularly.

- Computational Complexity
- Derandomization
- Probabilistic Method
- Introduction to Cryptography
- Kolmogorov Complexity
- Introduction to Algorithms
- Algorithmic Mechanism Design
- Randomized Algorithms
- Algorithmic and Economic Aspects of Social Networks
- Combinatorial Optimization
- Algorithmic Research for E-Commerce

## Recent Comments