Project Icon

RestoreFormerPlusPlus

先进的高质量人脸图像修复技术

RestoreFormerPlusPlus是一种高级人脸图像修复方法,采用全空间注意力机制和扩展退化模型(EDM)提高修复效果的保真度和真实感。该方法利用丰富的上下文信息和高质量先验,提升了对真实场景的适应性和通用性。项目开源了预训练模型、推理代码和在线演示,为研究和开发人员提供了实现高质量人脸图像修复的便捷工具。

RestoreFormer++: 基于未退化键值对的真实场景盲人脸修复

paper_RestroeForemer++   paere_RestroeForemer   code_RestroeForemer++   code_RestroeForemer   demo

这个仓库是"RestoreFormer++: 基于未退化键值对的真实场景盲人脸修复"的官方实现。

RestoreFormer++是我们RestoreFormer的扩展版本。它提出使用强大的全空间注意力机制来建模人脸中丰富的上下文信息及其与我们面向重建的高质量先验之间的相互作用,从而在保真度和真实性方面修复退化的人脸图像。此外,它引入了一个扩展退化模型(EDM),包含更多真实的退化场景用于训练数据合成,这有助于增强其在真实场景中的鲁棒性和泛化能力。我们的结果与最先进方法的比较以及有/无EDM的性能如下所示:

images/fig1.png

images/fig3.png

待办事项

  • 20240122 提供本地gradio演示
  • 20230915 更新在线演示 Huggingface Gradio
  • 20230915 提供用户友好的推理方法。
    • 可用于带RealESRGAN的背景超分辨率。
    • basicsr应升级到1.4.2
  • 20230914 上传模型
  • 20230914 发布代码
  • 20221120 介绍项目。

环境

  • python>=3.7
  • pytorch>=1.7.1
  • pytorch-lightning==1.0.8
  • omegaconf==2.0.0
  • basicsr==1.3.3.4 basicsr>=1.4.2
  • realesrgan==0.3.0
pip install -r RF_requirements.txt

❗❗❗ 警告 不同版本的pytorch-lightning和omegaconf可能导致错误或不同的结果。

数据集和模型准备

数据集

  • 训练数据:我们工作中的ROHQDRestoreFormer++都使用FFHQ进行训练,该数据集从FFHQ仓库获得。FFHQ中图像的原始尺寸为1024x1024。在我们的工作中,我们使用双线性插值将它们调整为512x512。将此数据集链接到./data/FFHQ/image512x512。
  • 测试数据CelebA-TestLFW-TestWebPhoto-TestCelebChild-Test

模型: 用于训练的预训练模型以及我们的RestoreFormer和RestoreFormer++的训练模型可以从Google Drive获得。将这些模型链接到./experiments。

Gradio演示

python gradio_demo/app.py

快速推理

python inference.py -i data/aligned -o results/RF++/aligned -v RestoreFormer++ -s 2 --aligned --save python inference.py -i data/raw -o results/RF++/raw -v RestoreFormer++ -s 2 --save python inference.py -i data/aligned -o results/RF/aligned -v RestoreFormer -s 2 --aligned --save python inference.py -i data/raw -o results/RF/raw -v RestoreFormer -s 2 --save

注意:相关代码借鉴自GFPGAN

测试

sh scripts/test.sh

scripts/test.sh

exp_name='RestoreFormer'
exp_name='RestoreFormerPlusPlus'

root_path='experiments'
out_root_path='results'
align_test_path='data/aligned'
# unalign_test_path='data/raw'
tag='test'

outdir=$out_root_path'/'$exp_name'_'$tag

if [ ! -d $outdir ];then
    mkdir -m 777 $outdir
fi

CUDA_VISIBLE_DEVICES=0 python -u scripts/test.py \
--outdir $outdir \
-r $root_path'/'$exp_name'/last.ckpt' \
-c 'configs/'$exp_name'.yaml' \
--test_path $align_test_path \
--aligned
  • 此代码库适用于RestoreFormerRestoreFormerPlusPlus。通过exp_name确定具体模型。
  • 通过root_path设置模型路径
  • 恢复结果保存在out_root_path
  • 将退化的人脸图像放在test_path
  • 如果退化的人脸图像已对齐,设置*--aligned*,否则从脚本中删除。data/aligned中提供的测试图像是对齐的,而data/raw中的图像未对齐且包含多个人脸。

训练

sh scripts/run.sh

scripts/run.sh

export BASICSR_JIT=True

# 对于RestoreFormer
# conf_name='HQ_Dictionary'
# conf_name='RestoreFormer'

# 对于RestoreFormer++
conf_name='ROHQD'
conf_name='RestoreFormerPlusPlus'

# gpus='0,1,2,3,4,5,6,7'
# node_n=1
# ntasks_per_node=8

root_path='PATH_TO_CHECKPOINTS'

gpus='0,'
node_n=1
ntasks_per_node=1

gpu_n=$(expr $node_n \* $ntasks_per_node)

python -u main.py \
--root-path $root_path \
--base 'configs/'$conf_name'.yaml' \
-t True \
--postfix $conf_name'_gpus'$gpu_n \
--gpus $gpus \
--num-nodes $node_n \
--random-seed True \
  • 此代码库适用于RestoreFormerRestoreFormerPlusPlus。通过conf_name确定训练模型。'HQ_Dictionary'和'RestoreFormer'用于RestoreFormer,而'ROHQD'和'RestoreFormerPlusPlus'用于RestoreFormerPlusPlus
  • 在训练'RestoreFormer'或'RestoreFormerPlusPlus'时,configs/中相应配置文件的*'ckpt_path'*应更新为'HQ_Dictionary'或'ROHQD'的训练模型路径。

评估指标

sh scripts/metrics/run.sh

注意

  • 如果您想获得IDD、PSRN、SSIM、LIPIS,需要在脚本中添加CelebA-Test数据集的路径。
  • 相关的评估模型在*./experiments/pretrained_models/*中。

引用

@article{wang2023restoreformer++,
  title={RestoreFormer++: Towards Real-World Blind Face Restoration from Undegraded Key-Value Paris},
  author={Wang, Zhouxia and Zhang, Jiawei and Chen, Tianshui and Wang, Wenping and Luo, Ping},
  booktitle={IEEE Transactions on Pattern Analysis and Machine Intelligence (T-PAMI)},
  year={2023}
}

@article{wang2022restoreformer,
  title={RestoreFormer: High-Quality Blind Face Restoration from Undegraded Key-Value Pairs},
  author={Wang, Zhouxia and Zhang, Jiawei and Chen, Runjian and Wang, Wenping and Luo, Ping},
  booktitle={The IEEE Conference on Computer Vision and Pattern Recognition (CVPR)},
  year={2022}
}

联系方式

如有任何问题,请随时发送电子邮件至wzhoux@connect.hku.hkzhouzi1212@gmail.com

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