Language Exchange Matchmaker
Team Size: 5
Tools: JavaScript, Node.js, React.js, EJS, HTML, SCSS, CSS, Agora.io SDK, MySQL, GitHub, Figma, Jira, Teams
Time Constraint: 8 months, May–December 2024
Role: Project Manager, Full Stack Programmer, UI/UX Designer, Document Writer, Researcher
Repository: https://github.com/shaiksaahir/JID_4203_Language_Exchange
Background and Concepts
Have you ever wanted to learn a new language, but struggled to get engaged with the learning process? Our Korean Language Exchange website seeks to resolve this problem by giving users the opportunity to study and learn together, enhancing their personal connection to the language and the process. This is accomplished through demographic matchmaking and video calling, among other features that enhance the user experience. Our users will gain a deeper, more personal understanding of the Korean and English languages through these cross-cultural connections and practices.
This was my Junior Design project at Georgia Tech. We developed the project in its third iteration over the course of two semesters under a client. The course’s intended purpose was to introduce us to a work environment outside of college, similar to what you might see at a computer science company. It included client and team charters, designing/drafting, researching users, LoFi and HiFi prototyping, an Agile development cycle across six sprints utilizing Jira, documenting every aspect of the project, writing memos, and other smaller duties.
Our client was an associate professor of Korean in the School of Modern Languages at Georgia Tech. This was rare among our peers, as many other teams’ clients were outside of the college, but it did present us with a very unique project. Georgia Tech has an exchange program with Yonsei University where the “exchange” is students of each school having the opportunity to study abroad. It is an amazing way for students of each school to learn the culture of the other school and country. Our client is one of the key figures in this exchange program, and he is also the head professor of Korean 1001: Elementary Korean 1. He recognized that learning a language by reading off of slides or flashcards does not get anyone engaged or culturally knowledgeable about the language and its practices. He sought to use the exchange program as a way to “exchange” languages. Rather than the typical language learning practices, he envisioned students studying Korean at Georgia Tech engaging with students studying English at Yonsei University and exchanging their culture alongside the languages, creating a much more engaging and culturally rich study environment.
Learning Curve
Okay, this may be the hardest project I have ever worked on. It was dang well at least the longest! Multiple factors contributed to the challenge of this project, pushing both my soft and hard skills.
As far as my soft skills were concerned, it was one of the most difficult projects I have had to manage. Let me start off by saying that I am in no way blaming my teammates for anything. Although they did challenge me on occasion, I for sure challenged them as well. We struggled as a team I assure you. It was primarily just the situation of our project. Iterating on a project over the course of eight months is a lot. I recognize that this is nothing compared to the length of projects I may work on in future jobs, but it was especially a struggle when we were the third iteration of the project with no documentation to look back on, hardly any of the core ideas of the project were things we had a say in, the actual course was not very friendly to continuation projects, and myself and all of my teammates had tons of other responsibilities, including other courses, internships, jobs, and even freaking getting married! All of that on top of our project responsibilities was just a lot, and I was barely able to keep it together, but it did get better over time. The beauty of having a project this length is that you get to iterate on yourself as well. I started not knowing my team well at all, especially their strengths and weaknesses as designers and developers. I assigned them to tasks that were not their forte, and it set back the project on occasion. For example, I assigned my teammate who was very experienced at MySQL to update our Agora.io features, unknowingly removing him from focusing on our MySQL for the entire course of the project. This forced another teammate to take up that responsibility; however, he was an amazing UI/UX developer, which our project desperately needed, so the MySQL work took time away from the UI/UX work. As you may can tell, I regret some of my managerial decisions… Over time, I grew to understand each of my team members and started recognizing these strengths, and by our last sprints, we were knocking tasks out a lot more efficiently. I will not take all of the credit, however, because a lot of that came down to us learning our tech stack over time.
As far as my hard skills were concerned, this was the hardest project I have ever worked on, no competition. As stated, the situation of our project was just not the best. Going into the project, we knew it was a continuation, and we assumed it would be fairly easier since a lot of the groundwork had been laid. Unfortunately, that groundwork was pretty shoddy. We had zero prior documentation which made it very difficult to work with the tech stack that we were given, especially the various APIs/SDKs we worked with. And since we worked on the third iteration, our codebase was pretty expansive. It made it very difficult to fully grasp what we were working in/with. This all resolved over time and with some extensive research. The only thing we had was the previous iteration’s repository which did not even work when we cloned it, and that rang true for many of the existing features in the project. It was extremely hard to develop new features when the previous features broke, and I hate to say that because the previous iteration did a lot of good work. One of the previous members of that iteration also told me that they inherited the project in a shoddy state as well, so it seems like it came down to no iteration having the time, ability, or objective required to get this project to a better state. I know for certain one aspect of this was the course not being super friendly to continuation projects, as I also previously stated. It seemed like every sprint we had to have new features, and because we were so focused on implementing new features and the old features just kept breaking or creating problems, we sunk further and further into a project that was simply not presentable. It all worked and we did do some good work, but it looked and functioned poorly. Thankfully, our professors recognized our struggles, and after having a difficult talk with our client where we explained how we would have to drop a feature he wanted in, we wiped our sprint 5 clean and focused solely on improving our UI and functionality. Let me tell you, it felt so great. We could actually see our hard work pay off in a fully functioning application that looks amazing. And the best part came during our Expo where multiple people, both judges and students, were very enamored by and interested in our project. When you get so sunk into a project that is beating you down, it is very hard to realize that you are making something potentially really good and interesting. It seems our hard work really paid off.
Development
The entire course/project was broken up between two semesters, with the first focused more on designing, drafting, prototyping, and researching and the second more focused on the actual implementation.
Research and User Stories
Following our team and client charters, we first created a vision statement detailing our motivation and potential users for the application. This led directly to our researching potential users, who we determined are primarily students at Georgia Tech learning Korean. This application has a lot of potential to be expanded for future languages, but that was beyond the scope of our iteration, unfortunately. We also really wanted Yonsei University students studying English to be a target audience as well, but that also fell out of scope. Because the application needed a lot of improvement work, we were primarily focused on expanding on current features or making existing features work better, so brand-new ideas and scaling the application up were not the primary objectives. I did our primary research, where I chose to do a post-event protocol on a student who previously took Korean 1001 at Georgia Tech. The main question I sought to answer was: Does this application accurately engage students in learning Korean? Since this is the third iteration, we decided that the best course of action in the progression of the application is to first understand how students react to it in its current state. The best method of achieving this was the post-event protocol since it allows us to observe students viewing the application uninterrupted as if it were the final product, and having a participant who previously took one of Tech’s introductory Korean courses can give us direct insight into what their specific needs are. We needed direct feedback on the application and this method gave us the best representation of that. The feedback we received was down the middle. On one hand, the concept really intrigued the participant and they loved how inclusive it felt. On the other hand, the participant stated what we already knew: The look and feel of the application was poor. All this told us was to strengthen what we already had, which directly influenced how we went about development starting with developing user stories. While these were the first drafts and got reset following the conclusion of the first semester, developing user stories helped our team understand exactly who we are making this application for, why they want it for, and what we need to do to meet their expectations. An example user story was: “As a user, I want to propagate a friends list so I can continue to chat with previous partners whom I connected well with.”
Minimum Viable Product (MVP)
Developing our potential users allowed us to map out our project's iteration. This was done by creating a Minimal Viable Product, which implores many Minimum Marketable Features (MMF) that connect a variety of user stories into actual goals and tasks. Like with many development cycles, this fluxuated as we went forward.
Prototyping
After we developed our MVP and figured out what we needed/wanted to do, we created both a low and high-fidelity prototype to help us visualize what we wanted the application to look like and how we wanted it to function. Since we did not create the application from the ground up, there were a lot of user interface and experience choices that had already been previously made. Our client wanted some of these changed, so when we were prototyping, we developed what we would like to turn the application into.
Pictured to the left is one of our LoFi images (for the video calling) and to the right is one of our HiFi images (for the dashboard). We performed heuristic evaluations with the HiFI prototype using Maze tasks integrated with our Figma flows.
The above HiFi prototype was rushed due to time constraints. We later iterated upon it and the new iteration became the basis for the final application design, spearheaded by our UI-inclined teammate. To the left is a picture of the application in its then original state and to the right is the new HiFi prototype. Both are of the dashboard.
Implementation
While we did implement a sprint at the end of the first semester (Sprint 1 in the MVP), all other five sprints were done through the course of our second semester. These sprints were achieved by utilizing Jira to create and assign tasks to each sprint. These tasks followed our iteration plan, which laid out the final user stories of our sprints. As project manager, it was primarily my responsibility to create and update both our Jira tasks and iteration plan as well as assign those tasks to each team member. Jira became a crucial tool for me as a project manager, allowing me to track each sprint’s progress, the progress of the application as a whole, and each team member in case anyone ran into any roadblocks or needed assistance. This also allowed me to keep our repository’s README up-to-date, efficiently documenting our entire project. These release notes in their final version can be viewed here. For the iteration plan, I initially followed very closely to our MVP, but I then went on to update it twice over the semester. The final plan is pictured below. Comparing it to our release notes, the difference between a formal user story versus what actually must be implemented is subtle but can make for a very big difference.
Our implementation was recorded in a grand design document, which I tasked myself to write. I updated it after every sprint and it thoroughly breaks down each component of our application. Unfortunately, due to time conflicts and constraints, I was unable to update the UI Design section following our Sprint 5, which is where we overhauled the user interface of the application. It does provide a very good snapshot into the original UI of the application, however. A few images of the final UI for the application can be viewed in this Google Drive folder. Our design document is viewable on our repository or through this PDF.
Since I had other writing and managerial tasks, I did not contribute as much to programming our implementation compared to my other team. All of my commits and pull requests can be viewed on our repository under my username — alrob22 — for a full breakdown, but I had two primary programming tasks. One of our biggest features is an expansive Find Friends page where users can view, search, and filter other users by name and demographics, such as age or hobby. The user determines all of these demographics when registering for a profile, as well as a profile visibility preference. This preference has two options: “Show” or “Hide.” Alongside another teammate adding that profile preference to the registration, I fully implemented its use within our application. Users with the “Show” option are listed on the Find Friends page, and users with the “Hide” option are not. This was achieved by using two Axios API calls to fetch all of our users and their preferences in our MySQL database, and then before listing them out on the page, checking if their visibility preference is equal to “Show.” The other big task I did was add room selection to our video calling using Agora.io SDK. The video calling we inherited only had one call room that did not have a user cap. We determined that having multiple users in a call may take away from personalized studying and that one-on-one study calls would be a better learning environment. However, that presented the problem of not allowing more than two users at a time to ever call since there was only one room. To resolve this problem, I thought of having different call rooms. A user first types in a number (or doesn’t type in anything for the original default room) and that number gets passed to our Video Room JavaScript file where a big if-else statement changes the Agora room name and ID based on the number before a user ever joins a room. After that, I put a two-user cap on every room by checking how many user IDs are active in a determined call room.
Expo
The culmination of our project was the Computer Science Junior Design Capstone Expo held on December 2, 2024. We had the amazing opportunity to showcase our application to students, professors, and judges alike, and it seemed to be a hit! Below are some images related to the expo.
A picture of our table and us mid-demonstration (I am on the very far left looking very professional (I hope)):
Here are pictures of our fantastic promotional fliers my more visual-design-oriented teammate made (the term LinguaLink comes from the previous iteration):
Takeaways
This was a tough project, but it hardened many of my skills. By the end of the project, I became a project manager who knew each team member’s strengths and weaknesses, and hell, I could even tell who wrote what code after a whole semester of staring at it. I was also a very good public speaker, taking center stage during multiple presentations, demos, and especially our expo. Presenting in front of professors and peers is one thing, but I had to speak in front of judges and those who did not know a lick about our project at the expo, and I kicked ass. This project’s tech stack beat me sideways throughout the entire implementation. It really taught me the importance of knowing what you are working with/on, i.e., documentation. But through persistence, my teammates and I all became maybe a little too comfortable in our codebase by the end of the project.
Most importantly, this was a snapshot into a more corporate work environment, and I think the takeaways form that are pretty obvious. This is by far one of the most important projects I have ever worked on in my development as a professional programmer.
Jumping Into GeoGuessr
Team Size: 4
Tools: JavaScript, D3.js, HTML, CSS, Visual Studio, Excel, Git, GitHub
Time Constraint: 2.5 months, October–December 2024
Role: Programmer, Data Visualization Designer, Process Book Writer
Background and Concepts
Jumping Into GeoGuessr is a data visualization website that teaches current or prospective GeoGuessr players how to better themselves at the game through pattern recognition. This was achieved using D3.js to create various interactive visualizations depicting a data story. Once these visualizations were created, my teammate Sean integrated them into a grand design using Vue and deployed the website through GitHub Pages. Sean was the head architect of this project, pitching the initial idea, guiding us through the best data attributes to use, knowing what was required to deploy this to GitHub Pages, and creating an intriguing narrative for the final website. He is an active fan of GeoGuessr and recognized while he was playing the game that pattern recognition is the key to success, allowing anyone regardless of experience to succeed in the game. He wanted to teach this to players, and it works very well too! I am not a huge player of GeoGuessr but my results became exponentially better after reading through our finished website.
Development and Learning Curve
This was the first project I had (in way too long) where I was not a manager in any way. As stated, my teammate Sean was the lead for this project, so most of my development came from what he needed me to do or how I could expand his ideas. Which, again, I was more than happy to do. Man, it felt nice not having to look over everything and everyone, but honestly, it was a bit of an adjustment. I love managing and would love to do it again, but I think I needed a project where I was not the manager to bring me back down to level with the rest of my peers. It reminded me how to follow orders instead of giving them. It was also an adjustment because this was not my idea. While developing this, I was working on two other projects where we were developing and iterating on my ideas, so it was strange not knowing exactly how I wanted the project to turn out. But again, it was refreshing and pushed me to think about bettering my other teammates’ ideas.
The project had three phases: Proposal, Ideation and Design, and Implementation and Evaluation. The Proposal phase consisted of creating an abstract and presenting potential data sources, with the ones we used linked at the bottom of the website. The abstract of our proposal is as follows:
GeoGuessr is an online game where you are placed in a random place on Google Street View with the goal to find where in the world you are. With our project, we seek to show some essential insights that can help with pinpointing your location, such as license plates, flag colors, road signs, languages, and more. Understanding the Google Street View coverage is also important for knowing which countries you are more likely to be placed in, since some have more dense information than others. In addition, understanding the different community map sets can help know what locations are overrepresented, and where there can be improvement in picking locations. Creating data stories and interactive visualizations from this data has the potential to improve creating community resources for different levels of play. We intend to create a visual story that starts with the most general, useful, and easy-to-learn clues(such as website top level domains, i.e. .mx for Mexico), and gradually moves down into more in-depth clues, such as road bollard shapes & colors, or which copyright years do not appear in certain regions, which is often useful for determining between two similar countries. There are many resources out there made by intensive research from the Geoguessr community that are only available as a Google doc. These can be compiled and used for higher quality visualizations to better encode the data they are trying to convey.
The Ideation and Design phase consisted of multiple steps, all to create the initial designs and sequence that we would then use as a basis for our final visualizations. We first outlined a project plan, detailing our target audience (GeoGuessr players that want useful data to better their geographical recognition and understanding), interesting questions about our data to inform what data we should focus on (such as: How can we most effectively determine our location from a common type of sign, such as a pedestrian crosswalk sign?), what data we have access to, and if we need to perform any data cleanup. We then performed a data exploration by taking our datasets and creating initial visualizations through them, typically using Excel, and jotting down any and all insights we gathered. Although we did find many useful insights, we needed a main insight to tie together our data story and centralize it with a theme.
While many novice players may believe that getting good at GeoGuessr requires a big time commitment, many top players got good at the game while putting much less time into the game than others; understanding and recognizing geographical patterns can greatly assist in getting good at identifying locations in GeoGuessr.
We chose this to be our main insight as it is a good segway into the rest of our data, or a good climax understanding built upon insights from the rest of our data. It can be understood as the call to action within our narrative or the big aha moment. We tell our audience that they too can become good at GeoGuessr without having to put in a huge time commitment, like what many other games require, and then we show them the geographical patterns from the rest of our data to help them build their pattern recognition and strategy, which helps them understand the skills they can implement to be good at GeoGuessr.
I then created a storyboard based on the main insight:
Following the storyboard, we then created sketches to fill each part of the storyboard. Below is my first out of eight sketches, which may be recognized from the website. This was initially designed for the Main Message part of the storyboard. It is a design for a mapping of a player’s rating over their XP in GeoGuessr, showcasing how even highly rated players are not as experienced in the game as one may think.
Taking 32 total sketches and ordering them in a sequence is a lot of work, but we streamlined it by voting on our favorite designs and mapping them out in an affinity diagram. This narrowed down the designs for the sequence by nearly 3/4ths. Sean created the sequence following our data story, and even though a few designs got left out, the sequence remains in the final website. It does differ a little from the storyboard, but it more closely resembles the flow from the original proposal, allowing the main insight to be the call to action to learn the rest of the data.
The Implementation and Evaluation section details our prototypes and the development of the final website. I developed our initial visualization, based directly on the above design. For this phase of our project, I tasked myself with finishing up our Process Book, primarily cleaning it up and detailing this phase. This is what I wrote about my contribution:
Beginning our sequence was the Player Rating Vs. XP Progression graph. This charted out a GeoGuessr’s lifetime rating and XP using this dataset: https://www.kaggle.com/datasets/mattop/geoguessr-user-dataset/data. While giving us the two attributes we required for the graph (rating and a player’s lifetime experience points), the dataset also detailed many demographic and statistical information about the players, both inside and outside of the game. This inspired us to further develop our initial design, creating the difference in our data exploration versus our final sketches, as we wanted to give our users a story about the differences and similarities in player demographics. We wanted our users to see, for example, that someone is also from the same country they are and possesses grand knowledge of the world, which would hopefully be inspirational to some extent. While our final sketch of this graph did showcase our initial design, we decided to create a more clean design with some drafts below.
We decided to use the top-right design so we could limit our data while presenting it in its own designated area. While the used dataset is very impressive and useful, it already ran us into the problem of having too much data, making it extremely difficult to load, debug, and integrate into code, especially within the website. Thankfully, deciding what attributes to keep was not a huge issue; it was simply a matter of what story we wanted to tell our users about the differences in player demographics. We did not want to give too much information nor did we want to give any unnecessary information for the sake of our overall theme, like statistics in the multiplayer game modes. The bottom left of the drafts showcases some initial decisions regarding what to include.
Here is the graph before adding in player demographics:
Here is the graph after adding in player demographics:
Here is the initial website version:
After receiving feedback, we ultimately decided to use D3’s tooltip mechanic and placed the information near where the user hovers so the player would not have to move their eyes elsewhere, allowing for a more streamlined and seamless information depiction. We had to update the tooltip, though, since the original version gave us issues when we first integrated it into the website. The final website version fixes design bugs and corrects the name.
Takeaways
This project taught me many skills. For hard skills, it taught me how to properly visualize data, and how to use Excel, D3.js, and even pencil and paper to do so. For soft skills, it helped me become a stronger team member. Being a leader for so long, I forgot how important a simple team member is.
Murder at Buzzard’s Roost
Team Size: 4
Tools: HTML, CSS, Javascript, Visual Studio Code
Time Constraint: 1.5 months, November–December 2022
Role: Project Lead, Lead Programmer
Background
Created under the direction of Dr. Jay Bolter, Murder at Buzzard’s Roost is a point-and-click murder mystery game. The main plot revolves around someone murdering a guest in a lonely cabin that the player, a detective, just happens to be staying at. The player must solve the mystery by interacting with the other guests and staff to gather all of the knowledge needed to ace the final quiz at the end.
This was the first game I ever worked on. Thankfully, it was on a smaller scale to ease me into the world of game development, but being the project manager held its own stresses. As the project manager, I made sure every team member stayed in contact, was frequently updated about the overall status of the game, and had a role that best suited them. I was also the lead programmer, writing roughly 90% of the game’s code and providing most of the logic/ideas that went into the code. My implementation of hidden dialogue options in the game remains one of my favorite—and the trickiest—ideas I have ever put into code.
Takeaways
Finally helping to create a game was an amazing experience. It helped hone my HTML, CSS, and Javascript skills while allowing me to craft and critique my management skills in a game development space.
Twitterbot
Team Size: 4
Tools: Javascript, Twitter API, Node.js, Visual Studio Code
Time Constraint: 1.5 months, October–November 2022
Role: Programmer
I had the fun experience of working on a Twitterbot with a team who let me theme it after Emperor Palpatine from Star Wars. Using the Node.js platform, all we had to do was type in “node bot.js” into our terminal and our Palpatine retweeted his favorite Death Star or Emperor posts, tweeted his favorite catchphrase or photos, and liked similar tweets.
This project helped me further understand Javascript and APIs and their usage in programming.
Recreation of Lion
Team Size: 3
Tools: HTML, CSS, A-Frame, Visual Studio Code
Time Constraint: 1 month, September 2022
Role: Programmer
The artwork on the left/top is Lion by Auguste Herbin (source), and on the right/bottom is my team and I’s 3D recreation of the piece using A-Frame, a virtual reality framework.
This project helped me familiarize myself with front-end development and the implementation of frameworks into programming.
Do not hesitate to reach out to me for more details!