pszemraj's picture
Update README.md
8ea9d7e verified
---
license: apache-2.0
base_model: facebook/convnextv2-nano-22k-384
tags:
- image-classification
- vision
- boulderspot
- climbing
- aerial imagery
- remote sensing
- bouldering
metrics:
- accuracy
- f1
- precision
- recall
- matthews_correlation
datasets:
- pszemraj/boulderspot
---
# convnextv2-nano-22k-384-boulderspot
This is a model fine-tuned to classify whether an aerial/satellite image contains a climbing area or not.
You can find some images to test inference with [in this old repo from the original project](https://github.com/pszemraj/BoulderAreaDetector/tree/cbb22bdb3373b4b72d798dedfcb28543c0dc769d/test_images)
## Model description
This model is a fine-tuned version of [facebook/convnextv2-nano-22k-384](https://huggingface.co/facebook/convnextv2-nano-22k-384) on the pszemraj/boulderspot dataset.
It achieves the following results on the evaluation set:
- Loss: 0.0340
- Accuracy: 0.9883
- F1: 0.9883
- Precision: 0.9883
- Recall: 0.9883
- Matthews Correlation: 0.8962
## example usage
```py
import requests
from PIL import Image
from transformers import pipeline
pipe = pipeline(
"image-classification",
model="pszemraj/convnextv2-nano-22k-384-boulderspot",
)
url = "https://huggingface.co/pszemraj/convnextv2-nano-22k-384-boulderspot/resolve/main/test_img_magic_wood.png?download=true"
image = Image.open(requests.get(url, stream=True).raw)
result = pipe(image)[0]
print(result)
# image.show()
```
## Intended uses & limitations
Classification of aerial/satellite imagery, ideally with spacial resolution 10-25 cm (_i.e. for 10 cm, each pixel in the image corresonds to approx. 10 cm x 10 cm area on the ground_). It may be suitable outside of that, but should be validated as other resolutions were not present in the training data.
## Training procedure
### Training hyperparameters
The following hyperparameters were used during training:
- learning_rate: 2e-05
- train_batch_size: 16
- eval_batch_size: 16
- seed: 7890
- gradient_accumulation_steps: 4
- total_train_batch_size: 64
- optimizer: Adam with betas=(0.9,0.999) and epsilon=1e-08
- lr_scheduler_type: cosine
- lr_scheduler_warmup_ratio: 0.05
- num_epochs: 5.0
### Training results
| Training Loss | Epoch | Step | Validation Loss | Accuracy | F1 | Precision | Recall | Matthews Correlation |
|:-------------:|:-----:|:----:|:---------------:|:--------:|:------:|:---------:|:------:|:--------------------:|
| 0.1102 | 1.0 | 203 | 0.0431 | 0.9839 | 0.9840 | 0.9841 | 0.9839 | 0.8590 |
| 0.0559 | 2.0 | 406 | 0.0476 | 0.9839 | 0.9845 | 0.9858 | 0.9839 | 0.8709 |
| 0.0402 | 3.0 | 609 | 0.0464 | 0.9810 | 0.9817 | 0.9831 | 0.9810 | 0.8468 |
| 0.0334 | 4.0 | 813 | 0.0348 | 0.9868 | 0.9869 | 0.9870 | 0.9868 | 0.8846 |
| 0.0445 | 4.99 | 1015 | 0.0340 | 0.9883 | 0.9883 | 0.9883 | 0.9883 | 0.8962 |
### Framework versions
- Transformers 4.39.2
- Pytorch 2.4.0.dev20240328+cu121
- Datasets 2.18.0
- Tokenizers 0.15.2