脸型匹配

方法1,基于曲率,计算曲率组成的特征向量的余弦距离

def cos_sim(vector_a, vector_b):
    """
    计算两个向量之间的余弦相似度
    :param vector_a: 向量 a 
    :param vector_b: 向量 b
    :return: sim
    """
    vector_a = np.mat(vector_a)
    vector_b = np.mat(vector_b)
    num = float(vector_a * vector_b.T)
    denom = np.linalg.norm(vector_a) * np.linalg.norm(vector_b)
    cos = num / denom
    sim = 0.5 + 0.5 * cos
    return sim


def compute_curvature_cov(input_numpy):
    #曲率越大,越弯曲
    #       |y''|
    #k= -----------
    #         3/2
    #   (1+y'2)
    #y’(i) = (y(i+1)-y(i))/h
    #y’’(i) = (y(i+1)+y(i-1)-2*y(i))/h^2

    input_numpy_yijie = (input_numpy[1:,1]-input_numpy[:-1,1])/(input_numpy[1:,0]-input_numpy[:-1,0])
    input_numpy_yijie = input_numpy_yijie[:-1]
    input_numpy_erjie = (input_numpy[2:,1]+input_numpy[:-2,1]-2*input_numpy[1:-1,1])/((input_numpy[2:,0]-input_numpy[:-2,0])*(input_numpy[2:,0]-input_numpy[:-2,0]))
    K = np.abs(input_numpy_erjie) /np.power((np.ones_like(input_numpy_yijie)+input_numpy_yijie*input_numpy_yijie),3.0/2.0)

    return K

方法2,基于人脸关键点坐标的L1距离,

方法3,基于对比的两个人脸的关键点组成区域的交集占整个图片的面积,

def area_sim(keypoints_Xs, keypoints_Xt):
    keypoints_Xt = keypoints_Xt.reshape(-1,2)
    process_num = 17
    keypoints_Xs = keypoints_Xs[:process_num]
    keypoints_Xt = keypoints_Xt[:process_num]

    scale = 256
    mask = np.zeros((scale,scale),np.uint8)
    for i in range(process_num-1):
        triangle = np.array([[[keypoints_Xs[i,0],keypoints_Xs[i,1]], [keypoints_Xs[i+1,0],keypoints_Xs[i+1,1]], [keypoints_Xt[i,0],keypoints_Xt[i,1]]]], dtype = np.int32)
        cv2.fillPoly(mask, triangle, 1)
        triangle = np.array([[[keypoints_Xs[i,0],keypoints_Xs[i,1]], [keypoints_Xs[i+1,0],keypoints_Xs[i+1,1]], [keypoints_Xt[i+1,0],keypoints_Xt[i+1,1]]]], dtype = np.int32)
        cv2.fillPoly(mask, triangle, 1)
        triangle = np.array([[[keypoints_Xt[i,0],keypoints_Xt[i,1]], [keypoints_Xt[i+1,0],keypoints_Xt[i+1,1]], [keypoints_Xs[i,0],keypoints_Xs[i,1]] ]], dtype = np.int32)
        cv2.fillPoly(mask, triangle, 1)
        triangle = np.array([[[keypoints_Xt[i,0],keypoints_Xt[i,1]], [keypoints_Xt[i+1,0],keypoints_Xt[i+1,1]], [keypoints_Xs[i+1,0],keypoints_Xs[i+1,1]] ]], dtype = np.int32)
        cv2.fillPoly(mask, triangle, 1)

    dis = 1- np.sum(mask)/(scale*scale)
    return dis,mask

方法4,对上面的3种方法进行融合,


def total_method(keypoints_Xs, keypoints_Xt):
    #(68, 2) (54,)
    #一共68个关键点,取前17个人脸边缘轮廓点使用
    keypoints_Xt = keypoints_Xt.reshape(-1,2)
    process_num = 17

    #method 1,曲率
    qulv_Xs = compute_curvature_cov(keypoints_Xs[:process_num])
    qulv_Xt = compute_curvature_cov(keypoints_Xt[:process_num])

    weights_matrix = np.ones_like(qulv_Xt, np.float32)
    #weights_matrix[3:12] =2.0
    dis1 = cos_sim(qulv_Xs*weights_matrix , qulv_Xt*weights_matrix)


    #method 2,坐标L1
    scale  =256
    keypoints_Xs = keypoints_Xs/scale
    keypoints_Xt = keypoints_Xt/scale

    dis2 = 1 - np.mean(np.abs(keypoints_Xs[:process_num] - keypoints_Xt[:process_num]))#cos_sim(keypoints_Xs[:process_num].reshape(-1,1).squeeze(), keypoints_Xt[:process_num].reshape(-1,1).squeeze())

    #method 3,面积
    dis3 ,mask= area_sim(keypoints_Xs*scale, keypoints_Xt*scale )

    dis = 0.1*dis1+ 0.1*dis2 +0.8*dis3



    return dis

调用,


def compare(points_Xs, face_npy):
    #输入:68个关键点numpy,68个人脸数据库,注意所有人脸都需要首先进行对齐操作,然后归一化到256*256
    #输出:最相似人脸轮廓的索引,人脸轮廓的相似度值,人脸轮廓的差异mask list
    indexs = None
    dis_ls = list()
    mask_list = []
    for j in range(len(face_npy)):  # len(face_npy)
        distz, mask = total_method(points_Xs, face_npy[j])
        dis_ls.append(distz)
        mask_list.append(mask)
    dis_ls_arr = np.array(dis_ls)
    print(dis_ls)
    euc_indexs = np.argsort(-1*dis_ls_arr)
    return euc_indexs, dis_ls ,mask_list

 

效果,

融合>面积>L1距离>曲率

 

 

 

 

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MICROSOFT 基础类库: 人脸相似度检测MFC 项目概述 =============================================================================== 应用程序向导已为您创建了这个 人脸相似度检测MFC 应用程序。此应用程序不仅演示 Microsoft 基础类的基本使用方法,还可作为您编写应用程序的起点。 本文件概要介绍组成 人脸相似度检测MFC 应用程序的每个文件的内容。 人脸相似度检测MFC.vcproj 这是使用应用程序向导生成的 VC++ 项目的主项目文件。 它包含生成该文件的 Visual C++ 的版本信息,以及有关使用应用程序向导选择的平台、配置和项目功能的信息。 人脸相似度检测MFC.h 这是应用程序的主要头文件。它包括其他项目特定的头文件(包括 Resource.h),并声明 C人脸相似度检测MFCApp 应用程序类。 人脸相似度检测MFC.cpp 这是包含应用程序类 C人脸相似度检测MFCApp 的主要应用程序源文件。 人脸相似度检测MFC.rc 这是程序使用的所有 Microsoft Windows 资源的列表。它包括 RES 子目录中存储的图标、位图和光标。此文件可以直接在 Microsoft Visual C++ 中进行编辑。项目资源位于 2052 中。 res\人脸相似度检测MFC.ico 这是用作应用程序图标的图标文件。此图标包括在主要资源文件 人脸相似度检测MFC.rc 中。 res\MFC.rc2 此文件包含不在 Microsoft Visual C++ 中进行编辑的资源。您应该将不可由资源编辑器编辑的所有资源放在此文件中。 ///////////////////////////////////////////////////////////////////////////// 应用程序向导创建一个对话框类: 人脸相似度检测MFCDlg.h,人脸相似度检测MFCDlg.cpp - 对话框 这些文件包含 C人脸相似度检测MFCDlg 类。该类定义应用程序主对话框的行为。该对话框的模板位于 人脸相似度检测MFC.rc 中,该文件可以在 Microsoft Visual C++ 中进行编辑。 ///////////////////////////////////////////////////////////////////////////// 其他功能: ActiveX 控件 应用程序包括对使用 ActiveX 控件的支持。 ///////////////////////////////////////////////////////////////////////////// 其他标准文件: StdAfx.h,StdAfx.cpp 这些文件用于生成名为 人脸相似度检测MFC.pch 的预编译头 (PCH) 文件和名为 StdAfx.obj 的预编译类型文件。 Resource.h 这是标准头文件,它定义新的资源 ID。 Microsoft Visual C++ 读取并更新此文件。 人脸相似度检测MFC.manifest 应用程序清单文件供 Windows XP 用来描述应用程序 对特定版本并行程序集的依赖性。加载程序使用此 信息从程序集缓存加载适当的程序集或 从应用程序加载私有信息。应用程序清单可能为了重新分发而作为 与应用程序可执行文件安装在相同文件夹中的外部 .manifest 文件包括, 也可能以资源的形式包括在该可执行文件中。 ///////////////////////////////////////////////////////////////////////////// 其他注释: 应用程序向导使用“TODO:”指示应添加或自定义的源代码部分。 如果应用程序在共享的 DLL 中使用 MFC,则需要重新发布这些 MFC DLL;如果应用程序所用的语言与操作系统的当前区域设置不同,则还需要重新发布对应的本地化资源 MFC90XXX.DLL。有关这两个主题的更多信息,请参见 MSDN 文档中有关 Redistributing Visual C++ applications (重新发布 Visual C++ 应用程序)的章节。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值