Python 搭建 AI 健身评分系统

news/2024/7/7 22:55:07

1f2579cad14c0d7c596c64d02edfe229.gif

作者|李秋键

来源|AI科技大本营(ID:rgznai100)

649818d2fda1c8e8de5cbeb22a05f41e.png

引言

人工智能作为计算机科学的一个分支,其主要是将人的思维与计算机网络相结合,令整个系统在对某一类事物进行处理时实现人工智能化分析,然后结合内部程序的设定,分析出当前事务处理所具备的各类功能如何实现。人工智能作为一项综合性学科,其在发展过程中可分为低级、中级、高级三个阶段,通过技术体系的逐步更新,人们将思维意识与计算机网络系统形成深度融合,利用人工智能体系在社会事务处理中实现智能化转变,以此来达到人力资源节约的效果。

将人工智能与体育产业的融合是指通过智能化体系的融合,体育产业以及其关联行业在发展过程中可对数据信息进行精准分辨,尤其是在大数据发掘技术的作用下,各类工作机制的建设可通过行业领域业务拓展实现技术性融合。然而,从现阶段实际应用趋势来看,人工智能与体育产业的融合无法得到有效基准的制定,这就造成相关职能部门在制定规范制度时,无法将人工智能与体育产业进行深度分析,令制度本身缺乏有效监管性。除此之外,体育产业作为综合型项目,人工智能体系的应用,无法覆盖到整个体育产业链中,只要造成体育项目在实际开展中无法形成合理、科学性的基准,进而令地区体育项目的发展无法达成一致,在一定程度上,将令体育产业形成以地区为主导的滞后性发展现象。

   本项目使用姿态估计技术,提取人体关键点后,对不同人体肢节进行组合,实时评估骨骼向量角数据,并根据人体向量角数据与建立好的标准动作比对,给出各肢体评分,和总评分。在这里我们以举哑铃动作为例,搭建我们的智能健身评分系统:

8b98a4e246aded853191b35b5cbcf05e.png

7dd126b8c8f0f4a7ff60c35e6c99c04c.png

1、系统使用

本系统主要使用的人体姿态估计技术。需要用到的知识点有openpose姿态估计算法、向量角组合和计算,评估准则的判定。

1.1 openpose姿态估计

Open Pose实时姿态监测估计算法是由卡内基梅隆大学的一个团队最先提出的。此算法使用一种叫做人体关键点亲和域的方法连接人体关键点。图中的网络结构分支1的S1代表一组关键点,分支2的Ll代表连接这些关键点的亲和向量。重复此步,可以得到一个所有2D关键点的集合S和关键点相关度的向量集合L,再根据相关度连接将得到一个近似度高的棍型图。所采用的数据集是COCO和MPI,并且收集了试验者执行的不同活动并与计算机相关联,既能检测人体,也能感知到周围环境中的信息。

Open Pose提供了23个精确的身体部位,包括肩膀、肘部、手腕、臀部、膝盖、脚踝等。为了减少数据集的冗余,系统参考不同身体关节的视觉效应,根据人体结构和运动特征将关节分成不同的组,并给每个关节分配不同的权重。

1)面部五官:面部关节分布集中密集,活动范围小。它们很少表现出明显的独立运动。

2)躯干关节:躯干关节包括肩关节、脊椎中心和臀部,它们体现了身体运动位移的主要趋势,是连接身体和四肢的枢纽。

3)一级关节:一级关节包括肘关节和膝关节,包含大量关于四肢动作的信息。当身体旋转和弯曲时,它在视觉上相对躯干关节有更重要的作用。

4)二级连接:二级连接部位包括手腕和脚踝。手腕和踝关节比肘关节和膝盖点延伸得更长,给人留下更加明显的视觉印象。

   5)三级连接:三级点包含右手、右臀、右脚、左手、左臀和左脚。手和脚是手腕和脚踝的延伸,没有明显的视觉印象。

f3818b35cb288c4fba8e7b595a6848d7.png

1.2标准动作

在这里我们设置标准动作如下:

93fd486faf72781a800c84ce81324e68.png

作为标准动作,统计出各个骨骼关键点坐标,并根据不同骨骼坐标点组合形成向量角,并计算不同关节之间的向量角作为标准。

1.3评估标准

对摄像头视频流或者本地视频流数据实时计算各个关键点角度,并逐一对比,并可视化。计算公式按照欧氏距离做出最简单评估即可。

f1afb6204f4d7f1c40e283a0d1c56b50.png

02048d99740fb02a2d8d677536bfb630.png

2、模型实验

2.1 环境搭建

1、首先下载好完整无误配置好的代码(包括模型等等,见文末)。

2、整个多目标动作监测系统的搭建主要是依赖于openpose的姿态识别环境。而openpose的基本环境依赖于python,CUDA和swig的支持,其中python是作为openpose的代码编写和运行工具,CUDA作为调用显卡训练测试的必须软件需要和python版本有一定的关系,swig目的在于给openpose编译环境。根据openpose官方提供的cmu模型、mobilenet_thin模型、mobilenet_v2_large模型和mobilenet_v2_small模型的评价,我们选择了cmu模型作为姿态识别的调用模型,主要原因在于cmu具有更高一些的识别精度。

Openpose的调用在这里通过调用其中设定好的主函数即可,其中包括模型加载程序、调用程序以及Estimator评估等等。

3、配置好python的cuda环境,以及opencv、pyqt5等基础环境。

4、运行GUI.py主界面,点击按钮即可。

2.2 姿态估计

这里设置默认的标准动作位为'Standard/1.jpg',默认使用模型为cmu模型。按照标准的姿态估计配置,设置代码如下:

parser = argparse.ArgumentParser(description='tf-pose-estimation run')
parser.add_argument('--image', type=str, default='Standard/1.jpg')
parser.add_argument('--model', type=str, default='cmu',help='cmu / mobilenet_thin / mobilenet_v2_large / mobilenet_v2_small')
parser.add_argument('--resize', type=str, default='0x0',help='if provided, resize images before they are processed. ''default=0x0, Recommends : 432x368 or 656x368 or 1312x736 ')
parser.add_argument('--resize-out-ratio', type=float, default=4.0,help='if provided, resize heatmaps before they are post-processed. default=1.0')
args = parser.parse_args()
w, h = model_wh(args.resize)
if w == 0 or h == 0:e = TfPoseEstimator(get_graph_path(args.model), target_size=(432, 368))
else:e = TfPoseEstimator(get_graph_path(args.model), target_size=(w, h))

2.3角度计算

计算需要使用到的关节角度,分别为右键、右手臂、左键、左手臂。代码如下:

image1 = TfPoseEstimator.draw_humans(image, humans, imgcopy=True)
cv2.imwrite("../img1.jpg", image1)
f = open("../img1.txt", 'w')
f.close()
line = Vector([0, 100])
'''角度'''
try:# 右肩5RShoulder = Vector(list_sub(skeleton[5], skeleton[6]))RShoulder_angel = line.angle_with(RShoulder)Angels[5]=str(round(RShoulder_angel,1))+"°"# 右手臂6RElbow = Vector(list_sub(skeleton[6], skeleton[7]))RElbow_angel = line.angle_with(RElbow)Angels[6] = str(round(RElbow_angel, 1)) + "°"# 左肩3LShoulder = Vector(list_sub(skeleton[2], skeleton[3]))LShoulder_angel = line.angle_with(LShoulder)Angels[2] = str(round(LShoulder_angel, 1)) + "°"# 左手臂4LElbow = Vector(list_sub(skeleton[3], skeleton[4]))LElbow_angel = line.angle_with(LElbow)Angels[3] = str(round(LElbow_angel, 1)) + "°"state=True
except:pass

2.4 评分可视化

在获取到角度值后,设置各个角度评分为(1 - abs((RShoulder_angel - Standard[i]) / Sum_Standard)) * 100,即最高分为100分,最低分为0分。其中标准对比值由标准动作自行计算,放入数组即可,代码如下:

if state:'''评分'''Standard = [150, 10, 150, 10]Sum_Standard = sum(Standard)Score1 = (1 - abs((RShoulder_angel - Standard[0]) / Sum_Standard)) * 100Score2 = (1 - abs((RElbow_angel - Standard[1]) / Sum_Standard)) * 100Score3 = (1 - abs((LShoulder_angel - Standard[2]) / Sum_Standard)) * 100Score4 = (1 - abs((LElbow_angel - Standard[3]) / Sum_Standard)) * 100Avg_Score=(Score1+Score2+Score3+Score4)/len(Standard)myfont = ImageFont.truetype(r'C:/Windows/SIMLI.TTF', 20)image2 = Image.fromarray(cv2.cvtColor(image2, cv2.COLOR_BGR2RGB))draw = ImageDraw.Draw(image2)draw.text((10, 10), "总评分:"+str(round(Avg_Score,1)), font=myfont, fill=(255, 0, 0))draw.text((10,50), "右肩评分:"+str(round(Score1,1)), font=myfont, fill=(255, 0, 0))draw.text((10, 90), "右臂评分:" + str(round(Score2, 1)), font=myfont, fill=(255, 0, 0))draw.text((10, 130), "左肩评分:" + str(round(Score3, 1)), font=myfont, fill=(255, 0, 0))draw.text((10, 170), "右臂评分:" + str(round(Score4, 1)), font=myfont, fill=(255, 0, 0))image2 = cv2.cvtColor(np.asarray(image2), cv2.COLOR_RGB2BGR)

运行过程如下可见,在这里通过双击“启动.bat”即可直接运行:

035008ae6538087400ce55d2ec2c60ff.png

8e9998d48b2829a5643c3ec382e05b94.png

完整代码:

附行为安全监测系统见文章

https://blog.csdn.net/dQCFKyQDXYm3F8rB0/article/details/120299561。

姿态估计代码:
链接:

https://pan.baidu.com/s/1vkc1EQuaAUMqoaegkdZ_pA

提取码:i46w

健身评分系统代码:

https://download.csdn.net/download/qq_42279468/33154887

李秋键,CSDN博客专家,CSDN达人课作者。硕士在读于中国矿业大学,开发有taptap竞赛获奖等。

e3e57f84ccdafec01d5769dc6ca5b47a.gif

65c4c53b839e8b886f3c3722338b8623.png

资讯

AI 将有自我视觉?Facebook正在研究新系统

资讯

微软、英伟达联手推出最大语言模型

资讯

“倚天”一出,谁与争锋?阿里发布云芯片

技术

ST-GCN 实现人体姿态行为分类

d733a57ed1d6230f09e840022c9d6fab.png

分享

eb1f03646f65859423e673c3a494b745.png

点收藏

e51338c0e8348bf57dd1797c415e4386.png

点点赞

ee83808b11f542758926ccde9c94b192.png

点在看


http://lihuaxi.xjx100.cn/news/258057.html

相关文章

终于把XGBoost总结写出来了!

↑↑↑关注后"星标"Datawhale每日干货 & 每月组队学习,不错过Datawhale干货 作者:王茂霖,华中科技大学,Datawhale成员内容概括XGBoost模型及调参总结XGBoost原理XGBoost优势总结XGBoost参数详解XGBoost快速使用XGBo…

使用 StopWatch 优雅打印执行耗时

欢迎关注方志朋的博客,回复”666“获面试宝典0x01:背景有时在做开发的时候需要记录每个任务执行时间,或者记录一段代码执行时间,最简单的方法就是打印当前时间与执行完时间的差值,然后这样如果执行大量测试的话就很麻烦…

Linux内核网络栈1.2.13-网卡设备的初始化流程

参考资料 <<linux内核网络栈源代码情景分析>>网卡设备的初始化 本文主要描述一下网卡设备的整个初始化的过程&#xff0c;该过程主要就是根据设备的硬件信息来获取与传输网络数据&#xff0c;注册相关的网卡中断处理函数&#xff0c;协议的初始化等内容。 初始化…

Matlab与线性代数 -- 矩阵的水平连接和垂直连接

本图文详细介绍了Matlab中矩阵的水平连接和垂直连接。

教大模型自己跳过“无用”层,推理速度×3性能不变,谷歌MIT这个新方法火了...

点击上方“视学算法”&#xff0c;选择加"星标"或“置顶”重磅干货&#xff0c;第一时间送达萧箫 发自 凹非寺量子位 | 公众号 QbitAI大语言模型用着爽&#xff0c;但推理速度实在太慢了&#xff1f;而且&#xff0c;增加模型体积&#xff0c;推理效果也并不一定就比…

android中的回调

1、引子 android中的回调最经典的就是点击事件设置监听&#xff08;一般通过switch&#xff08;v.getId()&#xff09;&#xff09;这里写个最主要的 btn_rigister.setOnClickListener(new View.OnClickListener() {Overridepublic void onClick(View view) {// TODO log in} }…

动态模板列更新数据分页的例子

前台&#xff1a;<% Page language"c#" Codebehind"WebForm30.aspx.cs" AutoEventWireup"false" Inherits"csdn.WebForm30" %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" > <HTML>…

mysql主主复制

1&#xff1a;两台mysql服务器主主复制大致图 2&#xff1a;大致的思路 (1)两台mysql的my.cnf都配置二进制日志和relay日志 (2)两台都授权一个可复制的账号密码 (3)互相把对面设计master 3: 实现过程如下[类似主从复制] (1)配置192.168.109.121服务器中my.cnf vim /etc/my.cnf …