Course Syllabus



     
  Instructor: Guanhong Tao Credit Hours: 3.0
  Department: Kahlert School of Computing Semester: Spring 2025
  Office: MEB 3470 Type: In Person
  Days / Times: MoWe / 03:00PM - 04:20PM Location: JTB 130 Links to an external site.
   
  Pre-requisites: 'C-' or better in CS 3190 Found. of Data Analysis AND CS 3500 Software Practice    
  Communication & Office Hours:  Review the "Communication" section below for more information.
   

Overview

Course CS 5956 Intro to Machine Learning
Department Kahlert School of Computing
Pre-Requisites 'C-' or better in CS 3190 Found. of Data Analysis AND CS 3500 Software Practice
Credit Hours 3.0
Semester Spring 2025
Days / Times MoWe / 03:00PM - 04:20PM
Location: JTB 130 Links to an external site.
Description

This course is designed to build a groundwork for both machine learning and deep learning early on in undergraduate studies. Each lecture is grounded in practical application, using Python and machine learning libraries such as PyTorch to implement and experiment with the discussed concepts; including various training paradigms, loss functions, optimization, evaluation measurements, hyperparameter tuning, generalization, overfitting, simple neural networks, backpropagation, featurization, and more. The course will cover topics in probability and linear algebra which are fundamental to understanding machine learning basics. By the end of the course, students will be prepared to take more advanced courses to deepen their theoretical and applied knowledge of machine learning and deep learning.

Goals & Objectives

This course covers the principles and practices of machine learning algorithms, including the basics, mathematical definitions, and implementation with Python. It begins with an introduction to the foundations of machine learning algorithms, such as linear regression, logistic regression, and perceptron. Later sections focus on modern machine learning algorithms, particularly deep learning models such as CNNs, RNNs, and Transformers. Hands-on coding assignments using popular ML libraries like PyTorch are included to provide students with practical experience. Additionally, the course aims to inspire exploration of advanced algorithms in the field by introducing recent generative models. By the end of the course, students will be equipped to mathematically analyze ML algorithms and implement them using Python.

At the end of this course, students will be able to:

  • Apply basic machine learning concepts, including various training paradigms, loss functions, optimization techniques, and hyperparameter tuning.
  • Utilize fundamental deep learning concepts, such as backpropagation, dropout, and feed-forward neural networks.
  • Understand documentation for a deep learning framework such as PyTorch and use it to implement simple deep learning models, such as feed-forward neural networks.
  • Build a neural classifier from scratch, as well as its training and evaluation, for a given classification or regression problem using Python and PyTorch.

Materials

There is no official textbook for the class. Slides will be provided and reading materials for each topic will be assigned from the following references:

Recommended Texts

Communication

Please use Canvas messages and the discussion forum as the preferred medium for interacting with the instructor and the teaching assistants rather than emailing directly. The easiest way to contact your instructor directly is to use the Inbox, located in the far left Canvas menu.

 

The instructor will hold office hours according to the following schedule:

Time: 4:20PM - 5:20PM, Wednesday

Location: MEB 3470

 

Soumil Datta Links to an external site.

Email: soumil.datta@utah.edu

Office hour: 1:30PM - 2:30PM, Monday

Location: MEB 3515

Evaluation

Your performance in this course will be evaluated by:

  • 20% Quizzes
  • 30% Homework Assignments
  • 25% Midterm Exam
  • 25% Final Exam

Schedule

Week Date Topic Note
Week 1 Mon, Jan 6 Course Overview, Logistics, and Introduction Reading: Chapter 5 of Deep Learning
Wed, Jan 8 Supervised Learning
Week 2 Mon, Jan 13 K-Nearest Neighbors (kNN)

HW1 Released (Due on Jan 27, 11:59 PM)

Quiz 1 (Wed, Jan 15)

Wed, Jan 15 Basics of Python, Numpy, and Colab
Week 3 Mon, Jan 20 Martin Luther King Day (No Class) Reading: Chapter 7 of Machine Learning: A Probabilistic Perspective
Wed, Jan 22 Linear Regression
Week 4 Mon, Jan 27 Optimization and Basics of PyTorch

HW1 Due (Jan 27, 11:59 PM)

Reading: Chapter 8 of Machine Learning: A Probabilistic Perspective

Wed, Jan 29 Regularization
Week 5 Mon, Feb 3 Logistic Regression

HW2 Released (Due on Feb 24, 11:59 PM)

Quiz 2 (Wed, Feb 5)

Reading: Chapter 8 of Machine Learning: A Probabilistic Perspective

Wed, Feb 5 Logistic Regression (Cont.)
Week 6 Mon, Feb 10 Perceptron Reading: Chapter 6-8 of Deep Learning
Wed, Feb 12 Neural Networks
Week 7 Mon, Feb 17 Presidents Day (No Class)

Quiz 3 (Wed, Feb 19)

Wed, Feb 19 Backpropagation
Week 8 Mon, Feb 24 Training Neural Networks HW2 Due (Feb 24, 11:59 PM)
Wed, Feb 26 Training Neural Networks (Cont.)
Week 9 Mon, Mar 3 Midterm Review

Wed, Mar 5 Midterm Exam (In Class)
Week 10 Mon, Mar 10 Spring Break (No Class)
Wed, Mar 12
Week 11 Mon, Mar 17 Convolutional Neural Networks (CNNs)

HW3 Released (Due on Apr 7, 11:59 PM)

Reading: Chapter 9 of Deep Learning

Wed, Mar 19 CNN Architectures
Week 12 Mon, Mar 24 Recurrent Neural Networks (RNNs)

Quiz 4 (Wed, Mar 26)

Reading: Chapter 10 of Deep Learning

Wed, Mar 26 Long Short-Term Memory (LSTM)
Week 13 Mon, Mar 31 Word Embeddings Attention Is All You Need Links to an external site.
Wed, Apr 2 Attention-based Transformers
Week 14 Mon, Apr 7 Attention-based Transformers (Cont.) HW3 Due (Apr 7, 11:59 PM)
Wed, Apr 9 Self-supervised Learning
Week 15 Mon, Apr 14 Diffusion Models
Wed, Apr 16 Autoregressive Models
Week 16 Mon, Apr 21 Final Review The final exam is in the same classroom.
Fri, Apr 25, 3:30-5:30 PM Final Exam (JTB 130)

Submitting Assignments

Each homework write-up must be neatly typeset as a PDF document. You can use LaTeX or any other system that produces typesetting of equal quality and legibility (especially for mathematical symbols and expressions). Please write your solutions as succinctly as possible while including all the necessary details. Ensure that the following appear at the top of the first page of the write-up: your name, your UID, and the ID’s of any students with whom you discussed the assignment. Submit your write-up as a single PDF file and corresponding code implementations (if any) on Canvas by 11:59 PM of the due date. It is your responsibility to ensure that the submission is successfully received by Canvas.

All assignments, unless otherwise announced, must be submitted to the designated area of
Canvas. Do not submit assignments via email.

Assignments will be accepted up until 11:59 PM on the due date. The score for late homework is 0. Exceptions will be made in case of serious illness or bereavement. If a student has a planned absence from a class when an exam will be given, the student should make arrangements before the planned absence to take the exam early or take a makeup exam after returning to campus.

Feedback on graded material will be posted on Canvas in as timely a manner as possible. Once feedback for a graded assignment is posted, you will have 1 week from the posting date to dispute a grade. No re-grade requests will be honored after 1 week from posting feedback. Grade changes will not be made at the end of the semester.

Collaboration Policy

You are encouraged to discuss course materials and reading assignments, and homework assignments with each other in small groups (two to three people). You must list all discussants in your homework write-up. Discussion about homework assignments may include brainstorming and verbally discussing possible solution approaches, but must not go as far as one person telling others how to solve a problem. In addition, you must write-up your solutions by yourself, and you may not look at another student’s homework write-up/solutions (whether partial or complete).

Late Assignments

There is a total of 3 days of grace period available for late submissions across all assignments. You may use this grace period for any assignment. However, please note that the grace period is cumulative. Once the 3-day grace period has been fully used, any further late submissions will receive a score of 0, in accordance with the assignment policy.

Grading

Grades will be determined based on correctness and relevance to the assignments and questions. Pay close attention to the instructions and rubrics provided for each assignment/task.

Extra credit opportunities may be available throughout the course. These will be clearly communicated and typically involve additional research, attending relevant events, or completing supplementary assignments. Extra credit can contribute up to 5% additional points to the final grade.

Letter Scoring
A 100% - 93%
A- 92.9% - 90%
B+ 89.9% - 87%
B 86.9% - 83%
B- 82.9% - 80%
C+ 79.9% - 77%
C 76.9% - 73%
C- 72.9% - 70%
D 69.9% - 60%
E 59.9% - 0%

Accommodations

Accommodations will be considered on an individual basis and may require documentation.

Please contact your instructor as soon as possible (preferably shortly before the semester begins) to request accommodations of any kind.

Please be aware that some materials and discussions within this course may contain challenging content. Your instructor may choose to notify students of potentially difficult content (e.g. explicit language, graphic images, violent themes, etc.) throughout the course.

If there are specific subjects that you need advanced notice for, please contact your instructor at the beginning of the semester.

Please contact your instructor as soon as possible if an extreme personal circumstance
(hospitalization, death of a close relative, natural disaster, etc.) is interfering with your ability to
complete your work.

To request an accommodation for religious practices, contact your instructor at the beginning of the semester.

If you are a student on active duty with the military and experience issues that prevent you from participating in the course because of deployment or service responsibilities, contact your instructor as soon as possible to discuss appropriate accommodations.

All written information in this course can be made available in an alternative format with prior notification to the Center for Disability Services (CDS). CDS will work with you and the instructor to make arrangements for accommodations. Prior notice is appreciated. To read the full accommodations policy for the University of Utah, please see Section Q of the Instruction & Evaluation regulations Links to an external site..

If you will need accommodations in this class, contact:

Center for Disability Services
801-581-5020
disability.utah.edu Links to an external site.
162 Union Building
    200 S. Central Campus Dr.
     Salt Lake City, UT 84112

Changes to the Syllabus

This syllabus is not a contract. It is meant to serve as an outline and guide for your course. Please note that your instructor may modify it to accommodate the needs of your class.

You will be notified of any changes to the Syllabus.