Skip to content

alexriedel1/Hand-Gesture-Recognition-in-manual-assembly-tasks-using-GCN

Repository files navigation

Hand Gesture Recognition in manual assembly tasks using GCN

This is the source code to the paper "Hand Gesture Recognition of Methods-Time Measurement-1 motions in manual assembly tasks using Graph Convolutional Networks".

@article{doi:10.1080/08839514.2021.2014191,
author = {Alexander Riedel and Nico Brehm and Tobias Pfeifroth},
title = {Hand Gesture Recognition of Methods-Time Measurement-1 Motions in Manual Assembly Tasks Using Graph Convolutional Networks},
journal = {Applied Artificial Intelligence},
volume = {0},
number = {0},
pages = {1-23},
year  = {2021},
publisher = {Taylor & Francis},
doi = {10.1080/08839514.2021.2014191},
URL = {https://doi.org/10.1080/08839514.2021.2014191}}

Make sure to have all the requirements installed via pip install -r requirements.txt. For working with all the models covered in the paper, install Pytorch Geometric Temporal.

Data

In this repository, the skeletal data is already extracted from the video data via MediaPipe Hands in /data/graphdata. For demo pruposes, you can run utils/video2landmark.py to create key points and their corresponding label from the video and annotation file in data/video_example.

You'll find the complete dataset here: https://drive.google.com/open?id=1JVPoCJdb8SNbQFLQAc1zDo0EoM6EukEC&authuser=alex.riedel%40gmail.com&usp=drive_fs Each video corresponds to a .csv file containing the annotations (e.g. 0.csv) and four .csv files containing the extracted hand keypoints in the original video, horizontally flipped video, vertically flipped video, and horizontally+vertically flipped video (=data augmentation!).

Training & Testing

Training the model can is done via train.py and the training parameters (models, lr, bs, additional joints, etc.) are defined in config.py. The training and validation split is defined in data/get_data_from_csv.py.

To get the final results using 2s-AGCN from the paper, run eval.py (either with the "Release" class or without, as defined in config.py no_release).

To inference on an example video including visualization, run inference.py.

Contact

For any questions leave a comment or contact me at [email protected]

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages