Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/a11ywatch/tensornet
MobileNet + ImageNet predictions in nodejs without node-canvas
https://github.com/a11ywatch/tensornet
tensorflow tensornetwork
Last synced: 8 days ago
JSON representation
MobileNet + ImageNet predictions in nodejs without node-canvas
- Host: GitHub
- URL: https://github.com/a11ywatch/tensornet
- Owner: a11ywatch
- License: mit
- Created: 2022-06-19T14:42:13.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2023-08-05T22:19:59.000Z (over 1 year ago)
- Last Synced: 2024-09-25T16:05:06.728Z (about 2 months ago)
- Topics: tensorflow, tensornetwork
- Language: TypeScript
- Homepage:
- Size: 365 KB
- Stars: 0
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# tensornet
[![Build and lint](https://github.com/A11yWatch/tensornet/actions/workflows/tests.yml/badge.svg?branch=main)](https://github.com/A11yWatch/tensornet/actions/workflows/tests.yml)
pure js classify base64 between Tensorflow Models
## Installation
```
npm i tensornet --save
```## Getting Started
Make sure to have `@tensorflow/tfjs-core` installed and a valid tensorflow backend set.
You also need to pick between [sync package jpeg-js](https://github.com/jpeg-js/jpeg-js) or [async package sharp](https://github.com/lovell/sharp).```sh
# pure js full sync blocking installation
npm i @tensorflow/tfjs-core jpeg-js
# if going to use async non blocking
npm i @tensorflow/tfjs-core sharp
```View the [classify.test.ts](./__tests__/classify.test.ts) file for an example setup.
```ts
import { classify, classifyAsync } from "tensornet";
import { setBackend } from "@tensorflow/tfjs-core";
import "@tensorflow/tfjs-backend-wasm";await setBackend("wasm");
const classification = await classify(mybase64); //using jpeg-js.
// or use native sharp for increased performance 2x
const classificationA = await classifyAsync(mybase64);
// output example
// [
// {
// className: 'Siamese cat, Siamese',
// probability: 0.9805548787117004
// }
// ]
```## Why
The benefits of using pure js to calc the image is in a couple areas:
1. size and portablity required is drastically less since you do not need `cairo` or any of the native img dev converters.
1. speed is also faster since the calcs are done at hand without needing to bridge any calls.
1. can use tensors in worker threads - allows for properly using Tensorflow wasm backends in an API service 🥳.The TF models are checked in localy.
## Benchmarks
Examples of some test ran on a mac m1(64gb):
| Name | chars | size | sync | async |
| ---- | ----- | -------- | ----- | ----- |
| jpeg | 26791 | 26.16 KB | 100ms | 50ms |