Skip to content

Shapeways is a multimedia sandbox at the bleeding edge of art and technology. It's a real-time music and art generator that responds to your movements. It's an audiovisual composition shaped by the user, made possible by machine learning. Powered by React, Google Magenta.js/music, ml5 Posenet, Tone.js, and p5.js.

Notifications You must be signed in to change notification settings

whateverSpace/shapeways-frontend

Repository files navigation

shapeways

6 Shapeways is a multimedia sandbox at the bleeding edge of art and technology. It's a real-time music and art generator that responds to your movements. It's an audiovisual composition shaped by the user, made possible by machine learning. It's an exploration of new forms of expression and interaction and new approaches to user interface. Shapeways is interactive installation art for the home, engineered with cutting edge technologies, including:

Requires Google Chrome or a Chrome-compatible browser like Brave, and a webcam.

Watch someone interact with Shapeways

Play Shapeways Now

Slides from Ben Beekman's presentation at Front End Small Talk meetup, 'Do Androids Dream of Electric Art'

Instructions

Make sure to allow access to your webcam when prompted.

Once the models have loaded, press spacebar to start the musical accompaniment. Spacebar will then toggle between pause and play mode. Everything else can be controlled without touching your computer, using your webcam. For best results, stand 3-6 feet from webcam in a well-lit room. 1

You will see green dots onscreen where Shapeways thinks your wrists are, and other dots representing your eye and nose location. Shapeways divides what the camera sees into six segments in a three by two grid. This grid, and the location of your wrists and nose within it, can be used to influence the neural-net-generated melodies played by the two instruments, in addition to sculpting the visual experience. 2

  • Use your wrists in different segments to trigger sounds and move shapes.
  • Bring them together, spread them apart, leave them in the middle, experiment!
  • The background color that slowly fills in segments is changed by the segment your nose is in.
  • Stand 3-6 feet away from the camera for optimal tracking. 3

How It Works

Shapeways uses ml5's PoseNet machine learning model to track your wrists and heads, and maps them to one of the six segments of the screen. Various calculations are made and passed to both the visual and musical components. On the musical side, "performance seeds" are generated. These seeds are made up of notes whose pitch and durations are defined by calculations relating to your wrist and head location relative to those six segments of the screen. 4

Those musical performance seeds are then sent in API calls to Magenta.js MusicVAE and MusicRNN checkpoints. The Magenta API responds with several bars of musical performance data inspired by the seeds. These responses are used to create unpredictable but musically related short melodic loops, which are played over two different Tone synths, routed through Tone.js filters and finally to the audio output. These short loops are played until the camera detects a head or hand in a different segment of the screen. In that case, a new seed is crafted with the new values, and new melody and counterpart are created.

7 On the visual side, P5.js is used to dynamically render and manipulate glowing 3d boxes that leave colorful ghost trails behind as they change. Different movements of your wrists causes the boxes to rotate, change color, spawn and destroy copies, change dimensions, and more. Your nose's location changes the color of the background that slowly fills parts of the screen. The end result is a meditative audiovisual experience that responds to your movements and gestures with melodic and visual strokes inspired by your changes.

How We Built It

We built our app using React components to isolate concerns, efficiently handle state management and respond to changes in tracking. We used ml5 PoseNet to track pose information, MagentaJS for generating music using machine learning, Tone.js to handle music timing, synthesis, and processing, and p5.js for real-time dynamic animation.

Challenges We Ran Into

Above all else, I would say one of the biggest challenges was figuring out how to do everything we wanted using only the camera tracking data for input. It took a lot of calculation, creative coding and experimentation to dynamically generate music seeds that produced the quality of generated music we were looking for. Once we were happy with the generated music, figuring out how to create the right amount of variety and repetition based on your movements or lack thereof was quite challenging, or at least it took a lot of trial and error.

Accomplishments That We're Proud Of

We had an ambitious and fairly abstract vision for the project, but we did a great job of communicating and collaborating to ensure a smooth chain from camera input to audiovisual output. Getting all of the cutting-edge technologies to play nicely together took no small amount of work.

What We Learned

We learned a lot about machine learning, finding creative ways to translate data into synaesthetic experiences, music theory, and creative engineering of dynamically generated, interactive, and semi-intelligent art.

What's Next for Shapeways?

We have many plans. We already set up functions to change keys and melodies, but didn't implement gestures to trigger those changes. We're also planning to add sensor-influenced and constantly changing low end drone noises to the sonic experience. And we'd like to have the effects chain parameters change as tracking data changes, not just the synths themselves.

Developer Instructions

Clone the repository, then navigate to the directory in the terminal and input npm i then npm run start.

About

Shapeways is a multimedia sandbox at the bleeding edge of art and technology. It's a real-time music and art generator that responds to your movements. It's an audiovisual composition shaped by the user, made possible by machine learning. Powered by React, Google Magenta.js/music, ml5 Posenet, Tone.js, and p5.js.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published