12#include <openpose/flags.hpp>
13#include <openpose/headers.hpp>
21 0 <= FLAGS_logging_level && FLAGS_logging_level <= 255,
"Wrong logging_level value.",
22 __LINE__, __FUNCTION__, __FILE__);
23 op::ConfigureLog::setPriorityThreshold((op::Priority)FLAGS_logging_level);
24 op::Profiler::setDefaultX(FLAGS_profile_speed);
28 const auto outputSize = op::flagsToPoint(op::String(FLAGS_output_resolution),
"-1x-1");
30 const auto netInputSize = op::flagsToPoint(op::String(FLAGS_net_resolution),
"-1x368");
32 const auto faceNetInputSize = op::flagsToPoint(op::String(FLAGS_face_net_resolution),
"368x368 (multiples of 16)");
34 const auto handNetInputSize = op::flagsToPoint(op::String(FLAGS_hand_net_resolution),
"368x368 (multiples of 16)");
36 const auto poseMode = op::flagsToPoseMode(FLAGS_body);
38 const auto poseModel = op::flagsToPoseModel(op::String(FLAGS_model_pose));
40 if (!FLAGS_write_keypoint.empty()) {
41 op::opLog(
"Flag 'write_keypoint' is deprecated and will eventually be removed. Please, use 'write_json'"
42 " instead.", op::Priority::Max);
45 const auto keypointScaleMode = op::flagsToScaleMode(FLAGS_keypoint_scale);
47 const auto heatMapTypes = op::flagsToHeatMaps(FLAGS_heatmaps_add_parts, FLAGS_heatmaps_add_bkg,
48 FLAGS_heatmaps_add_PAFs);
49 const auto heatMapScaleMode = op::flagsToHeatMapScaleMode(FLAGS_heatmaps_scale);
51 const auto multipleView = (FLAGS_3d || FLAGS_3d_views > 1);
53 const auto faceDetector = op::flagsToDetector(FLAGS_face_detector);
54 const auto handDetector = op::flagsToDetector(FLAGS_hand_detector);
56 const bool enableGoogleLogging =
true;
59 const op::WrapperStructPose wrapperStructPose{
60 poseMode, netInputSize, FLAGS_net_resolution_dynamic, outputSize, keypointScaleMode, FLAGS_num_gpu,
61 FLAGS_num_gpu_start, FLAGS_scale_number, (float)FLAGS_scale_gap,
62 op::flagsToRenderMode(FLAGS_render_pose, multipleView), poseModel, !FLAGS_disable_blending,
63 (float)FLAGS_alpha_pose, (
float)FLAGS_alpha_heatmap, FLAGS_part_to_show, op::String(FLAGS_model_folder),
64 heatMapTypes, heatMapScaleMode, FLAGS_part_candidates, (float)FLAGS_render_threshold,
65 FLAGS_number_people_max, FLAGS_maximize_positives, FLAGS_fps_max, op::String(FLAGS_prototxt_path),
66 op::String(FLAGS_caffemodel_path), (float)FLAGS_upsampling_ratio, enableGoogleLogging};
67 opWrapper.configure(wrapperStructPose);
69 const op::WrapperStructFace wrapperStructFace{
70 FLAGS_face, faceDetector, faceNetInputSize,
71 op::flagsToRenderMode(FLAGS_face_render, multipleView, FLAGS_render_pose),
72 (float)FLAGS_face_alpha_pose, (
float)FLAGS_face_alpha_heatmap, (float)FLAGS_face_render_threshold};
73 opWrapper.configure(wrapperStructFace);
75 const op::WrapperStructHand wrapperStructHand{
76 FLAGS_hand, handDetector, handNetInputSize, FLAGS_hand_scale_number, (float)FLAGS_hand_scale_range,
77 op::flagsToRenderMode(FLAGS_hand_render, multipleView, FLAGS_render_pose), (float)FLAGS_hand_alpha_pose,
78 (
float)FLAGS_hand_alpha_heatmap, (float)FLAGS_hand_render_threshold};
79 opWrapper.configure(wrapperStructHand);
81 const op::WrapperStructExtra wrapperStructExtra{
82 FLAGS_3d, FLAGS_3d_min_views, FLAGS_identification, FLAGS_tracking, FLAGS_ik_threads};
83 opWrapper.configure(wrapperStructExtra);
85 const op::WrapperStructOutput wrapperStructOutput{
86 FLAGS_cli_verbose, op::String(FLAGS_write_keypoint), op::stringToDataFormat(FLAGS_write_keypoint_format),
87 op::String(FLAGS_write_json), op::String(FLAGS_write_coco_json), FLAGS_write_coco_json_variants,
88 FLAGS_write_coco_json_variant, op::String(FLAGS_write_images), op::String(FLAGS_write_images_format),
89 op::String(FLAGS_write_video), FLAGS_write_video_fps, FLAGS_write_video_with_audio,
90 op::String(FLAGS_write_heatmaps), op::String(FLAGS_write_heatmaps_format), op::String(FLAGS_write_video_3d),
91 op::String(FLAGS_write_video_adam), op::String(FLAGS_write_bvh), op::String(FLAGS_udp_host),
92 op::String(FLAGS_udp_port)};
93 opWrapper.configure(wrapperStructOutput);
96 if (FLAGS_disable_multi_thread)
97 opWrapper.disableMultiThreading();
98 }
catch (
const std::exception & e) {
99 op::error(e.what(), __LINE__, __FUNCTION__, __FILE__);
105 gflags::ParseCommandLineFlags(argc, argv,
true);
106 op::Wrapper opWrapper { op::ThreadManagerMode::Asynchronous };
110 const auto imagePaths = op::getFilesOnDirectory(FLAGS_image_dir, op::Extensions::Images);
113 for (
const auto & imagePath : imagePaths) {
114 const cv::Mat cvImageToProcess = cv::imread(imagePath);
115 const op::Matrix imageToProcess = OP_CV2OPCONSTMAT(cvImageToProcess);
116 auto datumProcessed = opWrapper.emplaceAndPop(imageToProcess);
118 }
catch (
const std::exception & e) {
133 char *** localArgv = usageManagerInstance->
get_argv();
134 std::stringstream openPoseTerminalCommand;
140 openPoseTerminalCommand <<
"cd " << openPoseFolder <<
" && " << openPoseExecuteCommand
141 <<
" --net_resolution -1x128 --num_gpu 1 --num_gpu_start 2 --display 0 --render_pose 0 --image_dir "
142 << imagesFolder <<
"rgb/" <<
" --write_json " << outputFolder <<
"op/"
143 <<
" --logging_level 255 > /dev/null";
void configureWrapper(op::Wrapper &opWrapper)
void saveOpenPoseOutput(int *argc, char ***argv)
void setCommand(int *argc, char ***argv) override
Set the string command to an OpenPose properly formatted command.
virtual void setCommand(int *argc, char ***argv)=0
Set the string command. The method is inherited from the subclasses and overridden in order to expres...
UsageManager class is a utility class that helps with configuration parameters.
char *** get_argv(void)
Get the argv's pointer.
static UsageManager * getInstance(void)
Get the unique class instance. This methods should be called in the following scenario: when we just ...
static const short int openPoseFolderOffset
static const short int imagesFolderOffset
static const short int openPoseExecuteCommandOffset
static const short int USAGE_MANAGER_NULLPTR_ERROR
static const short int outputFolderOffset
static const char * USAGE_MANAGER_NULLPTR_SCOPE