Fix the issue with increasing latency
This commit is contained in:
parent
5361430648
commit
7d16f899a0
|
@ -50,21 +50,17 @@ class PoseTrackingImpl {
|
||||||
|
|
||||||
MP_RETURN_IF_ERROR(graph.Initialize(config));
|
MP_RETURN_IF_ERROR(graph.Initialize(config));
|
||||||
ASSIGN_OR_RETURN(mediapipe::OutputStreamPoller poller,
|
ASSIGN_OR_RETURN(mediapipe::OutputStreamPoller poller,
|
||||||
graph.AddOutputStreamPoller(kOutputSegmentationStream));
|
graph.AddOutputStreamPoller(kOutputSegmentationStream, true));
|
||||||
|
|
||||||
ASSIGN_OR_RETURN(mediapipe::OutputStreamPoller landmarksPoller,
|
ASSIGN_OR_RETURN(mediapipe::OutputStreamPoller landmarksPoller,
|
||||||
graph.AddOutputStreamPoller(kOutpuLandmarksStream));
|
graph.AddOutputStreamPoller(kOutpuLandmarksStream, true));
|
||||||
|
|
||||||
ASSIGN_OR_RETURN(mediapipe::OutputStreamPoller posePresencePoller,
|
|
||||||
graph.AddOutputStreamPoller(kOutpuPosePresenceStream));
|
|
||||||
|
|
||||||
maskPollerPtr = std::make_unique<mediapipe::OutputStreamPoller>(std::move(poller));
|
maskPollerPtr = std::make_unique<mediapipe::OutputStreamPoller>(std::move(poller));
|
||||||
|
|
||||||
landmarksPollerPtr =
|
landmarksPollerPtr =
|
||||||
std::make_unique<mediapipe::OutputStreamPoller>(std::move(landmarksPoller));
|
std::make_unique<mediapipe::OutputStreamPoller>(std::move(landmarksPoller));
|
||||||
|
|
||||||
posePresencePollerPtr =
|
|
||||||
std::make_unique<mediapipe::OutputStreamPoller>(std::move(posePresencePoller));
|
|
||||||
|
|
||||||
MP_RETURN_IF_ERROR(graph.StartRun({}));
|
MP_RETURN_IF_ERROR(graph.StartRun({}));
|
||||||
}
|
}
|
||||||
|
@ -89,17 +85,9 @@ class PoseTrackingImpl {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
mediapipe::Packet posePresencePacket;
|
|
||||||
if (!posePresencePollerPtr || !posePresencePollerPtr->Next(&posePresencePacket)) return false;
|
|
||||||
auto landmarksDetected = posePresencePacket.Get<bool>();
|
|
||||||
|
|
||||||
if (!landmarksDetected) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Get the graph result packet, or stop if that fails.
|
// Get the graph result packet, or stop if that fails.
|
||||||
mediapipe::Packet maskPacket;
|
mediapipe::Packet maskPacket;
|
||||||
if (!maskPollerPtr || !maskPollerPtr->Next(&maskPacket)) return false;
|
if (!maskPollerPtr || !maskPollerPtr->Next(&maskPacket) || maskPacket.IsEmpty()) return false;
|
||||||
auto& outputFrame = maskPacket.Get<mediapipe::ImageFrame>();
|
auto& outputFrame = maskPacket.Get<mediapipe::ImageFrame>();
|
||||||
|
|
||||||
// Get pose landmarks.
|
// Get pose landmarks.
|
||||||
|
@ -146,14 +134,12 @@ class PoseTrackingImpl {
|
||||||
mediapipe::Packet poseLandmarksPacket;
|
mediapipe::Packet poseLandmarksPacket;
|
||||||
cv::Mat segmentedMask;
|
cv::Mat segmentedMask;
|
||||||
nimagna::cv_wrapper::Point3f poseLandmarks[kLandmarksCount];
|
nimagna::cv_wrapper::Point3f poseLandmarks[kLandmarksCount];
|
||||||
std::unique_ptr<mediapipe::OutputStreamPoller> posePresencePollerPtr;
|
|
||||||
std::unique_ptr<mediapipe::OutputStreamPoller> maskPollerPtr;
|
std::unique_ptr<mediapipe::OutputStreamPoller> maskPollerPtr;
|
||||||
std::unique_ptr<mediapipe::OutputStreamPoller> landmarksPollerPtr;
|
std::unique_ptr<mediapipe::OutputStreamPoller> landmarksPollerPtr;
|
||||||
mediapipe::CalculatorGraph graph;
|
mediapipe::CalculatorGraph graph;
|
||||||
const char* kInputStream = "input_video";
|
const char* kInputStream = "input_video";
|
||||||
const char* kOutputSegmentationStream = "segmentation_mask";
|
const char* kOutputSegmentationStream = "segmentation_mask";
|
||||||
const char* kOutpuLandmarksStream = "pose_landmarks";
|
const char* kOutpuLandmarksStream = "pose_landmarks";
|
||||||
const char* kOutpuPosePresenceStream = "pose_presence";
|
|
||||||
};
|
};
|
||||||
|
|
||||||
namespace nimagna {
|
namespace nimagna {
|
||||||
|
|
Loading…
Reference in New Issue
Block a user