首页
/ TSD-SR: 一站式目标得分蒸馏扩散实现真实世界图像超分辨率

TSD-SR: 一站式目标得分蒸馏扩散实现真实世界图像超分辨率

2025-05-19 07:45:07作者:董斯意

1. 项目介绍

TSD-SR(Target Score Distillation for Real-World Image Super-Resolution)是一个基于PyTorch的开源项目,它提出了一种新的超分辨率方法,通过一步扩散和目标得分蒸馏来提高真实世界图像的恢复质量。该方法由浙江大学和Vivo Mobile Communication Co. Ltd等机构的研究人员共同开发,并被CVPR 2025接受。TSD-SR旨在解决传统超分辨率方法在真实世界图像处理中遇到的挑战,如噪声、模糊和不规则纹理等。

2. 项目快速启动

环境准备

首先,确保已经安装了conda和Python 3.9。然后,按照以下步骤准备环境:

git clone https://github.com/Microtreei/TSD-SR.git
cd TSD-SR
conda create -n tsdsr python=3.9
conda activate tsdsr
pip install -r requirements.txt

预训练模型下载

下载预训练的SD3模型和TSD-SR的loral权重及提示嵌入:

  • 从HuggingFace下载SD3模型。
  • 从GoogleDrive或OneDrive下载TSD-SR的loral权重和提示嵌入。

将下载的模型权重放入checkpoint/tsdsr,提示嵌入放入dataset/default

测试数据准备

将测试图像放入imgs/test目录。

测试命令执行

运行以下命令进行测试:

python test/test_tsdsr.py \
--pretrained_model_name_or_path /path/to/your/sd3 \
-i imgs/test \
-o outputs/test \
--lora_dir checkpoint/tsdsr \
--embedding_dir dataset/default

性能评估

使用以下命令进行性能评估:

python test/test_metrics.py \
--inp_imgs outputs/DrealSR \
--gt_imgs imgs/StableSR_testsets/DrealSRVal_crop128/test_HR \
--log logs/metrics

3. 应用案例和最佳实践

训练数据准备

  1. 下载训练数据集,如LSDIR、FLICKR2K、DIV2K、FFHQ,并存储在指定位置。
  2. 准备降质图像和提示文本,按照项目提供的路径和结构组织数据。

训练过程

  1. 修改data/data.pydata/process.py中的数据集路径。
  2. 运行data/process.py生成训练数据。
  3. 下载教师模型和空提示嵌入,并放置在相应的目录下。
  4. 运行训练命令开始训练过程。

模型优化

  • 使用教师模型的LoRA权重进行微调,提高模型对高质量数据的敏感度。
  • 使用空提示嵌入计算cfg,优化训练过程。

4. 典型生态项目

  • StableSR: 提供了一个精心策划的测试数据集,用于评估超分辨率方法的性能。
  • SD3: 用于图像超分辨率任务的基础模型,提供了强大的文本到图像生成能力。
  • DAPE: 生成基于标签的提示文本,用于训练过程。
  • LLaVA: 生成自然语言描述的提示文本,用于训练过程。

以上就是TSD-SR项目的最佳实践指南,希望对您有所帮助。

登录后查看全文
热门项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
22
6
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
161
2.05 K
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
146
191
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
60
16
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
198
279
apintoapinto
基于golang开发的网关。具有各种插件,可以自行扩展,即插即用。此外,它可以快速帮助企业管理API服务,提高API服务的稳定性和安全性。
Go
22
0
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
949
556
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
96
15
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
346
1.33 K