Project Icon

RGT

递归泛化Transformer模型实现高效图像超分辨率

RGT项目提出递归泛化Transformer模型,通过创新的自注意力机制高效捕获图像全局信息。该模型结合局部和全局特征,在图像超分辨率任务中实现了优异性能,为高质量图像重建提供新思路。实验结果显示RGT在多个评估指标上超越了现有先进方法。

递归泛化 Transformer 用于图像超分辨率

Zheng ChenYulun ZhangJinjin GuLinghe KongXiaokang Yang,"用于图像超分辨率的递归泛化 Transformer",ICLR,2024

[论文] [arXiv] [补充材料] [可视化结果] [预训练模型]

🔥🔥🔥 新闻

  • 2024-02-04: 代码和预训练模型已发布。🎊🎊🎊
  • 2023-09-29: 本仓库已发布。

摘要: Transformer 架构在图像超分辨率(SR)任务中表现出了卓越的性能。由于 Transformer 中自注意力(SA)的二次计算复杂度,现有方法倾向于在局部区域采用 SA 以减少开销。然而,局部设计限制了全局上下文的利用,而这对于准确的图像重建至关重要。在本工作中,我们提出了用于图像 SR 的递归泛化 Transformer (RGT),它可以捕获全局空间信息并适用于高分辨率图像。具体来说,我们提出了递归泛化自注意力(RG-SA)。它递归地将输入特征聚合成具有代表性的特征图,然后利用交叉注意力提取全局信息。同时,注意力矩阵($query$、$key$ 和 $value$)的通道维度进一步缩放以减少通道域中的冗余。此外,我们将 RG-SA 与局部自注意力相结合以增强全局上下文的利用,并提出了混合自适应集成(HAI)用于模块集成。HAI 允许不同层级(局部或全局)特征之间的直接有效融合。大量实验表明,我们的 RGT 在定量和定性方面都优于最近的最先进方法。


HRLRSwinIRCATRGT (ours)

⚙️ 依赖

  • Python 3.8
  • PyTorch 1.9.0
  • NVIDIA GPU + CUDA
# 克隆 GitHub 仓库并进入默认目录 'RGT'。
git clone https://github.com/zhengchen1999/RGT.git
conda create -n RGT python=3.8
conda activate RGT
pip install -r requirements.txt -f https://download.pytorch.org/whl/torch_stable.html
python setup.py develop

⚒️ 待办事项

  • 发布代码和预训练模型

🔗 目录

  1. 数据集
  2. 模型
  3. 训练
  4. 测试
  5. 结果
  6. 引用
  7. 致谢

🖨️ 数据集

使用的训练和测试集可以按以下方式下载:

训练集测试集可视化结果
DIV2K (800张训练图像,100张验证图像) + Flickr2K (2650张图像) [完整训练数据集 DF2K:Google Drive / 百度网盘]Set5 + Set14 + BSD100 + Urban100 + Manga109 [完整测试数据集:Google Drive / 百度网盘]Google Drive / 百度网盘

下载训练和测试数据集并将它们放入 datasets/ 的相应文件夹中。有关目录结构的详细信息,请参见 datasets

📦 模型

方法参数量 (M)FLOPs (G)PSNR (dB)SSIM模型库可视化结果
RGT-S10.20193.0827.890.8347Google Drive / 百度网盘Google Drive / 百度网盘
RGT13.37251.0727.980.8369Google Drive / 百度网盘Google Drive / 百度网盘

性能在 Urban100 (x4) 上报告。FLOPs 的输出尺寸为 3×512×512。

🔧 训练

  • 下载训练(DF2K,已处理)和测试(Set5、Set14、BSD100、Urban100、Manga109,已处理)数据集,将它们放在 datasets/ 中。

  • 运行以下脚本。训练配置在 options/train/ 中。

# RGT-S,输入=64x64,4个GPU
python -m torch.distributed.launch --nproc_per_node=4 --master_port=4321 basicsr/train.py -opt options/train/train_RGT_S_x2.yml --launcher pytorch
python -m torch.distributed.launch --nproc_per_node=4 --master_port=4321 basicsr/train.py -opt options/train/train_RGT_S_x3.yml --launcher pytorch
python -m torch.distributed.launch --nproc_per_node=4 --master_port=4321 basicsr/train.py -opt options/train/train_RGT_S_x4.yml --launcher pytorch

# RGT,输入=64x64,4个GPU
python -m torch.distributed.launch --nproc_per_node=4 --master_port=4321 basicsr/train.py -opt options/train/train_RGT_x2.yml --launcher pytorch
python -m torch.distributed.launch --nproc_per_node=4 --master_port=4321 basicsr/train.py -opt options/train/train_RGT_x3.yml --launcher pytorch
python -m torch.distributed.launch --nproc_per_node=4 --master_port=4321 basicsr/train.py -opt options/train/train_RGT_x4.yml --launcher pytorch

训练实验位于experiments/目录中。

🔨 测试

🌗 测试带有高分辨率图像的图片

  • 下载预训练的模型并将它们放在experiments/pretrained_models/目录中。

    我们提供了图像超分辨率的预训练模型:RGT-S和RGT(x2、x3、x4)。

  • 下载测试(Set5、Set14、BSD100、Urban100、Manga109)数据集,将它们放在datasets/目录中。

  • 运行以下脚本。测试配置在options/test/目录中(例如,test_RGT_x2.yml)。

    注1:您可以在YML文件中设置use_chop: True(默认为False)以对图像进行分块测试。

    # 不使用自集成
    # RGT-S,复现论文表2中的结果
    python basicsr/test.py -opt options/test/test_RGT_S_x2.yml
    python basicsr/test.py -opt options/test/test_RGT_S_x3.yml
    python basicsr/test.py -opt options/test/test_RGT_S_x4.yml
    
    # RGT,复现论文表2中的结果
    python basicsr/test.py -opt options/test/test_RGT_x2.yml
    python basicsr/test.py -opt options/test/test_RGT_x3.yml
    python basicsr/test.py -opt options/test/test_RGT_x4.yml
    
  • 输出结果在results/目录中。

🌓 测试没有高分辨率图像的图片

  • 下载预训练的模型并将它们放在experiments/pretrained_models/目录中。

    我们提供了图像超分辨率的预训练模型:RGT-S和RGT(x2、x3、x4)。

  • 将您的数据集(单个低分辨率图像)放在datasets/single目录中。该文件夹中已包含一些测试图像。

  • 运行以下脚本。测试配置在options/test/目录中(例如,test_single_x2.yml)。

    注1:默认模型是RGT。您可以通过修改YML文件来使用其他模型,如RGT-S。

    注2:您可以在YML文件中设置use_chop: True(默认为False)以对图像进行分块测试。

    # 在您的数据集上测试
    python basicsr/test.py -opt options/test/test_single_x2.yml
    python basicsr/test.py -opt options/test/test_single_x3.yml
    python basicsr/test.py -opt options/test/test_single_x4.yml
    
  • 输出结果在results/目录中。

🔎 结果

我们达到了最先进的性能。详细结果可以在论文中找到。

📎 引用

如果您在研究或工作中发现代码有帮助,请引用以下论文。

@inproceedings{chen2024recursive,
  title={Recursive Generalization Transformer for Image Super-Resolution},
  author={Chen, Zheng and Zhang, Yulun and Gu, Jinjin and Kong, Linghe and Yang, Xiaokang},
  booktitle={ICLR},
  year={2024}
}

💡 致谢

本代码基于BasicSR构建。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号