当前位置:   article > 正文

MediaPipe 集成人脸识别,人体姿态评估,人手检测等模型_mediapipe 人脸匹配

mediapipe 人脸匹配

一款多媒体机器学习应用的成败除了依赖于模型本身的好坏,还取决于设备资源的有效调配、多个输入流之间的高效同步、跨平台部署上的便捷程度、以及应用搭建的快速与否。

基于这些需求,除了上述的特性,MediaPipe 还支持 TensorFlow 和 TF Lite 的推理引擎(Inference Engine),任何 TensorFlow 和 TF Lite 的模型都可以在 MediaPipe 上使用。同时,在移动端和嵌入式平台,MediaPipe 也支持设备本身的 GPU 加速。

MediaPipe 主要概念

MediaPipe 的核心框架由 C++ 实现,并提供 Java 以及 Objective C 等语言的支持。MediaPipe 的主要概念包括数据包(Packet)、数据流(Stream)、计算单元(Calculator)、图(Graph)以及子图(Subgraph)。数据包是最基础的数据单位,一个数据包代表了在某一特定时间节点的数据,例如一帧图像或一小段音频信号;数据流是由按时间顺序升序排列的多个数据包组成,一个数据流的某一特定时间戳(Timestamp)只允许至多一个数据包的存在;而数据流则是在多个计算单元构成的图中流动。MediaPipe 图是有向的——数据包从数据源(Source Calculator或者 Graph Input Stream)流入图直至在汇聚结点(Sink Calculator 或者 Graph Output Stream) 离开。

 

 模型的图片代码检测import cv2

  1. import mediapipe as mp
  2. mp_drawing = mp.solutions.drawing_utils
  3. mp_holistic = mp.solutions.holistic
  4. file = '4.jpg'
  5. holistic = mp_holistic.Holistic(static_image_mode=True)
  6. image = cv2.imread(file)
  7. image_hight, image_width, _ = image.shape
  8. image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB)
  9. results = holistic.process(image)

首先,我们导入需要的第三方库,并配置一下需要画图的点的尺寸,线的尺寸以及颜色等,这些信息都可以自行修改,这里我们直接引用官方的配置进行设计(mp.solutions.drawing_utils函数)

然后定义一个holistic检测模型函数。

  1. mp_holistic = mp.solutions.holistic
  2. file = '4.jpg'
  3. holistic = mp_holistic.Holistic(static_image_mode=True)

然后使用我们前期介绍的opencv的相关知识从系统中读取我们需要检测的图片,并获取图片的尺寸。

  1. image = cv2.imread(file)
  2. image_hight, image_width, _ = image.shape

由于OpenCV默认的颜色空间是BGR,但是一般我们说的颜色空间为RGB,这里mediapipe便修改了颜色空间。

然后使用我们前面建立的holistic检测模型,对图片进行检测即可。

  1. image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB)
  2. results = holistic.process(image)

模型检测完成后的结果保存在results里面,我们需要访问此结果,并把检测到的人脸,人手,以及姿态评估的数据点画在原始检测的图片上,以便查看。

  1. if results.pose_landmarks:
  2. print(
  3. f'Nose coordinates: ('
  4. f'{results.pose_landmarks.landmark[mp_holistic.PoseLandmark.NOSE].x * image_width}, '
  5. f'{results.pose_landmarks.landmark[mp_holistic.PoseLandmark.NOSE].y * image_hight})'
  6. )
  7. annotated_image = image.copy()
  8. mp_drawing.draw_landmarks(
  9. annotated_image, results.face_landmarks, mp_holistic.FACE_CONNECTIONS)
  10. mp_drawing.draw_landmarks(
  11. annotated_image, results.left_hand_landmarks, mp_holistic.HAND_CONNECTIONS)
  12. mp_drawing.draw_landmarks(
  13. annotated_image, results.right_hand_landmarks, mp_holistic.HAND_CONNECTIONS)
  14. mp_drawing.draw_landmarks(
  15. annotated_image, results.pose_landmarks, mp_holistic.POSE_CONNECTIONS)

这里我们打印了图片检测的结果,并分别画出人脸检测模型数据,人左右手的检测数据,以及人体姿态检测数据。

  1. #cv2.imshow('annotated_image',annotated_image)
  2. cv2.imwrite('4.png', annotated_image)
  3. cv2.waitKey(0)
  4. holistic.close()

画图完成后,我们可以显示图片方便查看,也可以直接使用OpenCV的imwrite 函数进行结果图片的保存,最后只需要close holistic检测模型,这里在检测多人的时候出现了问题,只是检测了单人,我们后期研究。

当然,我们也可以直接在视频里面进行Mediapipe的模型检测。

  1. import cv2
  2. import time
  3. import mediapipe as mp
  4. mp_drawing = mp.solutions.drawing_utils
  5. mp_holistic = mp.solutions.holistic
  6. holistic = mp_holistic.Holistic(
  7. min_detection_confidence=0.5, min_tracking_confidence=0.5)

 首先跟图片检测一致,我们建立一个holistic检测模型,然后便可以打开摄像头进行模型的检测。

  1. cap = cv2.VideoCapture(0)
  2. time.sleep(2)
  3. while cap.isOpened():
  4. success, image = cap.read()
  5. if not success:
  6. print("Ignoring empty camera frame.")
  7. continue
  8. image = cv2.cvtColor(cv2.flip(image, 1), cv2.COLOR_BGR2RGB)
  9. image.flags.writeable = False
  10. results = holistic.process(image)

首先我们打开默认摄像头,并从摄像头中获取检测的实时图片。

  1. cap = cv2.VideoCapture(0)
  2. while cap.isOpened():
  3. success, image = cap.read()

检测到图片后,我们便可以直接使用图片检测的步骤,进行模型的检测。

  1. image = cv2.cvtColor(cv2.flip(image, 1), cv2.COLOR_BGR2RGB)
  2. image.flags.writeable = False
  3. results = holistic.process(image)

这里我们使用到了cv2.flip(image, 1)图片翻转函数来增强数据图片,由于我们摄像头中的影像跟我们是镜像关系

cv2.flip(image, 1)

使用此函数便可以镜像我们的图片影像,最后把图片赋值给holistic模型进行检测。

  1. image.flags.writeable = True
  2. image = cv2.cvtColor(image, cv2.COLOR_RGB2BGR)
  3. mp_drawing.draw_landmarks(
  4. image, results.face_landmarks, mp_holistic.FACE_CONNECTIONS)
  5. mp_drawing.draw_landmarks(
  6. image, results.left_hand_landmarks, mp_holistic.HAND_CONNECTIONS)
  7. mp_drawing.draw_landmarks(
  8. image, results.right_hand_landmarks, mp_holistic.HAND_CONNECTIONS)
  9. mp_drawing.draw_landmarks(
  10. image, results.pose_landmarks, mp_holistic.POSE_CONNECTIONS)
  11. cv2.imshow('MediaPipe Holistic', image)
  12. if cv2.waitKey(5) & 0xFF == ord('q'):
  13. break
  14. holistic.close()
  15. cap.release()

检测完成后,我们便可以把数据实时进行绘制,以便在视频中实时进行结果的查看。

视频检测

这里由于默认设置,线条与点的尺寸不太合适,我们后期慢慢优化。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/天景科技苑/article/detail/906109
推荐阅读
相关标签
  

闽ICP备14008679号