/tfjs-coco-ssd

Node-RED node for tensorflowjs coco ssd

Primary LanguageJavaScriptApache License 2.0Apache-2.0

node-red-contrib-tfjs-coco-ssd

platform

A Node-RED node for Object Detection using TensorFlowJS CoCo SSD.

NOTE: The Tensorflow.js library will be installed automatically. However Tensorflow.js is only available on certain OS/Hardware/processor combinations. Therfore it might not automatically work on all platforms, if you are unlucky...

Install

Either use the Node-RED Menu - Manage Palette option, or run the following command in your Node-RED user directory - typically ~/.node-red

npm i node-red-contrib-tfjs-coco-ssd

Overview

This node runs the CoCo Single Shot object detector on a jpg image, delivered via an msg.payload in one of the following formats:

  • As a string, that represents a file path to a jpg file.
  • As a buffer of a jpg.
  • As an https url that returns a jpg.

The CoCo-ssd model is loaded locally so it should work offline.

The model is currently trained to recognize the following object classes in an image:

person, bicycle, car, motorcycle, airplane, bus, train, truck, traffic light, fire hydrant, stop sign, parking meter, bird, cat, dog, horse, sheep, cow, elephant, bear, zebra, giraffe, backpack, umbrella, handbag, tie, suitcase, frisbee, skis, snowboard, sports ball, kite, baseball glove, skateboard, surfboard, tennis racket, bottle, wine glass, cup, fork, knife, spoon, bowl, banana, apple, sandwhich, orange, broccoli, carrot, pizza, donut, cake, chair, couch, potted plant, bed, dining table, toilet, tv, laptop, mouse, remote,, keyboard, cell phone, microwave, oven, toaster, sink, refrigerator, book, clock, vase, scissor, teddy bear, hair drier, toothbrush

Node usage

The following example will demonstrate how easy it is to use artificial intelligence in a Node-RED flow, to recognize objects in images.

TIP: avoid adding too much CoCo-ssd nodes in a flow, to avoid long startup times (for loading the same model N times). So from a performance point of view, it is better to reuse a single coco-ssd node for multiple sources. Although multiple CoCo-ssd nodes allows running multiple recognitions in parallel.

Basic example

Some of the supported object types (like cars, persons, ...) are very useful in a typical IOT environment, e.g. to implement a video surveillance application in Node-RED.

The following example flow shows how to recognize these object classes in an input image. Note that this flow requires that the node-red-contrib-image-output is installed, to be able to display the analyzed jpg images!

The recognition results will be displayed in the debug node's status:

Basic flow

[{"id":"9798f509.db7bc8","type":"inject","z":"9a61955d.6927f8","name":"Group of people","topic":"","payload":"","payloadType":"date","repeat":"","crontab":"","once":false,"onceDelay":0.1,"x":260,"y":920,"wires":[["d6d7a98f.929108"]]},{"id":"d6d7a98f.929108","type":"http request","z":"9a61955d.6927f8","name":"","method":"GET","ret":"bin","paytoqs":false,"url":"https://upload.wikimedia.org/wikipedia/commons/b/b3/Team_Queerala.jpg","tls":"","persist":false,"proxy":"","authType":"","x":490,"y":920,"wires":[["3e623d1a.c9fd42"]]},{"id":"4ec7b21f.c2d45c","type":"image","z":"9a61955d.6927f8","name":"","width":"250","data":"image","dataType":"msg","thumbnail":false,"active":true,"x":920,"y":1000,"wires":[]},{"id":"14fa8ce2.fc7043","type":"debug","z":"9a61955d.6927f8","name":"","active":true,"tosidebar":true,"console":false,"tostatus":true,"complete":"classes","targetType":"msg","x":910,"y":920,"wires":[]},{"id":"2b3074e9.e13fbc","type":"inject","z":"9a61955d.6927f8","name":"Cars and persons","topic":"","payload":"","payloadType":"date","repeat":"","crontab":"","once":false,"onceDelay":0.1,"x":270,"y":980,"wires":[["fa56b166.50b0d"]]},{"id":"fa56b166.50b0d","type":"http request","z":"9a61955d.6927f8","name":"","method":"GET","ret":"bin","paytoqs":false,"url":"https://upload.wikimedia.org/wikipedia/commons/9/9d/Pedestrian_checking_before_crossing_the_road.jpg","tls":"","persist":false,"proxy":"","authType":"","x":490,"y":980,"wires":[["3e623d1a.c9fd42"]]},{"id":"fa7c8056.39de2","type":"inject","z":"9a61955d.6927f8","name":"Single car","topic":"","payload":"","payloadType":"date","repeat":"","crontab":"","once":false,"onceDelay":0.1,"x":240,"y":1040,"wires":[["bc6d8978.d30338"]]},{"id":"bc6d8978.d30338","type":"http request","z":"9a61955d.6927f8","name":"","method":"GET","ret":"bin","paytoqs":false,"url":"https://upload.wikimedia.org/wikipedia/commons/c/cb/Old-style_VAZ_car_in_Kolpino_with_USSR-time_car_number.jpg","tls":"","persist":false,"proxy":"","authType":"","x":490,"y":1040,"wires":[["3e623d1a.c9fd42"]]},{"id":"68490c5d.480394","type":"inject","z":"9a61955d.6927f8","name":"Multiple cars","topic":"","payload":"","payloadType":"date","repeat":"","crontab":"","once":false,"onceDelay":0.1,"x":250,"y":1100,"wires":[["17e6db88.6c8274"]]},{"id":"17e6db88.6c8274","type":"http request","z":"9a61955d.6927f8","name":"","method":"GET","ret":"bin","paytoqs":false,"url":"https://upload.wikimedia.org/wikipedia/commons/3/36/Movement_and_cars.jpg","tls":"","persist":false,"proxy":"","authType":"","x":490,"y":1100,"wires":[["3e623d1a.c9fd42"]]},{"id":"9b5463ca.5bc32","type":"inject","z":"9a61955d.6927f8","name":"Pedestrians","topic":"","payload":"","payloadType":"date","repeat":"","crontab":"","once":false,"onceDelay":0.1,"x":250,"y":1160,"wires":[["2666c156.8217fe"]]},{"id":"2666c156.8217fe","type":"http request","z":"9a61955d.6927f8","name":"","method":"GET","ret":"bin","paytoqs":false,"url":"https://upload.wikimedia.org/wikipedia/commons/3/3f/Pedestrian_crossing_street.jpg","tls":"","persist":false,"proxy":"","authType":"","x":490,"y":1160,"wires":[["3e623d1a.c9fd42"]]},{"id":"3e623d1a.c9fd42","type":"tensorflowCoco","z":"9a61955d.6927f8","name":"","modelUrl":"http://localhost:1880/coco/model.json","scoreThreshold":0.5,"passthru":true,"x":690,"y":920,"wires":[["14fa8ce2.fc7043","4ec7b21f.c2d45c"]]}]

All images used are freely-licensed offered by Wikimedia Commons.