Fri Oct 11 2019Sound Maze: Interactive Machine Learning Game

GitHub Repo

This game allows user to interact and control with various sounds of everyday things.

I have this idea of creating my own little Guitar Hero game. In this project, I am exploring the capabilities of web development and machine learning, and checking how can I implement a solution using the sounds of everyday items.


Open the Weki project with Wekinator by double clicking on WekinatorProject.wekproj

Install Packages npm install

Run the Node servernode src/app.js

From your browser, go:

A guitar sound will let you go right, if you hit a plastic lid with a metal spoon that means going up. Hitting on a metal object with a spoon will suggest going down. You can also whistle to go left!


The Wekinator is free, open-source software created by Rebecca Fiebrink. It allows anyone to use machine learning to build new musical instruments, gestural game controllers, computer vision or computer listening systems, and more. For more information, visit here:


I literally used random sounds and recorded each of them individually for several hundred times. Things/sounds I used:

  • Salt shaker
  • Various kinds of IKEA plates, eventually decided on metallic ones
  • Ceramic mug
  • Plastic blender lid
  • Guitar
  • Coughing --> I don't recommend this one since you might have a sore throat after a while
  • Clapping
  • Whistling
    • notion image
      notion image


I tried a bunch of algorithms to evaluate to sound accuracy. I get the best results with k-Nearest-Neighbour and AdaBoost. I used three input values to classify the sound. These are:

  • Peak frequency (aka pitch)
  • Spectral centroid
  • RMS

I filtered the OSC data by its RMS value so that I can get the precise vibration of the sound.

The output has four classes, which are primarily up, down, left, right.


The game is developed on p5.js library itself; it receives the input/output values via a WebSocket built with Node.JS. It is also possible to use WASD keys, though I left it for only debugging purposes.

notion image

Little demo

(I know this gif does not actually show anything, but I was extremely lazy creating the same setup and take a video of it)


Stay up-to-date

Subscribe to my newsletter and stay up-to-date. Why not? It's free.