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

news2025/3/1 4:51:25

目录

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.coloradmin.cn/o/965548.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

系统中出现大量不可中断进程和僵尸进程(理论)

一 进程状态 当 iowait 升高时&#xff0c;进程很可能因为得不到硬件的响应&#xff0c;而长时间处于不可中断状态。从 ps 或者 top 命令的输出中&#xff0c;你可以发现它们都处于 D 状态&#xff0c;也就是不可中断状态&#xff08;Uninterruptible Sleep&#xff09;。 R …

Python Opencv实践 - 轮廓检测

import cv2 as cv import numpy as np import matplotlib.pyplot as pltimg cv.imread("../SampleImages/map.jpg") print(img.shape) plt.imshow(img[:,:,::-1])#Canny边缘检测 edges cv.Canny(img, 127, 255, 0) plt.imshow(edges, cmapplt.cm.gray)#查找轮廓 #c…

【C++代码】找出字符串中第一个匹配项的下标,重复的子字符串--代码随想录

题目&#xff1a;找出字符串中第一个匹配项的下标 给你两个字符串 haystack 和 needle &#xff0c;请你在 haystack 字符串中找出 needle 字符串的第一个匹配项的下标&#xff08;下标从 0 开始&#xff09;。如果 needle 不是 haystack 的一部分&#xff0c;则返回 -1 。 题…

地理测绘基础知识(4) 照射计算上篇

我们接着上一篇来推导。 照射计算&#xff0c;是一种常用的三维几何计算。已知一个光源的光强图&#xff0c;计算光源投射到地表各处的功率密度。这种计算需求可以直观的理解为计算已知位置、指向、聚光特性的手电筒&#xff0c;计算地表某地点强度。当然&#xff0c;如果穷尽地…

mysql使用st_distance_sphere函数报错Incorrect arguments to st_distance_sphere

最近发现执行mysql st_distance_sphere报错了。 报错的信息是Incorrect arguments to st_distance_sphere。 最开始以为是跟mysql的版本有关系&#xff0c;所以看了下自己本地的mysql版本&#xff0c;执行一下sql select version(); 发现自己本地的mysql版本是 5.7.30 这…

FFmpeg报错:Connection to tcp://XXX?timeout=XXX failed: Connection timed out

一、现象 通过FFmpeg&#xff08;FFmpeg的版本是5.0.3&#xff09;拉摄像机的rtsp流获取音视频数据&#xff0c;执行命令&#xff1a; ./ffmpeg -timeout 3000000 -i "rtsp://172.16.17.156/stream/video5" 报错&#xff1a;Connection to tcp://XXX?timeoutXXX …

JavaScript 生成 16: 9 宽高比

这篇文章只是对 for 循环一个简单应用&#xff0c;没有什么知识含量。 可以跳过这篇文章。 只是我用来保存一下我的代码&#xff0c;保存在本地我嫌碍眼&#xff0c;总想把他删了。 正文部分 公式&#xff1a;其中 width 表示宽度&#xff0c;height 表示高度 16 9 w i d t…

CLIP改进工作串讲(bryanyzhu)内容记录

文章目录 分割Language-driven semantic segmentation - ICLR2022GroupViT: Semantic Segmentation Emerges from Text Supervision 目标检测ViLD : Open-vocabulary object detection via vision and language knowledge distillation 视觉定位GLIP:Grounded Language-Image P…

VsCode搭建Java开发环境 vscode搭建java开发环境 vscode springboot 搭建springboot

VsCode搭建Java开发环境 vscode搭建java开发环境 vscode springboot 搭建springboot VsCode java开发截图1、安装Java 环境相关插件2、安装 Spring 插件3、安装 Mybatis 插件第一个 vsc-mybatis第二个 mybatisX 4、安装Maven环境4.1、安装Maven环境4.2、VsCode配置Maven环境 5、…

使用Python进行Base64编码和解码

假设您有一个想要通过网络传输的二进制图像文件。您很惊讶对方没有正确接收该文件 - 该文件只是包含奇怪的字符&#xff01; 嗯&#xff0c;您似乎试图以原始位和字节格式发送文件&#xff0c;而所使用的媒体是为流文本而设计的。 避免此类问题的解决方法是什么&#xff1f;答…

Interspeech 2023 | 火山引擎流媒体音频技术之语音增强和AI音频编码

背景介绍 为了应对处理各类复杂音视频通信场景&#xff0c;如多设备、多人、多噪音场景&#xff0c;流媒体通信技术渐渐成为人们生活中不可或缺的技术。为达到更好的主观体验&#xff0c;使用户听得清、听得真&#xff0c;流媒体音频技术方案融合了传统机器学习和基于AI的语音增…

微服务--Seata(分布式事务)

TCC模式在代码中实现&#xff1a;侵入性强&#xff0c;并且的自己实现事务控制逻辑 Try&#xff0c;Confirm() cancel() 第三方开源框架&#xff1a;BeyeTCC\TCC-transaction\Himly 异步实现&#xff1a;MQ可靠消息最终一致性 GlobalTransacational---AT模式

Threejs里反向播放动画

在Blender里给对象添加了一个动画后&#xff0c;假设是在帧1到帧40添加的动画帧&#xff0c;那么正常播放时是从帧1到帧40&#xff0c;反向播放则是从帧40到帧1&#xff0c;本文讲述如何在Threejs里方向播放Blender里添加的动画。 一 添加动画 之前文章中已经讲述如何在Blende…

MAC ITEM 解决cd: string not in pwd的问题

今天使用cd 粘贴复制的路径的时候,报了这么一个错. cd: string not in pwd eistert192 Library % cd Application Support cd: string not in pwd: Application eistert192 Library % 让人一脸懵逼. 对比一下,发现中文路径里的空格截断了路径 导致后面的路径就没有办法被包含…

财报解读:迈向高端化,珍酒李渡如何持续讲好品牌故事?

2023年上半年&#xff0c;尤其是第二季度&#xff0c;白酒行业淡季属性较为明显。对于市场情况&#xff0c;中国酒业协会《2023中国白酒市场中期研究报告》也有所披露&#xff1a;约40.91%的受访者反馈春节后平日的白酒消费量有所减少&#xff0c;约31.82%的受访者反馈五一期间…

数据结构与算法(二)算法分析

算法的特性 算法具有五个基本特性&#xff1a;输入、输出、有穷性、确定性和可行性。 输入输出 算法具有零个或多个输入至少有一个或多个输出&#xff1a;算法是一定需要输出的&#xff0c;不需要输出&#xff0c;你用这个算法干吗&#xff1f; 有穷性 指算法在执行有限的步骤…

教你如何进行vcruntime140_1.dll文件下载安装,4种方法详细的安装方法

今天主要要跟大家说说vcruntime140_1.dll文件下载安装&#xff0c;其实要下载安装这个文件还是有不少方法的&#xff0c;只要不要慌&#xff0c;有的时候办法解决&#xff0c;首先我们要知道vcruntime140_1.dll是Microsoft Visual C的一部分&#xff0c;是许多计算机程序运行所…

Python项目打包与部署(1):模块与包的概念与关系

Python是动态类型编程语言&#xff0c;意味着python不需要提前编译。1个Python项目通常也包含多个.py文件&#xff0c; 通常也会引用python标准库&#xff0c;或第3方库&#xff0c;也存在着依赖关系。因此python项目也 当实际构建1个 Python 项目时&#xff0c;模块与包是我们…

【python基础教程】类中属性和方法的具体定义方法及使用

前言 嗨喽&#xff0c;大家好呀~这里是爱看美女的茜茜呐 以下介绍在python的re模块中怎样应用正则表达式 &#x1f447; &#x1f447; &#x1f447; 更多精彩机密、教程&#xff0c;尽在下方&#xff0c;赶紧点击了解吧~ python源码、视频教程、插件安装教程、资料我都准备…

Mybatis1.2 查询所有数据

1.2 查询所有数据 1.2.1 编写接口方法1.2.2 编写SQL语句1.2.3 编写测试方法1.2.4 起别名解决上述问题1.2.5 使用resultMap解决上述问题1.2.6 小结 如上图所示就页面上展示的数据&#xff0c;而这些数据需要从数据库进行查询。接下来我们就来讲查询所有数据功能&#xff0c;而实…