概述
拉普拉斯算子的计算在浮点数类型的图像上进行。要对结果做缩放处理才能使其正常显示。缩放基于拉普拉斯算子的最大绝对值,其中数值 0 对应灰度级 128。类中有一个方
法可获得下面的图像表示:
// 获得拉普拉斯结果,存在 8 位图像中
// 0 表示灰度级 128
// 如果不指定缩放比例,那么最大值会放大到 255
// 在调用这个函数之前,必须先调用 computeLaplacian
cv::Mat getLaplacianImage(double scale=-1.0) {
if (scale<0) {
double lapmin, lapmax;
// 取得最小和最大拉普拉斯值
cv::minMaxLoc(laplace,&lapmin,&lapmax);
// 缩放拉普拉斯算子到 127
scale= 127/ std::max(-lapmin,lapmax);
}
// 生成灰度图像
cv::Mat laplaceImage;
laplace.convertTo(laplaceImage,CV_8U,scale,128);
return laplaceImage;
}
使用这个类,从 7×7 内核计算拉普拉斯图像的方法为:
// 用 LaplacianZC 类计算拉普拉斯算子
LaplacianZC laplacian;
laplacian.setAperture(7); // 7×7 的拉普拉斯算子
cv::Mat flap= laplacian.computeLaplacian(image);
laplace= laplacian.getLaplacianImage();
最后
以上就是坦率毛豆为你收集整理的OpenCV拉普拉斯算子使用的全部内容,希望文章能够帮你解决OpenCV拉普拉斯算子使用所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复