opencv学习-图像金字塔-上采样和下采样
Posted 殇堼
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了opencv学习-图像金字塔-上采样和下采样相关的知识,希望对你有一定的参考价值。
图像金字塔的理解
一个图像金字塔是由一系列的图像组成,最底下一张是图像尺寸最大,最上方的图像尺寸最小,从空间上从上向下看就想一个古代的金字塔。
为了更好理解上采样和下采样的概念,我个人将图像金字塔通过转化为倒金字塔进行理解,图像原图处于图像金字塔中间,越往上看,图像越来越大,即为上采样,反之为下采样。
因此通过上采样可以放大图像;下采样可以缩小图像。
高斯金字塔
用来对图像进行降采样
降采样之后图像大小是原图像长宽上都变成二分之一,首先 对当前层进行高斯模糊,然后删除当前层的偶数行与列,即得到降采样之后下一层的图片。
注意:高斯金字塔每一次下采样只能缩小1/4,而不能是其他缩小比例,也就是说无法越级缩放,而是逐层缩放。
相关API
pyrUp(Mat src, Mat dst, Size(src.cols2, src.rows2))
生成的图像是原图在宽与高各放大两倍
pyrDown(Mat src, Mat dst, Size(src.cols/2, src.rows/2))
生成的图像是原图在宽与高各缩小1/2
代码演示
#include<iostream>
#include<opencv2/opencv.hpp>
using namespace std;
using namespace cv;
int main()
{
Mat src,dst;
src = imread("D:/images/lena.png");
if (src.empty())
{
cout << "could not load image !";
return -1;
}
imshow("原图",src);
//放大图像两倍
pyrUp(src, dst, Size(src.cols *2, src.rows * 2));
imshow("上采样", dst);
//缩小图像两倍
pyrDown(src, dst, Size(src.cols / 2, src.rows / 2));
imshow("下采样", dst);
waitKey(0);
return 0;
}
结果
以上是关于opencv学习-图像金字塔-上采样和下采样的主要内容,如果未能解决你的问题,请参考以下文章