Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/benitomartin/birds-classification
Computer Vision (Pytorch) Birds Classification
https://github.com/benitomartin/birds-classification
efficientnet gradio jupyter-notebook python pytorch
Last synced: about 2 months ago
JSON representation
Computer Vision (Pytorch) Birds Classification
- Host: GitHub
- URL: https://github.com/benitomartin/birds-classification
- Owner: benitomartin
- Created: 2023-10-07T16:21:15.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-04-20T18:04:29.000Z (10 months ago)
- Last Synced: 2024-11-08T10:10:02.898Z (3 months ago)
- Topics: efficientnet, gradio, jupyter-notebook, python, pytorch
- Language: Jupyter Notebook
- Homepage: https://huggingface.co/spaces/bmartinc80/birds_pytorch
- Size: 5.67 MB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# BIRDS CLASSIFICATION ðĶ
![]()
This repository hosts a notebook featuring an in-depth analysis of 2 **Pytorch EfficientNet** models, along with an app deployment using Gradio. The following models were meticulously evaluated:
- EffNetB0
- EffNetB2The dataset used has been downloaded from [Kaggle](https://www.kaggle.com/datasets/gpiosenka/100-bird-species) and contains a set of 525 bird species. 84635 training images, 2625 test images(5 images per species) and 2625 validation images(5 images per species).
The app can be tested in **Hugging Face** (.py files hosted there) following this [link](https://huggingface.co/spaces/bmartinc80/birds_pytorch). Feel free to â and clone this repo ð
## ðĻâðŧ **Tech Stack**
data:image/s3,"s3://crabby-images/c4f08/c4f084e702bbe0616ebe34b9dcd84975e22c360b" alt="Visual Studio Code"
data:image/s3,"s3://crabby-images/7554e/7554e0670d90caea1686eb652d2ad4818dc65606" alt="Jupyter Notebook"
data:image/s3,"s3://crabby-images/f674e/f674e962628e905c7cd24fb8dc2bf66d94447618" alt="Python"
data:image/s3,"s3://crabby-images/f2fdd/f2fdd5d30864e34bb7077ff3640f399fce5fc56a" alt="Pandas"
data:image/s3,"s3://crabby-images/91661/91661a1745021a18258f6003f84adad02db75ecf" alt="NumPy"
data:image/s3,"s3://crabby-images/ab62b/ab62b9c29cd8b98f8b38c55324ad572277e2974c" alt="PyTorch"
data:image/s3,"s3://crabby-images/e08b0/e08b06a30b29c0e1a7008238d033daee2bf25bf6" alt="Matplotlib"
data:image/s3,"s3://crabby-images/529e4/529e408ad0a86e9e31b4d79885f8b3f1b9a5a7c3" alt="Linux"
data:image/s3,"s3://crabby-images/27317/273179ec694b6d821b72e69896f789b9458d0a3d" alt="Git"## ðŠķ Set Up
In the first stage, a set of helper functions was created in order to easily perform the modeling and prediction
- **Set seed**: Set random seeds for PyTorch operations, both on the CPU and the GPU
- **DataLoaders**: Create data loaders for training and testing datasets using PyTorch's DataLoader class
- **Writer**: SummaryWriter object for logging experiments and metrics in TensorBoard
- **Training and Testing**: Several functions for training and testing a PyTorch model
- **Plots**: Several plots including loss curve, predictions, and images## ðģ Modelling
The first approach was to train 2 Pytorch EfficientNet models (EffNetB0, EffNetB2) with **5 and 10 epochs** using the pre-trained model weights of EffNetB0 for the DataLoaders in order to establish a baseline. The **EffNetB2 with 10 epochs** showed the best performance above **93%** on the test set.
![]()
![]()
## âïļ Model Improvement
Then the EffNetB2 with 10 epochs was trained again but this time using the pretrained model weights of EffNetB2 for the DataLoaders. This time an accuracy above **95%** on the **test set** and above **93%** on the **validation set** was achieved.
![]()
## ð App Deployment
The last step was to deploy an app hosted in Hugging Face using Gradio. This app can be tested with available sample images or with your own ones.
![]()