diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..b7ff13a
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1 @@
+.DS_STORE
\ No newline at end of file
diff --git a/CS Classes vis workbook.pdf b/CS Classes vis workbook.pdf
new file mode 100644
index 0000000..8f9ea57
Binary files /dev/null and b/CS Classes vis workbook.pdf differ
diff --git a/Datavis Project.mp4 b/Datavis Project.mp4
new file mode 100644
index 0000000..9fb8692
Binary files /dev/null and b/Datavis Project.mp4 differ
diff --git a/README.md b/README.md
index 69875d8..f2a5254 100644
--- a/README.md
+++ b/README.md
@@ -1,123 +1,26 @@
-Final Project - Interactive Data Visualization
-===
+# Final Project - WPI CS Course Chart
-The key learning experience of this course is the final project.
-You will design a web site and interactive visualizations that answer questions you have, provide an exploratory interface to some topic of your own choosing, or take on a more ambitious experiment than A3.
-You will acquire the data, design your visualizations, implement them, and critically evaluate the results.
+
-The path to a good visualization is going to involve mistakes and wrong turns.
-It is therefore important to recognize that mistakes are valuable in finding the path to a solution, to broadly explore the design space, and to iterate designs to improve possible solutions.
-To help you explore the design space, we will hold events such as feedback sessions in which you propose your idea and initial designs and receive feedback from the class and staff.
+# Submission
+- All code is located in `index.html`
+- Data for the project is stored in a manually-written JSON available in `data/data.json`
-Proposals / Idea Generation
----
+# Links
+## [Live Site (GitHub Pages)](https://liamrathke.github.io/final/)
+## [Process Book](https://github.com/liamrathke/final/blob/main/CS%20Classes%20vis%20workbook.pdf)
+## [Video](https://raw.githubusercontent.com/liamrathke/final/main/Datavis%20Project.mp4)
-Submit project ideas using [this Google Form](https://docs.google.com/forms/d/e/1FAIpQLSepaCzjEq9AXwmJ8mJ-06ytkQUuLI1Z2QF5KGyhVnKaxBI-mA/viewform?usp=sf_link).
+# Features
+- Select courses in our bubble chart-based CS course picker, an alternative to the WPI CS course flowchart
+- Recommended courses (based on prerequisites) are highlighted in blue
+- Selecting a course (by clicking) will change the bubble to green, and reveal new courses that are recommended based on the selected course being completed
+- Click a selected course again to unselect it
-You're encouraged to submit many ideas-- staff will help you identify the most promising ones and possible roadblocks.
+# References
-Please stick to 1-4 folks per team.
+- Initial bubble chart adapted from https://www.webtips.dev/how-to-make-interactive-bubble-charts-in-d3-js
+- Font: https://fonts.google.com/specimen/Fredoka
+- Data sourced from the 2021-22 WPI CS course catalog and adapted for use in project
-Final Project Materials
----
-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.
-
-We 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.
-[Here](http://dataviscourse.net/2015/assets/process_books/bansal_cao_hou.pdf) are a [few examples](http://dataviscourse.net/2015/assets/process_books/walsh_trevino_bett.pdf) of process books from a similar course final.
-
-Tip: Start your process book on Day 1. Make entries after each meeting, and trim / edit as needed towards the end of the project. Many folks use either slides software (like PowerPoint) or Google Docs to make this book, as both allow for flexible layouts and export to PDF.
-
-
-### Project Website
-
-Create a public website for your project using GitHub pages or another 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 should be public if possible, unless you're running an experiment, etc.) and keep the level of discussion at the appropriate level.
-Your process book and data should be linked from the web site as well.
-Also embed your interactive visualization and your screen-cast in your website.
-If you are not able to publish your work (e.g., due to confidential data) please let us know in your project proposal.
-
-### Project Screen-Cast
-
-Each team will create a two minute screen-cast with narration showing a demo of your visualization and/or some slides.
-
-You can use any screencast tool of your choice, such as Camtasia or Loom (new and recommended).
-Please make sure that the sound quality of your video is good -- it may be worthwhile to invest in an external USB microphone-- campus IT should have some you can borrow.
-Upload the video to an online video-platform such as YouTube or Vimeo and embed it into your project web page.
-For our final project presentation day, we will show as many videos in class as possible, and ask teams to field questions.
-
-We will strictly enforce the two minute time limit for the video, so please make sure you are not running longer.
-Use principles of good storytelling and presentations to get your key points across. Focus the majority of your screencast 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.
-
-Outside Libraries/References
----
-
-For this project you *do not* have to write everything from scratch.
-
-You may *reference* demo programs from books or the web, and *include* popular web libraries like Material UI, React, Svelte, etcetera.
-
-Please *do not* use libraries on top of d3 without consulting staff, however.
-Libraries like nvd3.js look tempting, but such libraries often have poor defaults and result in poor visualizations.
-There may be exceptions.
-Instead, draw from the numerous existing d3 examples on the web.
-
-If you use outside sources please provide a References section with links at the end of your Readme.
-
-Resources
----
-The "[Data is Plural](https://tinyletter.com/data-is-plural/archive)" weekly letter often contains interesting datasets.
-
-Think of something you're interested in, go find data on it! Include data collection and processing as part of your work on this project.
-
-Requirements
----
-
-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 and screencast videos. The README must also explain any non-obvious features of your interface.
-
-GitHub Details
----
-
-- Fork the repo. You now have a copy associated with your username.
-- Make changes to index.html to fulfill the project requirements.
-- Make sure your "main" branch matches your "gh-pages" branch. See the GitHub Guides referenced above if you need help.
-- Edit the README.md with a link to your gh-pages or other external site: for example http://YourUsernameGoesHere.github.io/DataVisFinal/index.html
-- To submit, make a [Pull Request](https://help.github.com/articles/using-pull-requests/) on the original repository.
-
-Grading
----
-
-- 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 - Are your web site and screencast clear, engaging, and effective?
-Your individual project score will also be influenced by your peer evaluations.
-
-References
----
-
-- This final project is adapted from https://www.dataviscourse.net/2020/project/
+*D3 v6.7.0 is the only library used; there are no other code dependencies.*
diff --git a/data/data.json b/data/data.json
new file mode 100644
index 0000000..bc360a6
--- /dev/null
+++ b/data/data.json
@@ -0,0 +1,262 @@
+{
+ "nodes": [{
+ "id": 0,
+ "level": 1,
+ "category": "",
+ "number": "CS 1101/2",
+ "name": "Intro to Prog. Design",
+ "links": [1]
+ }, {
+ "id": 1,
+ "level": 2,
+ "category": "",
+ "number": "CS 2102/3",
+ "name": "OO Design",
+ "links": [3, 5, 9, 10, 11]
+ }, {
+ "id": 2,
+ "level": 2,
+ "category": "",
+ "number": "CS 2022",
+ "name": "Discrete Math",
+ "links": [5, 11]
+ }, {
+ "id": 3,
+ "level": 2,
+ "category": "",
+ "number": "CS 2023",
+ "name": "Systems",
+ "links": [4, 8, 13, 24, 25, 29]
+ }, {
+ "id": 4,
+ "level": 2,
+ "category": "",
+ "number": "CS 2011",
+ "name": "Machine Org/ Assembly",
+ "links": [7, 32]
+ }, {
+ "id": 5,
+ "level": 2,
+ "category": "",
+ "number": "CS 2223",
+ "name": "Algorithms",
+ "links": [6, 20, 22, 25, 27, 29, 30, 31, 33]
+ }, {
+ "id": 6,
+ "level": 3,
+ "category": "Theory & Languages",
+ "number": "CS 3133",
+ "name": "Foundations",
+ "links": [21, 23, 24, 33]
+ }, {
+ "id": 7,
+ "level": 3,
+ "category": "Systems",
+ "number": "CS 3013",
+ "name": "Operating Systems",
+ "links": [14, 15, 16, 17, 18, 19, 32]
+ }, {
+ "id": 8,
+ "level": 3,
+ "category": "",
+ "number": "CS 3516",
+ "name": "Networks",
+ "links": [14, 15, 16, 17]
+ }, {
+ "id": 9,
+ "level": 3,
+ "category": "Design",
+ "number": "CS 3733",
+ "name": "Soft Eng",
+ "links": [13, 19, 20, 34]
+ }, {
+ "id": 10,
+ "level": 3,
+ "category": "Design",
+ "number": "CS 3041",
+ "name": "HCI",
+ "links": []
+ }, {
+ "id": 11,
+ "level": 3,
+ "category": "Design",
+ "number": "CS 3431",
+ "name": "Databases I",
+ "links": [20, 34]
+ }, {
+ "id": 12,
+ "level": 3,
+ "category": "Social Imps",
+ "number": "CS 3043",
+ "name": "Social Imps.",
+ "links": []
+ }, {
+ "id": 13,
+ "level": 4,
+ "category": "Design",
+ "number": "CS 4233",
+ "name": "OO Analysis",
+ "links": []
+ }, {
+ "id": 14,
+ "level": 4,
+ "category": "Systems",
+ "number": "CS 4516",
+ "name": "Advanced Networks",
+ "links": []
+ }, {
+ "id": 15,
+ "level": 4,
+ "category": "Systems",
+ "number": "CS 4513",
+ "name": "Distributed Systems",
+ "links": []
+ }, {
+ "id": 16,
+ "level": 4,
+ "category": "",
+ "number": "CS 4518",
+ "name": "Mobile Computing",
+ "links": []
+ }, {
+ "id": 17,
+ "level": 4,
+ "category": "",
+ "number": "CS 4404",
+ "name": "Network Security",
+ "links": []
+ }, {
+ "id": 18,
+ "level": 4,
+ "category": "",
+ "number": "CS 4241",
+ "name": "Webware",
+ "links": []
+ }, {
+ "id": 19,
+ "level": 4,
+ "category": "",
+ "number": "CS 4401",
+ "name": "Software Security",
+ "links": []
+ }, {
+ "id": 20,
+ "level": 4,
+ "category": "",
+ "number": "CS 4445",
+ "name": "Data Mining",
+ "links": []
+ }, {
+ "id": 21,
+ "level": 4,
+ "category": "Theory & Languages",
+ "number": "CS 4123",
+ "name": "Theory of Computation",
+ "links": []
+ }, {
+ "id": 22,
+ "level": 4,
+ "category": "Theory & Languages",
+ "number": "CS 4120",
+ "name": "Analysis of Algorithms",
+ "links": []
+ }, {
+ "id": 23,
+ "level": 4,
+ "category": "Theory & Languages",
+ "number": "CS 4533",
+ "name": "Prog. Language Translation",
+ "links": []
+ }, {
+ "id": 24,
+ "level": 4,
+ "category": "Theory & Languages",
+ "number": "CS 4536",
+ "name": "Prog. Languages",
+ "links": []
+ }, {
+ "id": 25,
+ "level": 4,
+ "category": "",
+ "number": "CS 4731",
+ "name": "Graphics",
+ "links": [26]
+ }, {
+ "id": 26,
+ "level": 4,
+ "category": "",
+ "number": "CS 4732",
+ "name": "Animation",
+ "links": []
+ }, {
+ "id": 27,
+ "level": 4,
+ "category": "",
+ "number": "CS 4801",
+ "name": "Cryptography",
+ "links": []
+ }, {
+ "id": 28,
+ "level": 4,
+ "category": "",
+ "number": "CS 4342",
+ "name": "Machine Learning",
+ "links": []
+ }, {
+ "id": 29,
+ "level": 4,
+ "category": "",
+ "number": "CS 4100",
+ "name": "AI in IMGD",
+ "links": []
+ }, {
+ "id": 30,
+ "level": 4,
+ "category": "",
+ "number": "CS 4802",
+ "name": "Bio Visualization",
+ "links": []
+ }, {
+ "id": 31,
+ "level": 4,
+ "category": "",
+ "number": "CS 4803",
+ "name": "Bio. Data Mining",
+ "links": []
+ }, {
+ "id": 32,
+ "level": 4,
+ "category": "Systems",
+ "number": "CS 4515",
+ "name": "Computer Architecture",
+ "links": []
+ }, {
+ "id": 33,
+ "level": 4,
+ "category": "",
+ "number": "CS 4341",
+ "name": "AI",
+ "links": []
+ }, {
+ "id": 34,
+ "level": 4,
+ "category": "",
+ "number": "CS 4432",
+ "name": "Databases II",
+ "links": []
+ }, {
+ "id": 35,
+ "level": 4,
+ "category": "",
+ "number": "CS 4032",
+ "name": "(Non) Linear Systems",
+ "links": []
+ }, {
+ "id": 36,
+ "level": 4,
+ "category": "",
+ "number": "CS 4033",
+ "name": "Num. Meth. for Calc & Diff. Eq.",
+ "links": []
+ }]
+}
diff --git a/data/data.txt b/data/data.txt
new file mode 100644
index 0000000..c0d27b2
--- /dev/null
+++ b/data/data.txt
@@ -0,0 +1,33 @@
+CS 1101/2 Intro to Program Design
+CS 2102/3 Obj-Oriented Design Concepts
+CS 2022 Discrete Math
+CS 2303 Systems Prog. Concepts
+CS 2011 Mach. Org. & Assem. Lang
+CS 2223 Algorithms
+CS 3133 Foundation Of Computer Science
+CS 3013 Operating Systems
+CS 3516 Computer Networks
+CS 3733 Software Engineering
+CS 3041 HCI
+CS 3431 Database System I
+CS 3043 Social Impl. of Info. Proc.
+CS 4233 Obj-Oriented Analysis & Design
+CS 4515 Computer Architecture
+CS 4513 Distr. Computer Systems
+CS 4516 Advanced Computer Networks
+CS 4518 Mobile Computing
+CS 4404 Network Security
+CS 4241 Webware
+CS 4401 Software Security Engineering
+CS 4445 Data Mining
+CS 4123 Theory of Computation
+CS 4120 Analysis of Algorithms
+CS 4533 Programing Language Translation
+CS 4536 Programming Languages
+CS 4731 Computer Graphics
+CS 4732 Computer Animation
+CS 4801 Intro to Cryptology
+CS 4342 Machine Learning
+CS 4100 AI in IMGD
+CS 4802 Biovisualization
+CS 4803 Biological Data Mining
\ No newline at end of file
diff --git a/flowchart.png b/flowchart.png
new file mode 100644
index 0000000..274e009
Binary files /dev/null and b/flowchart.png differ
diff --git a/index.html b/index.html
new file mode 100644
index 0000000..4e463c1
--- /dev/null
+++ b/index.html
@@ -0,0 +1,267 @@
+
+
Find out which CS classes you're ready for*
+*Non-CS prerequisites not accounted for
+