The official complete code for paper "From Easy to Hard: Progressive Active Learning Framework for Infrared Small Target Detection with Single Point Supervision" [Paper/arXiv]
In this project demo, we have integrated multiple SIRST detection networks (ACM, ALC, MLCL-Net, ALCL-Net, DNANet, GGL-Net, UIUNet, MSDA-Net), label forms (Full supervision, Coarse single-point supervision, Centroid single-point supervision), and datasets (SIRST, NUDT-SIRST, IRSTD-1k and SIRST3). At the same time, more networks and functions can be integrated into the project later. We hope we can contribute to the development of this field.
We consider that an excellent learning process should be from easy to hard and take into account the learning ability of the current learner (model) rather than directly treating all tasks (samples) equally. Inspired by organisms gradually adapting to the environment and continuously accumulating knowledge, we first propose an innovative progressive active learning idea, which emphasizes that the network progressively and actively recognizes and learns more hard samples to achieve continuous performance enhancement. For details, please see [Paper/arXiv].
- Original datasets
- NUDT-SIRST [Original dataset] [paper]
- SIRST [Original dataset] [paper]
- IRSTD-1k [Original dataset] [paper]
- SIRST3 [Original dataset] [paper]
-
The labels are processed according to the "coarse_anno.m" and "centroid_anno.m" files in the "tools" folder to produce coarse point labels and centroid point labels. (You can also skip this step and use the complete dataset in step 3 directly.)
-
The datasets we created from original datasets (can be used directly in our demo)
- Download the dataset
Click download datasets
Unzip the downloaded compressed package to the root directory of the project.
-
Creat a Anaconda Virtual Environment
conda create -n PAL python=3.8 conda activate PAL
-
Configure the running environment
pip install torch==1.13.1+cu116 torchvision==0.14.1+cu116 torchaudio==0.13.1 --extra-index-url https://download.pytorch.org/whl/cu116 pip install segmentation_models_pytorch -i https://pypi.tuna.tsinghua.edu.cn/simple pip install PyWavelets -i https://pypi.tuna.tsinghua.edu.cn/simple pip install scikit-image -i https://pypi.tuna.tsinghua.edu.cn/simple pip install albumentations==1.3.0 -i https://pypi.tuna.tsinghua.edu.cn/simple pip install scikit-learn matplotlib thop h5py SimpleITK scikit-image medpy yacs torchinfo
-
Training the model
The default model, dataset and label forms are MSDA-Net, SIRST3, and coarse point labels. If you need to train others, please modify the corresponding setting in "train_model.py". Just change the settings to your choice. It's very simple. For details, please see the beginning of the code of "train_model.py".
python train_model.py
-
Testing the Model
The default model, dataset and label forms are MSDA-Net, SIRST3, and coarse point labels. If you need to test others, please modify the corresponding setting in "test_model.py". Notably, in the "test_model.py" file, you also need to assign the name of the folder where the weight file is located to the "test_dir_name" variable so that the program can find the corresponding model weights. For details, please see the beginning of the code of "test_model.py".
python test_model.py
-
Performance Evaluation Use "cal_mIoU_and_nIoU.py" and "cal_PD_and_Fa.py" for performance evaluation. Notably, the corresponding folder path should be replaced. default:SIRST3.
python cal_mIoU_and_nIoU.py python cal_PD_and_Fa.py
- Quantative Results on the SIRST3 dataset with Coarse point labels:
- Quantative Results on the three individual datasets with Coarse point labels:
- Quantative Results on the SIRST3 dataset with Centroid point labels:
- Quantative Results on the three individual datasets with Centroid point labels:
- Qualitative results on the SIRST3 dataset with Coarse point labels: (Red denotes the correct detections, blue denotes the false detections, and yellow denotes the missed detections.)
- Qualitative results on the SIRST3 dataset with Centroid point labels: (Red denotes the correct detections, blue denotes the false detections, and yellow denotes the missed detections.)
If you find this repo helpful, please give us a 🤩star🤩. Please consider citing the PAL if it benefits your project.
BibTeX reference is as follows.
@misc{yu2024easyhardprogressiveactive,
title={From Easy to Hard: Progressive Active Learning Framework for Infrared Small Target Detection with Single Point Supervision},
author={Chuang Yu and Jinmiao Zhao and Yunpeng Liu and Sicheng Zhao and Xiangyu Yue},
year={2024},
eprint={2412.11154},
archivePrefix={arXiv},
primaryClass={cs.CV},
url={https://arxiv.org/abs/2412.11154},
}
word reference is as follows.
Chuang Yu, Jinmiao Zhao, Yunpeng Liu, Sicheng Zhao, Xiangyu Yue. From Easy to Hard: Progressive Active Learning Framework for Infrared Small Target Detection with Single Point Supervision. arXiv preprint arXiv:2412.11154, 2024.