Skip to content

Classifiying tigers (and other species) in camera trap images using ML, open data, open source tools and free compute resources

License

Notifications You must be signed in to change notification settings

alexvmt/tiger_classification

Folders and files

NameName
Last commit message
Last commit date

Latest commit

6239c05 · Jan 3, 2025

History

31 Commits
Dec 7, 2024
Dec 7, 2024
Dec 2, 2024
Nov 30, 2024
Oct 28, 2024
Jan 3, 2025

Repository files navigation

Tiger classification

This repository contains scripts and notebooks to build a model that can classify tigers (and other species) in camera trap images, using ML (e. g. MegaDetector), open data (e. g. LILA BC), open source tools (e. g. MEWC) and free compute resources (i. e. Colab and Kaggle).

tiger

Credentials: LILA BC, MegaDetector, own illustration.

Motivation and relevance

  • tigers are an endangered species, NGOs like the Nepal Tiger Trust protect them
  • there is no open and easy way for ecologists/researchers/NGOs to classify their camera trap images with regard to tigers
  • ML and open data/tools can help reduce the amount of manual labor when sifting through large amounts of camera trap images, looking for the needle in the haystack
  • goal: train a species classifier for Nepal (focussing on tigers) and make it available through EcoAssist

Data

Data sources

Sample and download images

Open In Colab

  1. Download image URLs and labels from LILA BC
  2. For each selected species: sample and download images, create train test split if applicable
  3. Copy images to Drive

Note: Since Colab and Drive have limited capacities, one might have to further split up the process.

Note: I found the image downloading to be much faster in Colab and Drive compared to Kaggle.

Preprocess images

Open in Kaggle

  1. Run MegaDetector on all images
  2. Snip images following mewc-snip
  3. Copy snipped images to Kaggle Output

Note: Images must have been previously downloaded to Drive via Colab and then uploaded to Kaggle (zipped folder).

Note: I found access to free GPUs much better and transparent in Kaggle compared to Colab.

Training

Open in Kaggle

  1. Use Keras Image Models
  2. Follow mewc-train
  3. Log experiments using Weights & Biases

I selected a pre-trained EfficientNetV2S with 21 mio parameters because it constitutes a good compromise between predictive performance, training time and model size. The model has been trained for 30 epochs (early stopping after 24 epochs) with 4000 images per class. The model has been evaluated on 300 images per class. Below is the resulting confusion matrix.

confusion_matrix

Other metrics can be found in the respective experiment run on Weights & Biases.

Note: There are only ~300 tiger images on LILA BC. I didn't use them in training but instead put all of them in test2 to examine how the model would potentially generalize to tiger camera trap images from another source than the tiger training images (like it would be the case with the Nepal Tiger Trust using the model on their own images through EcoAssist).

Deployment

  1. Publish model on HuggingFace
  2. Integrate and use model in EcoAssist

Join AI for Conservation Slack and WILDLABS if you're interested in using technology for conservation.

Feel free to reach out if you have feedback/ideas or would like to contribute/collaborate!

About

Classifiying tigers (and other species) in camera trap images using ML, open data, open source tools and free compute resources

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages