OpenCV(十六):高斯图像金字塔

目录

1.高斯图像金字塔原理

2.高斯图像金字塔实现


1.高斯图像金字塔原理

高斯图像金字塔是一种用于多尺度图像表示和处理的重要技术。它通过对图像进行多次高斯模糊和下采样操作来生成不同分辨率的图像层级,每个层级都是原始图像的模糊和降采样版本。

以下是高斯图像金字塔的原理和步骤:

  1. 高斯模糊(Gaussian Blurring):首先,对原始图像应用高斯滤波器进行模糊处理。高斯滤波器是一种线性低通滤波器,可以在空域上对图像进行平滑,去除图像中的高频细节。

  2. 下采样(Subsampling):对模糊后的图像进行下采样操作,即将图像尺寸缩小一半。下采样操作可以通过选择每隔一定像素进行采样来实现,或者使用插值技术(如平均值、最近邻等)生成新尺寸更小的图像。

  3. 重复步骤1和2:以缩小的图像为输入,重复执行高斯模糊和下采样步骤来构建金字塔的下一层。每一层都是前一层的模糊和降采样版本。

  4. 金字塔构建:重复进行高斯模糊和下采样操作,直到到达所需的金字塔层级或图像尺寸小于一定阈值。每个层级的下采样图像作为金字塔的一层,并按顺序排列形成金字塔结构。

通过构建高斯图像金字塔,可以获取到原始图像的不同分辨率版本,其中高层级的图像具有较低的分辨率,低层级的图像具有较高的分辨率。这样的金字塔结构允许在不同尺度上进行图像处理和分析任务,例如特征提取、目标检测、图像融合等。

2.高斯图像金字塔实现

在OpenCV中,可以使用cv::pyrDown()和cv::pyrUp()函数来实现高斯图像金字塔的构建。高斯图像金字塔是一种多尺度表示的图像结构,通过不断对图像进行降采样(下采样)和上采样操作,获得不同分辨率的图像层级。

  1. cv::pyrDown()函数:

    • 函数原型:void pyrDown(InputArray src, OutputArray dst, const Size& dstsize = Size(), int borderType = BORDER_DEFAULT)

    • 参数说明:

      • src:输入图像,可以是单通道或多通道的图像,数据类型为 CV_8U、CV_16U、CV_16S、CV_32F 或 CV_64F。

      • dst:输出图像,下采样后的图像。

      • dstsize:可选参数,输出图像的尺寸,默认情况下,输出图像的尺寸为输入图像尺寸的一半,也可以手动指定输出图像的尺寸。

      • borderType:可选参数,用于边缘填充的类型,默认为 BORDER_DEFAULT。

    • 功能:执行高斯金字塔的下采样操作,将输入图像的尺寸减半,并生成一个尺寸更小的图像。

  2. cv::pyrUp()函数:

    • 函数原型:void pyrUp(InputArray src, OutputArray dst, const Size& dstsize = Size(), int borderType = BORDER_DEFAULT)

    • 参数说明:

      • src:输入图像,可以是单通道或多通道的图像,数据类型为 CV_8U、CV_16U、CV_16S、CV_32F 或 CV_64F。

      • dst:输出图像,上采样后的图像。

      • dstsize:可选参数,输出图像的尺寸,默认情况下,输出图像的尺寸为输入图像尺寸的两倍,也可以手动指定输出图像的尺寸。

      • borderType:可选参数,用于边缘填充的类型,默认为 BORDER_DEFAULT。

    • 功能:执行高斯金字塔的上采样操作,将输入图像的尺寸增大一倍,并生成一个尺寸更大的图像。

这两个函数结合使用可以实现图像金字塔的构建。通过多次使用cv::pyrDown()进行下采样,可以生成金字塔的较低层级图像。然后,如果需要,可以使用cv::pyrUp()进行上采样,将图像恢复到原始分辨率。

下面是一个使用OpenCV实现高斯图像金字塔的示例代码:

#include <opencv2/opencv.hpp>int main() {// 读取图像cv::Mat image = cv::imread("image.jpg");// 构建高斯图像金字塔std::vector<cv::Mat> Guass;int level=3;Guass.push_back(image);for(int i=0;i<level;i++){Mat guass;cv::pyrDown(Guass[i], guass);Guass.push_back(guass);}// 显示金字塔图像for (int i = 0; i < level; i++) {cv::imwrite("/sdcard/DCIM/guass" + std::to_string(i)+".png", Guass[i]);}return 0;
}

在这个示例中,我们首先使用cv::imread()函数读取一张图像。然后,我们创建一个std::vector<cv::Mat>类型的变量Guass来保存金字塔图像的每一层。我们将原始图像作为金字塔的第一层。

接下来,我们使用一个循环来对guass图像进行下采样操作。在每次迭代中,使用cv::pyrDown()函数将guass图像降采样,并将降采样后的图像添加到Guass向量中。

最后,我们通过遍历Guass向量将每一层金字塔图像显示出来,使用cv::imwrite()函数显示每一层图像。

需要注意的是,高斯图像金字塔的构建可以通过不断的下采样和上采样操作来实现。其中cv::pyrDown()用于下采样操作,将图像尺寸减半,而cv::pyrUp()用于上采样操作,将图像尺寸扩大一倍。你可以根据需求使用cv::pyrUp()函数来实现高斯图像金字塔的上采样操作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/102261.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

github网站打不开,hosts文件配置

首先获取github官网的ip地址&#xff0c; 打开cmd&#xff0c;输入ping github.com 配置&#xff1a; #github 140.82.114.4 github.com 199.232.69.194 github.global.ssl.fastly.net 185.199.108.153 assets-cdn.github.com 185.199.110.153 assets-cdn.github.com 185.199…

Linux与shell命令行学习

文章目录 走进shell基本的bash shell命令2.1 遍历目录 cd2.2 查看文件和目录列表 ls2.3 创建文件 touch2.4 复制文件 cp2.5 自动补全 tab2.6 链接文件 ln2.7 文件重命名 mv2.8 删除文件 rm2.9 创建目录 mkdir2.10 删除目录 rmdir2.11 查看文件类型 file2.12 查看整个文件 cat、…

23个react常见问题

1、setState 是异步还是同步&#xff1f; 合成事件中是异步 钩子函数中的是异步 原生事件中是同步 setTimeout中是同步 相关链接&#xff1a;你真的理解setState吗&#xff1f;&#xff1a; 2、聊聊 react16.4 的生命周期 图片 相关连接&#xff1a;React 生命周期 我对 Reac…

LeetCode(力扣)216. 组合总和 IIIPython

LeetCode216. 组合总和 III 题目链接代码 题目链接 https://leetcode.cn/problems/combination-sum-iii/ 代码 class Solution:def combinationSum3(self, k: int, n: int) -> List[List[int]]:result[]self.backtracking(n, k, 0, 1, [], result)return resultdef back…

PCL入门(三):矩阵变换实现平移和旋转

目录 1. pcl中的矩阵变换是什么2. 举例&#xff1a;如何做矩阵变换 1. pcl中的矩阵变换是什么 通过激光传感器等设备获得的3d点云在拼接成更大场景时&#xff0c;需要对点云数据进行旋转和平移操作。而旋转和平移操作&#xff0c;就可以通过矩阵变换来实现。 点的表示 对于点…

php 获取今日、昨日、上周、本月的起始时间戳和结束时间戳的方法非常简单

php 获取今日、昨日、上周、本月的起始时间戳和结束时间戳的方法&#xff0c;主要使用到了 php 的时间函数 mktime。下面首先还是以示例说明如何使用 mktime 获取今日、昨日、上周、本月的起始时间戳和结束时间戳&#xff0c;然后在介绍一下 mktime 函数作用和用法。非常简单哦…

使用ChatGLMTokenizer处理json格式数据

我下载了一些中文wikipedia数据&#xff0c;准备采用ChatGLMTokenizer对齐进行清洗&#xff0c;整理为预训练语料。 import numpy as np import json from tqdm import tqdm from chatglm_tokenizer.tokenization_chatglm import ChatGLMTokenizertokenizer ChatGLMTokenizer…

Python超入门(1)__迅速上手操作掌握Python

# 1.第一个代码&#xff1a;输出语句 # 1.第一个代码&#xff1a;输出语句 print("My dogs name is Huppy!") print(o----) print( ||| ) print("*" * 10) """ 输出结果&#xff1a; My dogs name is Huppy! o----||| ********** "&…

如何让自己的精力集中 Maven自学笔记 马云演讲观看

目录 如何让自己的精力集中 Avoid having multiple tasks and objects in your line of sight 人的脑袋是给自己思考用的 晚上床上想千条路&#xff0c;早上起床还是走原路 参与才会变得更好 共度灾难&#xff0c;是需要互相鼓励的 CFO Capital 上海各区都有哪些大学?…

奥菲斯办公

下载 运行 移除旧组件&#xff0c;移除之后重启电脑 部署&#xff0c;如图设置 下载&#xff0c;1.5GB&#xff0c;点击上方的开始部署。部署完成后。 安装许可证&#xff0c;安装成功后才能安装许可证 找一个 KMS 主机输入 主机列表 点击上方激活&#xff0c;有效…

2023数学建模国赛选题建议及BC题思路

大家好呀&#xff0c;全国大学生数学建模竞赛今天下午开赛啦&#xff0c;在这里先带来初步的选题建议及思路。 目前团队正在写B题和C题完整论文&#xff0c;后续还会持续更新哈&#xff0c;以下只是比较简略的图文版讲解&#xff0c;团队目前正在写B、C题完整论文&#xff0c;…

LeetCode 1113.报告的记录

数据准备 Create table If Not Exists Actions (user_id int, post_id int, action_date date, action ENUM(view, like, reaction, comment, report, share), extra varchar(10)); Truncate table Actions; insert into Actions (user_id, post_id, action_date, action, ext…