本节我们继续演示如何使用 demo 脚本进行 2D 脸部关键点的识别。同样的,用户仍要确保开发环境已经安装了 3.0 版本以上的 MMdetection 。
我们在 mmdet model zoo 提供了一个预训练好的脸部 Bounding Box 预测模型,用户可以前往下载。
python demo/topdown_demo_with_mmdet.py \
${MMDET_CONFIG_FILE} ${MMDET_CHECKPOINT_FILE} \
${MMPOSE_CONFIG_FILE} ${MMPOSE_CHECKPOINT_FILE} \
--input ${INPUT_PATH} [--output-root ${OUTPUT_DIR}] \
[--show] [--device ${GPU_ID or CPU}] [--save-predictions] \
[--draw-heatmap ${DRAW_HEATMAP}] [--radius ${KPT_RADIUS}] \
[--kpt-thr ${KPT_SCORE_THR}] [--bbox-thr ${BBOX_SCORE_THR}]
用户可以在 model zoo 获取预训练好的脸部关键点识别模型。
这里我们用 face6 model 来进行演示:
python demo/topdown_demo_with_mmdet.py \
demo/mmdetection_cfg/yolox-s_8xb8-300e_coco-face.py \
https://download.openmmlab.com/mmpose/mmdet_pretrained/yolo-x_8xb8-300e_coco-face_13274d7c.pth \
configs/face_2d_keypoint/rtmpose/face6/rtmpose-m_8xb256-120e_face6-256x256.py \
https://download.openmmlab.com/mmpose/v1/projects/rtmposev1/rtmpose-m_simcc-face6_pt-in1k_120e-256x256-72a37400_20230529.pth \
--input tests/data/cofw/001766.jpg \
--show --draw-heatmap
可视化结果如下图所示:
如果使用了 heatmap-based 模型同时设置了 --draw-heatmap
,预测的热图也会跟随关键点一同可视化出来。
如果想本地保存可视化结果可使用如下命令:
python demo/topdown_demo_with_mmdet.py \
demo/mmdetection_cfg/yolox-s_8xb8-300e_coco-face.py \
https://download.openmmlab.com/mmpose/mmdet_pretrained/yolo-x_8xb8-300e_coco-face_13274d7c.pth \
configs/face_2d_keypoint/rtmpose/face6/rtmpose-m_8xb256-120e_face6-256x256.py \
https://download.openmmlab.com/mmpose/v1/projects/rtmposev1/rtmpose-m_simcc-face6_pt-in1k_120e-256x256-72a37400_20230529.pth \
--input tests/data/cofw/001766.jpg \
--draw-heatmap --output-root vis_results
视频和图片使用了同样的接口,区别在于视频推理时 ${INPUT_PATH}
既可以是本地视频文件的路径也可以是视频文件的 URL 地址。
python demo/topdown_demo_with_mmdet.py \
demo/mmdetection_cfg/yolox-s_8xb8-300e_coco-face.py \
https://download.openmmlab.com/mmpose/mmdet_pretrained/yolo-x_8xb8-300e_coco-face_13274d7c.pth \
configs/face_2d_keypoint/rtmpose/face6/rtmpose-m_8xb256-120e_face6-256x256.py \
https://download.openmmlab.com/mmpose/v1/projects/rtmposev1/rtmpose-m_simcc-face6_pt-in1k_120e-256x256-72a37400_20230529.pth \
--input demo/resources/<demo_face.mp4> \
--show --output-root vis_results --radius 1
这段视频可以在 Google Drive 下载。
Inferencer 提供一个更便捷的推理接口,使得用户可以绕过模型的配置文件和 checkpoint 路径直接使用 model aliases ,支持包括图片路径、视频路径、图片文件夹路径和 webcams 在内的多种输入方式,例如可以这样使用:
python demo/inferencer_demo.py tests/data/wflw \
--pose2d face --vis-out-dir vis_results/wflw --radius 1
该命令会对输入的 tests/data/wflw
下所有的图片进行推理并且把可视化结果都存入 vis_results/wflw
文件夹下。
除此之外, Inferencer 也支持保存预测的姿态结果。具体信息可在 Inferencer 文档 查看。
对于 2D 脸部关键点预测模型,用户可以通过修改配置文件中的 model.test_cfg.flip_test=False
来加速,例如 aflw_hrnetv2 中的第 90 行。