Instructor: Mark Schmidt.

Instructor office hours: TBA.

Tutorials begin September 10.

Teaching Assistants: TBA

TA office hours (all in Demco Learning Centre) TBA.

**Synopsis**: We introduce basic principles and techniques in the fields of data mining and machine learning. These are some of the key tools behind the emerging field of data science and the popularity of the `big data' buzzword. These techniques are now running behind the scenes to discover patterns and make predictions in various applications in our daily lives. We'll focus on many of the core data mining and machine learning technlogies, with motivating applications from a variety of disciplines.

**Registration**: Undergraduate and graduate students from any department are welcome to take the course. Undergraduate students should enroll in CPSC 340 while graduate students should enroll in CPSC 532M (which has an extra small project component). Below are more details on registration for each course:

- The majority of the seats in 340 are reserved for UBC computer science majors. For other students,
. Note that last year all students on the wait list were ultimately accepted into the course (but we did not have room for auditors.)*to enroll in the course you need to sign up for the wait list* - Two-thirds of the seats in 532M will initially be reserved for UBC computer science grad students, while the remaining seats are open to graduate students from any department. Note that you will likely get a warning about prerequisities when you register (which you can ignore), but depending on your department you may later be contacted and asked to show how you satisfy the relevant prerequisites. As with 340,
**if 532M becomes full then signing up for the waiting list is the only way to enroll in the course**. Last year all students on the wait list were ultimately accepted into the course.

**Prerequisites**:

- Basic algorithms and data structures (CPSC 221, or both of CPSC 260 and EECE 320 as well as one of CPSC 210, EECE 201, or EECE 309).
- Linear algebra (one of MATH 152, 221, or 223).
- Probability (one of STAT 200, STAT 203, STAT 241, STAT 251, STAT 302, MATH 302, MATH 318, or BIOL 300).
- Multivariate calculus (one of MATH 200, 217, 226, 253, or 263).

**Textbook**: There is no required textbook for the class. A introductory book that covers many (but not all) the topics we will discuss is the Artificial Intelligence book of Rusell and Norvig (AI:AMA) or the Artificial Intelligence book of Poole and Mackworth (you may need these for other classes). More advanced books include The Elements of Statistical Learning (ESL) by Hastie et al., Murphy's Machine Learning: A Probabilistic Perspective (ML:APP) which can be accessed through the library here, and Bishop's Pattern Recognition and Machine Learning (PRML). For books with a bigger focus on data mining, see Introduction to Data Mining (IDM) and Mining of Massive DataSets.

**Grading**:

- 340: Assignments 30%, Midterm 20%, Final 50%.
- 532M: Assignments 25%, Midterm 15%, Final 35%, Project 25%.

Piazza for course-related questions.

- Data representation and summarization.
- Supervised learning with frequencies and distances.
- Data clustering, outlier detection, and association rules.
- Linear prediction, regularization, and kernels.
- Latent-factor models and collaborative filtering.
- Neural networks and deep learning.

Date | Slides | Related Readings and Links | Homework and Notes |
---|---|---|---|

Wed Sep 5 | Motivation and Syllabus | What is Machine Learning? Machine Learning Rise of the Machines Talking Machine Episode 1 |

- Machine Learning and Data Mining (UBC 2012)
- Introduction to Machine Learning (Alberta)
- Practical Machine Learning (Berkeley)
- Machine Learning (MIT)
- Machine Learning (CMU)
- Course in Machine Learning (Maryland)
- Principals of Knowledge Discovery in Data (Alberta)
- Mining Massive Data Sets (Stanford)
- Data Mining (CMU)

Mark Schmidt > Courses > CPSC 340