Final Project
Based on material from Alex Lex, University of Utah
Description
For your final assignment in this course you will work on a project. The goal of the project is to design and implement a web-based interactive visualization that allows you to answer questions you have about some topic of your own choosing. You will acquire the data, design your visualization, implement it using modern web frameworks, and evaluate the results.
Project Team
You will work closely with other classmates in a 2-3 person project team. You can come up with your own teams and use Piazza to find prospective team members. If you can't find a partner I will team you up randomly. In general, I do not anticipate that the grades for each group member will be different. However, I reserve the right to assign different grades to each group member based on peer assessments (see below).
Project Steps
There are a few actions you have to for your final project. It is critical to note that no extensions will be given for the final project presentation and the final submission for any reason. For due dates see the schedule below. Late days may only be used for the project proposal and milestone. Projects submitted after the final due date will not be graded. Here are the project steps:
- Project proposals (treated as a homework) & announcing your project repository
- Weekly project updates
- Milestone 1 - a functional project prototype
- Final project presentations
- Final project submission & peer evaluations
Proposal
You start your project by forming your groups and letting me know what topic you are interested in exploring by submitting a project data form. Each team will only need to submit one form. In addition to the form, you will create a proposal document, addressing the following points. Use these points as headers in your document.
- Basic Info. The project title, your names, e-mail addresses, IDs, a link to the project repository.
- Background and Motivation. Discuss your motivations and reasons for choosing this project, especially any background or research interests that may have influenced your decision.
- Project Objectives. Provide the primary questions you are trying to answer with your visualization. What would you like to learn and accomplish? List the benefits.
- Data. From where and how are you collecting your data? If appropriate, provide a link to your data sources.
- Data Processing. Do you expect to do substantial data cleanup? What quantities do you plan to derive from your data? How will data processing be implemented?
- Visualization Design. How will you display your data? Provide some general ideas that you have for the visualization design. Create three alternative designs for your visualization. Create one final design that incorporates the best of your three designs. Describe your designs and justify your choices of visual encodings. You use the Five Design Sheet Methodology.
- Must-Have Features. List the features without which you would consider your project to be a failure.
- Optional Features. List the features which you consider to be nice to have, but not critical.
- Project Schedule. Make sure that you plan your work so that you can avoid a big rush right before the final project deadline, and delegate different modules and responsibilities among your team members. Write this in terms of weekly deadlines.
Each team member must submit this document on Blackboard. As a ballpark number: your proposal should contain about 2-4 pages of text, plus 5-6 pages of sketches.
Weekly Project Udpates
We will dedicate class time on Thursdays to discuss class projects. Each team will have a chance to present their progress and ask any questions they may have. You may also schedule a project review meeting either during my office hours or at a time this is convient for all team members.
Project Milestone
For your Milestone I expect you to hand in your code and your process book in it's current state (see Final Project Submission for details), and your website template.
For your Milestone you should have completed your data acquisition, or at least have a significant sample of your data. You must have your data structures in place. For example, if you plan to collect 1000 data records, but only have 200, that's fine. If you are missing one of two datasets you want to use you will loose points, since you have to have the whole structure.
You must have a working visualization prototype. You must not have all your views up and running, and it must not be completely interactive, but the direction and the content must be clear.
If you are uncertain about the scope, please contact me.
Final Project Submission
For your final project you must hand in the following items.
Process Book
An important part of your project is your process book. Your process book details your steps in developing your solution, including the alternative designs you tried, and the insights you got. Develop your process book out of the project proposal. Equally important to your final results is how you got there! Your process book is the place you describe and document the space of possibilities you explored at each step of your project. It is not, however, a journal or lab notebook that describes every detail - you should think carefully about the important decisions you made and insights you gained and present your reasoning in a concise way.
I recommend that you use Google Docs (or equivalent) for collaborative writing. I also strongly advise you to include many figures in your process book, including photos of your sketches of potential designs, screen shots from different visualization tools you explored, inspirations of visualizations you found online, etc. Several images illustrating changes in your design or focus over time will be far more informative than text describing those changes. Instead, use text to describe the rationale behind the evolution of your project.
Your process book should include the following topics. Depending on your project type the amount of discussion you devote to each of them will vary:
- Overview and Motivation: Provide an overview of the project goals and the motivation for it. Consider that this will be read by people who did not see your project proposal.
- Related Work: Anything that inspired you, such as a paper, a web site, visualizations we discussed in class, etc.
- Questions: What questions are you trying to answer? How did these questions evolve over the course of the project? What new questions did you consider in the course of your analysis?
- Data: Source, scraping method, cleanup, etc.
- Exploratory Data Analysis: What visualizations did you use to initially look at your data? What insights did you gain? How did these insights inform your design?
- Design Evolution: What are the different visualizations you considered? Justify the design decisions you made using the perceptual and design principles you learned in the course. Did you deviate from your proposal?
- Implementation: Describe the intent and functionality of the interactive visualizations you implemented. Provide clear and well-referenced images showing the key design and interaction elements.
- Evaluation: What did you learn about the data by using your visualizations? How did you answer your questions? How well does your visualization work, and how could you further improve it?
As this will be your only chance to describe your project in detail make sure that your process book is a standalone document that fully describes your results and the final design.
Code
Your web-based visualization can be implemented using any API or programming language you would like as long as it runs in modern browsers, but I will only support and answer questions regarding Processing, Java, D3 and Javascript. I expect you to write high-quality and readable code. You should strive for doing things the right way and think about aspects such as reusability, error handling, etc. Here are some guidelines specific to JavaScript code. We also expect you to document your code.
Project Website
You will create a public website for your project using GitHub pages or any other web hosting service of your choice. The web site should contain your interactive visualization, summarize the main results of the project, and tell a story. Consider your audience (the site is public) and keep the level of discussion at the appropriate level. Your process book and data should be linked from the web site as well. If you are not able to publish your work (e.g., due to confidential data) please let me know in your project proposal.
Project Presentation
Each team will do a 5 minute presantion showing a demo of your visualization and/or some slides. Focus the majority of your presentation on your main contributions rather than on technical details. What do you feel is the best part of your project? What insights did you gain? What is the single most important thing you would like your audience to take away? Make sure it is front and center rather than at the end.
Peer Assessment
It is important to provide positive feedback to people who truly worked hard for the good of the team and to also make suggestions to those you perceived not to be working as effectively on team tasks. Please provide an honest assessment of the contributions of the members of your team, including yourself. The feedback you provide should reflect your judgment of each team member's:
- Preparation - were they prepared during team meetings?
- Contribution - did they contribute productively to the team discussion and work?
- Respect for others' ideas - did they encourage others to contribute their ideas?
- Flexibility - were they flexible when disagreements occurred?
Your teammate's assessment of your contributions and the accuracy of your self-assessment will be considered as part of your overall project score.
Submission Instructions
Submission will be handled trough github. All teams must use a single shared github repository. If I cannot access your work because these directions are not followed correctly, I will not grade your work.
Store the following in your github repository:
- Code - All web site files and libraries assuming they are not too big to include
- Data - Include all the data that you used in your project. If the data is too large for github store it on a cloud storage provider, such as Dropbox or Yousendit.
- Process Book- Your Process Book in PDF format.
- README - The README file must give an overview of what you are handing in: which parts are your code, which parts are libraries, and so on. The README must contain URLs to your project websites. The README must also explain any non-obvious features of your interface.
Grading Criteria
- Process Book - Are you following a design process that is well documented in your process book?
- Solution - Is your visualization effective in answering your intended questions? Was it designed following visualization principles?
- Implementation - What is the quality of your implementation? Is it appropriately polished, robust, and reliable?
- Presentation - Is your web site and presentation clear, engaging, and effective?
Your individual project score will also be influenced by your peer evaluations.
Schedule
due 11:59 on due date
- Project proposals (due 04/04)
- Milestone 1 - a functional project prototype (due 04/13)
- Final project submission, presentation & peer evaluations (due 04/27)
Inspiration
Project Examples from:- Harvard's Visualization Course
- University of Utah's Visualization Course
- UC Berkley's Information Visualization Course
Recommended Tools
- GitHub: Great for collaborative coding
- Trello: Great for project management
- Slack: Great for communicating w/ team members
- Google Docs: Great for collaborative writing
- Open Refine: Great for data cleaning
- Data Wrangling: Great for data cleaning