This document outlines how the course will be graded.
Assignment | % of Grade |
---|---|
4 homework assignments | 40% of grade |
8 online quizzes | 40% of grade |
1 final project/exam | 20% of grade |
Non-group programming assignments and quizzes must be completed indiviudally and all work must be your own. All students must abide by the following rules:
- you may not work as a partner with another student on an assignment,
- you may not show your solutions to another student or look at their solution,
- you may not discuss homework solutions in the course chat room or on the Issues pages,
We enforce these policies by periodically running similarity detection software over all submitted code. Students who violate this policy will receive zero scores on their submissions.
We encourage appropriate forms of collaboration during this course such as,
- asking for help in understanding a part of a lecture,
- assistance in the use of a software tool or library outside the context of a homework assignment,
- requesting a reference on a given software tool or library,
- discussion of topics beyond the scope of this course.
The instructors and teaching assistants hope that the student understands these policies are in place to help the student achieve a firm grasp of the course material. Cheating does not result in understanding and any assignments submitted which is not the product of your own hard work is a detriment only to yourself and your education.
The University of Washington explains academic integrity very clearly in the Student Academic Responsibility guide.
Each homework assignment will be graded based on several components:
- 60 / 100 points - code passes tests
- 20 / 100 points - well-written report and analysis
- 10 / 100 points - code is documented according to the rubric
- 10 / 100 points - sufficient program performance (where applicable)
Details:
-
code passes tests
Every student's code will be run against an automated test suite using Python's
unittest
module. A sample / toy test suite will be supplied with every homework assignment. This supplied test suite will be there to make sure your code compiles well against our own tests suite and that your implementation conforms to certain function prototypes and interfaces.When submitted, your code will be subjected to a "hidden" test suite written by the instructor and TAs. We will describe these hidden tests (in words) with each homework but it will be up to the student to write their own tests unless they wish to submit their homework based on faith. The purpose of this method is to encourage testing of your own work and to learn how to write automated tests using a well-known unit testing package.
The toy test suite included with the assignment can be run from the top-level assignment directory like so:
$ python test_homework1.py # or whatever the name is of the test suite
The functions that you have written in the
homeworkN
Python module orlib
directory (for C library code) will be imported and run against any tests that you have written in the test suite. Remember to compile your C code first before running the test suite. -
well-written report and analysis
Every homework assignment will have a handful of questions where the student will need to write some exposition. This may involve deriving certain formulae, determining the computational complexity of a certain algorithm, or plot and describe some results.
This report should be written up in a PDF file titled
report.pdf
located in the directoryreport
of the homework repository. -
code documentation
Good code is code that not only runs well but is well-understood by others. Your code will be graded for cleanliness and sufficient documentation. In particular, every Python function you write should have a docstring with the following formatting, similar to the formatting used in [Numpydoc]
def my_function(arg1, arg2, kwd1=default_value): """(one-line description of function) (extended description of function) Parameters ---------- arg1 : argument type (Descrtipion of parameter) arg2 : argument type (Description of parameter) kwd1 : keyword type Default: default_value. (Description of keyword) Returns ------- variable_name : output type (Description of output) """ # function body goes here.
C code should be similarly documented. If a parameter is returned by reference then be sure to indicate as such. Documentation should be provided for every function appearing in a header file. It is not necessary to duplicate the docstring for both the function prototype in the header and the function body in the source files. However, every function without a corresponding function prototype should be documented.
/* my_function (description of function) Parameters ---------- arg1 : parameter type (Descrtipion of parameter) arg2 : parameter type, (Description of parameter) Returns ------- argument or variable_name : output type (Description of output) arg2 : type, return by reference (Description of output) */ double my_function(int arg1, double* arg2); // function prototype
-
performance
Because this is a course on high-performance computing some of your code will be judged based on performance. While testing the correctness of your code it will be timed. The run times of every student's code will be collected and we will determine the average run time across all submissions. Performance score is based on which standard deviation your runtime will fall in.
Std. Deviation | Points Awarded |
---|---|
-3 | 0 / 10 |
-2 | 5 / 10 |
+/- 1 | 10 / 10 |
= +2 | 15 / 10
Every Monday you will be given a short quiz on the contents of the lectures from the previous week as well as the content in the "Primary References" for those lectures. See the Course Syllabus for the Primary Reference(s) associated with each lecture as well as information on when the quiz is administrated, how much time you have to do the quiz, etc.
The final examination consists of two parts:
- Final Project - similar in format to the homework. You will be asked to write some code and run it against an unknown test suite as well as write up a short report.
- Final Exam - a short, written exam designed to test you on the concepts learned in the course. You may be asked to write code by hand. The exam should take approximately 45 minutes.