我正在开发一个 C++ 程序,它应该从网络摄像头流中检测人脸,而不是使用人脸地标裁剪它们并交换它们。
我使用 OpenCV 和 Viola-Jones 人脸检测对人脸检测进行了编程。工作正常。比我搜索如何从 ROI 中分割只是面部。我尝试了一些皮肤检测实现,但没有一个成功。
比我发现 dlib 面部地标。我决定试一试。刚开始时我遇到了问题,因为我必须转换cv::Mat
为cv_image
, Rect 到 rectangle 等。所以我试着用 dlib 来做。我只是使用流,cv::VideoCapture
而不是想展示使用 dlib 捕获的内容image_window
。但问题是它非常慢。Down是使用的代码。注释行是执行相同但使用 OpenCV 的行。OpenCV 比没有注释的代码更快、更流畅、更连续,就像 5 FPS。那太糟了。我无法想象当我应用人脸检测和人脸地标时会有多慢。
难道我做错了什么?我怎样才能让它更快?或者我应该使用 OpenCV 进行视频捕获和显示?
cv::VideoCapture cap;
image_window output_frame;
if (!cap.open(0))
{
cout << "ERROR: Opening video device 0 FAILED." << endl;
return -1;
}
cv::Mat cap_frame;
//HWND hwnd;
do
{
cap >> cap_frame;
if (!cap_frame.empty())
{
cv_image<bgr_pixel> dlib_frame(cap_frame);
output_frame.set_image(dlib_frame);
//cv::imshow("output",dlib::toMat(dlib_frame));
}
//if (27 == char(cv::waitKey(10)))
//{
// return 0;
//}
//hwnd = FindWindowA(NULL, "output");
} while(!output_frame.is_closed())//while (hwnd != NULL);
编辑: 切换到释放模式后,显示捕获的帧变得很好。但是我继续尝试使用dlib进行人脸检测和形状预测,就像这里的示例http://dlib.net/face_landmark_detection_ex.cpp.html一样。这是相当滞后的。所以我关闭了形状预测。仍然“滞后。
所以我认为人脸检测会减慢速度。所以我尝试使用 OpenCV 进行人脸检测,因为它明显优于 dlib 检测器。我需要将检测到的 cv::Rect 转换为 dlib::rectangle。我用过这个。
std::vector<dlib::rectangle> dlib_rois;
long l, t, r, b;
for (int i = cv_rois.size() - 1; i >= 0; i--)
{
l = cv_rois[i].x;
t = cv_rois[i].y;
r = cv_rois[i].x + cv_rois[i].width;
b = cv_rois[i].y + cv_rois[i].height;
dlib_rois.push_back(dlib::rectangle(l, t, r, b));
}
但是这种OpenCV 人脸检测和dlib 形状预测的组合变得非常滞后。处理单帧大约需要4s。
我不知道为什么。OpenCV 人脸检测绝对没问题,dlib 形状预测似乎并不难处理。有人可以帮我吗?