CS 4641/7641: Machine Learning (Spring 2020)
Course Information
- Lecture time: Tuesdays and Thursdays, 9:30am-10:45am
- Location: College of Business 100
- Piazza: https://piazza.com/gatech/spring2020/mlspring2020aoncampus/home
Course Overview
This course introduces techniques in machine learning with an emphasis on algorithms and their applications to real-world data. We will investigate the following question: how to computationally extract useful knowledge from data for decision making and task support? We will focus on machine learning methods, which are organized into three parts:
Basic math for data science and machine learning
- Linear algebra
- Probability and statistics
- Information theory
Unsupervised machine learning for data exploration
- Clustering analysis
- Dimension reduction
- Kernel density estimation
Supervised learning for predictive data analysis
- Tree-based models
- Linear classification and regression
- Neural networks
Prerequisites for this course include 1) basic knowledge of probability, statistics, and linear algebra; 2) Basic programming experience in Python, especially Jupyter Notebook.
Schedule
Office Hours and Questions
Office Hours:
- Instructor: Thursdays 10:45-11:45am in Business School lobby (access to my office is not easy)
- Kevin and Danrong: Mondays 11:30-12:30pm
- Rodrigo and Shreeshaa: Tuesdays 02:30-03:30pm
- Nimisha and Kunal: Tuesdays 03:30-04:30pm
- Huili and Shalini: Wednesdays 11:30-12:30pm
- Ruijia and Jayanta: Thursdays 04:30-05:30pm
- Tongtong and Shubhangi: Fridays 02:30-03:30pm
TA Office Hours location: in Klaus building lobby at the first floor (next to room 1325)
Piazza will be the main place for course discussions and announcements. If you have questions, please ask it on Piazza first because 1) other students may have the same question; 2) you will get help much faster.
If it’s something you do not like to discuss publicly on Piazza, you can use private messaging on Piazza.
Anytime you want to send a private message just to me on Piazza, please make sure to add our HEAD TA too in case I may miss your message.
Grading
Assignments (50%)
- There will be four assignments. Each one is designed for testing your understanding of the taught algorithms. Assignments will have programming and written analysis.
- You will need to submit all your assignments using ipynb. In ipynb, you can use markdown text editor. Here is a quick guideline how to use Markdown in ipynb.
- You are required to use Markdown and Latex for the written questions.
- All assignments follow the “no-late” policy. Assignments received after the due time will receive zero credit.
- There are some bonus questions in assignments for Undergrad students. The bonus questions are required to be answered for all Grad students and they are not considered as bonus points.
- All students are expected to follow the Georgia Tech Academic Honor Code.
- You can easily export your Jupyter Notebook to a Python file and import that to your desired python IDE to debug your code for assignments.
- You are not allowed to share any assignment codes or answers with other students whatsoever. Piazza is the best place to have discussion regarding assignments. Discussions are just for the better understanding of questions and should not directly answer the questions.
Project Proposal (5%)
- A project proposal should be just one page pdf (less than 500 words single spaced)
- A project proposal should include:
- Introduction/Background
- Methods
- Potential results
- Discussion
- At least three references (preferably peer reviewed)
- A checkpoint to make sure you are working on a proper machine learning related project.
Project (20%)
- You are expected to complete a project on machine learning with real-life data. Your project needs to be clear about 1) the data you are using; 2) the problem you are attempting to solve; 3) the method you are using; 4) the results and conclusion you attain.
- You will need to turn in a GitHub page for your project. The project presentation and report must be combined into one deliverable using a GitHub page. For the project presentation, you just need to scroll down on your GitHub page when you present your project (make sure you have visible images and graph).
- Each project needs to be completed in a team of 5 people (you will be forming your team on your own. In case you can't find any team, we will randomly assign you a team). Team members need to clearly claim their contributions in the project report.
- Each presentation cannot exceed beyond N/A minutes. If your presentation takes more than N/A minutes, you will be asked to stop the presentation at N/A minute mark. There will be N/A minute for Q/A.
- There will be N/A judges who will grade your presentations
- Refer to Project hints for your project's template, creating GitHub page, and also some general hints to improve the accuracy of your predictive model.
- If you are in a Grad students team, you are required to have both unsupervised and supervised learning in your project.
- Google colaboratory allows free access to run your Jupyter Notebook. I strongly suggest to use it for your project, specially for teams that are going to employ Deep Learning.
Class participation (5%)
- Your class participation score will be graded based on attendance and possibly in-class quizzes. For some lectures, I will take attendance using CANVAS.
- Participation in class discussions (including asking relevant questions in class, volunteering to answer questions on Piazza) will be considered when determining your final grade. It will be especially useful when you are right on the edge of two letter grades.
- Participation is required on presentation days.
Midterm Exam (10%)
- The midterm exam will only cover the math and probability and un-supervised learning parts.
- The midterm exam will take place the regular class time slot.
- The midterm exam will be a written and open-book exam. No electronic material can be used except calculator. Only paper material can be used in the exam (books, printed notes, etc). It would be better if you prepare a one or two page cheatsheet for yourself.
- There will be no make-up exams. You will get zero credit for your missed midterm exam.
- Taking the exam is required in order to receive a letter grade for this course. Students who fail this requirement will receive an Incomplete grade on their transcript.
Final Exam (10%)
- The final exam will only cover the supervised learning part.
- The final exam will be at assigened date/time for this class.
- The final exam will be a written and open-book exam. No electronic material can be used except calculator. Only paper material can be used in the exam (books, printed notes, etc). It would be better if you prepare a one or two page cheatsheet for yourself (let's save some trees).
- Again, there will be no make-up exams. You will get zero credit for your missed final exam.
- Taking the exam is required in order to receive a letter grade for this course. Students who fail this requirement will receive an Incomplete grade on their transcript.
Bonus points
- About Bonus points: Bonus points will be counted to always be beneficial for your final grade. What do I mean by that? it means that if for some reasons I may need to curve the grades, bonus points will be applied to your grade after curving not before curving.
- Undergrads and grads: Piazza has statistics which give us many measurements regarding how much a student has been involved on Piazza's activities such as viewing posts, answering questions, asking questions and so on. Not only we use this to account for a minor part of the Class Participation score, we will use the statistics to give students bonus points. Bonus points will be applied to students who answer the other students' questions correctly. At the end of the semester, we will define a minimum and maximum number of involvement considering all the students, and based on those, some students will receive at most %3 bonus points. It is possible to receive less than 3% bonus based on your activities on Piazza.
- Undergrads: As you all know, we have bonus points for hws. Bonus points will be different for different hws.For example, hw 1 may have 30 bonus points, hw 2 may have 20 bonus points and so on. If you receive all the bonus points for all your hws, we will add %5 to your final grade.
Course Policy
- Regrade policy: Disputes of grading on assignments, exams, and project must be discussed within one week of their return or grade posting. Should you find yourself having an issue with a grade, contact the TA first. After you talk with your TA, if you are not satisfied you may contact the course instructor.
- Assignment extension: Assignments are designed in a way that students would have several weeks to finish them. Assignments will not be extended under any circumstances whatsoever. You will receive 0 credit if you submit an assignment after the deadline.
- Missed exam policy: There will be no makeups for missed exams. Any request for exceptions to this policy should be made in advance when at all possible. Requests should be due to incapacitating illness, emergency such as death in the family or something similarly serious, and should be accompanied by supporting documentation and to be submitted to Dean of Students. Excuses such as not being aware of the exam will not be considered.
Dataset Ideas (may need API, or scraping) Thanks to Polo
- Google Dataset Search
- Google public datasets. Thanks Revant!
- Kaggle public datasets
- Awesome Public Datasets. Thanks Marcel Gwerder!
- NYC Taxi data for 2013 (suggested by Chris Wong). 2013 Trip Data (11.0GB). 2013 Fare Data (7.7GB). Visualization for a days trip. Thanks Jitesh.
- Large datasets publicly available. Thanks Gopi!
- Georgia Tech's campus data (has APIs): bus info, directory, building, T-square, room reservation, building facilities usage (e.g., electricity, lights, A/C, etc.), Oscar/course info/registration, etc.
- Yahoo WebScope
- Data.gov: U.S. Government's open data
- IPEDS data: Postsecondary education data from National Centre for Education Statistics
- Bureau of Labor Statistics data
- Uber data: Anonymized data from over 2 billion trips
- Freebase
- Yelp
- Microsoft Academic Graph
- Numerous APIs from Google (e.g., Maps, Freebase, YouTube, etc.)
- Zillow: real estate listing site
- Numerous graph datasets (large and small): SNAP, Konect
- Movies data: IMDB
- List of lists of datasets for recommendations.
Thanks Jon! - Million song dataset by Echo Nest.
It contains not only the basic information of songs (artist, genre, year, length etc), but also some musical features(like tempo, pitch, key, brightness).
Thanks Minwei! - Dataset about soccer games, players, clubs.
No API, but easy to scrape.
For a soccer player: transfer history, performance, nationality, birth date, etc.
For a soccer club: performance, squad, etc.
Thanks Ding! - The Free 'Big Data' Sources Everyone Should Know
-
Quandl - a dataset search engine for time-series data.
Thanks Henry! -
UCI also has a collection of links to various datasets sorted for various tasks (Classification, Regression, etc)
Thanks Vinodh! - Amazon AWS Public Data Sets (Thanks Jonathan!)
- KDD Cup: annual competition in data mining, like Kaggle
- Academic domain: Microsoft Academic Search, DBLP
- Retrosheet: MLB statistics (Game/Play logs)
-
Classification datasets
Thanks Amish! -
Various geophysical datasets for the oceans (magnetism, gravity, seismology, etc).
Thanks Ryan! - Social trends (Thanks Jonathan!)
- Beer data (Thanks Jonathan!). Website offline :( . Older version at web.archive.org
- Academic torrents (terabytes) (Thanks Vaibhav!)
- Article Search API from the New York Times (all the way back to 1851!) (Thanks Guido!)
- Civil Engineering Dataset (Thanks Dr. Frost)
- (Kayak: flight, hotel, car, etc.)
- Data Science Initiative - Microsoft Research has various datasets and access to tools that can aid in data science research
Office of Disability Services
The Georgia Institute of Technology has policies regarding disability accommodation, which are administered through The Office of Disability Services: http://disabilityservices.gatech.edu. For students with disabilities, please contact this Office to request classroom accommodations.
Resources
Recommended books:
- Learning from data, by Yaser S. Abu-Mostafa
- Pattern recognition and machine learning, by Christopher Bishop
- Machine learning, by Tom Mitchell
- Data Mining: Concepts and Techniques, by Jiawei Han, Micheline Kamber, and Jian Pei
- The Elements of Statistical Learning, by Trevor Hastie, Robert Tibshirani, and Jerome Friedman
- Deep Learning, by Ian Goodfellow, Yoshua Bengio, and Aaron Courville
Other resources, such as machine learning toolboxes and datasets, will be provided throughout the course.