Model Card for MITLL/LADI-v2-classifier-small-reference

LADI-v2-classifier-small-reference is based on google/bit-50 and fine-tuned on the MITLL/LADI-v2-dataset. LADI-v2-classifier is trained to identify labels of interest to disaster response managers from aerial images.

🔴 IMPORTANT ❗🔴 This model is the 'reference' version of the model, which is trained on 80% of the 10,000 available images. It is provided to facilitate reproduction of our paper and is not intended to be used in deployment. For deployment, see the MITLL/LADI-v2-classifier-small and MITLL/LADI-v2-classifier-large models, which are trained on the full LADI v2 dataset (all splits).

Model Details

Model Description

The model architecture is based on Google's bit-50 model and fine-tuned on the LADI v2 dataset, which contains 10,000 aerial images labeled by volunteers from the Civil Air Patrol. The images are labeled using multi-label classification for the following classes:

  • bridges_any
  • buildings_any
  • buildings_affected_or_greater
  • buildings_minor_or_greater
  • debris_any
  • flooding_any
  • flooding_structures
  • roads_any
  • roads_damage
  • trees_any
  • trees_damage
  • water_any

This 'reference' model is trained on the training split, which contains 8,000 images from 2015-2022. It is provided for the purpose of reproducing the results from the paper. The 'deploy' model is trained on the training, validation, and test sets, and contains 10,000 images from 2015-2023. We recommend that anyone who wishes to use this model in production use the main versions of the models MITLL/LADI-v2-classifier-small and MITLL/LADI-v2-classifier-large.

  • Developed by: Jeff Liu, Sam Scheele
  • Funded by: Department of the Air Force under Air Force Contract No. FA8702-15-D-0001
  • License: MIT
  • Finetuned from model: google/bit-50

How to Get Started with the Model

LADI-v2-classifier-small-reference is trained to identify features of interest to disaster response managers from aerial images. Use the code below to get started with the model.

The simplest way to perform inference is using the pipeline interface

from transformers import pipeline
image_url = "https://fema-cap-imagery.s3.amazonaws.com/Images/CAP_-_Flooding_Spring_2023/Source/IAWG_23-B-5061/A0005/D75_0793_DxO_PL6_P.jpg"

pipe = pipeline(model="MITLL/LADI-v2-classifier-small-reference")
print(pipe(image_url))
[{'label': 'flooding_any', 'score': 0.9986758828163147},
 {'label': 'buildings_any', 'score': 0.9982584118843079},
 {'label': 'flooding_structures', 'score': 0.998119056224823},
 {'label': 'water_any', 'score': 0.9967329502105713},
 {'label': 'buildings_affected_or_greater', 'score': 0.9903663396835327}]

For finer-grained control, see below:

from transformers import AutoImageProcessor, AutoModelForImageClassification
import torch
import requests
from PIL import Image
from io import BytesIO

image_url = "https://fema-cap-imagery.s3.amazonaws.com/Images/CAP_-_Flooding_Spring_2023/Source/IAWG_23-B-5061/A0005/D75_0793_DxO_PL6_P.jpg"

img_data = requests.get(image_url).content
img = Image.open(BytesIO(img_data))

processor = AutoImageProcessor.from_pretrained("MITLL/LADI-v2-classifier-small-reference")
model = AutoModelForImageClassification.from_pretrained("MITLL/LADI-v2-classifier-small-reference")

inputs = processor(img, return_tensors="pt")

with torch.no_grad():
    logits = model(**inputs).logits

predictions = torch.sigmoid(logits).detach().numpy()[0]
labels = [(model.config.id2label[idx], predictions[idx]) for idx in range(len(predictions))]
print(labels)
[('bridges_any', 0.76203513),
 ('buildings_any', 0.9982584),
 ('buildings_affected_or_greater', 0.99036634),
 ('buildings_minor_or_greater', 0.57826394),
 ('debris_any', 0.18689156),
 ('flooding_any', 0.9986759),
 ('flooding_structures', 0.99811906),
 ('roads_any', 0.973596),
 ('roads_damage', 0.91898227),
 ('trees_any', 0.91444755),
 ('trees_damage', 0.7382976),
 ('water_any', 0.99673295)]

Citation

BibTeX:

@misc{ladi_v2,
      title={LADI v2: Multi-label Dataset and Classifiers for Low-Altitude Disaster Imagery}, 
      author={Samuel Scheele and Katherine Picchione and Jeffrey Liu},
      year={2024},
      eprint={2406.02780},
      archivePrefix={arXiv},
      primaryClass={cs.CV}
}

DISTRIBUTION STATEMENT A. Approved for public release. Distribution is unlimited.

This material is based upon work supported by the Department of the Air Force under Air Force Contract No. FA8702-15-D-0001. Any opinions, findings, conclusions or recommendations expressed in this material are those of the author(s) and do not necessarily reflect the views of the Department of the Air Force.

© 2024 Massachusetts Institute of Technology.

The software/firmware is provided to you on an As-Is basis

Delivered to the U.S. Government with Unlimited Rights, as defined in DFARS Part 252.227-7013 or 7014 (Feb 2014). Notwithstanding any copyright notice, U.S. Government rights in this work are defined by DFARS 252.227-7013 or DFARS 252.227-7014 as detailed above. Use of this work other than as specifically authorized by the U.S. Government may violate any copyrights that exist in this work.

Downloads last month
38
Safetensors
Model size
23.5M params
Tensor type
F32
·
Inference Examples
This model does not have enough activity to be deployed to Inference API (serverless) yet. Increase its social visibility and check back later, or deploy to Inference Endpoints (dedicated) instead.

Dataset used to train MITLL/LADI-v2-classifier-small-reference

Collection including MITLL/LADI-v2-classifier-small-reference