# DeSRA (ICML 2023) š© Updates - ā The collected datasets, the codes of detecting artifacts and calculating metrics are released. - ā Release the MSE and GAN models (Real-ESRGAN, LDL, SwinIR) and SegFormer (the checkpoint and configuration). - ā Release the GAN-DeSRA models (RealESRGAN-DeSRA, LDL-DeSRA and SwinIR-DeSRA). --- This paper aims at **dealing with GAN-inference artifacts**. <br> We design a method to effectively detect regions with GAN-inference artifacts, and further propose a fine-tuning strategy that only requires a small number of artifact images to eliminate the same kinds of artifacts, which bridges the gap of applying SR algorithms to practical scenarios. --- ### :book: DeSRA: Detect and Delete the Artifacts of GAN-based Real-World Super-Resolution Models > [[Paper](https://openreview.net/pdf?id=M0bwbIl4Bl)]   [Project Page]   [[Video](https://recorder-v3.slideslive.com/#/share?share=82996&s=e6ebdd07-a83b-4f4b-8eab-a5f103c6c46b)]   [Bē«]   [[Poster](https://docs.google.com/presentation/d/18-kVUBRgGKF4JUrN253yURJGDKcFNpaB/edit?usp=drive_web&ouid=113023682396793851067&rtpof=true)]   [[PPT slides](https://docs.google.com/presentation/d/15zGKWNd6vPuGI-dMf0ZsGrfMnPhXO-8s/edit?rtpof=true)]<br> > [Liangbin Xie*](https://liangbinxie.github.io/), [Xintao Wang*](https://xinntao.github.io/), [Xiangyu Chen*](https://chxy95.github.io/), [Gen Li](https://scholar.google.com/citations?user=jBxlX7oAAAAJ&hl=en), [Ying Shan](https://scholar.google.com/citations?user=4oXBp9UAAAAJ&hl=en), [Jiantao Zhou](https://www.fst.um.edu.mo/personal/jtzhou/), [Chao Dong](https://scholar.google.com.hk/citations?user=OSDCB0UAAAAJ) <br> > Tencent ARC Lab; University of Macau; Shenzhen Institutes of Advanced Technology; Shanghai AI Lab <p align="center"> <img src="./assets/DeSRA_teasor.jpg", height=400> </p> --- ## š§ Dependencies and Installation - Python >= 3.7 (Recommend to use [Anaconda](https://www.anaconda.com/download/#linux) or [Miniconda](https://docs.conda.io/en/latest/miniconda.html)) - [PyTorch >= 1.7](https://pytorch.org/) - Option: NVIDIA GPU + [CUDA](https://developer.nvidia.com/cuda-downloads) - Option: Linux ### Installation (The version of mmsegmentation utilized in this project is 0.29.0.) 1. Install [mmsegmentation](<https://github.com/open-mmlab/mmsegmentation>) package and install dependent packages. **Note**: The version of mmsegmentation and mmcv-full that used in the experiment are <b>0.29.0</b> and <b>1.6.1</b>, respectively. Setting up the environment might take some time. ```bash git clone https://github.com/open-mmlab/mmsegmentation.git cd mmsegmentation pip install -r requirements.txt ``` 2. Clone repo and move the provided scripts into the demo folder (a subfolder) in mmsegmentation folder. ```bash git clone https://github.com/TencentARC/DeSRA cd DeSRA mv scripts/* mmsegmentation/demo (you need to modify the path) ``` If you encounter problem, I also provide the environment that I used in the experiments. You can refer to the [requirements.txt](./requirements.txt) --- ## š¦ Testing datasets For three representative methods: [RealESRGAN](<https://github.com/xinntao/Real-ESRGAN#-demos-videos>), [LDL](<https://github.com/csjliang/LDL>) and [SwinIR](<https://github.com/JingyunLiang/SwinIR>), we choose nearly 200 representative images with GAN-inference artifacts to construct this GAN-SR artifact dataset. You can download from [GoogleDrive](<https://drive.google.com/drive/folders/1jPTvXq_uJvpOaP5uCZ6unmb13Gt2naVC?usp=sharing>) and [BaiduDisk](<https://pan.baidu.com/s/1rwwEpATlPo9RFzTv6D7lBw?pwd=DGLF>). (For each methods, we provide the MSE-SR, GAN-SR, DeSRA-Mask, LR, and human-labeled GT-Mask) --- ## š° Pre-trained Models We have provided the MSE-based and GAN-based models used to detect artifacts generated by the three methods: Real-ESRGAN, LDL, and SwinIR, as well as the corresponding checkpoint and configuration files of the SegFormer we used in the experiment. You can download from [GoogleDrive](https://drive.google.com/drive/folders/10vzKAJjHm5GEb0_LESnHYmuCnBwdoFpm?usp=sharing). The GAN-DeSRA models are also released [GoogleDrive](https://drive.google.com/drive/folders/14cLRrE4GjbgxIlVz6RoeRr0-2-NiTHrf?usp=drive_link). For each method, we have released the corresponding three checkpoints. The effect of the model fine-tuned for 1000 iterations may not be significant under some methods. In this case, you can try other checkpoints that have been fine-tuned for a longer time. --- ## āļø Quick Inference 1. Detect the artifacts between the MSE-SR results and GAN-SR results. We store many intermediate results and the final detected binary artifact map are stored in *Final_Artifact_Map* folder. The config file and checkpoint of [SegFormer](<https://github.com/open-mmlab/mmsegmentation/tree/main/configs/segformer>) can be found in the mmsegmentation package. ```bash python demo/artifact_detection.py --mse_root="./LDL/MSE-SR" --gan_root="./LDL/GAN-SR" --save_root="./results/LDL/DeSRA-Mask" ``` 2. Evaluate the performance. As mentioned in our paper, we provide three scripts to calculate **IOU**, **Precision** and **Recall**, respectively. You can find these scripts in *metrics* folder. ```bash python metrics/calc_iou.py python metrics/calc_precision.py python metrics/calc_recall.py ``` --- ## š License and Acknowledgement DeSRA is released under Apache License Version 2.0. ## BibTeX @article{xie2023desra, title={DeSRA: Detect and Delete the Artifacts of GAN-based Real-World Super-Resolution Models}, author={Xie, Liangbin and Wang, Xintao and Chen, Xiangyu and Li, Gen and Shan, Ying and Zhou, Jiantao and Dong, Chao}, year={2023} } ## š§ Contact If you have any question, please email `lb.xie@siat.ac.cn`.