YOLO7 姿势识别实例

news/2024/11/29 7:51:37/

文章目录

  • 1. 预训练模型
  • 2. 测试代码
  • 3. 运行代码
  • 4. 问题

上文搭建了YOLO7开发环境,并进行了物体定位测试。参见:YOLO7环境搭建、代码测试。本文将介绍如何使用YOLO7进行姿势识别。
姿势识别

1. 预训练模型

下载YOLO7姿势识别预训练模型(点击下载),将下载的yolov7-w6-pose.pt放到YOLO7项目根目录下。
预训练模型下载

2. 测试代码

在项目跟目录下,新建文件pos_reg.py,并输入如下代码:

# 姿势识别# 导入类库
import matplotlib.pyplot as plt
import torch
import cv2
from torchvision import transforms
import numpy as np
from utils.datasets import letterbox
from utils.general import non_max_suppression_kpt
from utils.plots import output_to_keypoint, plot_skeleton_kpts# 加载模型
device = torch.device("cuda:0" if torch.cuda.is_available() else "cpu")
weigths = torch.load('yolov7-w6-pose.pt')
model = weigths['model']
model = model.half().to(device)
_ = model.eval()# 读取图片
image = cv2.imread('./person.jpg')
image = letterbox(image, 960, stride=64, auto=True)[0]
image_ = image.copy()
image = transforms.ToTensor()(image)
image = torch.tensor(np.array([image.numpy()]))
image = image.to(device)
image = image.half()# 姿势识别
output, _ = model(image)# 输出结果
output = non_max_suppression_kpt(output, 0.25, 0.65, nc=model.yaml['nc'], nkpt=model.yaml['nkpt'], kpt_label=True)
output = output_to_keypoint(output)
nimg = image[0].permute(1, 2, 0) * 255
nimg = nimg.cpu().numpy().astype(np.uint8)
nimg = cv2.cvtColor(nimg, cv2.COLOR_RGB2BGR)
for idx in range(output.shape[0]):plot_skeleton_kpts(nimg, output[idx, 7:].T, 3)# 保存结果
cv2.imwrite("pos_reg.jpg",nimg)

3. 运行代码

找一张图片放到项目根目录下(示例图片下载),命名为person.jpg。打开并运行pos_reg.py,运行完成后会输出pos_reg.jpg,即姿势识别后的图片。
运行代码
姿势识别

4. 问题

如果提示错误:RuntimeError: Can’t call numpy() on Tensor that requires grad. Use tensor.detach().numpy() instead.,则需修改utils/plots.py的442行和443行,将将cpu().numpy()修改为cpu().detach().numpy()

def output_to_keypoint(output):# Convert model output to target format [batch_id, class_id, x, y, w, h, conf]targets = []for i, o in enumerate(output):kpts = o[:,6:]o = o[:,:6]# 将cpu().numpy()修改为cpu().detach().numpy()for index, (*box, conf, cls) in enumerate(o.cpu().detach().numpy()): targets.append([i, cls, *list(*xyxy2xywh(np.array(box)[None])), conf, *list(kpts.cpu().detach().numpy()[index])])return np.array(targets)

http://www.ppmy.cn/news/334877.html

相关文章

android平板车载,酷狗发布Android Pad版 抢滩车载及平板应用市场

继成功登陆Android手机和苹果手机之后,酷狗音乐隆重推出了其首款为Android平板电脑及车载设备所设计的Android Pad 应用软件。据悉,这是一款针对三星、联想等众多知名品牌推出的安卓平板设备所量身定制的音乐应用软件。它不但沿袭了酷狗音乐pc端及手机端…

平板上pyto软件_平板电脑性价比排行大更新!

阅读本文前,请您先点击上面的蓝色字体,再点击“关注”,这样您就可以继续免费收到最新文章了。每天都有分享。完全是免费订阅,请放心关注。注:本文转载自网络,不代表本平台立场,仅供读者参考&…

电容笔适用所有平板吗?值得推荐电容笔排行

Apple Pencil的性能确实很好,但因为售价太贵,大部分的普通消费者并没有足够的钱去购买。目前市面上有大量的平替电容笔,由于其实惠的价格而深受人们的青睐。那我们该用哪个品牌的电容笔呢?最值得注意的地方又在哪?下面…

几句话,当老板了。

本文原创公众号&#xff1a;不会笑青年&#xff0c;授权转载请联系微信(laughyouth369)&#xff0c;授权后&#xff0c;请在原创发表48小时后再转载。 < END > 作者&#xff1a;不会笑青年 漫画师&#xff1a;Ys #往期精彩内容# 点击关键词&#xff0c;即可获取&#xff…

【MySQL日常运维】Linux安装MySQL5.7.32

【MySQL日常运维】Linux安装MySQL5732 # 添加mysql用户 [rootcentos76mysql57 /]# useradd mysql [rootcentos76mysql57 opt]# ls -lth total 631M -rw-r--r--. 1 root root 631M Sep 4 13:44 mysql-5.7.32-linux-glibc2.12-x86_64.tar.gz # 解压文件 [rootcentos76mysql57 …

心酸,上班带薪拉屎被老板骂了……

&#x1f447;&#x1f447;关注后回复 “进群” &#xff0c;拉你进程序员交流群&#x1f447;&#x1f447; 作者丨了不起的你我他 来源丨了不起的程序员&#xff08;ID&#xff1a;great_developer&#xff09; 珍爱PP 人人有责 写在最后 了不起的程序员摸鱼基地成立了&…

Linux安装MySQL5.7(敲硬核、敲简单der)

文章目录 1.安装前准备2.修改配置文件3.创建操作数据库的用户4.启动数据库5.设置远程访问 1.安装前准备 检查系统有没有安装mysql&#xff0c;需要卸载 rpm -qa | grep mysql如果你的系统有Mariadb数据库&#xff0c;需要卸载 rpm -qa | grep mariadb # 如果存在&#xff0c…

如果员工是老油条,那他的老板也是

分享嘉宾&#xff1a;袁征&#xff08;Eric Yuan&#xff09;&#xff0c;视频会议软件提供商zoom创始人兼首席执行官。在创立zoom之前&#xff0c;曾在WebEx工作&#xff0c;将部门的工程师从区区10名发展到了超过800名&#xff0c;并将收入增长从0发展到超过8亿美元。2018被知…