0

我正在查看 objectdetect 样本,并在我用人行天桥的相机拍摄的一些镜头上尝试了几个身体检测级联(*haarcascade_fullbody/haarcascade_upperbody/haarcascade_lowerbody,haarcascade_mcs_upperbody*)。到目前为止一切都很好,但这是一项要求很高的功能。

我认为如果我通过最小/最大尺寸可能会运行得更顺畅,因为我的相机总是在同一个地方并且我找出了最小/最大边界框。不幸的是,我在尝试这样做时遇到了语法错误:

//my call
body.detectMultiScale( gray, bodies, 1.1, 2, 0|CV_HAAR_SCALE_IMAGE, cv::Size(30, 30),cv::Size(0,0),cv::Size(5,13),cv::Size(45,80));
//errors:
main.cpp:43: error: no matching function for call to 'cv::CascadeClassifier::detectMultiScale(cv::Mat&, std::vector<cv::Rect_<int>, std::allocator<cv::Rect_<int> > >&, double, int, int, cv::Size, cv::Size, cv::Size, cv::Size)'
/opt/local/include/opencv2/objdetect/objdetect.hpp:383: note: candidates are: virtual void cv::CascadeClassifier::detectMultiScale(const cv::Mat&, std::vector<cv::Rect_<int>, std::allocator<cv::Rect_<int> > >&, double, int, int, cv::Size, cv::Size)
/opt/local/include/opencv2/objdetect/objdetect.hpp:393: note:                 virtual void cv::CascadeClassifier::detectMultiScale(const cv::Mat&, std::vector<cv::Rect_<int>, std::allocator<cv::Rect_<int> > >&, std::vector<int, std::allocator<int> >&, std::vector<double, std::allocator<double> >&, double, int, int, cv::Size, cv::Size, bool)

我只是添加了两个cv::Size对象作为最小值最大值,但老实说我不确定:

  1. 当文档将它们列为 ints 时,为什么前面的参数也是 Size() 对象?
  2. 我是在查看错误的文档还是以错误的方式查看文档?

C++: void CascadeClassifier::detectMultiScale(const Mat& image, vector& objects, double scaleFactor=1.1, int minNeighbors=3, int flags=0, Size minSize=Size(), Size maxSize=Size())

来自文档。

4

2 回答 2

3

看来我传递了错误的论点。这有效:

body.detectMultiScale(gray,bodies,1.1,3,3,cv::Size(5,13),cv::Size(45,80));
于 2012-07-28T10:56:00.417 回答
0

在我的情况下面临同样的问题。以下线路对我有用。如果您考虑,我只提供最小尺寸cv::Size(45,80)。我仍在调查其他参数,但这目前正在工作。

haar_cascade.detectMultiScale(gray,faces,1.1,3,3,cv::Size(45,80));
于 2014-04-14T08:36:30.017 回答