我嘗試使用OpenCV C++的cv :: Moments找到質心。無論我提出什麼論點,我收到的所有回覆都是零。很明顯,我做了一件非常簡單的事情。輸出代碼:OpenCV C++使用cv :: Moments
23 of 500 elements in unit 3
point values 2.976444 18.248287
matrix size 23
moments 0.000000 0.000000 0.000000 0.000000 0.000000 0.000000 0.000000 0.000000
moments 0.000000 0.000000 0.000000 0.000000 0.000000 0.000000 0.000000
和代碼:
printf("%d of %d elements in unit %d\n",k,number_of_features,i);
cv::Mat x(k, 1, cv::DataType<cv::Point2f>::type);
k=0;
for(int j=0;j <number_of_features;j++) {
if(i == labels.at<int>(j)) {
x.at<cv::Point2f>(k++) = samples.at<cv::Point2f>(i);
}
}
printf("point values %f %f\n", x.at<cv::Point2f>(0).x,x.at<cv::Point2f>(0).y);
cv::Size s=x.size();
printf("matrix size %d\n",s.height);
cv::Moments m=cv::moments(x);
printf("moments %f %f %f %f %f %f %f %f\n",m.m00,m.m01,m.m20,m.m11,m.m02,m.m30,m.m21,m.m03);
double h[7];
cv::HuMoments(m,h);
printf("moments %f %f %f %f %f %f %f\n",h[0],h[1],h[2],h[3],h[4],h[5],h[6]);
奇怪的是我無法找到谷歌的任何相同的代碼示例。我所看到的都是C風格的方法。
謝謝!首先我確認你的方法有效,其次我發現我的錯誤,因爲使用你的代碼。我用「i」代替「j」: x.at(k ++)= samples.at (j/* BUG WAS HERE * /); –