This is the offical PyTorch code for paper "RSVG: Exploring Data and Model for Visual Grounding on Remote Sensing Data", Paper.
[2023/04/10]: Update the DIOR_RSVG dataset and the source code. (to clarify, we have been planning to continuously optimize this dataset, and the previous public version was wrong and has now been restored.)
[2022/11/07]: Release the DIOR_RSVG dataset.
[2022/10/22]: Release the training code. Publish the manuscript on arXiv.
This is Multi-Granularity Visual Language Fusion (MGVLF) Network, the PyTorch source code of the paper "RSVG: Exploring Data and Model for Visual Grounding on Remote Sensing Data". It is built on top of the TransVG in PyTorch. Our method is a transformer-based method for visual grounding for remote sensing data (RSVG). It has achieved the SOTA performance in the RSVG task on our constructed RSVG dataset.
We recommended the following dependencies.
- Python 3.6.13
- PyTorch 1.9.0
- NumPy 1.19.2
- cuda 11.1
- opencv 4.5.5
- torchvision
Download our constructed RSVG dataset files. We build the first large-scale dataset for RSVG, termed DIOR-RSVG, which can be downloaded from our Google Drive. The download link is available below:
https://drive.google.com/drive/folders/1hTqtYsC6B-m4ED2ewx5oKuYZV13EoJp_?usp=sharing
We expect the directory and file structure to be the following:
./ # current (project) directory
├── models/ # Files for implementation of RSVG model
├── utils/ # Some scripts for data processing and helper functions
├── saved_models/ # Savepath of pth/ckpt and pre-trained model
├── logs/ # Savepath of logs
├── data_loader.py # Load data
├── main.py # Main code for training, validation, and test
├── README.md
└── RSVGD/ # DIOR-RSVG dataset
├── Annotations/ # Query expressions and bounding boxes
│ ├── 00001.xml/
│ └── ..some xml files..
├── JPEGImages/ # Remote sensing images
│ ├── 00001.jpg/
│ └── ..some jpg files..
├── train.txt # ID of training set
├── val.txt # ID of validation set
└── test.txt # ID of test set
1、Download dataset
2、Download detr-r50-e632da11.pth
3、Train
python main.py
Run main.py
using --test False
to train new models on DIOR-RSVG.
4、Evaluate trained models on DIOR-RSVG
Run main.py
using --test True
.
Remember to set "--resume" and "--pretrain" to your needs in the parameters.
If you found this code useful, please cite the paper. Welcome 👍Fork and Star
👍, then I will let you know when we update.
@ARTICLE{10056343,
author={Zhan, Yang and Xiong, Zhitong and Yuan, Yuan},
journal={IEEE Transactions on Geoscience and Remote Sensing},
title={RSVG: Exploring Data and Models for Visual Grounding on Remote Sensing Data},
year={2023},
volume={61},
number={},
pages={1-13},
doi={10.1109/TGRS.2023.3250471}
}
Our DIOR-RSVG is constructed based on the DIOR remote sensing image dataset. We thank to the authors for releasing the dataset. Part of our code is borrowed from TransVG. We thank to the authors for releasing codes. I would like to thank Xiong zhitong and Yuan yuan for helping the manuscript. I also thank the School of Artificial Intelligence, OPtics, and ElectroNics (iOPEN), Northwestern Polytechnical University for supporting this work.