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

人像面部关键点检测

此工作为本人近期做人脸情绪识别,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  # 关键点半径 只能为整型)

http://www.xdnf.cn/news/150.html

相关文章:

  • 力扣刷题Day 20:柱状图中最大的矩形(84)
  • FPGA HR Bank如何支持ODELAY问题分析
  • Yocto项目实战教程 · 第4章:4.3小节-层
  • 七、LangChain Tool类参数对接机制解析:基于Pydantic的类型安全与流程实现
  • JavaScript 核心特性完全指南
  • Python如何助力区块链网络安全?从攻击防范到智能合约审计
  • Jenkins 多分支管道
  • uniapp打包报错,
  • LeetCode -- Flora -- edit 2025-04-17
  • 间接飞行时间 (iToF) 原理介绍
  • 守护进程编程
  • idea 许可证过期
  • docker中freshrss不自动更新问题解决方案
  • 【ROS】TEB 规划器
  • Vue3 + TypeScript中provide和inject的用法示例
  • 【映客直播-注册/登录安全分析报告】
  • Kafka系列之:计算kafka集群topic占的存储大小
  • FairMOT与MCFairMOT算法对比
  • 智能翻译播放器,让无字幕视频不再难懂
  • 基于CNN卷积神经网络和GEI步态能量提取的视频人物步态识别算法matlab仿真
  • 基于WOA鲸鱼优化的NARMAX模型参数辨识算法MATLAB仿真,对比PSO优化算法
  • 系统架构师2025年论文写作技巧
  • 使用Pydantic优雅处理几何数据结构 - 前端输入验证实践
  • RESTful API工具和框架详解
  • (论文阅读)RNNoise 基于递归神经网络的噪声抑制库
  • 第五章 SQLite数据库:5、SQLite 进阶用法:JOIN、UNION、TRIGGER、INDEX、ALIAS、INDEXED BY 等模块
  • 2025年GitHub平台上的十大开源MCP服务器汇总分析
  • 主动防御VS自动化筛查:渗透测试与漏洞扫描的深度攻防指南
  • 【Easylive】微服务架构在系统中的优缺点的具体体现
  • Linux之基础命令