-
Notifications
You must be signed in to change notification settings - Fork 33
/
Copy pathwholebody_demo.py
50 lines (37 loc) · 1.2 KB
/
wholebody_demo.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
import time
import cv2
from rtmlib import PoseTracker, Wholebody, draw_skeleton
# import numpy as np
device = 'cpu'
backend = 'onnxruntime' # opencv, onnxruntime, openvino
cap = cv2.VideoCapture(0)
openpose_skeleton = False # True for openpose-style, False for mmpose-style
wholebody = PoseTracker(
Wholebody,
det_frequency=7,
to_openpose=openpose_skeleton,
mode='performance', # balanced, performance, lightweight
backend=backend,
device=device)
frame_idx = 0
while cap.isOpened():
success, frame = cap.read()
frame_idx += 1
if not success:
break
s = time.time()
keypoints, scores = wholebody(frame)
det_time = time.time() - s
print('det: ', det_time)
img_show = frame.copy()
# if you want to use black background instead of original image,
# img_show = np.zeros(img_show.shape, dtype=np.uint8)
# print(scores)
img_show = draw_skeleton(img_show,
keypoints,
scores,
openpose_skeleton=openpose_skeleton,
kpt_thr=4)
img_show = cv2.resize(img_show, (960, 540))
cv2.imshow('img', img_show)
cv2.waitKey(10)