Difference between revisions of "MC1-Homework-1"

From Quantitative Analysis Software Courses
Jump to navigation Jump to search
(Included link to test cases)
 
(11 intermediate revisions by 2 users not shown)
Line 5: Line 5:
 
==Task==
 
==Task==
  
Your task for this homework is to write two Python functions: One named <tt>stdev_p()</tt> that computes the population standard deviation of a list of numbers, and another named <tt>stdev_s()</tt> that computes the sample standard deviation. We will use the definitions of population and sample standard deviation provided at wikipedia [[https://en.wikipedia.org/wiki/Standard_deviation here]].  Specifically the sample stdev should use the "Bessell Correction."
+
You should create and test your code in the virtual machine you've installed separately.
 +
 
 +
Your task for this homework is to write two Python functions: One named <tt>stdev_p()</tt> that computes the population standard deviation of a list of numbers, and another named <tt>stdev_s()</tt> that computes the sample standard deviation. We will use the definitions of population and sample standard deviation provided at wikipedia [[https://en.wikipedia.org/wiki/Standard_deviation here]].  Specifically the sample stdev should use the "Bessel Correction."
 +
 
 +
Note that only the functions stdev_s() and stdev_p() will be tested.  The main part of the code will not be called or tested.  The main code is only there to help you test your code.
  
 
==You have to write it yourself!==
 
==You have to write it yourself!==
  
We want you to implement the functions described above using basic Python functions and control flow comments (e.g., while, for, etc.).  You are not allowed to import any libraries.
+
We want you to implement the functions described above using basic Python functions and control flow comments (e.g., while, for, etc.).  You are not allowed to import any libraries besides the standard math library.
  
 
==Template==
 
==Template==
Line 16: Line 20:
  
 
<PRE>
 
<PRE>
 +
import math as m
 +
 
# calculate the population standard deviation
 
# calculate the population standard deviation
 
def stdev_p(data):
 
def stdev_p(data):
Line 32: Line 38:
 
</PRE>
 
</PRE>
  
Cut and paste this template into a local file <TT>stdev_code.py</TT>.  Note that the main part of the code tests the two functions.  Note also that your main code <b>will not be tested</b> by the auto grading code.  Only your functions will be called and tested.
+
Cut and paste this template into a local file <TT>stdev_code.py</TT>.  Note that the main part of the code tests the two functions.  Note also that your main code <b>will not be tested</b> by the auto grading code.  Only the specific functions we describe will be called and tested.
  
 
You can run your program using the command: <tt>python stdev_code.py</tt>
 
You can run your program using the command: <tt>python stdev_code.py</tt>
Line 43: Line 49:
 
==What to turn in==
 
==What to turn in==
  
You can compose and test your code via the Udacity platform (continue here: [https://www.udacity.com/course/viewer#!/c-ud501/l-4180469313/m-4236488542 MC1-Homework-1 - Instructions]), however you must submit your final code via t-square.
+
* Submit your code as a single file <tt>stdev_code.py</tt> via t-square.  It is essential that you use that name exactly.
 
+
* Do not submit other files.
* Submit your code as <tt>nth_prime.py</tt> via t-square.  It is essential that you use exactly that name.
+
* Do not submit zip files.
 +
* Make sure your code file is named correctly.
 +
* Under no circumstance should you submit a word document.
  
==Udacity login instructions==
+
==Rubric==
  
If you are a GT OMSCS or on-campus student taking this course for credit, you must log in to Udacity using your Georgia Tech account:
+
* 4 test cases: We will test your code against 4 cases (25% per case).  Each case will be deemed "correct" if:
[https://login.gatech.edu/cas/login?service=http%3A%2F%2Fweb.iam.gatech.edu%2Fudacity-login%2F GT-Udacity Login]
+
** 12.5%: stdev_p = reference answer within 10%
 +
** 12.5%: stdev_s = reference answer within 10%
  
Here's a [https://www.youtube.com/watch?v=pyqirZW_sT8 helpful video]. Once you're in, visit the above link again, or navigate to the course from '''My Courses'''.
+
==Test cases==
  
'''Note''': DO NOT log in using your personal Udacity account, in case you have one.
+
Here are the test cases used while grading. These are updated each semester and released after grading.
 +
* [[MC1-Homework-1-Test-Cases-spr2016]]
  
 
==Required, Allowed & Prohibited==
 
==Required, Allowed & Prohibited==
Line 60: Line 70:
 
Required:
 
Required:
 
* Your project must be coded in Python 2.7.x.
 
* Your project must be coded in Python 2.7.x.
* Your code must run on one of the university-provided computers (e.g. buffet02.cc.gatech.edu), or on one of the provided virtual images.
+
* Your code must run successfully on one of the university-provided computers (e.g. buffet02.cc.gatech.edu), or on the provided virtual image.
* Your code must run in less than 5 seconds on one of the university-provided computers.
+
* Your code must solve a 1000 element list in less than 1 second on one of the university-provided computers.
  
 
Allowed:
 
Allowed:
 
* You can develop your code on your personal machine, but it must also run successfully on one of the university provided machines or virtual images.
 
* You can develop your code on your personal machine, but it must also run successfully on one of the university provided machines or virtual images.
* Your code may use standard Python libraries.
+
* Your code may import the Python math library.
* You may use the NumPy, SciPy and Pandas libraries.
 
* Small sections of code (up to 5 lines) that you collected from other students or the internet.
 
* Code provided by the instructor, or allowed by the instructor to be shared.
 
  
 
Prohibited:
 
Prohibited:
 +
* Print statements in your function definitions.  No need to print anything.
 
* Any libraries not listed in the "allowed" section above.
 
* Any libraries not listed in the "allowed" section above.
* Any code you did not write yourself (except for the 5 line rule in the "allowed" section).
+
* Any code you did not write yourself.
* Any Classes other than Random that create their own instance variables for later use (e.g., learners like kdtree).
 

Latest revision as of 15:49, 26 January 2016

Overview

The purpose of this assignment is to get you started programming in Python. Note that we'll be using Python 2.7 for this course (not Python 3.0). This assignment is structured like many of the homeworks and projects for this course, namely that you are to create a Python function that solves a specific problem. We will call your function and verify that it provides the correct answer.

Task

You should create and test your code in the virtual machine you've installed separately.

Your task for this homework is to write two Python functions: One named stdev_p() that computes the population standard deviation of a list of numbers, and another named stdev_s() that computes the sample standard deviation. We will use the definitions of population and sample standard deviation provided at wikipedia [here]. Specifically the sample stdev should use the "Bessel Correction."

Note that only the functions stdev_s() and stdev_p() will be tested. The main part of the code will not be called or tested. The main code is only there to help you test your code.

You have to write it yourself!

We want you to implement the functions described above using basic Python functions and control flow comments (e.g., while, for, etc.). You are not allowed to import any libraries besides the standard math library.

Template

Here's a template for what your code should look like:

import math as m

# calculate the population standard deviation
def stdev_p(data):
    result = 2.0 # your code goes here
    return result

# calculate the sample standard deviation
def stdev_s(data):
    result = 1.9 # your code goes here
    return result

if __name__ == "__main__":
    test = [2.0, 4.0, 4.0, 4.0, 5.0, 5.0, 7.0, 9.0]
    print "the population stdev is", stdev_p(test)
    print "the sample stdev is", stdev_s(test)

Cut and paste this template into a local file stdev_code.py. Note that the main part of the code tests the two functions. Note also that your main code will not be tested by the auto grading code. Only the specific functions we describe will be called and tested.

You can run your program using the command: python stdev_code.py

Resources and ideas

What to turn in

  • Submit your code as a single file stdev_code.py via t-square. It is essential that you use that name exactly.
  • Do not submit other files.
  • Do not submit zip files.
  • Make sure your code file is named correctly.
  • Under no circumstance should you submit a word document.

Rubric

  • 4 test cases: We will test your code against 4 cases (25% per case). Each case will be deemed "correct" if:
    • 12.5%: stdev_p = reference answer within 10%
    • 12.5%: stdev_s = reference answer within 10%

Test cases

Here are the test cases used while grading. These are updated each semester and released after grading.

Required, Allowed & Prohibited

Required:

  • Your project must be coded in Python 2.7.x.
  • Your code must run successfully on one of the university-provided computers (e.g. buffet02.cc.gatech.edu), or on the provided virtual image.
  • Your code must solve a 1000 element list in less than 1 second on one of the university-provided computers.

Allowed:

  • You can develop your code on your personal machine, but it must also run successfully on one of the university provided machines or virtual images.
  • Your code may import the Python math library.

Prohibited:

  • Print statements in your function definitions. No need to print anything.
  • Any libraries not listed in the "allowed" section above.
  • Any code you did not write yourself.