2A Programming Assignment: Sinusoids and DFT (Week 2) : Instructions

Download as pdf or txt
Download as pdf or txt
You are on page 1of 3

2A Programming assignment: Sinusoids and DFT (week

2): Instructions

Help Center

The second programming assignment is for you to get a better understanding of the basic concepts in
audio signal processing. You will write snippets of code to generate sinusoids and to implement the
discrete Fourier transform (DFT) and the inverse DFT. There are five parts in this assignment with the last
part being optional that will not contribute to the grading.You can download the PDF document that
explains the assignment and the zip folder containing the necessary python scripts.

Download: PDF, ZIP

General Guidelines
Before you start, please make sure you have a working installation of python 2.7.* and Ubuntu (preferably
the latest LTS version). We recommend you to install ipython so that you can interactively test/run your
code. Go through this page for guidelines on python coding style, setting up sms-tools repository, working
directory for assignments, testing your code and instructions for submitting your answers.

Python coding style


To maintain uniformity in the python code we write in assignments, we recommend the use of four spaces
for each indentation level of the code.

Setting up sms-tools
Throughout the course we will be using the functions in the sms-tools repository for our programming
assignments. It is therefore important to setup sms-tools properly and make sure it works.
Download sms-tools
You can download the repository directly as a zip archive from github.
For students familiar with git, we recommend you to clone the sms-tools repository using git. Since the
repository evolves over time and undergoes changes, it is easier to keep the code synchronized with the
latest version on github through git. For the course, you just need to use the clone and pull commands of
git.
Installation
To start working with sms-tools you just need to install some dependencies. Read the instructions in the
README.md file inside sms-tools repository.
You can use this thread for discussions related to the installation of sms-tools.

Working directory for programming assignments


In sms-tools, there is a folder called workspace. We will use this folder as our working directory for all the

programming assignments. For every assignment you need to download a zip folder from the course
website and unzip it in workspace directory. Taking an example of the first programming assignment, the
directory structure should look like this:
$ /sms-tools/workspace/A1

Programming assignment folder for each week will contain templates for answer scripts (*.py files)
corresponding to every part of the assignment, a pickle file (*.pkl) containing the test cases, a PDF file
explaining the assignment and a script to submit your answers (submitA*.py). You have to complete the
code (functions) in the template script without altering the name of the functions or variables already
specified in the template. You should not rename or delete any file inside this folder.

Sound files
Most assignments require the use of sound files. You can use your own, making sure that they are in the
right format, or you can use the ones in the folder sounds of sms-tools, which are all in the required
format. To facilitate the work we have restricted the formats of sound files to use. You should always use
wav audio files that are mono (one channel), sampled at 44100 Hz and stored as 16 bit integers. Within the
code, we use floating point arrays to store the sound samples, thus the samples in the audio files are
converted to floating point values with a range from -1 to 1. The wavread function from the
utilFunctions module in the sms-tools reads a wav file and returns a floating point array with the
sample values normalized to the range -1 to 1, which is what we want.

Testing your code


After you complete a part of an assignment, make sure you run and test the code before submitting it for
automatic evaluation on the coursera servers. All the programming assignment questions will require that
you write a python function. The question will specify an input, or a type of input, and what output the
function has to return. Follow these steps to test a function (the example here considers the first
programming assignment):
Open the terminal and go to the directory where your code is.
$ cd */sms-tools/workspace/A1

Open the Ipython shell by typing:


$ ipython

Import the module (name of the `.py' file in this case) to test.
In [1]: import A1Part1

Run the code by calling the function with appropriate input arguments..
In [2]: A1Part1.readAudio(`../../sounds/piano.wav')

In the explanation of each assignment question we describe some example test cases that you can use to
run and test your code and make sure that it gives meaningful results.

Submission Instructions
You will need a working internet connection to submit your solutions. Once you complete a specific part of
an assignment, after testing it on few example test cases you can submit your solution from the terminal as
(the example here considers the first programming assignment):

$ python submitA1.py

Follow the instructions that appear on the terminal. You need to enter the email address you used to
register for the course and the Submission Password that is generated on the Programming Assignments
page of the course. Answers to each part are submitted separately. e.g. For Part-1, you will complete the
code in A1Part1.py and submit it by choosing '1' when prompted for the part you wish to submit. If the
submission is successful, you will the following message on the terminal
$ == Your submission has been accepted and will be graded shortly.

The answers are then submitted to a queue and we use a grader script that evaluates your submission and
provides you an appropriate score and feedback, which can be seen on the assignment page. It might take
a few minutes for the evaluation to complete and the score to get updated. You can submit your answers
as many times as you wish, but please wait to see the feedback and score before making the next attempt
at submission. Good luck coding!

You might also like