当前位置:   article > 正文

OpenCV图像处理学习十三,图像金字塔——高斯金字塔和拉普拉斯金字塔_open cv掩码金字塔 平均梯度 高斯金字塔

open cv掩码金字塔 平均梯度 高斯金字塔

一.图像金字塔概念

我们在图像处理中常常会调整图像大小,最常见的就是放大(zoom in)和缩小(zoom out),尽管几何变换也可以实现图像放大和缩小,但是这里我们介绍图像金字塔 。 一个图像金字塔是由一系列的图像组成,最底下一张是图像尺寸最大,最上方的图像尺寸最小,从空间上从上向下看就想一个古代的金字塔。

金字塔的底部是待处理图像的高分辨率表示,而顶部是低分辨率的近似。我们将一层一层的图像比喻成金字塔,层级越高,则图像越小,分辨率越低。

二.图像金字塔:

高斯金字塔 – 用来对图像进行降采样

拉普拉斯金字塔 – 用来重建一张图片根据它的上层降采样图片

-------------------------------------------------------------------------------------------------------------------------------

高斯金字塔

高斯金子塔是从底向上,逐层降采样得到。 降采样之后图像大小是原图像MxN的M/2 x N/2 ,就是对原图像删除偶数行与列,即得到降采样之后上一层的图片。 

高斯金子塔的生成过程分为两步:     1.对当前层进行高斯模糊      2.删除当前层的偶数行与列     即可得到上一层的图像,这样上一层跟下一层相比,都只有它的1/4大小。

---------------------------------------------------------------------------------------------------------------------------------

三.高斯不同(Difference of Gaussian-DOG)

 DOG定义:

就是把同一张图像在不同的参数下做高斯模糊之后的结果相减,得到的输出图像,称为高斯不同(DOG) ,高斯不同是图像的内在特征,在灰度图像增强、角点检测和特征提取中经常用到。

四.API函数接口:

上采样(cv::pyrUp) – zoom in 放大

  1. #上采样API
  2. void pyrUp(InputArray src, OutputArraydst, const Size& dstsize=Size(), int borderType=BORDER_DEFAULT )

参数说明:

第一个参数,InputArray类型的src,输入图像,Mat类的对象即可。
第二个参数,OutputArray类型的dst,输出图像,必须和源图片有一样的尺寸和类型。
第三个参数,const Size&类型的dstsize,输出图像的大小;有默认值Size(),即默认情况下,由Size(src.cols*2,src.rows*2)来进行计算。

第四个参数,int类型的borderType,即边界模式。

--------------------------------------------------------------------------------------------------------------------------------
 

降采样 (cv::pyrDown) – zoom out 缩小

  1. #降采样API
  2. void pyrDown(InputArray src,OutputArray dst, const Size& dstsize=Size(), int borderType=BORDER_DEFAULT)

参数说明:

第一个参数,InputArray类型的src,输入图像,Mat类的对象即可。
第二个参数,OutputArray类型的dst,输出图像,必须和源图片有一样的尺寸和类型。
第三个参数,const Size&类型的dstsize,输出图像的大小;有默认值Size(),即默认情况下,由Size Size((src.cols+1)/2, (src.rows+1)/2)来进行计算。

第四个参数,int类型的borderType,即边界模式。

归一化函数API

归一化就是要把需要处理的数据经过处理后(通过某种算法)限制在你需要的一定范围内。

  1. #归一化函数API接口
  2. cv::normalize(InputArry src,InputOutputArray dst,double alpha=1,double beta=0,int norm_type=NORM_L2,int dtype=-1,InputArray mark=noArry())

参数说明:

src               输入图像;
dst               输出图像,图像的大小和原图像一致;
alpha           可以用来规范值,也可以用来规范范围,并且是范围的下限;
beta             只用来规范范围并且是范围的上限;
norm_type   归一化选择的数学公式类型;有NORM_INF(无穷范数),NORM_L1(1范数), NORM_INFL2(2范数),NORM_MINMAX(范围归一化)
dtype           当为负,输出在大小深度通道数都等于输入,当为正,输出只在深度与输出不同,不同的地方由dtype决定;否则 和src通道一致,depth =CV_MAT_DEPTH(dtype).
mark            掩码。选择感兴趣区域,选定后只能对该区域进行操作。
 

=========================================================================

代码实现:

  1. #include"stdafx.h"
  2. #include<opencv2\imgproc\types_c.h>
  3. #include<opencv2\opencv.hpp>
  4. #include<iostream>
  5. using namespace std;
  6. using namespace cv;
  7. int main(int agrc, char** argv) {
  8. Mat src, dst;
  9. src = imread("F:/photo/qx.jpg");
  10. if (!src.data) {
  11. printf("could not load image...");
  12. return -1;
  13. }
  14. //char INPUT_WIN[] = "input image";
  15. //char OUTPUT_WIN[] = "sample up";
  16. namedWindow("input image", 0);
  17. resizeWindow( "input image", 300, 300);
  18. imshow("input image", src);
  19. namedWindow("sample up", WINDOW_AUTOSIZE);
  20. // 上采样
  21. pyrUp(src, dst, Size(src.cols *2, src.rows * 2));
  22. imshow("sample up", dst);
  23. // 降采样
  24. Mat s_down;
  25. pyrDown(src, s_down, Size(src.cols / 2, src.rows / 2));
  26. imshow("s_down", s_down);
  27. // DOG
  28. Mat gray_src, g1, g2, dogImg;
  29. cvtColor(src, gray_src, CV_BGR2GRAY);
  30. GaussianBlur(gray_src, g1, Size(5, 5), 0, 0);
  31. GaussianBlur(g1, g2, Size(5, 5), 0, 0);
  32. subtract(g1, g2, dogImg, Mat());
  33. // 归一化显示
  34. normalize(dogImg, dogImg, 255, 0, NORM_MINMAX);
  35. imshow("DOG Image", dogImg);
  36. waitKey(0);
  37. return 0;
  38. }

--------------------------------------------------------------------------------------------------------------------------------

图像处理效果:

图像降采样

 图像原图

 图像上采样

 高斯不同(DOG)图像

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家自动化/article/detail/545488
推荐阅读
相关标签
  

闽ICP备14008679号