图像金字塔
高斯金字塔:
高斯金字塔是由底向上,逐层降采样得到,降采样之后图像大小是原图像的M/2*N/2,就是对原图像删除偶数行与列,即得到降采样之后上一层的图片
高斯金字塔的生成部分分为两步:
对当前层进行高斯模糊
删除当前层的偶数行与列
即可得到上一层的图像,这样上一层与下一层相比,只有它的四分之一
高斯不同:就是把一张图像在不同的参数下进行高斯模糊之后的结果相减,得到的输出图像 成为高斯不同
高斯不同是图像的内在特征,在灰度图像增强 角点检测中经常用到
采样相关的API:
上采样:
zoom in 放大
pryUP(Mat src,Mat dst,Size())
生成的图像是原来宽与高各放大两倍
降采样
zoom out 缩小
生成的图像在原图宽与高各缩小1/2
先对图像进行降采样 或者上采样进行图像处理
然后在进行高斯模糊 归一化
#include<iostream>
#include<opencv2\opencv.hpp>
using namespace cv;
using namespace std;
int main(int argc,char** argv) {
Mat src;
src = imread("1.jpg");
if (src.empty())
{
printf("could not load image...");
return -1;
}
char INPUT_WIN[] = "input image";
char OUTPUT_WIN[] = "output image";
imshow(INPUT_WIN, src);
//上采样
Mat up_image;
pyrUp(src, up_image, Size(src.cols*2, src.rows*2));
imshow(OUTPUT_WIN, up_image);
//降采样
Mat dowm_image;
pyrDown(src,dowm_image, Size(src.cols / 2, src.rows / 2));
imshow(OUTPUT_WIN, dowm_image);
//高斯模糊
Mat gray_src,g1, g2,dog_img;
cvtColor(src, gray_src, CV_RGB2GRAY);
GaussianBlur(gray_src, g1, Size(3, 3), 0, 0);
GaussianBlur(g1, g2, Size(3, 3), 0, 0);
//图像相减 g1-g2=dog_img
subtract(g1, g2, dog_img, Mat());
//归一化到0-255之间
normalize(dog_img, dog_img, 0, 255, NORM_MINMAX);
imshow("Dog iamge", dog_img);
waitKey(0);
return 0;
}
#include<opencv2\opencv.hpp>
using namespace cv;
using namespace std;
int main(int argc,char** argv) {
Mat src;
src = imread("1.jpg");
if (src.empty())
{
printf("could not load image...");
return -1;
}
char INPUT_WIN[] = "input image";
char OUTPUT_WIN[] = "output image";
imshow(INPUT_WIN, src);
//上采样
Mat up_image;
pyrUp(src, up_image, Size(src.cols*2, src.rows*2));
imshow(OUTPUT_WIN, up_image);
//降采样
Mat dowm_image;
pyrDown(src,dowm_image, Size(src.cols / 2, src.rows / 2));
imshow(OUTPUT_WIN, dowm_image);
//高斯模糊
Mat gray_src,g1, g2,dog_img;
cvtColor(src, gray_src, CV_RGB2GRAY);
GaussianBlur(gray_src, g1, Size(3, 3), 0, 0);
GaussianBlur(g1, g2, Size(3, 3), 0, 0);
//图像相减 g1-g2=dog_img
subtract(g1, g2, dog_img, Mat());
//归一化到0-255之间
normalize(dog_img, dog_img, 0, 255, NORM_MINMAX);
imshow("Dog iamge", dog_img);
waitKey(0);
return 0;
}