Skip to content

Latest commit

 

History

History
103 lines (66 loc) · 3.38 KB

README.md

File metadata and controls

103 lines (66 loc) · 3.38 KB

The Creation of Swordle: Building a CNN Classifier with Mediapipe and Keras to identify American Sign Language Fingerspelling

Introduction

As part of our final project for the 9 week Data Science bootcamp with Le Wagon, our team created a CNN classifier to identify different American Sign Language Fingerspelling letters packaged into a word game to allow the user to practice their signing in American Sign Language. We chose American Sign Language as this was the language that we were able to find the most data for, but given more resources and a longer time frame, we would have liked to source more accurate Auslan data and expanded our approach to include words as well as individual letters.

Flowchart

The above flowchart shows the process that information follows to create the prediction:

  1. Image capture from frontend camera
  2. Frontend sends image to web server via FastAPI
  3. Web server applies Mediapipe coordinate transformation to image
  4. Data is normalized and preprocessed
  5. Pre-processed data is passed to model for prediction
  6. Model predicts based on input data
  7. Prediction sent from web-server back to frontend via FastAPI

Our product is packaged across three repos:

  1. swordle (this repo containing notebooks showing model development and a service to host the trained model)
  2. swordle-streamlit-ui (a simple UI showing the prediction of a ASL letter from a photo)
  3. swordle-ui (a React UI to gamify ASL learning)

For more information on model preparation and training, please see the Summary.ipynb notebook in the notebooks folder.

Inspiration for the CNN model architecture was derived from this notebook on kaggle.

We were able to achieve results of 0.71% accuracy against our self-constructed real-world sign test set, and >90% cross-validated accuracy.


Instructions to Run

1. Clone both repos

gh repo clone cpsnowden/swordle
gh repo clone cpsnowden/swordle-streamlit-ui

2. Start web-server in swordle

With a terminal instance inside swordle:

Create VENV

pyenv virtualenv swordle
pyenv activate swordle
pyenv local swordle

Install Requirements

pip install -r requirements.txt

Start Local Fast API

make run

This starts the webserver locally.

3. Start the streamlit UI in swordle-streamlit-ui

CD into swordle-streamlit-ui

cd ../swordle-streamlit-ui

Start local API

make run_local

Connect to localhost

  • click on the link in your terminal or follow the URL presented

Development FAQ

Running Local API with New Keras Model

  1. Update .env with the path to the new model
  2. Run make run
  3. Check that you model is picked up at http://localhost:8000/info
  4. To switch production to the new model ensure you update .env.yaml

Developing on Mac

If you are developing on mac and get a runtime error using protobuf, this is due to a dependency conflict, and you can fix it by copying helper/builder.py to <your-site-packages>/google/protobuf/internal/

Deployment

This main branch of this repository is built automatically using Google Cloud Build and deployed on Google Cloud Run