基于人脸5个关键点的人脸对齐(人脸纠正)

摘要:人脸检测模型输出人脸目标框坐标和5个人脸关键点,在进行人脸比对前,需要对检测得到的人脸框进行对齐(纠正),本文将通过5个人脸关键点信息对人脸就行对齐(纠正)。

一、输入图像就行人脸检测:

人脸检测模型输出每个人脸的目标框坐标以及5个关键点坐标。

二、利用5个特征点进行人脸对齐(纠正)

人脸1:

人脸1纠正结果:

人脸2:

人脸2纠正后结果:

人脸3:

人脸3纠正后结果:

三、人脸对齐(纠正)代码示例:

python 复制代码
import cv2
import numpy as np
import skimage.transform


ST_KEYPOINT = np.array(
    [
        [0.34191607, 0.46157411],
        [0.65653393, 0.45983393],
        [0.500225, 0.64050536],
        [0.37097589, 0.82469196],
        [0.63151696, 0.82325089]]
    , dtype=np.float32)


def get_aligned_face(image, keypoint, align_size):
    '''
    Args:
        image: origin imsge
        keypoint: five keypoints with shape of (5, 2)
        align_size: output size of (w, h), exp: (112, 112)
    Returns:
        aligned face with the size of align_size
    '''

    st_kp = ST_KEYPOINT * np.array(align_size)
    st = skimage.transform.SimilarityTransform()  # define the  function of affine transformation
    st.estimate(keypoint, st_kp)  # calculate the matrix of affine transformation
    align_face = cv2.warpAffine(image, st.params[0:2, :], align_size, flags=cv2.INTER_LINEAR, borderValue=0.0)  # face align
    return align_face
相关推荐
元亓亓亓3 分钟前
LeetCode热题100--739. 每日温度--中等
python·算法·leetcode
一碗白开水一6 分钟前
【论文阅读】Denoising Diffusion Probabilistic Models (DDPM)详细解析及公式推导
论文阅读·人工智能·深度学习·算法·机器学习
是Dream呀10 分钟前
多样化算力使能:openFuyao引领算力池化与调度革命
人工智能·python·算力
CoovallyAIHub15 分钟前
AI模型训练有哪些关键步骤与必备工具?从概念到可运行的智能模型
深度学习·算法·计算机视觉
Daily Mirror24 分钟前
Day 32 类的定义和方法
python
秋刀鱼 ..31 分钟前
第五届机电一体化、自动化与智能控制国际学术会议(MAIC 2025)
运维·人工智能·python·机器人·自动化·制造·新人首发
musk121238 分钟前
深度学习中 z-score 标准化理解
人工智能·深度学习·z-socre
2501_9216494938 分钟前
亚太股票数据API:日股、韩股、新加坡股票、印尼股票市场实时行情,实时数据API-python
开发语言·后端·python·websocket·金融
Hello.Reader40 分钟前
用 Python 跑通第一个 Flink ML 项目KMeans 聚类从本地到集群实战
python·flink·kmeans
Wiktok43 分钟前
【WIT】解决导入pywinauto相关库会导致程序UI界面(tkinter/pyside6)浏览文件等操作卡住问题
python·ui·pywinauto