【OpenCV图像处理9】图像金字塔

简介: 【OpenCV图像处理9】图像金字塔

九、图像金字塔

1、图像金字塔介绍

图像金字塔是图像中多尺度表达的一种,最主要应用于图像分割,是一种以多分辨率来解释图像的有效但概念简单的结构。

简单的来说,图像金字塔是同一图像不同分辨率的子图集合。

图像金字塔最初应用于机器视觉和图像压缩,一幅图像的金字塔是一系列以金字塔形状排列的分辨率逐步降低,且来源于同一张原始图的图像集合。其通过梯次向下采样获得,直到达到某个终止条件才停止采样。

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

常见的两类图像金字塔:

  • 高斯金字塔(Gaussian pyramid): 用来向下/降取样,主要的图像金字塔
  • 拉普拉斯金字塔(Laplacian pyramid): 用来从金字塔底层图像重建上层未采样图像,在数字图像处理中即是预测残差,可以对图像进行最大程度的还原,配合高斯金字塔一起使用。

2、高斯金字塔

高斯金字塔是通过高斯平滑和亚采样(subsampling)获得一系列下采样图像。

向下采样:cv2.pyrDown()

原理非常简单,如下图所示:

原始图像 M ∗ N M * NMN —> 处理后图像 M / 2 ∗ N / 2 M/2 * N/2M/2N/2

每次处理后,结果图像是原来的 1 / 4 1/41/4

注意: 向下取样会丢失图像信息。

代码实现:

import cv2
img = cv2.imread('../resource/lena.bmp')
print(img.shape)
# 向下采样
dst = cv2.pyrDown(img)
print(dst.shape)
cv2.imshow('lena', img)
cv2.imshow('dst', dst)
cv2.waitKey(0)
cv2.destroyAllWindows()

向上采样:cv2.pyrUp()

  • 是向下采样的相反过程,是指图像从小变大的过程。

1、将图像在每个方向扩大为原来的两倍,新增的行和列以0填充。

2、使用先前同样的内核(乘以4)与放大后的图像卷积,获得近似值。

代码实现:

import cv2
img = cv2.imread('../resource/lena.bmp')
print(img.shape)
# 向上采样
dst = cv2.pyrUp(img)
print(dst.shape)
cv2.imshow('lena', img)
cv2.imshow('dst', dst)
cv2.waitKey(0)
cv2.destroyAllWindows()

3、拉普拉斯金字塔

将向下/降采样之后的图像再进行向上采样操作,然后与之前还没向下/降采样的原图像进行做差得到残差图,为还原图像做信息的准备。

也就是说,拉普拉斯金字塔是通过原图像减去先缩小后放大的图像的一系列图像构成的,保留的是残差。

拉普拉斯金字塔是由高斯金字塔构成的,没有专门的函数。

拉普拉斯金字塔图像只像图像边缘,它的大部分元素都是0,用于图像压缩。

代码实现:

import cv2
import numpy as np
img = cv2.imread('../resource/lena.bmp')
# 先 向下采样 后 向上采样
dst = cv2.pyrUp(cv2.pyrDown(img))
# 拉普拉斯金字塔 = 原图像 - 高斯金字塔
lap = img - dst
cv2.imshow('lena', np.hstack((img, dst, lap)))
cv2.waitKey(0)
cv2.destroyAllWindows()

目录
相关文章
|
2月前
|
算法 计算机视觉
基于qt的opencv实时图像处理框架FastCvLearn实战
本文介绍了一个基于Qt的OpenCV实时图像处理框架FastCvLearn,通过手撕代码的方式详细讲解了如何实现实时人脸马赛克等功能,并提供了结果展示和基础知识回顾。
104 7
基于qt的opencv实时图像处理框架FastCvLearn实战
|
1月前
|
计算机视觉
Opencv学习笔记(三):图像二值化函数cv2.threshold函数详解
这篇文章详细介绍了OpenCV库中的图像二值化函数`cv2.threshold`,包括二值化的概念、常见的阈值类型、函数的参数说明以及通过代码实例展示了如何应用该函数进行图像二值化处理,并展示了运行结果。
328 0
Opencv学习笔记(三):图像二值化函数cv2.threshold函数详解
|
2月前
|
算法 计算机视觉
opencv图像形态学
图像形态学是一种基于数学形态学的图像处理技术,它主要用于分析和修改图像的形状和结构。
49 4
|
2月前
|
存储 计算机视觉
Opencv的基本操作(一)图像的读取显示存储及几何图形的绘制
本文介绍了使用OpenCV进行图像读取、显示和存储的基本操作,以及如何绘制直线、圆形、矩形和文本等几何图形的方法。
Opencv的基本操作(一)图像的读取显示存储及几何图形的绘制
|
1月前
|
机器学习/深度学习 算法 计算机视觉
【Python篇】Python + OpenCV 全面实战:解锁图像处理与视觉智能的核心技能
【Python篇】Python + OpenCV 全面实战:解锁图像处理与视觉智能的核心技能
68 2
|
3月前
|
算法 计算机视觉 Python
python利用opencv进行相机标定获取参数,并根据畸变参数修正图像附有全部代码(流畅无痛版)
该文章详细介绍了使用Python和OpenCV进行相机标定以获取畸变参数,并提供了修正图像畸变的全部代码,包括生成棋盘图、拍摄标定图像、标定过程和畸变矫正等步骤。
python利用opencv进行相机标定获取参数,并根据畸变参数修正图像附有全部代码(流畅无痛版)
WK
|
3月前
|
计算机视觉 Python
如何使用OpenCV进行基本图像处理
使用OpenCV进行基本图像处理包括安装OpenCV,读取与显示图像,转换图像颜色空间(如从BGR到RGB),调整图像大小,裁剪特定区域,旋转图像,以及应用图像滤镜如高斯模糊等效果。这些基础操作是进行更复杂图像处理任务的前提。OpenCV还支持特征检测、图像分割及对象识别等高级功能。
WK
49 4
WK
|
3月前
|
编解码 计算机视觉 Python
如何在OpenCV中进行图像转换
在OpenCV中,图像转换涉及颜色空间变换、大小调整及类型转换等操作。常用函数如`cvtColor`可实现BGR到RGB、灰度图或HSV的转换;`resize`则用于调整图像分辨率。此外,通过`astype`或`convertScaleAbs`可改变图像数据类型。对于复杂的几何变换,如仿射或透视变换,则可利用`warpAffine`和`warpPerspective`函数实现。这些技术为图像处理提供了强大的工具。
WK
108 1
|
4月前
|
机器学习/深度学习 XML 计算机视觉
OpenCV(Open Source Computer Vision Library)是一个开源的计算机视觉和机器学习库,它提供了大量的函数和工具,用于处理图像和视频数据。
OpenCV(Open Source Computer Vision Library)是一个开源的计算机视觉和机器学习库,它提供了大量的函数和工具,用于处理图像和视频数据。
|
5月前
|
算法 计算机视觉
【Qt&OpenCV 图像的感兴趣区域ROI】
【Qt&OpenCV 图像的感兴趣区域ROI】
165 1