火爆全网的老照片修复技术,手把手教你怎么玩儿!

小伙伴们应该在别的自媒体平台上看到过,关于老照片修复的文章或短视频,而这项技术目前在用户群体中很受欢迎,目前作为服务早早已经在各大电商平台售卖了

image-20210403000923387

作为一个技术号主,今天给大家介绍一个老照片修复相关的 Github 项目,并手把手教学,带大家将这个项目跑起来,

学会了之后可以把项目应用到自己收集的图片上,有想法的读者也可以借助这个项目帮别人修复照片赚点零花钱,岂不美滋滋~

Github 项目叫 Bringing-Old-Photos-Back-to-Life,是微软公司把去年发表在 CVPR 上的一篇期刊的源码,项目地址 https://github.com/microsoft/Bringing-Old-Photos-Back-to-Life

名称就代表了项目用途:对老照片进行修复,恢复它原有的样貌;下面是官方公布的一些修复前后对比效果图,看上去是不是很赞 ~

image-20210403003019086

根据上面给定的样例,如果对项目的功能细分的话可分为以下三类

  • 1,旧照片全景修复;
  • 2,照片折痕识别、修复;
  • 3,照片人脸识别、人脸部分增强;

上面对项目一个简单介绍以后,下面开始正式介绍它的用法,先交代一下本次的测试环境:

  • OS: Windows 10,
  • Python :python 3.7.6,
  • IDE : Pycharm;
  • torch : 1.6.0+cpu
  • torchvision : 0.7.0+cpu

1,下载项目,克隆到本地

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4hcf5lUC-1617634643560)(https://images.zeroingpython.top/img/image-20210403081648547.png)]

项目下载方式有两种,Download Zip 或 git 命令(需借助 Git 工具) ;Download Zip 通过浏览器来下载,得到的是个解压包,下载到本地之后解压即可

解压后的目录如下:

image-20210403093607006

2,配置环境

该项目是基于深度学习训练得到的,但官方已经提供了训练好的权重文件,可以直接下载下来供我们使用(网络当然也可以重新训练,但极其不建议,因为耗时、耗钱并且最终权重精度远不如官方),一共需要配置 3 部分权重文件

2.1 Global 权重配置

该权重是用于图片全局修复,下载地址

https://facevc.blob.core.windows.net/zhanbo/old_photo/pretrain/Global/checkpoints.zip

下载后把文件加压至 ./Global 文件目录下

2.2 Face_Detection 权重

在前面项目介绍中,提到过该项目除了可以照片修复之外,还可以进行人脸增强,简单理解就是把模糊的人脸图像清晰化

人脸增强 首先需要解决的是人脸识别问题,项目中借助的是一个Python库 dlib,关于 dlib 使用可以参考之前我写的一篇文章

dlib 库安装也可以通过 pip 工具,但需要注意两个点 :

  • 1, pip 安装 dlib 之前,需提前安装好 Cmake ,pip install Cmake,否则会安装失败;
  • **2,用 dlib 进行人脸识别需要一个权重文件 **

dlib 权重文件下载地址如下,下载完之后将权重文件解压至 文件夹 ./Face_Detection/

http://dlib.net/files/shape_predictor_68_face_landmarks.dat.bz2
2.3 Face_Enhancement 权重

Face_Enhancement 权重用于人脸部位增强,下载后权重文件解压至 ./Face_Enhancement ,下载地址如下

https://facevc.blob.core.windows.net/zhanbo/old_photo/pretrain/Face_Enhancement/checkpoints.zip
2.4 Synchronized-BatchNorm-PyTorch

这是 Pytorch 框架的一个 同步BatchNorm 一个分支仓库,此项目中用到了这个模块;仓库地址

https://github.com/vacancy/Synchronized-BatchNorm-PyTorch

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-k4lwGZ5I-1617634643569)(https://images.zeroingpython.top/img/image-20210403121032169.png)]

将仓库克隆到本地,解压后目录如下:

image-20210403121156745

项目中两处地方用到了 sync_batchnorm 文件夹,这里需要注意下一下

1,将 sync_batchnorm 复制到 Face_Enhancement/models/network 文件夹下,还需要改动一点项目中的代码部分,找到 Face_Enhancement/models/network/normalize.py 脚本,更改第 8 行代码,将

from models.networks.sync_batchnorm import SynchronizedBatchNorm2d

改为

from models.networks.sync_batchnorm.batchnorm import SynchronizedBatchNorm2d

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-u2Ym6MZW-1617634643575)(https://images.zeroingpython.top/img/image-20210403122243629.png)]

2,将 sync_batchnorm 复制到 Global/detection_models ,找到 Global/detection_models/network.py 脚本,更改第 7 行代码,将

from detection_models.sync_batchnorm import DataParallelWithCallback

改为

from detection_models.sync_batchnorm.replicate import DataParallelWithCallback

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-dMLSqWoM-1617634643578)(https://images.zeroingpython.top/img/image-20210403122934310.png)]

2.5 安装依赖项

在终端输入下面命令,安装项目中所需的第三方程序包

pip install -r requirements.txt

3,运行,修复自己收集的图片

上面环境配置好之后,下面就可以正常使用了;在项目中官方给的有测试图片,存放在 test_images, 分为两类

  • old 老照片,没有折痕的照片;
image-20210403131857917
  • old_w_scratch ,有折痕的照片

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZUPxVwtm-1617634643583)(https://images.zeroingpython.top/img/image-20210403131925463.png)]

3.1 修复不带折痕的照片

对于不带折痕的照片,终端输入时需要三个参数,

  • --input_folder ,存放需要修复图片的文件路径,不指定时默认为 ./test_images/old;

  • --output_folder,存放修复后图片的文件路径,不指定时默认为 ./output/

  • --GPU,指定用到的 GPU 编号,可设定为 00,10,1,2 ,没有 GPU 配置时 设为 -1 表示运行时只用 CPU ; 设定 GPU 时需要确保配置的 Pytorch 是 GPU 版本,相对 CPU 的话,GPU 测试时间会更短;

测试时,启动命令如下,这里 --input_folder、--output_folder参数都为默认,所以命令中加这两个参数,电脑比较渣没有 GPU 所以设为 -1;

python run.py --GPU -1
3.2 修复带折痕的照片

与不带折痕相比,修复带折痕照片要多加入一个参数 --with_scratch,还有一点不同的是存放原照片默认路径更改为为 ./test_images/old_w_scratch ,其它参数设置见 3.1

终端中输入的测试命令如下:

python run.py --GPU -1 --with_scratch

最终的运行结果

image-20210403142509068

官方在 ./test_images/old./test_images/old_w_scratch 文件夹下提供的有测试图片,读者们想要测试自己收集的图片时,有两种方法

  • 1,把自己图片放入默认 --input_folder 文件夹中,运行时无需指定 --input_folder 参数
  • 2,运行命令指定 --input_folder参数,后跟自己存放照片的文件路径;

关于此项目的使用方法,基本就这些了,最后在这里贴几张我运行得到的几张修复图

不带折痕的图像修复

图一

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-eP1jRJb8-1617634643589)(https://images.zeroingpython.top/img/image-20210403143657329.png)]

图二

image-20210403143728767

图三

image-20210403143958480

图四

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-dVq4jqjT-1617634643597)(https://images.zeroingpython.top/img/image-20210403144155738.png)]

上面这张图大致一看没什么变化,是因为原图像本身就很清晰,但如果把图片放大的话就明显看到两者之间的差距

放大后的左图

image-20210403144545563

放大后的右图

image-20210403144557891

带有折痕的图片修复

图一

image-20210403144719774

图二

image-20210403144750227

图三

image-20210403144805095

项目源码获取

为了方便起见,我已经把配置好的项目文件打包成一个解压包,解压后只需安装项目中的所需依赖项即可,无需再配置权重文件;

pip install -r requirements.txt

项目源码获取方式,关注微信公众号:小张Python,后台回复关键字 210404 即可

小结

关于本项目中图像修复技术原理,这里并没有特别介绍,如果只是想用一下这项技术的话,这篇文章已经足够能帮到你了;当然如果有读者想深入了解一下这项技术的背后原理,可以阅读一下原 Paper《Bringing Old Photos Back to Life》

好了,以上就是本篇文章的全部内容了,最后感谢大家的阅读,我们下期见~

你可能感兴趣的:(火爆全网的老照片修复技术,手把手教你怎么玩儿!)