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
-
YoloV5
: Object detection. This forms the basis of the other models. Pretrained onCOCO
. Documentation here -
Gender
:ResNet18
is used as the models backend. Transfer learning is applied to model gender. The additional gender training was done on the gender classification dataset, using code extract from here. -
Age
: The age model is an implementation of theSSR-Net
paper: SSR-Net: A Compact Soft Stagewise Regression Network for Age Estimation. ThepyTorch
model was largely derived from oukohou.
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:
yolo
is used to identify objects.IF
a person is detected, thegender
andage
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.
.
The staged output is also useful:
.
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
Built Distribution
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
Algorithm | Hash digest | |
---|---|---|
SHA256 | e799527932a26d3f33bacb4fdea1d3206aa380b1ce3df234f0231663b564cd7e |
|
MD5 | 301321a1457808c7238aa3efa0254b06 |
|
BLAKE2b-256 | eda28789cc96ff02ff5915e8226d8f6e81890e35b686325406b544a794b2dc5d |
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
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4328c0901d9c8dad94ef02e89faffc082acac61681db0bfce3ff6a0a6dc5c155 |
|
MD5 | 86b70157ed24a348485eb53248232ea6 |
|
BLAKE2b-256 | c3c30798dd4a9b7dc0284d6c0e447f906312a4012a47f1fd33b1c3dec26aff7c |