理论
相关API
normalize(Mat src,Mat dst, double alpha = 1, double beta = 0, intnorm_type = NORM_L2, int dtype = -1, InputArray mask = noArray());
代码示例
Mat src;
src = imread(...);
//显示原图
char INPUT_WIN[] = "input image";
namedWindow(INPUT_WIN, CV_WINDOW_AUTOSIZE);
imshow(INPUT_WIN,src);
// 显示提取的特征图
Mat gray_src, g1, g2, dogImg;
//先转为灰度图
cvtColor(src, gray_src,CV_BGR2GRAY);
// 第1次高斯模糊
GaussianBlur(gray_src, g1, Size(3, 3), 0, 0);
// 第2次高斯模糊
GaussianBlur(g1, g2, Size(3, 3), 0, 0);
//g1 减去 g2
subtract(g1, g2, dogImg, Mat());
namedWindow("DOG Image",CV_WINDOW_AUTOSIZE);
imshow("DOG Image", dogImg);
特征提取图:
看不太清,,,原因是高斯模糊的两个差值很小,所以反映到灰度图上像素值也就很低,这个时候就需要我们用到上边提到的API了, normalize进行归一化显示(我们是线性提亮嘛)
把代码稍微改一下:
Mat src;
src = imread(...);
//显示原图
char INPUT_WIN[] = "input image";
namedWindow(INPUT_WIN, CV_WINDOW_AUTOSIZE);
imshow(INPUT_WIN,src);
// 显示提取的特征图
Mat gray_src, g1, g2, dogImg;
//先转为灰度图
cvtColor(src, gray_src,CV_BGR2GRAY);
// 第1次高斯模糊
GaussianBlur(gray_src, g1, Size(3, 3), 0, 0);
// 第2次高斯模糊
GaussianBlur(g1, g2, Size(3, 3), 0, 0);
//g1 减去 g2, 正常也就是低 减去 高, 用高 减去 低的话, 线条会更明显
subtract(g1, g2, dogImg, Mat());
//归一化显示
normalize(dogImg, dogImg, 255, 0, NORM_MINMAX);
namedWindow("DOG Image",CV_WINDOW_AUTOSIZE);
imshow("DOG Image", dogImg);