npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

agedetection

v0.1.2

Published

Testing Age detection model in TensorFlow.js

Downloads

15

Readme

Face and Age Detection

Face and Age detection model that aims to localize, identify and distinguish different faces with age prediction in a single image.

This project uses Blazeface model from Tensorflow.js models to detect faces and face-api.js age classifier to predict age.

This TensorFlow.js model does not require you to know about machine learning. It can take input as any browser-based image elements (<img>, <video>, <canvas> elements, for example) and returns an array of bounding boxes with class name and confidence level.

Usage

There are one main way to get this model in your JavaScript project : by installing it from NPM and using a build tool like Parcel, WebPack, or Rollup.

via NPM (or yarn)

npm install agedetection

or

yarn add agedetection
// Note: you do not need to import @tensorflow/tfjs here.

import * as faceage from 'agedetection';

const img = document.getElementById('img');

// Load the model.
const model = await faceage.load(PATH_TO_JSON_BLAZEFACE_MODEL, PATH_TO_WEIGHTS_FACEAPI_AGE_MODEL);

// Classify the image.
const predictions = await model.estimatefaces(img);

console.log('Predictions: ');
console.log(predictions);

API

Loading the model

agedetection is the module name. When using ES6 imports, faceage is the module.


faceage.load(PATH_TO_JSON_BLAZEFACE_MODEL, PATH_TO_WEIGHTS_FACEAPI_AGE_MODEL);

Args: PATH_TO_JSON_BLAZEFACE_MODEL string that specifies json file containing blazeface model as input of the model. This file can be an url or a locally stored file. PATH_TO_WEIGHTS_FACEAPI_AGE_MODEL string that specifies weights file containing face-api weights of age detection model as input of the model. This file can be an url or a locally stored file.

Returns a model object.

Detecting Faces with Age prediction

You can detect faces with age predictions with the model without needing to create a Tensor. model.estimatefaces takes an input image element and returns an array of bounding boxes around the face with the predicted age.

This method exists on the model that is loaded from faceage.load.

model.estimatefaces(
  img: tf.Tensor3D | ImageData | HTMLImageElement |
      HTMLCanvasElement | HTMLVideoElement
)

Args:

img: A Tensor or an image element to make a detection on.

Returns an array of classes and probabilities that looks like:

[{
  topLeft: 145,
  bottomRight: 300,
  age : 17
}, {
  topLeft: 300,
  bottomRight: 450,
  age : 25
}]