/Exercise_Recognition_AI

Developing a virtual personal fitness tracker and exercise activity recognition A.I. using computer vision and deep learning.

Primary LanguageJupyter NotebookMIT LicenseMIT

🤖📹 Building an AI for Real-Time Exercise Recognition using Computer Vision & Deep Learning 🏋️‍♂️💪

Description

In this project, I designed an AI that uses webcam footage to accurately detect exercises in real time and counts reps. OpenCV is used to access the webcam on your machine, a pretrained CNN is implemented for real-time pose estimation, and custom deep learning models are built using TensorFlow/Keras to recognize what exercise is being performed. In addition, this project includes a guided data collection pipeline which is used to generate training data for the custom deep learning models. Using my data, the LSTM model achieved an accuracy score of 97.78% and a categorical cross-entropy loss of 1.51e-3 on the validation dataset. The attention-based LSTM achieved an accuracy score of 100% and a categorical cross-entropy loss of 2.08e-5 on the validation dataset. From that point, joint angles are extracted from the pose estimation coordinates and heuristics are used to track the exercise and count reps. Finally, visualization tools are included that display joint angles, rep counts, and probability distributions.

AttnLSTM_real_time_test.mp4

Installation

  • Download this repository and move it to your desired working directory

  • Download Anaconda if you haven't already

  • Open the Anaconda Prompt

  • Navigate to your working directory using the cd command

  • Run the following command in the Anaconda prompt:

     conda env create --name NAME --file environment.yml
    

    where NAME needs to be changed to the name of the conda virtual environment for this project. This environment contains all the package installations and dependencies for this project.

  • Run the following command in the Anaconda prompt:

     conda activate NAME
    

    This activates the conda environment containing all the required packages and their versions.

  • Open Anaconda Navigator

  • Under the "Applications On" dropdown menu, select the newly created conda environment

  • Install and open Jupyter Notebook. NOTE: once you complete this step and if you're on a Windows device, you can call the installed version of Jupyter Notebook within the conda environment directly from the start menu.

  • Navigate to the ExerciseDecoder.ipynb file within the repository

Features

  • Implementation of Google MediaPipe's BlazePose model for real-time human pose estimation
  • Computer vision tools (i.e., OpenCV) for color conversion, detecting cameras, detecting camera properties, displaying images, and custom graphics/visualization
  • Inferred 3D joint angle computation according to relative coordinates of surrounding body landmarks
  • Guided training data generation
  • Data preprocessing and callback methods for efficient deep neural network training
  • Customizable LSTM and Attention-Based LSTM models
  • Real-time visualization of joint angles, rep counters, and probability distribution of exercise classification predictions

To-Do

  • Higher Priority
    • Add precision-recall analysis
    • Train networks using angular joint kinematics rather than xyz coordinates
    • Deploy AI to a web app using tools and techniques such as Flask, Docker, DevOps, and CI/CD
    • Translate AI to a portable embedded system that you can take outdoors or at a commercial gym. Components may include a microcontroller (e.g., Raspberry Pi), external USB camera, LED screen, battery, and 3D-printed case
  • Back-burner
    • Add AI features that can detect poor form (e.g., leaning, fast eccentric motion, knees caving in, poor squat depth, etc.) and offer real-time advice/feedback for
    • Optimize hyperparameters based on minimizing training time and cross-entropy loss on the validation dataset
    • Add more exercise classes
    • Add additional models. For instance, even though BlazePose is a type of CNN, there may be benefits to including convolutional layers within the custom deep learning models

Credits

License

MIT