Project Icon

SeeSR

基于语义感知的实景图像超分辨率方法

SeeSR是一种新型语义感知实景图像超分辨率技术,结合稳定扩散模型和语义信息提升低分辨率图像质量。该方法已被CVPR2024接收并在GitHub开源。SeeSR可处理多种场景图像,并支持快速推理。项目提供预训练模型、测试数据集和使用说明,便于研究和应用。此外,项目还包含DAPE和SeeSR模型的训练指南,以及用于生成训练数据的工具。SeeSR采用tiled vae方法节省GPU内存,并提供Gradio演示界面。该技术在多个真实世界图像数据集上展现出优异性能。

SeeSR:面向语义感知的真实世界图像超分辨率(CVPR2024)

     

吴荣源1,2 | 杨涛3 | 孙凌晨1,2 | 张政强1,2 | 李帅1,2 | 张磊1,2

1香港理工大学, 2OPPO研究院, 3字节跳动

:star: 如果SeeSR对您的图像或项目有帮助,请给这个仓库点个星。谢谢!:hugs:

🚩已被CVPR2024接收

📢 新闻

  • 2024.06 我们的一步式真实世界图像超分辨率工作OSEDiff,可达到SeeSR级别的质量,但速度快10倍以上
  • 2024.03.10 支持sd-turbo,SeeSR只需2步就能得到不错的图像⚡️。请参考这里
  • 2024.01.12 🔥🔥🔥 已集成到 试用Replicate在线演示 ❤️ 感谢lucataco的实现。
  • 2024.01.09 🚀 添加Gradio演示,包括turbo模式。
  • 2023.12.25 🎅🎄🎅🎄 圣诞快乐!!!
    • 🍺 发布SeeSR-SD2-Base,包括代码和预训练模型。
    • 📏 我们还发布了RealLR200。它包含200张真实世界的低分辨率图像。
  • 2023.11.28 创建此仓库。

📌 待办事项

  • SeeSR-SDXL
  • SeeSR-SD2-Base-face,text
  • SeeSR加速

🔎 总体框架

seesr

📷 真实世界结果

seesr

⚙️ 依赖项和安装

## 克隆此仓库
git clone https://github.com/cswry/SeeSR.git
cd SeeSR

# 创建一个Python版本 >= 3.8的环境
conda create -n seesr python=3.8
conda activate seesr
pip install -r requirements.txt

🚀 快速推理

步骤1:下载预训练模型

您可以将模型放入preset/models目录。

步骤2:准备测试数据

您可以将测试图像放入preset/datasets/test_datasets目录。

步骤3:运行测试命令

python test_seesr.py \
--pretrained_model_path preset/models/stable-diffusion-2-base \
--prompt '' \
--seesr_model_path preset/models/seesr \
--ram_ft_path preset/models/DAPE.pth \
--image_path preset/datasets/test_datasets \
--output_dir preset/datasets/output \
--start_point lr \
--num_inference_steps 50 \
--guidance_scale 5.5 \
--process_size 512 

更多详情请参阅此处

SD-Turbo步骤

只需从sd-turbo下载权重,并将它们放入preset/models。然后,您就可以运行命令了。更多比较可以在这里找到。请注意,在turbo模式下,guidance_scale固定为1.0

python test_seesr_turbo.py \
--pretrained_model_path preset/models/sd-turbo \
--prompt '' \
--seesr_model_path preset/models/seesr \
--ram_ft_path preset/models/DAPE.pth \
--image_path preset/datasets/test_datasets \
--output_dir preset/datasets/output \
--start_point lr \
--num_inference_steps 2 \
--guidance_scale 1.0 \
--process_size 512 

注意

请仔细阅读test_seesr.py中的参数。我们采用了multidiffusion-upscaler-for-automatic1111提出的平铺VAE方法来节省GPU内存。

Gradio演示

请将所有预训练模型放在preset/models目录下,然后运行以下命令以与gradio网站交互。

python gradio_seesr.py 

我们还提供了带有sd-turbo的gradio,祝您使用愉快。🤗

python gradio_seesr_turbo.py 

seesr

测试基准

我们在GoogleDriveOneDrive上发布了我们的RealLR200。您可以从StableSR下载RealSRDRealSR。我们还在GoogleDriveOneDrive上提供了其副本。至于合成测试集,您可以通过下面描述的合成方法获得。

🌈 训练

步骤1:下载预训练模型

下载预训练的SD-2-base模型RAM。您可以将它们放入preset/models目录。

步骤2:准备训练数据

我们为训练过程预先准备训练数据对,这会占用一些内存空间但可以节省训练时间。我们使用COCO数据集训练DAPE,使用常见的低级数据集(如DF2K)训练SeeSR。

要为DAPE训练制作配对数据,可以运行:

python utils_data/make_paired_data_DAPE.py \
--gt_path 路径_1 路径_2 ... \
--save_dir preset/datasets/train_datasets/training_for_dape \
--epoch 1

要为SeeSR训练制作配对数据,可以运行:

python utils_data/make_paired_data.py \
--gt_path 路径_1 路径_2 ... \
--save_dir preset/datasets/train_datasets/training_for_dape \
--epoch 1
  • --gt_path 高清图像的路径。如果有多个高清图像目录,可以设置为路径1 路径2 路径3 ...
  • --save_dir 配对图像的保存路径
  • --epoch 你想要制作的轮次数

make_paired_data_DAPE.pymake_paired_data.py的区别在于,make_paired_data_DAPE.py将整个图像调整为512的分辨率,而make_paired_data.py随机裁剪出512分辨率的子图像。

一旦创建了降质数据对,你可以基于它们通过运行utils_data/make_tags.py来生成标签数据。

数据文件夹应该如下所示:

your_training_datasets/
    └── gt
        └── 0000001.png # 高清图像,(512, 512, 3)
        └── ...
    └── lr
        └── 0000001.png # 低分辨率图像,(512, 512, 3)
        └── ...
    └── tag
        └── 0000001.txt # 标签提示
        └── ...

步骤3:训练DAPE

请在basicsr/options/dape.yaml的第13行指定DAPE训练数据路径,然后运行训练命令:

python basicsr/train.py -opt basicsr/options/dape.yaml

你可以修改dape.yaml中的参数以适应你的具体情况,比如GPU数量、批量大小、优化器选择等。更多细节请参考Basicsr中的设置。

步骤4:训练SeeSR

CUDA_VISIBLE_DEVICES="0,1,2,3,4,5,6,7," accelerate launch train_seesr.py \
--pretrained_model_name_or_path="preset/models/stable-diffusion-2-base" \
--output_dir="./experience/seesr" \
--root_folders 'preset/datasets/training_datasets' \
--ram_ft_path 'preset/models/DAPE.pth' \
--enable_xformers_memory_efficient_attention \
--mixed_precision="fp16" \
--resolution=512 \
--learning_rate=5e-5 \
--train_batch_size=2 \
--gradient_accumulation_steps=2 \
--null_text_ratio=0.5 
--dataloader_num_workers=0 \
--checkpointing_steps=10000 
  • --pretrained_model_name_or_path 步骤1中预训练SD模型的路径
  • --root_folders 步骤2中训练数据集的路径
  • --ram_ft_path 步骤3中DAPE模型的路径

总批量大小由CUDA_VISIBLE_DEVICES--train_batch_size--gradient_accumulation_steps共同决定。如果你的GPU内存有限,可以考虑减小--train_batch_size并增加--gradient_accumulation_steps

❤️ 致谢

本项目基于diffusersBasicSR。部分代码来自PASDRAM。感谢他们出色的工作。我们也向StableSR的开创性工作致敬。

📧 联系方式

如果你有任何问题,请随时联系:rong-yuan.wu@connect.polyu.hk

🎓引用

如果我们的代码对你的研究或工作有帮助,请考虑引用我们的论文。 以下是BibTeX引用:

@inproceedings{wu2024seesr,
  title={Seesr: Towards semantics-aware real-world image super-resolution},
  author={Wu, Rongyuan and Yang, Tao and Sun, Lingchen and Zhang, Zhengqiang and Li, Shuai and Zhang, Lei},
  booktitle={Proceedings of the IEEE/CVF conference on computer vision and pattern recognition},
  pages={25456--25467},
  year={2024}
}

🎫 许可证

本项目在Apache 2.0许可证下发布。

统计数据

访问量

项目侧边栏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号