0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

瑞芯微RK3576人体关键点识别算法(骨骼点)

广州灵眸科技有限公司 2025-08-27 10:07 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

1.人体关键点识别简介

人体关键点识别是一种基于深度学习的对人进行检测定位与姿势估计的模型,广泛应用于体育分析、动物行为监测和机器人等领域,帮助机器实时解读物理动作。本算法具有运行效率高、实时性强的特点。

本人员检测算法在数据集表现如下所示:

人体关键点识别算法mAP pose@0.5
Person Pose-S86.3
Person Pose-M89.3

基于EASY-EAI-Orin-Nano(RK3576)硬件主板的运行效率:

算法种类运行效率
Person Pose-S53ms
Person Pose-M93ms

17个人体关键点索引定义:

索引定义
0鼻子
1左眼
2右眼
3左耳
4右耳
5左肩
6右肩
7左肘
8右肘
9左腕
10右腕
11左髋关节
12右髋关节
13左膝
14右膝
15左脚踝
16右脚踝

2.快速上手

如果您初次阅读此文档,请阅读:《入门指南/源码管理及编程介绍/源码工程管理》,按需管理自己工程源码(注:此文档必看,并建议采用【远程挂载管理】方式,否则有代码丢失风险!!!)

2.1开源码工程下载

先在PC虚拟机定位到nfs服务目录,再在目录中创建存放源码仓库的管理目录:

cd ~/nfsroot mkdir GitHub cd GitHub

再通过git工具,在管理目录内克隆远程仓库(需要设备能对外网进行访问)

git clone https://github.com/EASY-EAI/EASY-EAI-Toolkit-3576.git

wKgZO2ie21qAX1F1AAThXkdBXf4444.png

注:

* 此处可能会因网络原因造成卡顿,请耐心等待。

* 如果实在要在gitHub网页上下载,也要把整个仓库下载下来,不能单独下载本实例对应的目录。

2.2开发环境搭建

通过adb shell进入板卡开发环境,如下图所示。

wKgZPGie23iAAjukAASksyxe3Mo794.png

通过以下命令,把nfs目录挂载上nfs服务器。

mount -t nfs -o nolock : /home/orin-nano/Desktop/nfs/

wKgZPGie26OAe4rXAANSYXB8WZg622.png

2.3例程编译

然后定位到板卡的nfs的挂载目录(按照实际挂载目录),进入到对应的例程目录执行编译操作,具体命令如下所示:

cd EASY-EAI-Toolkit-3576/Demos/algorithm-person_pose/ ./build.sh

wKgZO2iuZa-ATRTEAAdJRnzdM6w083.png

2.4模型部署

要完成算法Demo的执行,需要先下载人体关键点识别算法模型。

百度网盘链接为:https://pan.baidu.com/s/1ln9kclhgl6JqXtOzS3y5PQ?pwd=1234(提取码:1234)。

wKgZPGiuZcGAPKKcAASks-zU0ZI206.png

同时需要把下载的人体关键点识别算法模型复制粘贴到Release/目录:

wKgZO2iuZdGAO5NpAAkMUY4UCJ0255.png

2.5例程运行及效果

进入开发板Release目录,执行下方命令,运行示例程序:

cd Release/ ./test-person_pose person_pose_m.model test.jpg

运行例程命令如下所示:

wKgZO2iuZfeAM7CFAAHVjsivpAs751.png

结果图片如下所示:

wKgZO2iuZgaANmrVAApEnAIcuFo367.png

API的详细说明,以及API的调用(本例程源码),详细信息见下方说明。

3.人体关键点检测API说明

  1. 引用方式

为方便客户在本地工程中直接调用我们的EASY EAIapi库,此处列出工程中需要链接的库以及头文件等,方便用户直接添加。

选项

描述

头文件目录easyeai-api/algorithm/person_pose
库文件目录easyeai-api/algorithm/person_pose
库链接参数-lperson_pose

3.1人体关键点识别初始化函数

人体关键点识别初始化函数原型如下所示。

int person_pose_init(const char *c, person_pose_context_t *p_person_pose, int cls_num)

具体介绍如下所示。

函数名:person_pose_init()
头文件person_pose.h
输入参数p_model_path:算法模型的路
输入参数p_person_pose:算法的句柄
输入参数cls_num:类别数
返回值成功返回:0
失败返回:-1
注意事项

3.2人体关键点识别运行函数

人体关键点识别运行函数person_pose_run原型如下所示。

std::vector person_pose_run(cv::Mat image, person_pose_context_t *p_person_pose, float nms_threshold, float conf_threshold);

具体介绍如下所示。

函数名:person_pose_run()
头文件person_pose.h
输入参数image:图像数据输入(cv::Mat是Opencv的类型)
输入参数p_person_pose:算法的句柄
输入参数nms_threshold:NMS阈值
输入参数conf_threshold:置信度阈值
返回值std::vector:person pose检测结果
注意事项

3.3人体关键点识别释放函数

人体关键点识别释放函数原型如下所示。

int person_pose_release(person_pose_context_t* p_person_pose)

具体介绍如下所示。

函数名:person_pose_release()
头文件person_pose.h
输入参数p_person_pose:算法句柄
返回值成功返回:0
失败返回:-1
注意事项

4.人体关键识别算法例程

例程目录为Demos/algorithm-person_pose/test-person_pose.cpp,操作流程如下。

wKgZPGiuZn-AU1JfAATXhWo__pE989.png

参考例程如下所示。

#include #include #include #include #include "person_pose.h" #include // 画线 cv::Mat draw_line(cv::Mat image, float *key1, float *key2, cv::Scalar color) { if (key1[2] > 0.1 && key2[2] > 0.1) { cv::Point pt1(key1[0], key1[1]); cv::Point pt2(key2[0], key2[1]); cv::circle(image, pt1, 2, color, 2); cv::circle(image, pt2, 2, color, 2); cv::line(image, pt1, pt2, color, 2); } return image; } // 绘制结果: // 0鼻子, 1左眼, 2右眼,3左耳,4右耳,5左肩,6右肩,7左肘,8右肘,9左腕,10右腕,11左髋关节,12右髋关节,13左膝,14右膝,15左脚踝,16右脚踝 cv::Mat draw_image(cv::Mat image, std::vector results) { long unsigned int i =0; for (i = 0; i < results.size(); i++) { // 绘制脸部 image = draw_line(image, results[i].keypoints[0], results[i].keypoints[1], CV_RGB(0, 255, 0)); image = draw_line(image, results[i].keypoints[0], results[i].keypoints[2], CV_RGB(0, 255, 0)); image = draw_line(image, results[i].keypoints[1], results[i].keypoints[3], CV_RGB(0, 255, 0)); image = draw_line(image, results[i].keypoints[2], results[i].keypoints[4], CV_RGB(0, 255, 0)); image = draw_line(image, results[i].keypoints[3], results[i].keypoints[5], CV_RGB(0, 255, 0)); image = draw_line(image, results[i].keypoints[4], results[i].keypoints[6], CV_RGB(0, 255, 0)); // 绘制上半身 image = draw_line(image, results[i].keypoints[5], results[i].keypoints[6], CV_RGB(0, 0, 255)); image = draw_line(image, results[i].keypoints[5], results[i].keypoints[7], CV_RGB(0, 0, 255)); image = draw_line(image, results[i].keypoints[7], results[i].keypoints[9], CV_RGB(0, 0, 255)); image = draw_line(image, results[i].keypoints[6], results[i].keypoints[8], CV_RGB(0, 0, 255)); image = draw_line(image, results[i].keypoints[8], results[i].keypoints[10], CV_RGB(0, 0, 255)); image = draw_line(image, results[i].keypoints[5], results[i].keypoints[11], CV_RGB(0, 0, 255)); image = draw_line(image, results[i].keypoints[6], results[i].keypoints[12], CV_RGB(0, 0, 255)); image = draw_line(image, results[i].keypoints[11], results[i].keypoints[12], CV_RGB(0, 0, 255)); // 绘制下半身 image = draw_line(image, results[i].keypoints[11], results[i].keypoints[13], CV_RGB(255, 255, 0)); image = draw_line(image, results[i].keypoints[13], results[i].keypoints[15], CV_RGB(255, 255, 0)); image = draw_line(image, results[i].keypoints[12], results[i].keypoints[14], CV_RGB(255, 255, 0)); image = draw_line(image, results[i].keypoints[14], results[i].keypoints[16], CV_RGB(255, 255, 0)); cv::Rect rect(results[i].left, results[i].top, (results[i].right - results[i].left), (results[i].bottom - results[i].top)); cv::rectangle(image, rect, CV_RGB(255, 0, 0), 2); } return image; } /// 主函数 int main(int argc, char **argv) { if (argc != 3) { printf("%s \n", argv[0]); return -1; } const char *p_model_path = argv[1]; const char *p_img_path = argv[2]; printf("Model path = %s, image path = %s\n\n", p_model_path, p_img_path); cv::Mat image = cv::imread(p_img_path); printf("Image size = (%d, %d)\n", image.rows, image.cols); int ret; person_pose_context_t yolo11_pose; memset(&yolo11_pose, 0, sizeof(yolo11_pose)); person_pose_init(p_model_path, &yolo11_pose, 1); double start_time = static_cast(cv::getTickCount()); std::vector results = person_pose_run(image, &yolo11_pose, 0.35, 0.35); double end_time = static_cast(cv::getTickCount()); double time_elapsed = (end_time - start_time) / cv::getTickFrequency() * 1000; std::cout << "person pose run time: " << time_elapsed << " ms" << std::endl; // 绘制结果 image = draw_image(image, results); cv::imwrite("result.jpg", image); printf("Detect size = %ld\n", results.size()); ret = person_pose_release(&yolo11_pose); return ret; }

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 算法
    +关注

    关注

    23

    文章

    4761

    浏览量

    97153
  • 人工智能
    +关注

    关注

    1813

    文章

    49746

    浏览量

    261601
  • rk3576
    +关注

    关注

    1

    文章

    228

    浏览量

    1374
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    基于RK3576开发板的人脸识别算法

    RK3576开发板展示人脸识别算法例程和API说明
    的头像 发表于 05-07 16:48 2493次阅读
    基于<b class='flag-5'>RK3576</b>开发板的人脸<b class='flag-5'>识别</b><b class='flag-5'>算法</b>

    RK3588与RK3576技术参数详解

    保持高速增长,特别在汽车电子、工业应用、机器视觉及各类机器等重点领域持续扩张。RK3588和RK3576
    的头像 发表于 09-23 08:20 7855次阅读
    <b class='flag-5'>瑞</b><b class='flag-5'>芯</b><b class='flag-5'>微</b><b class='flag-5'>RK</b>3588与<b class='flag-5'>RK3576</b>技术参数详解

    米尔RK3576实测轻松搞定三屏八摄像头

    RK3576参数强劲RK3576推出的一款高性能AIoT处理器,这款芯片以其卓越的计算能力、多屏幕支持、强大的视频编解码能力和高效的
    发表于 01-17 11:33

    国产开发板的端侧AI测评-基于米尔RK3576

    ,国产自主可控必须搞起来。那与非网本期内容就跟自主可控强关联——评测一款基于国产SoC的板卡,由米尔电子推出的RK3576开发板(MYD-LR
    发表于 02-14 16:29

    适配多种系统,米尔RK3576核心板解锁多样化应用

    米尔电子发布的基于 RK3576 核心板和开发板,具备高性能数据处理能力、领先的AI智能分析功能、多样化的显示与操作体验以及强大的扩展性与兼容性,适用于多种应用场景。目前米尔电子
    发表于 05-23 16:07

    Onenet云网关方案应用--基于米尔RK3576开发板

    -------------------------------------------------------------------------------------------------- 板卡说明: MYC-LR3576 核心板是基于
    发表于 06-06 16:54

    单板挑战4路YOLOv8!米尔RK3576开发板性能实测

    道路和车辆形状。 -posePose关键点检测边界框+人体关键(17个)检测人体
    发表于 09-12 17:52

    RK3576机器核心:三屏异显+八路摄像头,重塑机器交互与感知

    RK3576 AIoT处理器处理器凭借其卓越的多屏异显与8路摄像头接入能力,为机器领域带来革新。米尔电子MYD-LR
    发表于 10-29 16:41

    怎样使用Rock-X SDK对人体骨骼关键进行开发获取呢

    主要功能本篇是使用Rock-X SDK进行获取人体骨骼关键快速开发的过程,使用自定义或其它的模型的请使用rknn-toolkit和rk
    发表于 06-29 15:19

    RK3576|触觉智能:开启科技新篇章

    ,创新不止步!”——全新芯片RK3576即将震撼登场。指引科技风潮,创造未来无限可能!这款芯片在
    的头像 发表于 03-21 08:31 2006次阅读
    <b class='flag-5'>瑞</b><b class='flag-5'>芯</b><b class='flag-5'>微</b><b class='flag-5'>RK3576</b>|触觉智能:开启科技新篇章

    新品体验 | RK3576开发板

    前言:RK3576作为第二代8nm高性能AIOT平台,一经推出便获得了极大的关注。广州眺望电子科技有限公司是一家专注于嵌入式处理器模组研发与应用的国家高新技术企业,目前公司已推出
    的头像 发表于 11-01 08:08 2791次阅读
    新品体验 | <b class='flag-5'>RK3576</b>开发板

    有奖丨米尔 RK3576开发板免费试用

    米尔与合作发布的新品基于RK3576应用
    的头像 发表于 11-12 01:00 1250次阅读
    有奖丨米尔 <b class='flag-5'>瑞</b><b class='flag-5'>芯</b><b class='flag-5'>微</b><b class='flag-5'>RK3576</b>开发板免费试用

    追加名额丨米尔RK3576开发板有奖试用

    米尔与合作发布的新品基于RK3576应用
    的头像 发表于 11-22 01:00 1032次阅读
    追加名额丨米尔<b class='flag-5'>瑞</b><b class='flag-5'>芯</b><b class='flag-5'>微</b><b class='flag-5'>RK3576</b>开发板有奖试用

    RK3576主板YNH-536-规格书

    RK3576主板YNH-536-V1
    发表于 05-19 09:51 4次下载

    RK3576RK3576S有什么区别,性能参数配置与型号差异解析

    第二代8nm高性能AIOT平台RK3576家族再添新成员-RK3576S,先说结论:相较主型号的R
    的头像 发表于 08-14 23:57 1767次阅读
    <b class='flag-5'>瑞</b><b class='flag-5'>芯</b><b class='flag-5'>微</b><b class='flag-5'>RK3576</b>与<b class='flag-5'>RK3576</b>S有什么区别,性能参数配置与型号差异解析