I'm Kaushik Iyer, a Computer Science Masters student at Cornell University. Originally from Mumbai, I'm currently based in Ithaca, NY. At present, I'm trying to make the most out of my winter break between semesters by working on personal projects, reading, and making some open source contributions. My focus is on software development, and I'm actively seeking full-time opportunities as a software developer where I can apply my skills and passion for building scalable, efficient solutions. I'm always eager to take on new challenges and contribute to innovative projects in the tech world.
I'm a software developer with a passion for backend and product development. When I'm not coding, you'll find me watching soccer, exploring new cuisines, reading books, or exploring the beautiful gorges of Ithaca. I believe in building technology that makes a difference, whether it's through optimizing system performance or creating tools that bring value to users.
About MeI just recently completed a year of internship experience as a software developer at Skima.ai, an early age startup. At Cornell, along with my courses, I'm also working as a Document Conversion Assistant for Student Disability Services, where I help in formatting word documents to make them more accessible for students with disabilities
A weekend project using Google Maps APIs to suggest places to visit. Select a country, continent, or randomize!
Note: Random results may include water bodies or remote locations.
Apart from geographical filters, you can also filter the places of interest:
After a place is selected, a maximum of 4 spots nearby are shown, with a photo and a description of it. All of the data is pulled from google maps.
(Doesn’t work for mobile screens)
Technologies: JavaScript, Google Maps API, Python
View on GitHub Live DemoThis was a personal project on which I worked at during summer 2024. Since a long time I had been wanting to develop a proper project from scratch which was not a youtube tutorial or a walkthrough. All of the ideas for this project were things that I wanted to implement. The whole backend and frontend has been done by myself, and since I like working on backend more, unfortunately the frontend aesthetics and accessibility are not upto the mark. Anyway, the frontend is in React, and backend built in python’s FASTAPI. The scores are regularly updated from a third party API through websockets, the nearby grounds are fetched by using the user’s location and Google Places API. The website also performs Google OAuth 2.0 through the frontend itself. A large part of the project also involved figuring out the hosting aspects, including getting a domain, and hosting the frontend as well as the backend folders. I eventually got a domain free for a year through name.com, hosted the frontend through cloudflare pages in their free tier, and got to host the backend in heroku for 2 years through Github’s Student Developer Pack.
Technologies: Python, React, Websockets, Full Stack Development
View on GitHub Live DemoBuilt this group project as part of Cornell’s Applications of Parallel Computers course (CS 5220), where we tackled the classic Traveling Salesman Problem using various optimization techniques. The goal was to push the boundaries of what’s possible with parallel computing.
We implemented four different approaches - from exact solutions using Brute Force and Dynamic Programming to heuristic methods like Greedy and Genetic algorithms. The real challenge was optimizing these for parallel execution using OpenMP and CUDA.
The results were pretty exciting:
The project really showcases how parallel computing can transform traditionally complex problems. We built a comprehensive testing framework to make sure our optimizations didn’t sacrifice accuracy for speed.
This was a great deep dive into high-performance computing, showing how theoretical concepts can be applied to solve real-world optimization challenges. I also attempted to solve the World TSP dataset using the CUDA version of the greedy algorithm implementation.
Technologies: C++, CUDA, OpenMP, Parallel Computing, Dynamic Programming, Python
View on GitHubI developed this project during my first semester at Cornell, as a part of my M.Eng Project for the Systems Engineering faculty. This project aims to solve some of the shortcomings of existing greentech technologies such as lack of verifiability and difficulty in tracking orders by leveraging the strengths of blockchain technology and its features of immutability, verifiability, and transparency.
And since this was a part of an academic research paper as well, extensive efforts were put into performance testing of the platform, which included performing load testing under multiple simultaneous users calling computationally intensive functionalities such as create project, and upload images. These tests were performed under different request body sizes and multiple such calls. The test suites and visualizations were custom developed in Python, primarily using modules such as asyncio, locust, and matplotlib for concurrency, load test configurations, and visualizations respectively. These were custom made because Postman’s collection run functionality did not cater to this particular use case.
Technologies: Solidity, React, Python, Smart Contracts, Ganache, Postman, Performance Testing
Developed a robust distributed key-value store that implements fundamental distributed systems concepts, progressing through multiple stages of complexity:
The project demonstrates practical implementation of distributed systems theory, focusing on:
This implementation served as a practical exploration of how production-grade distributed storage systems handle reliability and consistency challenges.
Technologies: Python, gRPC, Distributed Systems, Docker
Developed an innovative healthcare automation system combining robotics and IoT to assist medical staff in routine patient care tasks. The project integrated multiple technologies to create a comprehensive solution for patient monitoring and medication delivery. It is a line following robot, which successfully navigates across ‘+’ junctions, performs a U-turn at the end and starts sensory activity when the finger is placed. The value is updated immediately on the Blynk app’s displays, and then the robot automatically follows the same path back to the starting position.
This project took us more time than expected, since I had no prior experience in working with Arduino, or building robots from scratch, and the other group members also were assigned unfamiliar tasks. But it was a very fruitful experience, especially in the end when we saw the whole bot perform end-to-end operations.
Technologies: Arduino, NodeMCU (ESP8266), IoT, Blynk Platform, Sensors, Robotics
Co-founder at Skima
July 1, 2024
I had Kaushik as an intern for over a year at Skima, where he was deeply involved in developing our product's functionalities. Despite juggling college commitments, he was regularly present, completing tasks on time, and handling on-the-spot assignments effectively. Over the year, Kaushik progressed from minimal technical experience to independently creating end-to-end features. Kaushik’s technical proficiency, work ethic, and positive attitude will surely make him a valuable addition to any organisation.
Engineering@Skima
July 1, 2024
I worked closely with Kaushik during his year-long internship at Skima, where he quickly became key to our team. Kaushik balanced working alone and with others well. He handled backend tasks like developing our billing using the Stripe SDK, and the analytics dashboard using Elasticsearch and Sidekiq workers on his own, while also collaborating regularly with frontend, content, and testing teams to make sure everything worked together smoothly. He owned his work, keeping everyone updated about progress as well as challenges, without needing reminders. An important part of Kaushik's growth was learning to code with users in mind, which significantly improved his work quality. He demonstrated strong skills in Ruby on Rails, effectively utilizing ActiveRecord for database operations with PostgreSQL. His optimizations resulted in query speed improvements of up to 70%. I recommend Kaushik for any software development job. His technical skills, user-focused approach, and teamwork would make him valuable to any company.