Sam*_*nga 8 c++ opencv assertion projection-matrix
我尝试使用countNonZero()函数进行水平投影,如下所示.
Mat src = imread(INPUT_FILE, CV_LOAD_IMAGE_COLOR);
Mat binaryImage = src.clone();
cvtColor(src, src, CV_BGR2GRAY);
Mat horizontal = Mat::zeros(1,binaryImage.cols, CV_8UC1);
for (int i = 0; i<binaryImage.cols; i++)
{
Mat roi = binaryImage(Rect(0, 0, 1, binaryImage.rows));
horizontal.at<int>(0,i) = countNonZero(roi);
cout << "Col no:" << i << " >>" << horizontal.at<int>(0, i);
}
Run Code Online (Sandbox Code Playgroud)
但是在调用countonZero()函数时出现错误.错误如下.
OpenCV Error: Assertion failed (src.channels() == 1 && func != 0) in cv::countNo
nZero, file C:\builds\2_4_PackSlave-win32-vc12-shared\opencv\modules\core\src\st
at.cpp, line 549
Run Code Online (Sandbox Code Playgroud)
有人可以指出错误吗?
Mik*_*ail 15
断言src.channels() == 1意味着图像应该有1个通道,即它必须是灰色的,而不是彩色的.你调用countNonZero上roi,这是一个子图像binaryImage,这是一个克隆src,这是原来的颜色.
我想你想写cvtColor(binaryImage, binaryImage, CV_BGR2GRAY);.在这种情况下,它是有道理的.但是,我没有看到你src再次使用,所以也许你不需要这个中间图像.如果你这样做,不要叫"二进制",因为计算机视觉中的"二进制"通常代表黑白图像,只有两种颜色.你的图像是"灰色的",因为它有黑色和白色的所有色调.
关于你的原始任务,Miki是对的,你应该使用cv::reduce它.他已经给你一个如何使用它的例子.
| 归档时间: |
|
| 查看次数: |
10687 次 |
| 最近记录: |