Final Project
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, organized into (non-exhaustive) "tracks". Discuss any and all with your TF! And if you’d like to solicit collaborators for an idea you have, do post to Discourse!
If at a loss for ideas, here are some seminars from years past for inpsiration!
Software Track
-
a web-based application using JavaScript, Python, and SQL, based in part on Problem Set 8’s distribution code
-
a web-based application using PHP or Ruby
-
a plugin for CS50 IDE using JavaScript
-
a Chrome extension using JavaScript
-
an iOS app using Swift (or Objective-C)
-
an Android app using Java
-
a command-line program using C
-
…
Cross-Course Track
Like to combine two courses' projects? 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 (as from your TF in CS50).
Hardware Track
Like to integrate hardware into your project? Know that CS50 has the following hardware with which you’re welcome to create something amazing:
-
an iOS Developer Program, which allows you to install homemade apps on your own iOS device,
-
some Arduino Uno boards, for which there’s an API,
-
some Google Cardboards, for which there’s an developers.google.com/cardboard[API],
-
some Internet of Things hardware development kits and Internet Buttons, for which there’s an IDE and API,
-
some Leap Motion Controllers, for which there’s an API,
-
a Microsoft HoloLens, for which there’s an SDK
-
an Oculus Rift and an Oculus DK2, for which there’s an SDK
-
some Philips hue bulbs, for which there’s an API,
-
some Samsung Gear VRs, for which there’s an SDK, and
-
some Sonos PLAY:1s, for which there’s an API.
If you’d like to borrow something for a project, email heads@cs50.harvard.edu, and we’ll do our best to oblige, sharing hardware across classmates as needed. Let us know, too, if there’s some other hardware or software you’d like to utilize for a project, and we’ll do our best to find it.
Specifications
Extensions on the final project are not granted, except in cases of emergency.
Preproposal
due by Tue 11/6, 11:59pm
Intended to promote early thought, the preproposal is your opportunity to bounce one or more ideas off of your teaching fellow. If collaborating with one or two classmates, each of you should submit a preproposal, even if identical.
Here’s how to submit your preproposal. Log into CS50 IDE and then, in a terminal window:
-
Execute
update50
to ensure your IDE is up-to-date. That command might take a few minutes to finish. -
Execute
cd
to ensure that you’re in~/workspace/
(i.e., a directory calledworkspace
that’s in your home directory, aka~
). -
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 http://cdn.cs50.net/2018/fall/project/preproposal.zip
to download a (compressed) ZIP file. -
Execute
unzip preproposal.zip
to uncompress that file. -
Execute
rm preproposal.zip
followed byyes
ory
to delete that ZIP file. -
Execute
ls
. You should see a directory calledpreproposal
, which was inside of that ZIP file. -
Execute
cd preproposal
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.
Then execute the below from within your ~/workspace/project/preproposal
directory, logging in with your GitHub username and password when prompted. For security, you’ll see asterisks (*
) instead of the actual characters in your password.
submit50 cs50/2018/fall/project/preproposal
Proposal
due by Tue 11/13, 11:59pm
The proposal is your opportunity to receive approval and counsel from your teaching fellow before you proceed to design. If collaborating with one or two classmates, each of you should submit a proposal, even if identical.
Your teaching fellow 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 your teaching fellow’s approval for any modifications. Projects submitted without approval may not receive credit.
After submitting your proposal, a teaching fellow other than your own may be appointed your advisor and grader for the remainder of the final project, depending on your proposal’s nature.
Here’s how to submit your proposal.
Step 1 of 2
Submit this form.
Step 2 of 2
Log into CS50 IDE and then, in a terminal window:
-
Execute
update50
to ensure your IDE is up-to-date. That command might take a few minutes to finish. -
Execute
cd
to ensure that you’re in~/workspace/
(i.e., a directory calledworkspace
that’s in your home directory, aka~
). -
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 http://cdn.cs50.net/2018/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.
Then execute the below from within your ~/workspace/project/proposal
directory, logging in with your GitHub username and password when prompted. For security, you’ll see asterisks (*
) instead of the actual characters in your password.
submit50 cs50/2018/fall/project/proposal
Status Report
due by Tue 11/27, 11:59pm
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 submit your status report. Log into CS50 IDE and then, in a terminal window:
-
Execute
update50
to ensure your IDE is up-to-date. That command might take a few minutes to finish. -
Execute
cd
to ensure that you’re in~/workspace/
(i.e., a directory calledworkspace
that’s in your home directory, aka~
). -
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 http://cdn.cs50.net/2018/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.
Then execute the below from within your ~/workspace/project/status
directory, logging in with your GitHub username and password when prompted. For security, you’ll see asterisks (*
) instead of the actual characters in your password.
submit50 cs50/2018/fall/project/status
CS50 Hackathon
Thu 11/29, 7pm – Fri 11/30, 7am
The CS50 Hackathon is an epic all-nighter across the river atop the i-lab during which you can dive into your final project’s implementation alongside classmates and staff. If you choose to partake, you’ll be asked to propose three milestones for yourself that evening: a "good" one that you intend to achieve no matter what; a "better" one that you think you can achieve; and a "best" one that you hope to achieve.
Dinner will be served around 9pm, second dinner will be served around 1am, and those still standing around 5am will be treated to breakfast at IHOP.
Additional details on the CS50 Hackathon’s logistics will be announced via email and the course’s home page the week before the CS50 Hackathon.
Implementation
due by Thu 12/6, 11:59pm
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. -
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. -
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. Upload your video to YouTube as "public" or "unlisted" and take note of its URL.
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 TF advising you is aware of and has approved your project’s needs.
Step 1 of 2
update50
cd ~/workspace/project/ # or wherever you've stored your project
submit50 cs50/2018/fall/project/implementation
Step 2 of 2
This last form is on the longer side, so no worries if you start it before the deadline but finish a bit after.
CS50 Fair
Fri 12/7, 12pm – 4pm
The CS50 Fair is an epic display of final projects, your opportunity to showcase your work not only to us but also to others on campus. You will be expected to bring to the CS50 Fair a laptop with which to demonstrate your project. Plan to tell attendees what you have done and why you have done it. And perhaps have in mind a few anecdotes about lessons you learned, roadblocks you hit, or the like.
The CS50 Fair will take place in Harvard Commons in the Smith Center.
Additional details on the CS50 Fair’s logistics will be announced via email and the course’s home page the week before the CS50 Fair.
Academic Honesty
This course’s philosophy on academic honesty is best stated as "be reasonable." The course recognizes that interactions with classmates and others can facilitate mastery of the course’s material. However, there remains a line between enlisting the help of another and submitting the work of another. This policy characterizes both sides of that line.
The essence of all work that you submit to this course must be your own. Collaboration on problem sets is not permitted except to the extent that you may ask classmates and others for help so long as that help does not reduce to another doing your work for you. Generally speaking, when asking for help, you may show your code to others, but you may not view theirs, so long as you and they respect this policy’s other constraints. Collaboration on the course’s test and quiz is not permitted at all. Collaboration on the course’s final project is permitted to the extent prescribed by its specification.
Below are rules of thumb that (inexhaustively) characterize acts that the course considers reasonable and not reasonable. If in doubt as to whether some act is reasonable, do not commit it until you solicit and receive approval in writing from the course’s heads. Acts considered not reasonable by the course are handled harshly. If the course refers some matter for disciplinary action and the outcome is punitive, the course reserves the right to impose local sanctions on top of that outcome that may include an unsatisfactory or failing grade for work submitted or for the course itself. The course ordinarily recommends exclusion (i.e., required withdrawal) from the course itself.
If you commit some act that is not reasonable but bring it to the attention of the course’s heads within 72 hours, the course may impose local sanctions that may include an unsatisfactory or failing grade for work submitted, but the course will not refer the matter for further disciplinary action except in cases of repeated acts.
Reasonable
-
Communicating with classmates about problem sets' problems in English (or some other spoken language).
-
Discussing the course’s material with others in order to understand it better.
-
Helping a classmate identify a bug in his or her code at office hours, elsewhere, or even online, as by viewing, compiling, or running his or her code, even on your own computer.
-
Incorporating a few lines of code that you find online or elsewhere into your own code, provided that those lines are not themselves solutions to assigned problems and that you cite the lines' origins.
-
Reviewing past semesters' tests and quizzes and solutions thereto.
-
Sending or showing code that you’ve written to someone, possibly a classmate, so that he or she might help you identify and fix a bug.
-
Sharing a few lines of your own code online so that others might help you identify and fix a bug.
-
Submitting the same or similar work to this course that you have submitted previously to this course, CS50 AP, or CS50x.
-
Turning to the course’s heads for help or receiving help from the course’s heads during the quiz or test.
-
Turning to the web or elsewhere for instruction beyond the course’s own, for references, and for solutions to technical difficulties, but not for outright solutions to problem set’s problems or your own final project.
-
Whiteboarding solutions to problem sets with others using diagrams or pseudocode but not actual code.
-
Working with (and even paying) a tutor to help you with the course, provided the tutor does not do your work for you.
Not Reasonable
-
Accessing a solution to some problem prior to (re-)submitting your own.
-
Asking a classmate to see his or her solution to a problem set’s problem before (re-)submitting your own.
-
Decompiling, deobfuscating, or disassembling the staff’s solutions to problem sets.
-
Failing to cite (as with comments) the origins of code or techniques that you discover outside of the course’s own lessons and integrate into your own work, even while respecting this policy’s other constraints.
-
Giving or showing to a classmate a solution to a problem set’s problem when it is he or she, and not you, who is struggling to solve it.
-
Looking at another individual’s work during the test or quiz.
-
Paying or offering to pay an individual for work that you may submit as (part of) your own.
-
Providing or making available solutions to problem sets to individuals who might take this course in the future.
-
Searching for or soliciting outright solutions to problem sets online or elsewhere.
-
Splitting a problem set’s workload with another individual and combining your work.
-
Submitting (after possibly modifying) the work of another individual beyond the few lines allowed herein.
-
Submitting the same or similar work to this course that you have submitted or will submit to another.
-
Submitting work to this course that you intend to use outside of the course (e.g., for a job) without prior approval from the course’s heads.
-
Turning to humans (besides the course’s heads) for help or receiving help from humans (besides the course’s heads) during the quiz or test.
-
Viewing another’s solution to a problem set’s problem and basing your own solution on it.