English | 简体中文
行为识别在智慧社区,安防监控等方向具有广泛应用,PP-Human中集成了基于骨骼点的行为识别模块。
在这里,我们提供了检测/跟踪、关键点识别以及识别摔倒动作的预训练模型,用户可以直接下载使用。
任务 | 算法 | 精度 | 预测速度(ms) | 模型权重 | 预测部署模型 |
---|---|---|---|---|---|
行人检测/跟踪 | PP-YOLOE | mAP: 56.3 MOTA: 72.0 |
检测: 28ms 跟踪:33.1ms |
下载链接 | 下载链接 |
关键点识别 | HRNet | AP: 87.1 | 单人 2.9ms | 下载链接 | 下载链接 |
行为识别 | ST-GCN | 准确率: 96.43 | 单人 2.7ms | - | 下载链接 |
注:
配置文件中与行为识别相关的参数如下:
ACTION:
model_dir: output_inference/STGCN # 模型所在路径
batch_size: 1 # 预测批大小。 当前仅支持为1进行推理
max_frames: 50 # 动作片段对应的帧数。在行人ID对应时序骨骼点结果时达到该帧数后,会通过行为识别模型判断该段序列的动作类型。与训练设置一致时效果最佳。
display_frames: 80 # 显示帧数。当预测结果为摔倒时,在对应人物ID中显示状态的持续时间。
coord_size: [384, 512] # 坐标统一缩放到的尺度大小。与训练设置一致时效果最佳。
./output_inference
路径下。目前行为识别模块仅支持视频输入,启动命令如下:
python deploy/pphuman/pipeline.py --config deploy/pphuman/config/infer_cfg.yml \
--video_file=test_video.mp4 \
--device=gpu \
--enable_action=True
./deploy/pphuman/config/infer_cfg.yml
下可以配置不同模型路径,关键点模型和行为识别模型分别对应KPT
和ACTION
字段,修改对应字段下的路径为实际期望的路径即可。--model_dir
修改模型路径:
python
python deploy/pphuman/pipeline.py --config deploy/pphuman/config/infer_cfg.yml \
--video_file=test_video.mp4 \
--device=gpu \
--enable_action=True \
--model_dir kpt=./dark_hrnet_w32_256x192 action=./STGCN
COCO数据集
部分。每个跟踪ID对应的目标行人各自累计骨骼特征点结果,组成该人物的时序关键点序列。当累计到预定帧数或跟踪丢失后,使用行为识别模型判断时序关键点序列的动作类型。当前版本模型支持摔倒行为的识别,预测得到的class id
对应关系为:
0: 摔倒,
1: 其他
行为识别模型使用了ST-GCN,并基于PaddleVideo套件完成模型训练。
我们已经提供了检测/跟踪、关键点识别以及识别摔倒动作的预训练模型,可直接下载使用。如果希望使用自定义场景数据训练,或是对模型进行优化,根据具体模型,分别参考下面的链接: | 任务 | 算法 | 模型训练及导出文档 | | ---- | ---- | -------- | | 行人检测/跟踪 | PP-YOLOE | 使用教程 | | 关键点识别 | HRNet | 使用教程 | | 行为识别 | ST-GCN | 使用教程 |
@inproceedings{stgcn2018aaai,
title = {Spatial Temporal Graph Convolutional Networks for Skeleton-Based Action Recognition},
author = {Sijie Yan and Yuanjun Xiong and Dahua Lin},
booktitle = {AAAI},
year = {2018},
}