Skip to content

An Arbitrary-Scale Image Super-Resolution Framework (CVPR2023)

License

Notifications You must be signed in to change notification settings

neuralchen/EQSR

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Deep Arbitrary-Scale Image Super-Resolution via Scale-Equivariance Pursuit (EQSR)

Accepted by CVPR2023

The official repository with Pytorch

Our paper can be downloaded from EQSR.

Introduction

EQSR is designed to pursue scale-equivariance image super-resolution. We compare the PSNR degradation rate of our method and ArbSR. Taking the SOTA fixed-scale method HAT as reference, our model presents a more stable degradation as the scale increases, reflecting the equivariance of our method. motivation

Installation

Clone this repo:

git clone https://github.com/neuralchen/EQSR.git
cd EQSR

Dependencies:

  • python3.7+
  • pytorch
  • pyyaml, scipy, tqdm, imageio, einops, opencv-python
  • cupy

(Note: Please do not directly use "pip install" to install basicsr. It might lead to some issues due to version differences.)

Training

We divide the training into two stages. The first stage involves pretraining on the ImageNet dataset, and the second stage entails fine-tuning on the DF2K dataset.

You can modify parameters such as batch size, iterations, learning rate, etc. in the configuration files.

  • Phase 1 Modify the dataset path in options/train/train*.xml, and run the following command to train.
CUDA_VISIBLE_DEVICES=0,1,2,3 python -m torch.distributed.launch --nproc_per_node=4 --master_port=4320 train.py -opt train_EQSR_ImageNet_from_scratch --launcher pytorch
  • Phase 2 Modify the paths of the datasets and the location of the pretrained model in the configuration file.
CUDA_VISIBLE_DEVICES=0,1,2,3 python -m torch.distributed.launch --nproc_per_node=4 --master_port=4320 train.py -opt train_EQSR_finetune_from_ImageNet_pretrain --launcher pytorch

Datasets

TODO

Preprocess

TODO

Inference with a pretrained EQSR model

Pretrained Models

Modify the dataset path and pre-trained model path in options/test/test*.xml, and run the following command to test. If GPU memory is limited, you can consider adding PYTORCH_CUDA_ALLOC_CONF=max_split_size_mb:32 before these commands.

python test.py -opt options/test/testx234.yml
python test.py -opt options/test/testx6.yml
python test.py -opt options/test/testx8.yml

Ackownledgements

This code is built based on HAT and BasicSR. We thank the authors for sharing the codes.

To cite our paper

Related Projects

About

An Arbitrary-Scale Image Super-Resolution Framework (CVPR2023)

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published