Final Project
Like to see some of last yearās final projects?
The climax of this course is its final project. The final project is your opportunity to take your newfound savvy with programming out for a spin and develop your very own piece of software. So long as your project draws upon the courseās lessons, the nature of your project is entirely up to you, albeit subject to the staffās approval. You may implement your project in any language(s) as long as the staff approves. You are welcome to utilize any infrastructure, provided the staff ultimately has access to any hardware and software that your project requires. All that we ask is that you build something of interest to you, that you solve an actual problem, that you impact campus, or that you change the world. Strive to create something that outlives this course.
Inasmuch as software development is rarely a one-person effort, you are allowed an opportunity to collaborate with one or two classmates for this final project. Needless to say, it is expected that every student in any such group contribute equally to the design and implementation of that groupās project. Moreover, it is expected that the scope of a two- or three-person groupās project be, respectively, twice or thrice that of a typical one-person project. A one-person project, mind you, should entail more time and effort than is required by each of the courseās problem sets. Although no more than three students may design and implement a given project, you are welcome to solicit advice from others, so long as you respect the courseās policy on academic honesty.
Extensions on the final project are not ordinarily granted, except in cases of emergency.
Ideas
Here are just some of the possibilities. Discuss any and all with the the staff! And if youād like to solicit collaborators for an idea you have, do post in Ed!
- a web-based application using JavaScript, Python, and SQL
- an iOS app using Swift
- a game using Lua with LĆVE
- an Android app using Java
- a Chrome extension using JavaScript
- a command-line program using C
- a hardware-based application for which you program some device
- ā¦
Combining Courses
If taking some other course this semester that has a final project, you are welcome and encouraged to combine this courseās project and that courseās project into one, toward an end of applying lessons learned in CS50 to some other field, so long as the joint project satisfies this courseās and that courseās expectations. Before pursuing a joint project, though, you must disclose to both courses and receive approval from both courses.
Specifications
Extensions on the final project are not granted, except in cases of emergency. Late submissions of any of the final projectās milestones will not be accepted! Submissions of any part of the final project outside of Gradescope will not accepted, except as outlined in the instructions for submitting your implementation at the end of this specification.
Proposal
The proposal is your opportunity to receive approval and counsel from the staff before you proceed to design. If collaborating with one or two classmates, each of you should submit a proposal, even if identical.
The staff will either approve your proposal or require modifications on your part for subsequent approval. Your proposal, even if approved, is not binding; you may alter your plan at any point, provided you obtain the staffās approval for any modifications. Projects submitted without approval may not receive credit.
Hereās how to complete your proposal.
Log into CS50 IDE and then, in a terminal window:
- Execute
cd
to ensure that youāre in~/
(i.e., your home directory). - If you havenāt already, execute
mkdir project
to make (i.e., create) a directory calledproject
in your home directory. - Execute
cd project
to change into (i.e., open) that directory. - Execute
wget https://cdn.cs50.net/2020/fall/project/proposal.zip
to download a (compressed) ZIP file. - Execute
unzip proposal.zip
to uncompress that file. - Execute
rm proposal.zip
followed byyes
ory
to delete that ZIP file. - Execute
ls
. You should see a directory calledproposal
, which was inside of that ZIP file. - Execute
cd proposal
to change into that directory. - Execute
ls
. You should see a file calledREADME.md
therein.
Edit that file in CS50 IDE, answering the questions therein. To submit your proposal, follow these instructions.
- Download your proposalās
README.md
file by control-clicking on the file in CS50 IDEās file browser and choosing Download. - Go to CS50ās Gradescope page.
- Click āFinal Project: Proposalā.
- Drag and drop your
README.md
file to the area that says āDrag & Dropā. - Click āUploadā.
You should see a message that says āFinal Project: Proposal submitted successfully!ā
Status Report
Not only is the status report intended to keep the staff apprised of your progress, it is an opportunity to keep yourself on track. If collaborating with one or two classmates, each of you should submit a status report, even if identical.
Hereās how to complete your status report. Log into CS50 IDE and then, in a terminal window:
- Execute
cd
to ensure that youāre in~/
(i.e., your home directory). - If you havenāt already, execute
mkdir project
to make (i.e., create) a directory calledproject
in yourworkspace
directory. - Execute
cd project
to change into (i.e., open) that directory. - Execute
wget https://cdn.cs50.net/2020/fall/project/status.zip
to download a (compressed) ZIP file. - Execute
unzip status.zip
to uncompress that file. - Execute
rm status.zip
followed byyes
ory
to delete that ZIP file. - Execute
ls
. You should see a directory calledstatus
, which was inside of that ZIP file. - Execute
cd status
to change into that directory. - Execute
ls
. You should see a file calledstatus.md
therein.
Edit that file in CS50 IDE, answering the questions therein. To submit your status report, follow these instructions.
- Download your status reportās
status.md
file by control-clicking on the file in CS50 IDEās file browser and choosing Download. - Go to CS50ās Gradescope page.
- Click āFinal Project: Status Reportā.
- Drag and drop your
status.md
file to the area that says āDrag & Dropā. - Click āUploadā.
You should see a message that says āFinal Project: Status Report submitted successfully!ā
Implementation
Ultimately due are implementation and documentation of your final project. Your submission thereof must include all of the below.
- Documentation for your project in the form of a Markdown file called
README.md
. This documentation is to be a userās manual for your project. Though the structure of your documentation is entirely up to you, it should be incredibly clear to the staff how and where, if applicable, to compile, configure, and use your project. Your documentation should be at least several paragraphs in length. It should not be necessary for us to contact you with questions regarding your project after its submission. Hold our hand with this documentation; be sure to answer in your documentation any questions that you think we might have while testing your work. Do not save this step for last, it will take you longer than you think to write a comprehensiveREADME
! - A ādesign documentā for your project in the form of a Markdown file called
DESIGN.md
that discusses, technically, how you implemented your project and why you made the design decisions you did. Your design document should be at least several paragraphs in length. Whereas your documentation is meant to be a userās manual, consider your design document your opportunity to give the staff a technical tour of your project underneath its hood. Similarly, we do not advise saving this step for last. - Any and all files required to run your software (even if intended for some infrastructure other than CS50 IDE), including source code as well as, if applicable, configuration files, Makefiles, sample inputs, SQLite databases, and so forth. Needless to say, all source code should be thoroughly commented.
- A short video (thatās no more than 2 minutes in length) in which you present your project to the world, as with slides, screenshots, voiceover, and/or live action. Your video should somehow include your projectās title, your name and year, your dorm/house and concentration, and any other details that youād like to convey to viewers. See CS171ās tips on how to make a āscreencastā though youāre welcome to use an actual camera. Do not upload the video file to Gradescope; rather, upload your video to YouTube as āpublicā or āunlistedā and include the URL of the video in your README.md file.
How to Submit
If you have collaborated with one or two other students, each of you should submit via this same process.
If your project requires (for execution and testing) hardware or software other than that offered by CS50 IDE, be sure that the the staff are aware of and have approved your projectās needs.
Step 1 of 2
Gradescope does have a soft file size limit when uploading (if it times out, Gradescope will reject it). We recommend your ZIP be no larger than 15MB if at all possible; you can probably help trend it in this direction by, if needed, omitting any large assets like images and any datasets that your project requires. At an absolute minimum, and only if none of the above options work, you may upload just your README.md
file to Gradescope. Ultimately you must have something uploaded to Gradescope before the deadline for your project to be accepted. You can then share the remainder of your project directly with your TF out of band of Gradescope (e.g. via GitHub, Dropbox, e-mail, or Google Drive.)
- Download a ZIP file of your final project by control-clicking on the project folder in CS50 IDEās file browser and choosing Download. (If you created your final project outside of CS50 IDE, you should still create a ZIP file of the project folder.)
- Go to CS50ās Gradescope page.
- Click āFinal Project: Implementationā.
- Drag and drop your ZIP file to the area that says āDrag & Dropā.
- Click āUploadā.
You should see a message that says āFinal Project: Implementation submitted successfully!ā
Step 2 of 2
Submit this form.
This last form is on the longer side, so no worries if you start it before the deadline but finish a bit after.
And thatās it; youāve finished. This was CS50!