User Tools

Site Tools


syllabus

This is an old revision of the document!


Overview

Description

This course covers fundamental and advanced concepts and methods involving deep neural networks for solving problems in data classification, prediction, visualization, and reinforcement learning. Students will learn how to

  • read data files of various formats and visualize characteristics of the data,
  • perform statistical analyses on multivariate data,
  • develop and apply classification algorithms to classify multivariate data,
  • develop and apply regression algorithms for finding relationships between data variables,
  • develop and apply reinforcement learning algorithms for learning to control complex systems,
  • write scientific reports on computational machine learning methods, results and conclusions,
  • use the latest features in python, including jupyter notebooks, and
  • how to repeat experiments described in on-line tutorials, documentation, and publications in deep learning.

For implementations we will be using Python. Previous experience with Python and its numpy package is helpful. To prepare for this course, please download and install Python on your computer, and work through on-line tutorials to help prepare for this course. The Anaconda distribution is recommended, which is a free download for all platforms.

CS440 is the prerequesite for this course. However, CS445 provides a more relevant background for the material in CS545. Some of the CS445 will be revisited in CS545. The main difference between CS545 and CS445 is the scale of the assignments, more material relates to Pytorch and Tensorflow, and discussions of recent papers in the research literature on deep learning.

Class meetings will be a combination of lectures by the instructor, discussions of students' questions, and some student presentations in class. All questions are welcome, no matter how simple you think they are; it is always true that someone else has a similar question. It is critical that everyone in class respect each other when questions are asked and answers are suggested and at all times. Please contact the instructor when you have felt disrespect from other students, the instructor, or the graduate teaching assistants. This may be anonymous if you prefer.

A lot of material will be covered in this course. Students are expected to speak up in class with questions and observations they have about the material. Do not expect to be able to complete all assignments working on your own and without asking any questions. If you find yourself wondering what the next step is in finishing an assignment, please feel free to e-mail the instructor. You may also discuss assignments with other students directly, or via our Piazza Discussion board, but your code and report must be written by you. Do not post code on the Piazza Discussion board as part of your question nor as part of your answer.

You are expected to be familiar with the CS Department policy on cheating and with the CS Department Code of Conduct found at the department's Policies & Resources web page. This course will adhere to the CSU Academic Integrity Policy as found on the Student Responsibilities page of the CSU General Catalog and in the Student Conduct Code. At a minimum, violations will result in a grading penalty in this course and a report to the Office of Student Resolution Center.

Time and Place

Class meets every Tuesday and Thursday, 8:00 AM - 9:15 AM in Room 130 in the CS Building. Distance-learning students will be able to watch video recordings of lectures through our Canvas web page.

Prerequisites

CS440 with a grade of C or better, and some experience with python.

Textbook

There are no required text books for this course. Readings may be assigned from the following on-line books.

From Python to Numpy by Nicolas P. Rougier

Deep Learning by Ian Goodfellow, Yoshua Bengio, and Aaron Courville

Reinforcement Learning: An Introduction, by Richard Sutton and Andrew Barto, 2nd edition

Instructors

Office Hours Contact
Chuck Anderson Computer Science Building (CSB) Room 444 Tuesday 10 AM - 12
Wednesday 1 PM - 3
chuck.anderson@colostate.edu
970-491-7491
GTA: Dejan Markovikj CSB 235, Desk 1 CS120
Tuesday/Thursday 12 - 2 PM
dejan.markovikj@colostate.edu

Grading

Your grade for this course will be based on the assignments, most of which will require the submission of a jupyter notebook that includes text descriptions of your methods, results and conclusions and the python code for defining machine learning algorithms, loading data and applying your algorithms to the data. Each notebook will be graded for correct implementation and results, thorough discussion of your code and observations of results, and good organization, grammar and spelling. No quizzes or exams will be given.

Six to seven regular assignments are planned during the semester. In total these will count for 70% of your semester grade. The final assignment is a project designed by you and is worth 20% of your semester grade. 10% of your final grade for on-campus students will be based on your in-class presentation made during the final three weeks of the semester. The final grade for lineline students will only be based on assignments.

  • 70% regular assignments, from 10% to 13% each (80% for online students)
  • 2% for the project proposal
  • 18% for the project written report
  • 10% in-class presentation (only for on-campus students)

Semester letter grades will include plus and minus grades. Assume standard ranges of numerical grades will be used. Ranges might be shifted a little lower, depending on the grade distribution at the end of the semester, but they will not be raised.

Some assignments will include extra credit points. These will be accumulated during the semester. At the end of the semester, if your grade is just below a letter grade cutoff, the extra credit points might push you up to the higher grade. Each extra credit point is roughly worth 1/2 a percent. For example, if your grade is 88% and the cutoff or A- is 90%, four extra credit points will bump your grade up to an A-.

Late reports will not be accepted, unless you make arrangements with the instructor at least two days before the due date.

syllabus.1567096910.txt.gz · Last modified: 2019/08/29 10:41 by 127.0.0.1