Teachable Machine Node empowers you to load any image classification model trained with Google's Teachable Machine tool in a Node.Js project.
Teachable Machine makes AI easy for everyone, by offering a fast and fun way to train a real TensorFlow.js Machine Learning Models without any coding required. You can train the computer to recognize images, sounds, & poses, using your camera or your own dataset. Check The Awesome Teachable Machine List full of useful resources and amazing projects to gain some cool ideas.
For now, Teachable Machine Node holds support only for image models, but we won't stop here. Check out the Roadmap of what comes next!
- Install using npm
npm install @sashido/teachablemachine-node
- Install using yarn
yarn add @sashido/teachablemachine-node
-
Gathering samples is the fundamental first step to your Teachable Machine Model. Use your camera to collect data or upload some preselected images.
Check the Advanced
option for further insights on the model performance and accuracy. Once certain it returns valid results, hit the Export option.
- Make sure that you select Tensorflow.js format when exporting. That way your model will be uploaded (for free) and you will receive an access URL.
- Pass the URL to the teachablemachine-node to load the model. Next, let it have the image and call
classify
to get the predictions. You can pass the image URL or deliver it in base 64. It's up to your preference.
SashiDo's team is full of notorious animal lovers and no wonder the sample model was trained to recognize dog pics from other images. 😊 We've collected a dataset of more than 2000 images of dogs, cats, horses, other animals, people and everyday objects and uploaded them into two different classes with Teachable Machine.
A big shoutout to Unsplash.com as a great platform for free photos. Check it out in case you're just starting and do not have raw data yet.
You can load our Is_It_A_Dog model using this URL and following the example below:
https://teachablemachine.withgoogle.com/models/r6BBk-hiN/
Here's a quick example of how to load the model in your project.
const TeachableMachine = require("@sashido/teachablemachine-node");
const model = new TeachableMachine({
modelUrl: "https://teachablemachine.withgoogle.com/models/r6BBk-hiN/"
});
model.classify({
imageUrl: "https://media-blog.sashido.io/content/images/2020/09/SashiDo_Dog.jpg",
}).then((predictions) => {
console.log("Predictions:", predictions);
}).catch((e) => {
console.log("ERROR", e);
});
And the alternative for all Express fans.
const express = require("express");
const TeachableMachine = require("@sashido/teachablemachine-node");
const model = new TeachableMachine({
modelUrl: "https://teachablemachine.withgoogle.com/models/r6BBk-hiN/"
});
const app = express();
const port = 3000;
app.get("/image/classify", async (req, res) => {
const { url } = req.query;
return model.classify({
imageUrl: url,
}).then((predictions) => {
console.log(predictions);
return res.json(predictions);
}).catch((e) => {
console.error(e);
res.status(500).send("Something went wrong!")
});
});
app.listen(port, () => {
console.log(`Example app listening at http://localhost:${port}`);
});
In the long run, we will add more options, so you can train and load all kinds of Teachable Machine Models.
-
Add support for Pose Models.
-
Add support for Audio Models.
-
Add support for Gifs.
-
Add support for Videos.
We would love to have your opinion which's the one you would like to see supported first. Don't be shy and drop us a line at [email protected].
Contributors of any kind are welcome. Share your awesome improvements in a pull request and join our mission to make Machine Learning more affordable & accessible!
Copyright © 2020, CloudStrap AD. See LICENSE for further details.