Mediapipe笔记:安装Mediapipe+手部检测+动作识别

Mediapipe

安装Mediapipe

  • 打开Anaconda prompt
  • 检查环境和python运行环境是否一致(默认base环境,不用切换)
  • 输入命令行pip install mediapipe==0.9.1.0 -i https://pypi.tuna.tsinghua.edu.cn/simple

Mediapope完成手部关键点检测

手部检测

  • 创建对象(加载模型参数) mp.solutions.hands.Hands()
  • 图像通道更换(BGR --> RGB) cv2.cvtColor(frame, cv2.COLOR_BGR2RGB)
  • 获得手部标志 result = hand.process(frame_rgb)
  • 获得手部关键点 result.multi_hand_landmarks
  • 获得左手关键点 hand_landmarks = result.multi_hand_landmarks[0]
  • 绘制样式 mp.solutions.drawing_utils.draw_landmarks
    • 参数1 样式绘制的图像
      • 视频捕捉的图像 frame
    • 参数2 左手关键点
      • hand_landmarks
    • 参数3 连接点
      • cnn = mp.solutions.hands_connections.HAND_CONNECTIONS
    • 参数4 关键点样式
      • lm_style = mp.solutions.drawing_styles.DrawingSpec()
    • 参数5 连接线样式
      • cnn_style = mp.solutions.drawing_styles.DrawingSpec(color=(255, 0, 0))

视频捕捉

  • 初始化手部检测属性
    • self.hand = HandProcess()
  • 打开摄像头 cap = cv2.VideoCapture(0)
    • 0 表示打开本地摄像头
    • 1 2 3 外接摄像头
    • 路径/播放视频
  • 循环一帧一帧读取图像 while cap.isOpened():
    • 获得图像 retval, frame = cap.read()
    • 手部检测 self.hand.process(frame)
    • 显示图像 cv2.imshow(‘frame’, frame)
    • 等待显示 key = cv2.waitKey(25)
      • if key == ord(‘z’): break
  • 释放摄像头 cap.release()
  • 释放显示窗口 cv2.destroyAllWindows()

动作识别分析

  1. 准备数据(标准动作/标签)
    • 录制视频,某个动作的视频帧较多(50帧),抽取出(5帧)作为标准的动作
    • 视频保存一帧一帧图像 OpenCV
    • 间隔时间保存
  2. 根据标签提取特征(向量vector)
  3. 保存提取出来的特征(db_feats)
  4. 当前的动作(图像/某帧)提取特征(feat)
  5. 当前的feat和已存储的db_feats进行比较
    • 范式/距离
    • 余弦定理 v1和v2作比较 cos 0-1 (1为最相似)
  6. 模块分析
    • 视频采集 video_process
      • 循环一帧一帧读取图像 capture()
      • 继承修改 process() 用于 pose_rec 调用识别
    • 动作识别 pose_rec
      • 存放 frame_feat 对象
      • 调用 recognize() 进行识别,获得 cal_similarity() 预测动作
    • 提取图像特征 frame_feat
      • 获得关键点 get_pose_landmark
      • 获得图像特征 get_frame_feat
      • 加载标准数据库 load_db_feat
      • 相似度比较 cal_similarity

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/711930.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

(二十二)devops持续集成开发——jenkins服务代理Agent搭建

前言 在Jenkins 中,代理(Agent)是一种用于执行构建、部署和其他任务的计算节点。代理节点可以是物理机器、虚拟机或容器,它们负责接收 Jenkins 主控节点委派的任务并执行这些任务。通过使用代理节点,可以有效地分担Je…

Redis内存淘汰策略详解

Redis作为一个高性能的键值对数据库,被广泛应用于各种需要快速响应和持久存储的场景中。然而,由于其内存存储的特性,当Redis的内存使用达到其最大配置限制时,就需要有一种策略来管理内存的使用,以避免内存溢出。这就是…

NLP Seq2Seq模型

🍨 本文为[🔗365天深度学习训练营学习记录博客🍦 参考文章:365天深度学习训练营🍖 原作者:[K同学啊 | 接辅导、项目定制]\n🚀 文章来源:[K同学的学习圈子](https://www.yuque.com/mi…

深入理解Linux线程(LWP):概念、结构与实现机制(2)

🎬慕斯主页:修仙—别有洞天 ♈️今日夜电波:会いたい—Naomile 1:12━━━━━━️💟──────── 4:59 🔄 ◀️ ⏸ ▶️ ☰ &a…

Vue3+vite打包后页面空白问题

vite.config.js vite.config.js 增加 base: ./ import { fileURLToPath, URL } from node:url import { defineConfig } from vite import vue from vitejs/plugin-vue// https://vitejs.dev/config/ export default defineConfig({base: ./,resolve: {alias: {: fileURLToPath…

解析短视频美颜SDK:美颜美型技术的深度剖析

美颜并非简单的滤镜叠加,而是依托着先进的图像处理和人工智能技术,才能够达到如此出色的效果。本文将深入探讨短视频美颜SDK背后的技术原理和实现方法,从而揭示其美颜美型技术的深度剖析。 一、美颜SDK的基本原理 美颜SDK的基本原理是通过对…

maven 包管理平台-01-maven 入门介绍 + Maven、Gradle、Ant、Ivy、Bazel 和 SBT 的详细对比表格

拓展阅读 maven 包管理平台-01-maven 入门介绍 Maven、Gradle、Ant、Ivy、Bazel 和 SBT 的详细对比表格 maven 包管理平台-02-windows 安装配置 mac 安装配置 maven 包管理平台-03-maven project maven 项目的创建入门 maven 包管理平台-04-maven archetype 项目原型 ma…

docker单机启动mysql、redis容器命令

将your_path、your_password、your_version替换成自己需要的 mysql docker run -d -p 3306:3306 --name mysql --restartalways \ -v /your_path/my.cnf:/etc/mysql/my.cnf \ -v /your_path/log:/logs \ -v /your_path/mysql:/var/lib/mysql \ -e MYSQL_ROOT_PASSWORDyour_pa…

java 企业培训管理系统Myeclipse开发mysql数据库web结构jsp编程计算机网页项目

一、源码特点 java 企业培训管理系统是一套完善的java web信息管理系统,对理解JSP java编程开发语言有帮助,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。开发环境为TOMCAT7.0,Myeclipse8.5开发,数据库为Mysql5.0&…

UCWSC

feature fusion neural network based on a decomposition mechanism (FFDM) 辅助信息 作者未提供代码

学习大数据,所必需的java基础(6)

文章目录 集合Set集合介绍HashSet集合的介绍和使用LinkedHashSet的介绍以及使用哈希值哈希值的计算方式HashSet的存储去重的过程 Map集合Map的介绍HashMap的介绍以及使用HashMap的两种遍历方式方式1:获取key,然后再根据key获取value方式2:同时…

【Sql Server】Update中的From语句,以及常见更新操作方式

欢迎来到《小5讲堂》,大家好,我是全栈小5。 这是《Sql Server》系列文章,每篇文章将以博主理解的角度展开讲解, 特别是针对知识点的概念进行叙说,大部分文章将会对这些概念进行实际例子验证,以此达到加深对…

Docker技术概论(4):Docker CLI 基本用法解析

Docker技术概论(4) Docker CLI 基本用法解析 - 文章信息 - Author: 李俊才 (jcLee95) Visit me at: https://jclee95.blog.csdn.netMy WebSite:http://thispage.tech/Email: 291148484163.com. Shenzhen ChinaAddress of this article:http…

Python实现PPT演示文稿中视频的添加、替换及提取

无论是在教室、会议室还是虚拟会议中,PowerPoint 演示文稿都已成为一种无处不在的工具,用于提供具有影响力的可视化内容。PowerPoint 提供了一系列增强演示的功能,在其中加入视频的功能可以大大提升整体体验。视频可以传达复杂的概念、演示产…

ArkTS中的路由跳转和HTTP数据请求

路由跳转 步骤1:找到箭头所指的文件,在其中添加已创建的页面 步骤2:导包 步骤3: HTTP数据请求 步骤1:导包 > import http from ohos.net.http; 步骤2:(如果需要在页面加载前请求&#xf…

TcpServer服务器管理模块(模块十)

目录 类功能 类定义 类实现 编译测试 server.cc gdb测试断点 忽略SIGPIPE信号 类功能 类定义 // TcpServer服务器管理模块(即全部模块的整合) class TcpServer { private:uint64_t _next_id; // 这是一个自动增长的连接IDint _port;i…

Linux学习-C语言-运算符

目录 算术运算符: - * /:不能除0 %:不能对浮点数操作 :自增与运算符 i:先用再加 i:先加再用 --:自减运算符 常量,表达式不可以,--,变量可以 赋值运算符 三目运算符 逗号表达式 size…

alpine创建lnmp环境alpine安装nginx+php5.6+mysql

前言 制作lnmp环境,你可以在alpine基础镜像中安装相关的服务,也可以直接使用Dockerfile创建自己需要的环境镜像。 注意:提前确认自己的alpine版本,本次创建基于alpine3.6进行创建,官方在一些版本中删除了php5 1、拉取…

JS正则02——js正则表达式中常用的方法、常见修饰符的使用详解以及各种方法使用情况示例

JS正则02——js正则表达式中常用的方法、常见修饰符的使用详解以及各种方法使用情况示例 1. 前言1.1 简介1.2 js正则特殊字符即使用示例 2. 创建正则表达式的方式2.1 两种创建正则表达式的方式2.2 关于修饰符 3. 正则表达式中常用的方法3.1 test() 方法——正则表达式对象的方法…

Vue之监测数据的原理(对象)

大家有没有想过,为什么vue可以监测到数据发生改变?其实底层借助了Object.defineProperty,底层有一个Observer的构造函数 让我为大家简单的介绍一下吧! 我用对象为大家演示一下 const vm new Vue({el: "#app",data: {ob…