AI model for computer vision and music composition
Built a custom YOLO5 AI model to detect objects in video frames and use the results to compose music. Winner of the Seeed Studio Vision challenge.
- C++
- MQTT
- Roboflow
- Python
Built a custom YOLO5 AI model to detect objects in video frames and use the results to compose music. Winner of the Seeed Studio Vision challenge.
Developed advanced advertising and tracking features for a complex Next.js codebase to support the Berliner Zeitung's monetization strategy. Co-ordination with multiple third-party vendors for custom React solutions.
Refactored and modernized the React Native codebase used in the iOS and Android mobile applications for Berliner Zeitung. Improved code maintainability, performance, and developer experience while ensuring backward compatibility.
Berlin has over 300 active art galleries and pop-up projects. Keeping track of them all can be overwhelming. This web application scrapes the gallery websites on a regular basis to provide current screenshots of the homepages. I built berlinartgalleries.de as a way of checking the emphasis and vibe of the different spaces.
Frontend development for the Deed mobile app using React Native. Specialized in accessibility improvements, ensuring that applications met WCAG standards and provided excellent user experiences for all users.
This site serves a LLM from a Flask web application to generate reviews based on natural language prompts. It makes use of 1000s of reviews from 50 years of Artforum Magazine. Art Review Generator also uses a novel queuing system to avoid overloading server resources. The overall project makes use of a wide range of machine learning techniques, including tuning GPT-2 language models and Tensorflow generation.
In the middle of a large code migration from PHP to React, Chegg called me in to help with their Math Solver (now Mathway) product. It was a high traffic destination with multiple levels of login states. Each state had different behaviors and constraints beyond presentation changes. Special attention was given to accessibility. In addition to converting Twig templates to React components with JSX, new functionality was added along with Jest unit tests.
As part of a major branding effort and integration of company wide accessibility initiatives, Oath (now Verizon Media Group Yahoo!) commissioned me to rebuild the navigation and significant sections of the website. The navigation works with screen readers and assistive controls on both mobile and desktop, using a single codebase. As a global brand, the site required legacy compatibility with older browsers as well as modern mobile and tablet contexts. Localization and marketing tracking were also high priorities.
I used Runscope and Thingsboard to prototype an IoT API for a working steam engine. With experience in API production and consumption, I wanted it to be a relevant POC for devs trying to integrate the physical world with the virtual. One of the challenges I wanted to take on is how to differentiate a hardware failure versus an API failure and then pass that response on for debugging by a dev down the line. The base IoT capability of the devices is to send MQTT messages to an external broker. Thingboard.io digests MQTT and offers distinct REST API endpoints for each device, as well as an administrative API that offers historical data queries.
Originally prototyped at the Gray Area Art Foundation Creative Code Immersive, Embers is an interactive installation built from 1250 LEDs that react to collaborative wind movement such as breath. The core of the piece is an Arduino Mega 2560, followed by 25 strands of 50-count WS2811 LEDs, 16 improved Modern Device wind sensors (Rev. P), and 300 ft. of calligraphy grade rice paper. It was debuted at the SubZERO art festival and displayed at Kaleid gallery.
The interactive division of Blackbaud, Inc. was looking for a distinctive and modern way to showcase their extensive custom design work. The challenge was to offer unique, yet responsive, layouts for each case study. Also, the information and bio pages had their own designs and interactivity needs. I used Bootstrap to build a custom Wordpress theme and tailored the CMS to offer custom content types and fields for future entry without additional development. The project entailed extensive device testing, javascript, and PHP.
After an interim redesign, DreamFactory needed a wide variety of site and platform enhancements. From simple network visualization to 42 A/B tested landing pages, I provided a wide spectrum of frontend services, including Javascript refactoring, responsive design elements, form processing, and tasteful CSS and Javascript animation. Using PHP, I modernized a legacy platform authentication flow with their changing API plaftorm needs.
The Charleston City Paper provides comprehensive coverage of the annual Spoleto Festival USA over the course of three weeks. To better serve the many out of town visitors using mobile devices, I planned, designed, and coded this fully featured HTML5 app. In addition to editorial content and complete event calendar, it offered geolocation based suggestions for dining near events. It was compatible with a broad range of devices and automatically updated with fresh content.
To follow a public art performance of animated wolves projected in neighborhoods, viewers used this GPS powered app. It was made with Python, Javascript, PHP, and MySQL. Wolf Tracker also uses OpenLayers to display a custom map with bespoke KML overlays. It was designed to be platform independent and function on a wide variety of mobile devices. The client and server components were built from scratch.