妆容迁移的目的在于从给定的一个带妆图片中的化妆风格迁移到一张不带妆的照片中,并且保留其面部特征。属于局部风格迁移。
这种实例级别的风格迁移比常规的域迁移更具有挑战性:
BeautyGAN:综合考虑global domain-level loss, 和local instance-level loss. 使用两个输入输出的GAN网络。总的损失函数包括四个部分:
此外还开源了一个数据集,包括3834张高分辨率的面部照片。
例如美图秀秀等传统的虚拟画妆工具需要用户手动的进行交互,并且只提供一小部分固定的妆容风格。
而自动的妆容迁移是一种帮助用户选择最合适的妆容风格的有效方法,通过给定一些妆容的参考,可以在不改变面部特征的情况下,实现自动对不带妆的照片进行上妆。
目前自动的妆容迁移技术主要分为两类:传统的图像处理方法和深度学习的方法。其中图像处理方法通常将图像分解成几层(例如,面部结构,颜色,皮肤),将参考面部图像变形为非化妆图像之后,将每一层迁移。深度学习的方法采用几个独立的网络单独处理不同的妆容。之前的方法将妆容的风格看作为不同“容器”的简单的组合,因此,在组合位置时,整体输出图像看起来不自然。
妆容迁移是无法直接使用端到端的结构产生高质量的图像的,因为妆容迁移存在以下问题:
BeautyGAN:
网络首先使用几个判别器将非化妆脸部转移到化妆域,以区分从domain真实样本生成的图像。在域级别迁移的基础上,在不同面部区域的计算用像素直方图损失实现实例级别的迁移。为了保留脸部特征,还在整体损失函数中加入了感知损失和循环一致性损失。
两张图片作为输入,A是不带妆的图片的集合,B是带妆的图片集合。
其中 I s r c I_{src} Isrc作为不带妆的源图片, I r e f I_{ref} Iref作为带妆的参考图片。
网络输出为 I s r c B I_{src}^{B} IsrcB作为带妆的源图片:在保留源图片的面部特征下,合成参考图片的妆容风格。
I r e f A I_{ref}^{A} IrefA作为不带妆的参考图片:参考图片去掉妆容的图片。
首先输入两张图片,然后通过不同的两组卷积提取特征,然后concatenate在一起,
输入residual block中,之后通过两组反卷积,将输出的feature map上采样,生成 I s r c B I_{src}^{B} IsrcB和 I r e f A I_{ref}^{A} IrefA
生成的图片再次经过同样的G得到最终的 I s r c r e c I^{rec}_{src} Isrcrec和 I r e f r e c I^{re c}_{ref} Irefrec。
注意:
生成器G使用了instance normalization
判别器 D A D_A DA, D B D_B DB中使用了 70*70 的 Patch GAN
总的Loss函数包括四个部分:
GAN Loss主要是使得生成的图片更加逼真。
其包括两个判别器 D A D_A DA、 D B D_B DB的对抗损失
Perceptual Loss 的目的在于更好的保留图片的面部特征。
首先使用16层的VGG网络在ImageNet上做预训练, F l ( x ) F_l(x) Fl(x)表示图片X在VGG中第i层的特征, C l , H l , W l C_l, H_l, W_l Cl,Hl,Wl分别是feature map的数量、高度、宽度。
Cycle Consistency Loss 目的在于保持背景信息的一致。
通过直接对比生成图像和原图像的距离,L1或者L2距离都可以。
Makeup Loss目的在于迁移时只将化妆部位的颜色迁移过来,而不改变源图的形态。具体的方法是采用直方图匹配(Histogram Matching)。
首先先对 I s r c I_{src} Isrc, I r e f I_{ref} Iref, I s r c B I_{src}^{B} IsrcB面部进行分割,采用的方法是PSPNet,得到不同部位的Mask,在所有的Mask中只挑选出face eye lip部分进行二值化,得到 M l i p M_{lip} Mlip, M l e y e M_{leye} Mleye, M f a c e M_{face} Mface.。
然后用该模板与对应的图像相乘,得到源图片x和参考图片y的不同部位。
对这些部位进行颜色直方图匹配,得到相同颜色分布的H(x,y),其保留了x的特征,和y的颜色分布。
然后对生成的带妆图 I s r c B I^B_{src} IsrcB和直方图匹配的函数进行对比。
利用人对不同方法生成的图片进行打分,可以看到BueatyGAN打分在RANK1区间的最高,所以效果最好。
对不同的Loss的作用进行对比。
可以看到去掉了perceptual loss之后,面部的特征发生了变化,所以perceptual loss的作用对于保留面部特征起到很大的作用。
C、D、E依次加上了不同化妆部位的Loss,可以看到三个不同部分的妆容依次添加了上去。
本文发布于:2024-01-28 17:18:59,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/17064335469006.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |