drawing

CMSC 478 — Introduction to Machine Learning

Spring 2024


Logistics

  • Instructor: KMA Solaiman, ksolaima@umbc.edu
  • Teaching assistant: Rama Sai Mamidala, ramasam1@umbc.edu
  • Lecture time: TTh 1:00-2:15pm (04), TTh 4:00-5:15pm (02)
  • Location: ITE 240 (04), SONDHEIM 111 (02)
  • Credit Hours: 3.00
  • Q&A, Course discussion and announcements: Campuswire
  • For any sensitive issue, please email me (ksolaima@umbc.edu), preferrably with a subject preceded by CMSC478-concern.
  • Exam and assignment submissions: Blackboard and Gradescope.
  • Office hours
    • Wed 5:45 - 6:30 pm, Thu 3 - 3:45 pm, or by appointment, ITE 201-C, KMA Solaiman
    • TW 2:30 - 3:30 pm, ITE 334, Rama Sai Mamidala

Note: Visit Blackboard for instructions on joining Campuswire and Gradescope.

Course Description

This course serves as a foundation to apply machine learning techniques in different domains and for more advanced learning problems. The topics covered will include supervised learning, unsupervised learning, reinforcement learning, weakly or self-supervised learning, Generalization and Regularization, and Ensemble Learning.

The goals for this course are:

  • be introduced to some of the core problems and solutions of ML;
  • learn different ways that success and progress can be measured in ML;
  • be exposed to how these problems relate to those in computer science and subfields of computer science;
  • have experience experimenting with ML approaches;
  • identify issues with features, data, and how to handle them;

Textbooks

Hal Daume from UMCP has written a good text for an introductory course in machine learning. You can get it here: CIML. Another good source is Machine Learning by Tom Mitechell. There are also some lecture notes from Stanford ML group. We will use some parts of that.

There are a few other online texts that we’ll draw from or I will give you specific lecture notes. You’ll find links to them below in the schedule of topics, with specific sections that you should read.

Prerequisites

This is an upper-level undergraduate level Computer Science course and we will assume that you will have a good grounding in algorithms, statistics, and adequate programming skills (CMSC 341). Many of the homework assignments will involve programming and you will be expected to do them in Python. Having said that, we will try our best to provide materials or backgrounds for the programming assignments.

Course Schedule

This syllabus and schedule is preliminary and subject to change. Abbreviations refer to the following:

DateTopicsNotesReadings
Week 1   
Tue
Jan 30
Course Overview and Administrivia. What is ML?
Slides
1. YOLO Object Detection
2. 10 years of training in 10 days for learning to be a warrior
TOS Chapter 1
 Supervised Learning  
Thu
Feb 01
Supervised learning setup, LMS, Gradient Descent
Slides
 SML Part 1, Chap 1, 1.1;
Optional: TOS Chapter 2
Week 2   
Tue
Feb 06
SGD, Perceptron, Logistic regression
Slides
Homework01SML 1.1; TOS Chapter 2
Thu
Feb 08
Logistic regression, Multi-class classification
Slides.v2 // Annotated-Slides
 SML 2.1 - 2.3
Week 3   
Tue
Feb 13
Decision Tree Learning
Slides.v2 // Notes // Annotations
Homework01 is dueTM 3
 Generalization and Regularization  
Thu
Feb 15
Decision Tree // Annotated-Slides
Overfitting, Validation, Bias // Class-Notes
 TM 3
Week 4   
Tue
Feb 20
Bias - Variance Tradeoff, Regularization. Feature / Model selection.
Class-Notes
Homework 2
Optional: Mathematical derivation of test loss - Slides
SML 8.1, 9.1, 9.3
Thu
Feb 22
K-Means
Slides
 CIML Chapter 3
Week 5 Homework 2 is due on Feb 26 
Tue
Feb 27
Class Cancelled  
Thu
Feb 29
KNN
Slides
Homework 3CIML Chapter 3
Week 6   
Tue
Mar 05
PCA, ICA
Slides
PCA in actionChapter 15 section 2 of CIML for PCA
Thu
Mar 07
Density estimation. Bayes Rule. MLE vs MAP
Slides
Homework 3 is dueEstimating Probabilities
Week 7   
Tue
Mar 12
Naive Bayes
Slides
 Mitchell-Notes Chapter 3
Thu
Mar 14
Gaussian Naive Bayes
Slides // Reinforcement Learning
Slides
  
Week 8   
 Spring Break  
Week 9   
Tue
Mar 26
Midterm Review
Slides//Bias - Variance Tradeoff, Regularization Notes-1, Notes-2
  
Thu
Mar 28
Midterm Exam  
Week 10   
Tue
Apr 02
RL: Value Iteration, Policy Iteration
Slides, Q-learning example
If you are interested to learn more: check these - chapter 4, 5, 8.11SML Chapter 15.1 - 15.4
Thu
Apr 04
RL: Value Iteration, Policy Iteration
Slides, Q-learning example
HW5 is released in BB 
Week 11   
Tue
Apr 09
Support Vector Machine
Slides.v3
 A guide to SVM
Thu
Apr 11
Kernel SVM
Slides
Kernel-Example-Question 
Week 12 HW5 is due on Apr 14 
Tue
Apr 16
Neural Network
Lecture notes: SML 7.2
HW6 is released on Blackboard
Kernel-Example-Question
SML 7.2
Thu
Apr 18
NN:Backpropagation
Class-notes-2-layer-backprop.v2//
Slide.v2
Practice Colab NotebooksChapter 10 of CIML
Week 13   
Tue
Apr 23
NN:Backpropagation
Class-notes-multilayer-backprop.v2 // Recording
HW6 is due
Demo Colab Notebooks
 
Thu
Apr 25
Convolutional Neural Network (CNN) SlideHW7 is released on Blackboard
Demo Colab Notebooks
CNN-explained
Week 14   
Tue
Apr 30
ML tools
Slides // Recording
  
Thu
May 02
Ensemble Learning
Slides // Annotated-slide // Class-notes // Audio-recording
 CIML Chap 13
Week 15   
Tue
May 07
Recurrent neural networks
Slides
RNN-video // LSTM-video 
Thu
May 09
Writing Codes for NN - Slides // Fine-tuning and Transfer Learning - Slides // Word Embedding - SlidesQuiz-LinkOptional: Transformers in Detail
Week 16 HW7 is due on May 10 
Tue
May 14
Final Exam Review
Recording
  
Week 17   
Fri
May 17
Final Exam6-8 pmITE 241

Midterm and Final Exams

The material covered by the exams will be drawn from assigned readings in the text, from lectures, and from the homework. Material from the readings that is not covered in class is fair game, so you are advised to keep up with the readings.

Course Evaluation

Grades will be based on your performance in homework assignments, project, a mid-term examination and a final examination. There will be 5-10 homeworks throughout the semester. The overall evaluation is as follows:

Component%
Homework/Programming Assignments10% each, 70%
Exams15% each, 30%

As per University policy, incompletes will be granted only under extraordinary circumstances; students who are enrolled after the last day to drop a class should be prepared to receive a grade of A-F.

Grading Scale: The following grading scale is used on the normalized final, rounded percentages:

If you get at least a/an…you are guaranteed a/an… or higher
90A
80B
70C
60D
0F

Policies

If you have extenuating circumstances that result in an assignment being late, please talk to me as soon as possible.

Due Dates

Due dates will be announced on the course website and Campuswire. Unless stated otherwise, items are due by 11:59 PM (UMBC time) of the specified day. Submission instructions will be provided with each assigned item.

Extensions and Late Policy

Personal or one-off extensions will not be granted. Instead, everyone in this course has ten (10) late days (3 days maximum for each assignment) to use as needed throughout the course. These are meant for personal reasons and emergencies; do not use them as an excuse to procrastinate. Late days are measured in 24 hour blocks after a deadline. They are not fractional: an assignment turned in between 1 minute and 23 hours, 59 minutes (1,439 minutes) after the deadline uses one late day, an assignment turned in between 24 hours and 47 hours, 59 minutes (2879) after the deadline uses two late days, etc. The number of late days remaining has no bearing on assignments you turn in by the deadline; they only affect assignments you turn in after the deadline. If you run out of late days and do not turn an assignment in on time, please still complete and turn in the assignments. Though late assignments after late days have been exhausted will be recorded as a 0, they will still be marked and returned to you. Morever, they could count in your favor in borderline cases. There is a hard cutoff of the final exam block. Late days cannot be used beyond this time. I reserve the right to issue class-wide extensions.

Academic Honesty

Do not cheat, deceive, plagiarize, improperly share, access or use code, or otherwise engage in academically dishonest behaviors. Doing so may result in lost credit, course failure, suspension, or dismissal from UMBC. Instances of suspected dishonesty will be handled through the proper administrative procedures.

We will follow a policy described in this statement adopted by UMBC’s Undergraduate Council and Provost’s Office.

By enrolling in this course, each student assumes the responsibilities of an active participant in UMBC’s scholarly community, in which everyone’s academic work and behavior are held to the highest standards of honesty. Cheating, fabrication, plagiarism, and helping others to commit these acts are all forms of academic dishonesty, and they are wrong. Academic misconduct could result in disciplinary action that may include, but is not limited to, suspension or dismissal.

Especially for computer science classes, there are generally questions about what is and is not alloThu. You are encouraged to discuss the subject matter and assignments with others. The Campuswire discussion board provides a great forum for this. However, you may not write or complete assignments for another student; allow another student to write or complete your assignments; pair program; copy someone else’s work; or allow your work to be copied. (This list is not inclusive.)

As part of discussing the assignments, you may plan with other students; be careful when dealing with pseudocode. A good general rule is that if anything is written down when discussing the assignments with others, you must actually implement it separately and you must not look at your discussion notes.

You are free to use online references like Stack Overflow for questions that are not the primary aspect of the course. If, for example, you’re having an issue with unicode in Python, or are getting a weird compilation error, then sites like Stack Overflow are a great resource. Don’t get stuck fighting your tools.

You may generally use external libraries (and even parts of standard libraries), provided what you use does not actually implement what you are directed to implement.

Generative AI: For this class, if you use ChatGPT (or similar chatbots or AI-based generation tools), you must describe exactly how you used it, including providing the prompt, original generation, and your edits. This applies to prose, code, or any form of content creation. Not disclosing is an academic integrity violation. If you do disclose, your answer may receive anywhere from 0 to full credit, depending on the extent of substantive edits, achievement of learning outcomes, and overall circumvention of those outcomes.

Use of AI/automatic tools for grammatical assistance (such as spell-checkers or Grammarly) or small-scale predictive text (e.g., next word prediction, tab completion) is okay. Provided the use of these tools does not change the substance of your work, use of these tools may be, but is not required to be, disclosed.

Be sure to properly acknowledge whatever external help—be it from students, third party libraries, or other readings—you receive in the beginning of each assignment. Please review this overview of how to correctly cite a source and these guidelines on acceptable paraphrasing or here.

Accomodations

Students with Accommodation Needs

The Office of Student Disability Services (SDS, https://sds.umbc.edu) works to ensure that students can access and take advantage of UMBC’s educational environment, regardless of disability. From the SDS,

Accommodations for students with disabilities are provided for all students with a qualified disability under the Americans with Disabilities Act (ADA & ADAAA) and Section 504 of the Rehabilitation Act who request and are eligible for accommodations. The Office of Student Disability Services (SDS) is the UMBC department designated to coordinate accommodations that creates equal access for students when barriers to participation exist in University courses, programs, or activities.

If you have a documented disability and need to request academic accommodations in your courses, please refer to the SDS website at sds.umbc.edu for registration information and office procedures.

SDS email: disAbility@umbc.edu

SDS phone: 410-455-2459

If you require the use of SDS-approved accommodations in this class, please make an appointment with me to discuss the implementation of the accommodations.

Religious Observances & Accommodations UMBC Policy provides that students should not be penalized because of observances of their religious beliefs, and that students shall be given an opportunity, whenever feasible, to make up within a reasonable time any academic assignment that is missed due to individual participation in religious observances. It is the responsibility of the student to inform me of any intended absences or requested modifications for religious observances in advance, and as early as possible.

Sexual Assault, Sexual Harassment, and Gender-based Violence and Discrimination

UMBC Policy in addition to federal and state law (to include Title IX) prohibits discrimination and harassment on the basis of sex, sexual orientation, and gender identity in University programs and activities. Any student who is impacted by sexual harassment, sexual assault, domestic violence, dating violence, stalking, sexual exploitation, gender discrimination, pregnancy discrimination, gender-based harassment, or related retaliation should contact the University’s Title IX Coordinator to make a report and/or access support and resources. The Title IX Coordinator can be reached at titleixcoordinator@umbc.edu or 410-455-1717.

You can access support and resources even if you do not want to take any further action. You will not be forced to file a formal complaint or police report. Please be aware that the University may take action on its own if essential to protect the safety of the community.

If you are interested in making a report, please use the Online Reporting/Referral Form. Please note that, if you report anonymously, the University’s ability to respond will be limited.

Faculty Reporting Obligations

All faculty members and teaching assistants are considered Responsible Employees, per UMBC’s Policy on Sexual Misconduct, Sexual Harassment, and Gender Discrimination. So please note that as instructors, I, other faculty members, and the teaching assistants are required to report all known information regarding alleged conduct that may be a violation of the Policy to the University’s Title IX Coordinator, even if a student discloses an experience that occurred before attending UMBC and/or an incident that only involves people not affiliated with UMBC. Reports are required regardless of the amount of detail provided and even in instances where support has already been offered or received.

While faculty members want to encourage you to share information related to your life experiences through discussion and written work, students should understand that faculty are required to report past and present sexual harassment, sexual assault, domestic and dating violence, stalking, and gender discrimination that is shared with them to the Title IX Coordinator so that the University can inform students of their rights, resources, and support. While you are encouraged to do so, you are not obligated to respond to outreach conducted as a result of a report to the Title IX Coordinator.

If you need to speak with someone in confidence, who does not have an obligation to report to the Title IX Coordinator, UMBC has a number of Confidential Resources available to support you:

  • Retriever Integrated Health (Main Campus): 410-455-2472; Tueday – Friday 8:30 a.m. – 5 p.m.; For After-Hours Support, Call 988.

  • Pastoral Counseling via The Gathering Space for Spiritual Well-Being: 410-455-6795; i3b@umbc.edu; Tueday – Friday 8:00 a.m. – 10:00 p.m.

  • For after-hours emergency consultation, call the police at 410-455-5555

Other Resources:

Child Abuse and Neglect

Please note that Maryland law and UMBC policy require that I report all disclosures or suspicions of child abuse or neglect to the Department of Social Services and/or the police even if the person who experienced the abuse or neglect is now over 18.

Hate, Bias, Discrimination, and Harassment

UMBC values safety, cultural and ethnic diversity, social responsibility, lifelong learning, equity, and civic engagement.

Consistent with these principles, UMBC Policy prohibits discrimination and harassment in its educational programs and activities or with respect to employment terms and conditions based on race, creed, color, religion, sex, gender, pregnancy, ancestry, age, gender identity or expression, national origin, veterans status, marital status, sexual orientation, physical or mental disability, or genetic information.

Students (and faculty and staff) who experience discrimination, harassment, hate, or bias based upon a protected status or who have such matters reported to them should use the online reporting/referral form to report discrimination, hate, or bias incidents. You may report incidents that happen to you anonymously. Please note that, if you report anonymously, the University’s ability to respond may be limited.

Acknowledgements

This class borrows inspirations from several incredible sources. The project description is inspired by my colleague, Tim Oates. Some of the lecture slides’ material will be adapted from Machine Learning course offered by Stanford.