2012 May 29,

CS 111: Project

Carleton College, Spring 2012

Prof. Joshua R. Davis, , Goodsell 106B, x4473

Introduction

Most of the rest of this course will be occupied by the final project. It must be handed in electronically by Sunday 2012 June 3 at 6:00PM. You are strongly encouraged to work on the project with one (and only one) partner, because two workers can produce a more interesting product than one worker. If you would like help in finding a partner, then e-mail me.

The goal of the project is for you to write a program of significant size and complexity in an object-oriented style. Your project must involve at least one subclass of your own creation, that demonstrates that you understand subclassing. You have over two weeks to work on the project, and the size of the project should reflect that amount of time and effort. You may develop your project on your own computer, but it must function correctly on our lab machines.

Ideas

The kind of program is up to you, but here are a few suggestions.

Dave and I will talk with you occasionally, to see how your ideas are evolving and how your project is progressing. I have one last request: Do not make a project about zombies.

Polishing and Submitting your Work

You and your partner will submit a single copy of your project. In your hand-in folder on the COURSES file server, make a new folder called "project". You will place your program files, image files, sound files, and any other supporting files in this folder.

Among the files that you submit, there must be a file called "readme.txt" or "readme.pdf". (It should be a plain text file, of the sort made by TextWrangler or a text editor, or a PDF file. Do not submit documents of any proprietary format, such as Microsoft Word.) I will read this readme file, just before grading your project. Hence the readme file is your chance to "frame" your project, so that I come away satisfied and impressed. The readme file should probably explain:

Remember to polish your code. The code should be appropriately commented, with comments that explain the purpose of each logical chunk. Every function and method should be preceded by a comment that explains its purpose, its inputs, and its outputs. Any function, method, or other block of code that is more than about one screen long should probably be broken up into pieces. There should be no extraneous or obviously-inefficient code. See the Image Processing assignment, for other polishing tips.

After you have polished your code, make sure to test it one last time, to make sure that you have not messed it up. If you have written your project on a non-lab computer, then be sure to test it on a lab computer, which is where it will be graded.

Your project will be graded based on its fulfilment of the basic requirements (e.g. at least one subclass), its technical competence (does it work?), its technical difficulty (was it hard?), its polish (clean, efficient code), its documentation (comments and readme), and its creativity.