This is a demo for using a machine learning algorithm to recognise webcam output, written entirely in Javascript.
To teach the machine to recognise webcam output, you can click the 'associate' button to associate the current webcam output with one of the three 'Adventure Time' images.
For example, take a few shots where you sit really close to the webcam, and associate this with the close-up of Finn. Do this a couple of times with different variations of sitting close to the camera.
When all three images have been associated with webcam output, you can click start. The machine will start analysing the webcam and decide for itself which of the three images it should show.
This algorithm is based on finding the nearest predefined points, given a new point. In the screenshot below, the color of the small dots is determined by the color of the three nearest large dots (The 'K' stands for the amount of points you want to compare).
Supervised learning means that we first associate data with a label. This is called training data. In the screenshot our training data consists of the large dots. They have an X,Y coordinate and a label (red or green).
Once you have enough training data, you can provide a fresh data set to the machine, and then ask which existing label comes closest to that new set of data. This is called classifying. Classifying always results in ONE label: the one that comes closest to the data you provided.
The mind-boggling thing is that this algorithm works just as well with more than two dimensions. In this repository we use webcam data that has 100 dimensions (10 x 10 rows of colors). As long as you provide arrays of numbers, the source can be anything - an excel sheet, a sound file, location data, etc. You could also use a 1000 dimensions for much more detailed analysis, but at some point your CPU might melt...
You can associate more than one array (a tensor) with a class. We do this in the webcam example - we provided different close-up webcam images that all need to be associated with the close-up image of Finn. This way, the machine can learn what a close-up webcam image looks like, approximately.
The javascript kNear library provides you with these functions to apply the algorithm:
// a machine that looks at the three nearest neighbours for a point
let machine = new KNear(3)
// associate this data set with the label "mylabel"
machine.learn([2,3,7,12], "mylabel")
// ask the machine which label comes closest to this dataset
let label = this.machine.classify([6,2,9,4])
To quickly build your own demo, replace all code in grid.js
with this example code. You don't need util.js, this is only used for color conversion.
import KNear from './knear'
export default class App {
constructor() {
this.machine = new KNear(3)
this.machine.learn([2,3,7,12], "labelOne")
this.machine.learn([5,9,12,16], "labelTwo")
let label = this.machine.classify([6,2,9,4])
console.log("the label for 6,2,9,4 is " + label)
}
}
new App()
To build the project you can install Parcel and then run the build command. It should also work with Webpack but then you need one of those pesky config files, and who wants that?
npm install -g parcel-bundler
npm run build
- Inspired by Machine Learning for Artists
- Uses the K-Nearest-Neighbour javascript library kNearJS
- K-nearest-neighbour on Wikipedia