Register
Login
Resources
Docs Blog Datasets Glossary Case Studies Tutorials & Webinars
Product
Data Engine LLMs Platform Enterprise
Pricing Explore
Connect to our Discord channel

05_keypoints_from_images_multi_gpu.py 4.2 KB

You have to be logged in to leave a comment. Sign In
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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
  1. # From Python
  2. # It requires OpenCV installed for Python
  3. import sys
  4. import cv2
  5. import os
  6. from sys import platform
  7. import argparse
  8. import time
  9. try:
  10. # Import Openpose (Windows/Ubuntu/OSX)
  11. dir_path = os.path.dirname(os.path.realpath(__file__))
  12. try:
  13. # Windows Import
  14. if platform == "win32":
  15. # Change these variables to point to the correct folder (Release/x64 etc.)
  16. sys.path.append(dir_path + '/../../python/openpose/Release');
  17. os.environ['PATH'] = os.environ['PATH'] + ';' + dir_path + '/../../x64/Release;' + dir_path + '/../../bin;'
  18. import pyopenpose as op
  19. else:
  20. # Change these variables to point to the correct folder (Release/x64 etc.)
  21. sys.path.append('../../python');
  22. # If you run `make install` (default path is `/usr/local/python` for Ubuntu), you can also access the OpenPose/python module from there. This will install OpenPose and the python library at your desired installation path. Ensure that this is in your python path in order to use it.
  23. # sys.path.append('/usr/local/python')
  24. from openpose import pyopenpose as op
  25. except ImportError as e:
  26. print('Error: OpenPose library could not be found. Did you enable `BUILD_PYTHON` in CMake and have this Python script in the right folder?')
  27. raise e
  28. # Flags
  29. parser = argparse.ArgumentParser()
  30. parser.add_argument("--image_dir", default="../../../examples/media/", help="Process a directory of images. Read all standard formats (jpg, png, bmp, etc.).")
  31. parser.add_argument("--no_display", default=False, help="Enable to disable the visual display.")
  32. parser.add_argument("--num_gpu", default=op.get_gpu_number(), help="Number of GPUs.")
  33. args = parser.parse_known_args()
  34. # Custom Params (refer to include/openpose/flags.hpp for more parameters)
  35. params = dict()
  36. params["model_folder"] = "../../../models/"
  37. params["num_gpu"] = int(vars(args[0])["num_gpu"])
  38. numberGPUs = int(params["num_gpu"])
  39. # Add others in path?
  40. for i in range(0, len(args[1])):
  41. curr_item = args[1][i]
  42. if i != len(args[1])-1: next_item = args[1][i+1]
  43. else: next_item = "1"
  44. if "--" in curr_item and "--" in next_item:
  45. key = curr_item.replace('-','')
  46. if key not in params: params[key] = "1"
  47. elif "--" in curr_item and "--" not in next_item:
  48. key = curr_item.replace('-','')
  49. if key not in params: params[key] = next_item
  50. # Construct it from system arguments
  51. # op.init_argv(args[1])
  52. # oppython = op.OpenposePython()
  53. # Starting OpenPose
  54. opWrapper = op.WrapperPython()
  55. opWrapper.configure(params)
  56. opWrapper.start()
  57. # Read frames on directory
  58. imagePaths = op.get_images_on_directory(args[0].image_dir);
  59. # Read number of GPUs in your system
  60. start = time.time()
  61. # Process and display images
  62. for imageBaseId in range(0, len(imagePaths), numberGPUs):
  63. # Create datums
  64. datums = []
  65. images = []
  66. # Read and push images into OpenPose wrapper
  67. for gpuId in range(0, numberGPUs):
  68. imageId = imageBaseId+gpuId
  69. if imageId < len(imagePaths):
  70. imagePath = imagePaths[imageBaseId+gpuId]
  71. datum = op.Datum()
  72. images.append(cv2.imread(imagePath))
  73. datum.cvInputData = images[-1]
  74. datums.append(datum)
  75. opWrapper.waitAndEmplace([datums[-1]])
  76. # Retrieve processed results from OpenPose wrapper
  77. for gpuId in range(0, numberGPUs):
  78. imageId = imageBaseId+gpuId
  79. if imageId < len(imagePaths):
  80. datum = datums[gpuId]
  81. opWrapper.waitAndPop([datum])
  82. print("Body keypoints: \n" + str(datum.poseKeypoints))
  83. if not args[0].no_display:
  84. cv2.imshow("OpenPose 1.5.1 - Tutorial Python API", datum.cvOutputData)
  85. key = cv2.waitKey(15)
  86. if key == 27: break
  87. end = time.time()
  88. print("OpenPose demo successfully finished. Total time: " + str(end - start) + " seconds")
  89. except Exception as e:
  90. print(e)
  91. sys.exit(-1)
Tip!

Press p or to see the previous file or, n or to see the next file

Comments

Loading...