错误的梯度矢量场OpenCV C++
Wrong gradient vector field OpenCV C++
我尝试在OpenCV(C++)中显示图像的梯度向量场。
我使用了OpenCV中绘制梯度矢量场的代码:
cv::Mat img(cv::imread("C:/gradient2.png",1));
cv::Mat smoothedPlane = cv::Mat::zeros(img.rows,img.cols,CV_8UC1);
cv::Mat gradientField = cv::Mat::zeros(img.rows,img.cols,CV_32FC2);
cv::Mat GradX, GradY;
//cv::Mat AbsGradX, AbsGradY;
int ddepth = CV_16S;
int scale = 1;
int delta = 0;
auto size = 40;
GaussianBlur(img,smoothedPlane,cv::Size(51, 51),img.rows*img.cols*0.5);
erode(smoothedPlane, smoothedPlane, cv::getStructuringElement(cv::MORPH_ELLIPSE, cv::Size(size+1,size+1)));
dilate(smoothedPlane, smoothedPlane, cv::getStructuringElement(cv::MORPH_ELLIPSE, cv::Size(size, size)));
dilate(smoothedPlane, smoothedPlane, cv::getStructuringElement(cv::MORPH_ELLIPSE, cv::Size(size, size)));
erode(smoothedPlane, smoothedPlane, cv::getStructuringElement(cv::MORPH_ELLIPSE, cv::Size(size, size)));
Scharr( smoothedPlane, GradX, ddepth, 1, 0, scale);
Scharr( smoothedPlane, GradY, ddepth, 0, 1, scale);
//convertScaleAbs( GradX, AbsGradX );
//convertScaleAbs( GradY, AbsGradY );
for (int i = 0 ; i < GradX.rows ; i ++)
{
for (int j = 0 ; j < GradX.cols ; j ++)
{
cv::Scalar xval = GradX.at<float>(i,j);
cv::Scalar yval = GradY.at<float>(i,j);
gradientField.at<cv::Point2f>(i,j) = cv::Point2f(xval.val[0],yval.val[0]);
}
}
auto resolution = 30;
for (int i = 0 ; i < img.rows ; i += resolution)
{
for (int j = 0 ; j < img.cols ; j+= resolution)
{
cv::Point2f p(j,i);
cv::Point2f p2(gradientField.at<cv::Point2f>(p)+p);
cv::arrowedLine(img,p,p2,cv::Scalar(0,0,255),1.5,8,0,0.1);
}
}
cv::imshow("gradient", img);
cv::waitKey(0);
如果我通过这个访问复制梯度值:
cv::Scalar xval = GradX.at<float>(i,j);
cv::Scalar yval = GradY.at<float>(i,j);
输出的结果看起来像浮动访问的结果
如果我通过这个访问复制梯度值:
cv::Scalar xval = GradX.at<short>(i,j);
cv::Scalar yval = GradY.at<short>(i,j);
输出的结果看起来像短访问的结果
正确的结果应该显示箭头线,该箭头线来自暗磁盘的外部边界,指向磁盘的外部。提前感谢您的帮助。
我想我找到了解决方案,我用将输入图像转换为灰度
cv::cvtColor(img, img, CV_BGR2GRAY);
并保留
cv::Scalar xval = GradX.at<short>(i,j);
cv::Scalar yval = GradY.at<short>(i,j);
结果如下:良好的梯度矢量场
相关文章:
- C++,OpenCV,尝试显示图像时"OpenCV(4.3.0) Error: Assertion failed (size.width>0 && size.height>0)"此错误
- 尝试导入pybind-opencv模块时出现libgtk错误
- 在编译C++代码(具有dlib和opencv)到WASM时面临问题
- 如何使用OpenCV将RBG图像转换为HSV,并将H、S和V值保存为C++中的3个独立图像
- OpenCV EqualizeHist()从彩色图像创建黑白图像
- 将OpenCV C++重写为EmguCV C#-如何使用指针
- OpenCV C++.快速计算混淆矩阵
- 在C++代码中包含opencv时,使用ctypes创建.so文件
- 哪些库可以通过Opencv调整曝光率
- 安装opencv失败-粘贴CMakeError.log的内容
- C++中的openCV Mat访问冲突
- OpenCV Android C++ imwrite not found
- 未定义的引用 .. 使用 OpenCV 编译 C++ 代码时,从命令行
- 将 OpenCV 与 CMAKE 中的项目一起构建为第三方库的正确方法
- CV_OCL_RUN宏如何在OpenCV(版本3.4.5)的goodFeaturesToTrack实现中工作?
- OpenCV 4.1.2 - 从网络摄像头获取帧并将其拆分
- C++ OpenCV 卡尔曼滤波器构造函数错误
- 使用OpenCV和覆盆子上的多个网络摄像头拍摄延时摄影,出现多个V4L错误
- 如何使用OpenCV-C++编写*.mp4视频?
- Mingw-64 在构建和安装后不会编译 openCV 代码