当前位置: 首页 > news >正文

人像面部关键点检测

此工作为本人近期做人脸情绪识别,CBAM模块前是否能加人脸关键点检测而做的尝试。由于创新点不是在于检测点的标注,而是CBAM的改进,因此,只是借用了现成库Dilb与cv2进行。

首先,下载人脸关键点预测模型:Index of /files,文件:shape_predictor_68_face_landmarks.dat

逻辑如下:

   使用cv2库进行图像读取--->

   将读取的图像转为灰度图--->

   判断该图是否存在face--->否--->return

   将读取的图像输入预测模型--->

   进行关键点预测--->(存储关键点位置)

   在原图上进行关键点标识--->

   保存预测后的图。

效果图如下:(使用fer2013数据集)

                                                                         

Python代码如下

import os
import cv2
import dlib
import numpy as np# init
detector = dlib.get_frontal_face_detector()
predictor = dlib.shape_predictor("./shape_predictor_68_face_landmarks.dat")def process_image(image_path, output_dir="output", point_radius=0.1):os.makedirs(output_dir, exist_ok=True)# cv2 read imageimage = cv2.imread(image_path)# image to graygray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)faces = detector(gray, 1)if len(faces) == 0:print(f"no face!:{image_path}")return None# get pointlandmarks = predictor(gray, faces[0])landmarks = np.array([[p.x, p.y] for p in landmarks.parts()])# draw key point for facefor (x, y) in landmarks:cv2.circle(image, (x, y), radius=point_radius, color=(0, 255, 0), thickness=-1)output_path = os.path.join(output_dir, f"processed_{os.path.basename(image_path)}")cv2.imwrite(output_path, image)print(f"Saved:{output_path}")return landmarksif __name__=="__main__":landmarks = process_image(image_path="./00001.png",output_dir="./processed_00001",point_radius=1  # 关键点半径 只能为整型)

相关文章:

  • 【路由交换方向IE认证】BGP选路原则之AS-Path属性
  • 基于autoware1.14的实车部署激光雷达循迹,从建图、定位、录制轨迹巡航点、到实车运行。
  • MySQL+Redis实战教程:从Docker安装部署到自动化备份与数据恢复20250418
  • MCP协议量子加密实践:基于QKD的下一代安全通信(2025深度解析版)
  • 服务器架构:SMP、NUMA、MPP及Docker优化指南
  • Oracle 19c新特性:OCP认证考试与职业跃迁的关键?
  • 日本公司如何实现B2B商城订货系统的自动化和个性化?
  • 珈和科技:无人机技术赋能智慧农业,精准施肥与病虫害监控全面升级
  • STM32F103_HAL库+寄存器学习笔记18 - CAN接收溢出中断
  • win10 应用市场 开发
  • 【java 13天进阶Day04】常用API、正则表达式,泛型、Collection集合API
  • P10416 [蓝桥杯 2023 国 A] XYZ
  • 关于yarn和hadoop
  • STM32 HAL库 Freertos队列使用解析
  • 深入理解红黑树:原理、实现与应用
  • 02.diboot项目分析
  • 【数据结构与算法】——插入排序
  • 论文阅读:2023 arxiv Safe RLHF: Safe Reinforcement Learning from Human Feedback
  • Spring Boot日志系统详解:Logback与SLF4J的默认集成
  • iOS Facebook 登录
  • “80后”保利文化集团董事长王波挂职哈尔滨副市长,负责文旅、招商
  • 大卫·第艾维瑞谈历史学与社会理论②丨马克斯·韦伯与历史学研究
  • 上海之旅相册②俄罗斯Chaika:客居六年,致上海的情书
  • 国开行原副行长李吉平一审获刑14年
  • 中国房地产报:以改促治实现楼市多难并解
  • “30小时不够”,泽连斯基建议延长停火至30天