python opencv做界面 python基于opencv的人脸识别

0 前言当前基于深度学习的人工智能的换脸技术比较多,但实际上,对于一些相同角度、相似肤色换脸场景其实无须通过深度学习模型即可达到比较好的效果 。本文基于OpenCV针对相同脸部角度、相似肤色场景实现完美换脸 。最终效果如下所示(下图为动态图,读者可以仔细观察脸部变化过程):

python opencv做界面 python基于opencv的人脸识别

文章插图


1 原理原理如下:
  1. 查找脸部关键点
  2. 获取关键点凸包,并对凸包点计算delanauy三角形 。
  3. 每个对应的delanauy三角形做仿射变换
  4. 人脸融合
2 查找脸部关键点脸部关键点可以通过dlib库获取:
pip install dlib
如果安装失败,可以尝试一下将Python版本降到3.6
dlib可以检测人脸68个关键点,如下所示:
python opencv做界面 python基于opencv的人脸识别

文章插图
68个关键点
3 delanauy三角形得到68个关键点后无法直接贴脸,因为每个人的脸型大小不一致 。为了适配不同大小的脸型,我们将人脸区域划分为多个delanauy三角形,每个三角形区域单独做仿射变换 。
首先获取人脸关键点凸包,即得到处于外围的关键点,直接调用opencv函数cv2.convexHull即可 。得到如下所示:
python opencv做界面 python基于opencv的人脸识别

文章插图

对凸包点计算delanauy三角形,每个三角形区域单独仿射变换 。如下所示:
python opencv做界面 python基于opencv的人脸识别

文章插图
仿射变换实现如下:
def apply_affine_transform(src, src_tri, dst_tri, size):
\'\'\' 应用仿射变换
src: 输入图像
src_tri: 输入图像中的三个点
dst_tri: 输入图像三个点对应输出图像中三个点
size: 输出图像大小
return: 返回输入图像按照两个三角形对应点的仿射变换得到的图像
\'\'\'
# 得到仿射矩阵
warp_mat = cv2.getAffineTransform(np.float32(src_tri), np.float32(dst_tri))

# Apply the Affine Transform just found to the src image
dst = cv2.warpAffine(src,
warp_mat, (size[0], size[1]),