Skip to main content

Off-the-shelf computer vision ML models. Yolov5, gender and age determination.

Project description

QuickTake

Off-the-shelf computer vision ML models. Yolov5, gender and age determination.

The goal of this repository is to provide, easy to use, abstracted, APIs to powerful computer vision models.

Models

$3$ models are currently available:

  • Object detection
  • Gender determination
  • Age determination

Model Engine

The models

Getting Started

Install the package with pip:

pip install quicktake

Usage

Build an instance of the class:

from quicktake import QuickTake

Image Input

Each model is designed to handle $3$ types of input:

  • raw pixels (torch.Tensor): raw pixels of a single image. Used when streaming video input.
  • image path (str): path to an image. Used when processing a single image.
  • image directory (str): path to a directory of images. Used when processing a directory of images.

Expected Use

Gender and age determination models are trained on faces. They work fine on a larger image, however, will fail to make multiple predictions in the case of multiple faces in a single image.

The API is currently designed to chain models:

  1. yolo is used to identify objects.
  2. IF a person is detected, the gender and age models are used to make predictions.

This is neatly bundled in the QuickTake.yolo_loop() method.

Getting Started

Launch a webcam stream:

QL = QuickTake()
QL.launchStream()

Note: Each model returns the results results_ as well as the runtime time_.

Run on a single frame:

from IPython.display import display
from PIL import Image
import cv2

# example images
img = './data/random/dave.png'

# to avoid distractions
import warnings
warnings.filterwarnings('ignore')

# init module
from quicktake import QuickTake
qt = QuickTake()

# extract frame from raw image path
frame = qt.read_image(img)

We can now fit qt.age(<frame>) or qt.gender(<frame>) on the frame. Alternatively we can cycle through the objects detected by yolo and if a person is detected, fit qt.age() and qt.gender():

# generate points
for _label, x0,y0,x1,y1, colour, thickness, results, res_df, age_, gender_ in qt.yolo_loop(frame):
    _label = QuickTake.generate_yolo_label(_label)
    QuickTake.add_block_to_image(frame, _label, x0,y0,x1,y1, colour=colour, thickness=thickness)

The result is an image with the bounding boxes and labels, confidence (in yolo prediction), age, and gender if a person is detected.

Example output: a person is detected and thus age, gender are estimated.

The staged output is also useful:

Example of the YoloV5 detection boundaries.

For a more comprehensive example directory.

Future

I have many more models; deployment methods & applications in the pipeline.

If you wish to contribute, please email me @zachcolinwolpe@gmail.com.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

quicktake-0.0.12.tar.gz (6.0 kB view details)

Uploaded Source

Built Distribution

quicktake-0.0.12-py3-none-any.whl (6.2 kB view details)

Uploaded Python 3

File details

Details for the file quicktake-0.0.12.tar.gz.

File metadata

  • Download URL: quicktake-0.0.12.tar.gz
  • Upload date:
  • Size: 6.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.4

File hashes

Hashes for quicktake-0.0.12.tar.gz
Algorithm Hash digest
SHA256 e799527932a26d3f33bacb4fdea1d3206aa380b1ce3df234f0231663b564cd7e
MD5 301321a1457808c7238aa3efa0254b06
BLAKE2b-256 eda28789cc96ff02ff5915e8226d8f6e81890e35b686325406b544a794b2dc5d

See more details on using hashes here.

File details

Details for the file quicktake-0.0.12-py3-none-any.whl.

File metadata

  • Download URL: quicktake-0.0.12-py3-none-any.whl
  • Upload date:
  • Size: 6.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.4

File hashes

Hashes for quicktake-0.0.12-py3-none-any.whl
Algorithm Hash digest
SHA256 4328c0901d9c8dad94ef02e89faffc082acac61681db0bfce3ff6a0a6dc5c155
MD5 86b70157ed24a348485eb53248232ea6
BLAKE2b-256 c3c30798dd4a9b7dc0284d6c0e447f906312a4012a47f1fd33b1c3dec26aff7c

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page