|
--- |
|
tags: |
|
- image-classification |
|
- pytorch |
|
metrics: |
|
- accuracy |
|
|
|
model-index: |
|
- name: SDO_VT1 |
|
results: |
|
- task: |
|
name: Image Classification |
|
type: image-classification |
|
metrics: |
|
- name: Accuracy |
|
type: accuracy |
|
value: 0.8695651888847351 |
|
--- |
|
|
|
# NASA Solar Dynamics Observatory Vision Transformer v.1 (SDO_VT1) |
|
|
|
## Authors: |
|
[Frank Soboczenski](https://h21k.github.io/), King's College London, London, UK<br> |
|
[Paul Wright](https://www.wrightai.com/), Wright AI Ltd, Leeds, UK |
|
|
|
## General: |
|
This Vision Transformer model has been fine-tuned on Solar Dynamics Observatory (SDO) data. The images used are available here: |
|
[Solar Dynamics Observatory Gallery](https://sdo.gsfc.nasa.gov/gallery/main/search). This is the first version of a Vision Transformer model on SDO data in an active region classification task. We aim to highlight the ease of use of the HuggingFace platform, integration with popular deep learning frameworks such as PyTorch, TensorFlow, or JAX, performance monitoring with Weights and Biases, and the ability to effortlessly utilize pre-trained large scale Transformer models for targeted fine-tuning purposes. This is to our knowledge the first Vision Transformer model on NASA SDO mission data and we are working on additional versions to address challenges in this domain. |
|
|
|
<b>The data used was provided courtesy of NASA/SDO and the AIA, EVE, and HMI science teams. |
|
The authors gratefully acknowledge the entire NASA Solar Dynamics Observatory Mission Team.</b> |
|
|
|
## Example Images |
|
--> Drag one of the images below into the inference API field on the upper right. |
|
|
|
Additional images for testing can be found at: |
|
[Solar Dynamics Observatory Gallery](https://sdo.gsfc.nasa.gov/gallery/main/search) |
|
You can use the following tags to further select images for testing: |
|
"coronal holes", "loops" or "flares" |
|
You can also choose "active regions" to get a general pool for testing. |
|
|
|
### NASA_SDO_Coronal_Hole |
|
|
|
![NASA_SDO_Coronal_Hole](images/NASA_SDO_Coronal_Hole2.jpg) |
|
|
|
### NASA_SDO_Coronal_Loop |
|
|
|
![NASA_SDO_Coronal_Loop](images/NASA_SDO_Coronal_Loop.jpg) |
|
|
|
### NASA_SDO_Solar_Flare |
|
|
|
![NASA_SDO_Solar_Flare](images/NASA_SDO_Solar_Flare.jpg) |
|
|
|
## Training data |
|
The ViT model was pretrained on a dataset consisting of 14 million images and 21k classes ([ImageNet-21k](http://www.image-net.org/). |
|
More information on the base model used can be found here: (https://huggingface.co/google/vit-base-patch16-224-in21k) |
|
|
|
## How to use this Model |
|
|
|
```python |
|
!pip install transformers --quiet |
|
from transformers import AutoFeatureExtractor, AutoModelForImageClassification |
|
from PIL import Image |
|
import requests |
|
|
|
url = 'https://sdo.gsfc.nasa.gov/assets/gallery/preview/211_coronalhole.jpg' |
|
image = Image.open(requests.get(url, stream=True).raw) |
|
|
|
feature_extractor = AutoFeatureExtractor.from_pretrained("kenobi/SDO_VT1") |
|
model = AutoModelForImageClassification.from_pretrained("kenobi/SDO_VT1") |
|
inputs = feature_extractor(images=image, return_tensors="pt") |
|
|
|
outputs = model(**inputs) |
|
logits = outputs.logits |
|
# model predicts one of the three fine-tuned classes (NASA_SDO_Coronal_Hole, NASA_SDO_Coronal_Loop or NASA_SDO_Solar_Flare) |
|
predicted_class_idx = logits.argmax(-1).item() |
|
print("Predicted class:", model.config.id2label[predicted_class_idx]) |
|
``` |
|
|
|
## References |
|
|
|
A publication on this work is currently in preparation. In the meantime, please refer to this model by using the following citation: |
|
``` |
|
@misc{sdovt2022, |
|
author = {Frank Soboczenski and Paul J Wright}, |
|
title = {SDOVT: A Vision Transformer Model for Solar Dynamics Observatory (SDO) Data}, |
|
url = {https://huggingface.co/kenobi/SDO_VT1/}, |
|
version = {1.0}, |
|
year = {2022}, |
|
} |
|
``` |
|
|
|
For the base ViT model used please refer to: |
|
|
|
```bibtex |
|
@misc{wu2020visual, |
|
title={Visual Transformers: Token-based Image Representation and Processing for Computer Vision}, |
|
author={Bichen Wu and Chenfeng Xu and Xiaoliang Dai and Alvin Wan and Peizhao Zhang and Zhicheng Yan and Masayoshi Tomizuka and Joseph Gonzalez and Kurt Keutzer and Peter Vajda}, |
|
year={2020}, |
|
eprint={2006.03677}, |
|
archivePrefix={arXiv}, |
|
primaryClass={cs.CV} |
|
} |
|
``` |
|
|
|
|