【youcans 的 OpenCV 学习课】21. Haar 小波变换

news2025/1/16 16:13:50

专栏地址:『youcans 的图像处理学习课』
文章目录:『youcans 的图像处理学习课 - 总目录』


【youcans 的 OpenCV 学习课】21. Haar 小波变换

    • 1. 小波变换
      • 1.1 小波变换基本概念
        • 例程 17_1:常用小波族的图像
      • 1.2 连续小波变换
      • 1.3 离散小波变换(Discrete wavelet transform, DWT)
      • 1.4 二维离散小波变换
        • 例程 17_3:图像的小波变换
    • 2. Haar 小波变换
      • 2.1 Haar 小波变换的基本概念
        • 例程 17_4:一维信号的 Haar 小波分解
        • 例程 17_5:图像的 Haar 小波分解
      • 2.2 小波变换在图像处理中的应用


1. 小波变换

1.1 小波变换基本概念

信号变换是为了分析时间和频率之间的相互关系。

傅里叶变换(FFT)将信号表示为无限三角函数的叠加,从而将信号从时域转换到频域,可以分析信号的频谱,但不能反映信号的时频特征,丢失了局部信息。

短时傅里叶变换(STFT)通过引入时间窗获得信号的时频谱图,但窗口尺寸是固定的,不能兼顾频域信息与时域信息,即不能同时对高频和低频进行精确分析。

小波变换以尺度函数(scaling)和小波函数(wavelet function)作为基函数进行信号分解。缩放母小波的宽度获得信号的频域特征,通过平移母小波获得信号的时间信息。

小波函数是定义在有限间隔且均值为0的一种函数。使用有限长的衰减的小波基, 既包含了频率的信息,也包含了时间的信息 。小波函数的尺度对应于频率,控制小波函数的伸缩,平移量对应于时间,控制小波函数的平移。

小波族类的产生只需要满足两个条件:归一化约束和正交化约束。因此小波有很多族类, 每个小波族在小波的紧凑性和平滑性做出了不同的权衡,对应着不同的形状、光滑度和紧密型,应用于不同的场景和状况。


例程 17_1:常用小波族的图像

import pywt
print(pywt.families(short=False))

# 显示的结果
['Haar', 'Daubechies', 'Symlets', 'Coiflets', 'Biorthogonal', 'Reverse biorthogonal', 
'Discrete Meyer (FIR Approximation)', 'Gaussian', 'Mexican hat wavelet', 'Morlet wavelet', 
'Complex Gaussian wavelets', 'Shannon wavelets', 'Frequency B-Spline wavelets', 'Complex Morlet wavelets']

运行结果:

[‘Haar’, ‘Daubechies’, ‘Symlets’, ‘Coiflets’, ‘Biorthogonal’, ‘Reverse biorthogonal’, ‘Discrete Meyer (FIR Approximation)’, ‘Gaussian’, ‘Mexican hat wavelet’, ‘Morlet wavelet’, ‘Complex Gaussian wavelets’, ‘Shannon wavelets’, ‘Frequency B-Spline wavelets’, ‘Complex Morlet wavelets’]

在这里插入图片描述


1.2 连续小波变换

傅里叶变换将信号 f ( t ) f(t) f(t)分解为一系列不同频率的正弦信号的叠加,傅里叶系数对应于不同正弦信号的幅值。小波变换将信号 f ( t ) f(t) f(t)分解为一系列小波信号的叠加,产生一系列小波信号的基本小波可以根据需要来选择或设计。

连续小波变换为:
γ ( s , τ ) = ∫ f ( t ) Ψ s , τ ∗ ( t ) d t \gamma (s,\tau) = \int f(t) \Psi ^* _{s,\tau} (t) dt γ(s,τ)=f(t)Ψs,τ(t)dt
连续小波变换的逆变换为:
f ( t ) = ∫ ∫ γ ( s , τ ) Ψ s , τ ( t ) d s d t f(t) = \int \int \gamma (s,\tau) \Psi _{s,\tau} (t) dsdt f(t)=∫∫γ(s,τ)Ψs,τ(t)dsdt
其中,* 表示复共轭, Ψ s , τ ( t ) \Psi _{s,\tau} (t) Ψs,τ(t)为小波基函数(basic wavelet)。

不同小波基函数,都是由同一个基本小波(母小波) Ψ ( t ) \Psi (t) Ψ(t) 经过缩放和平移产生。
Ψ s , τ ( t ) = 1 s Ψ ( t − τ s ) \Psi _{s,\tau} (t) = \frac{1}{\sqrt {s}} \Psi (\frac {t-\tau}{s}) Ψs,τ(t)=s 1Ψ(stτ)
离散小波变换,通过二进小波变换(缩放因子取为2)把由基本小波生成小波基函数的方法表示为:
Ψ j , k ( x ) = 2 j / 2 ∗ Ψ ( 2 j x − k ) , k = 0 , . . . 2 j − 1 \Psi_{j,k}(x) = 2^{j/2} * \Psi(2^j x-k) , \quad k=0,...2^j-1 Ψj,k(x)=2j/2Ψ(2jxk),k=0,...2j1
其中j决定缩放系数,k决定平移幅度。

在图像处理中,离散小波变换将图像分解为大小、位置和方向都不同的分量。对图像进行小波分解后,可以得到一系列不同分辨率的子图像,构造出图像金字塔。

小波变换中,缩放因子scale越小,表示小波越窄,对应的信号频率越高,反映的是信号的细节变化;缩放因子越大,表示小波越宽,对应的信号频率越低,反映的是信号的轮廓变化。


1.3 离散小波变换(Discrete wavelet transform, DWT)

双通道子带编码通过两个互补的滤波器组:

  • 低通滤波器,得到信号的近似值A,相当于小波伸展,获得当前信号的低频特征,反映轮廓特征;
  • 高通滤波器,得到信号的细节值D,相当于小波伸缩,获得当前信号的高频特征,反映细节特征。

实际应用中,信号的低频特征最重要,高频分量只起细化修饰的作用。

小波变换可以表示为由低通滤波器和高通滤波器组成的一棵树。原始信号经过一对互补的滤波器组进行的分解称为一级分解,继续下去可以进行多级分解。

如果对信号的高频分量不再分解,而对低频分量进行连续分解,可以得到信号在不同分辨率下的低频分量。

在这里插入图片描述


1.4 二维离散小波变换

图像是典型的二维离散信号。将一维离散小波变换开展到二维函数,就能实现图像的二维离散小波变换。

在二维情况下,每个二维小波都是两个一维小波的积,产生 4 个可分离的尺度函数:
φ ( x , y ) = φ ( x ) φ ( y ) Ψ H ( x , y ) = Ψ ( x ) φ ( y ) Ψ V ( x , y ) = φ ( x ) Ψ ( y ) Ψ D ( x , y ) = Ψ ( x ) Ψ ( y ) \varphi (x,y) = \varphi (x) \varphi (y)\\ \varPsi ^H(x,y) = \varPsi (x) \varphi (y)\\ \varPsi ^V(x,y) = \varphi (x) \varPsi (y) \\ \varPsi ^D(x,y) = \varPsi (x) \varPsi (y) φ(x,y)=φ(x)φ(y)ΨH(x,y)=Ψ(x)φ(y)ΨV(x,y)=φ(x)Ψ(y)ΨD(x,y)=Ψ(x)Ψ(y)
这些小波度量图像中灰度沿不同方向的变化:

  • Ψ H ( x , y ) \varPsi ^H(x,y) ΨH(x,y) 响应列的变化(水平边缘)。
  • Ψ V ( x , y ) \varPsi ^V(x,y) ΨV(x,y) 响应行的变化(垂直边缘)。
  • Ψ D ( x , y ) \varPsi ^D(x,y) ΨD(x,y) 响应对角线的变化。

在这里插入图片描述


例程 17_3:图像的小波变换

import numpy as np
import pywt
import cv2
import matplotlib.pyplot as plt

if __name__ == '__main__':
    # (3) 图像的二维小波变换
    img = cv.imread("../images/Fig0515a.tif", flags=0)
    img = cv.resize(img, (512, 512)).astype(np.float32)

    coeffs = pywt.dwt2(img, 'haar')
    cA, (cH, cV, cD) = coeffs  # 低频分量,(水平高频,垂直高频,对角线高频)

    # 拼接子图
    AH = np.concatenate([cA, cH], axis=1)
    VD = np.concatenate([cV, cD], axis=1)
    dwt1 = np.concatenate([AH, VD], axis=0)
    print(img.shape, dwt1.shape)

    # 显示为灰度图
    plt.imshow(dwt1, 'gray')
    plt.title('DWT'), plt.xticks([]), plt.yticks([])
    plt.show()

在这里插入图片描述


2. Haar 小波变换

2.1 Haar 小波变换的基本概念

Haar 变换又称 Haar 小波变换,由 Alfred Haar于1910年提出,是最早提出的正交小波,也是唯一既具有对称性又是有限支撑的正交小波。

Haar 小波函数是最简单的基函数,是一组分段的常值函数组成的函数集合。这个函数集定义在半开区间[0,1)上,每个分段常值函数的数值在一个小范围为 1 而在其它区域为 0。

Haar小波的母小波(mother wavelet)表示为:

Ψ ( x ) = { 1 , 0 ≤ x < 1 / 2 − 1 , 1 / 2 ≤ x < 1 0 , o t h e r w i s e \Psi(x) = \begin{cases} \begin{aligned} 1 , \quad &0 \le x \lt 1/2\\ -1 , \quad &1/2 \le x \lt 1\\ 0 , \quad & otherwise \end{aligned} \end{cases} Ψ(x)= 1,1,0,0x<1/21/2x<1otherwise

对应的尺度函数(scaling function)表示为:

ϕ ( x ) = { 1 , 0 ≤ t < 1 0 , o t h e r w i s e \phi(x) = \begin{cases} \begin{aligned} 1 , \quad &0 \le t \lt 1\\ 0 , \quad & otherwise \end{aligned} \end{cases} ϕ(x)={1,0,0t<1otherwise

其滤波器 h[n]定义为:

h [ n ] = { 1 / 2 , n = 0 , 1 0 , o t h e r w i s e h[n] = \begin{cases} \begin{aligned} 1 / \sqrt{2} , \quad & n=0,1\\ 0 , \quad & otherwise \end{aligned} \end{cases} h[n]={1/2 ,0,n=0,1otherwise

因此,

Ψ ( t / 2 ) = 2 ∑ n = − ∞ ∞ ( − 1 ) 1 − n ∗ h [ 1 − n ] ∗ ϕ ( t − n ) = ϕ ( t − 1 ) − ϕ ( t ) \begin{aligned} \Psi (t/2) &= \sqrt{2} \sum _{n=-\infty} ^{\infty} (-1)^{1-n}*h[1-n]*\phi (t-n)\\ &= \phi (t-1) - \phi (t) \end{aligned} Ψ(t/2)=2 n=(1)1nh[1n]ϕ(tn)=ϕ(t1)ϕ(t)

即:

Ψ i j ( x ) = Ψ ( 2 j ∗ x − i ) , i = 0 , . . . ( 2 j − 1 ) \Psi_i^j(x) = \Psi(2^j*x-i) , i=0,...(2^j-1)\\ Ψij(x)=Ψ(2jxi),i=0,...(2j1)

Ψ ( x ) = ϕ ( 2 x ) − ϕ ( 2 x − 1 ) \Psi(x) = \phi(2x) - \phi(2x-1) Ψ(x)=ϕ(2x)ϕ(2x1)

Haar 基函数可以获取信号的尺度信息,而 Haar 小波函数可以表示信号的细节信息。
Haar 小波具有如下特点:
(1)Haar 小波在时域是紧支撑的,即其非零区间为 [0,1)
(2)Haar 小波属于正交小波。
(3)Haar 小波是对称的。
(4)Haar 小波仅取 +1 和 -1,计算简单。
(5)Haar 小波是不连续小波,在实际的信号分析与处理中受到了限制。


例程 17_4:一维信号的 Haar 小波分解

对一维 Chirp 信号进行 Haar 小波变换的例程和结果如下。

import numpy as np
import pywt
import cv2
import matplotlib.pyplot as plt

if __name__ == '__main__':
   # (4) Chirp 信号的 Haar 小波分解
    x = np.linspace(0, 1, num=2048)
    chirp_signal = np.sin(250 * np.pi * x ** 2)

    fig, ax = plt.subplots(figsize=(8, 2))
    ax.set_title("Original Chirp Signal")
    ax.plot(chirp_signal)
    plt.show()

    data = chirp_signal
    waveletname = 'haar'

    fig, axarr = plt.subplots(nrows=5, ncols=2, figsize=(8, 6))
    for ii in range(5):
        (data, coeff_d) = pywt.dwt(data, waveletname)
        axarr[ii, 0].plot(data, 'r')
        axarr[ii, 1].plot(coeff_d, 'g')
        axarr[ii, 0].set_ylabel("Level {}".format(ii + 1), fontsize=14, rotation=90)
        axarr[ii, 0].set_yticklabels([])
        if ii == 0:
            axarr[ii, 0].set_title("Approximation coefficients", fontsize=14)
            axarr[ii, 1].set_title("Detail coefficients", fontsize=14)
        axarr[ii, 1].set_yticklabels([])
    plt.tight_layout()
    plt.show()

在这里插入图片描述


例程 17_5:图像的 Haar 小波分解

对二维图像进行 Haar 小波变换的例程和结果如下。

import numpy as np
import pywt
import cv2
import matplotlib.pyplot as plt
from pywt._doc_utils import wavedec2_keys, draw_2d_wp_basis

if __name__ == '__main__':
# (5) 图像的 Haar 小波分解
    x = pywt.data.camera().astype(np.float32)
    shape = x.shape
    max_lev = 3  # 要绘制多少级分解
    label_levels = 3  # 图上要显式标注多少层

    fig, axes = plt.subplots(2, 4, figsize=[14, 8])
    for level in range(0, max_lev + 1):
        if level == 0:
            # 显示原始图像
            axes[0, 0].set_axis_off()
            axes[1, 0].imshow(x, cmap=plt.cm.gray)
            axes[1, 0].set_title('Image')
            axes[1, 0].set_axis_off()
            continue

        # 绘制标准DWT基的子带边界
        draw_2d_wp_basis(shape, wavedec2_keys(level), ax=axes[0, level], label_levels=label_levels)
        axes[0, level].set_title('{} level\ndecomposition'.format(level))

        # 计算二维 DWT
        c = pywt.wavedec2(x, 'haar', mode='periodization', level=level)

        # 独立规范化每个系数数组以获得更好的可见性
        c[0] /= np.abs(c[0]).max()
        for detail_level in range(level):
            c[detail_level + 1] = [d / np.abs(d).max() for d in c[detail_level + 1]]

        # 显示归一化系数 (normalized coefficients)
        arr, slices = pywt.coeffs_to_array(c)
        axes[1, level].imshow(arr, cmap=plt.cm.gray)
        axes[1, level].set_title('Coefficients\n({} level)'.format(level))
        axes[1, level].set_axis_off()
    plt.tight_layout()
    plt.show()

在这里插入图片描述


2.2 小波变换在图像处理中的应用

小波变换在图像处理中的应用与傅里叶变换类似,基本方法是:
(1)计算一幅图像的二维小波变换,并得到小波系数
(2)对小波系数进行修改,保留有效成分,过滤不必要成分
(3)使用修改后的小波系数进行图像重建

基于小波变换的图像去噪步骤:
(1)图像小波变换。选择一个小波,计算噪声图像的小波系数。
(2)对细节系数通过阈值进行过滤。选择一个细节系数阈值,并对所有细节系数进行阈值化操作。
(3)基于阈值化过滤后的细节系数及原始近似系数,使用小波变换对图像进行重建。


版权声明:

youcans@xupt 原创作品,转载必须标注原文链接:(https://blog.csdn.net/youcans/article/details/130320033)
Copyright 2022 youcans, XUPT
欢迎关注 『youcans 的 OpenCV 学习课』 系列,持续更新

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

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

相关文章

《通过十几轮数据进行模型训练,实现精确的无创血糖测量的演绎学习》阅读笔记

目录 0 演绎学习 1 论文摘要 2 论文十问 3 论文亮点与不足之处 4 与其他研究的比较 5 实际应用与影响 6 个人思考与启示 参考文献 0 演绎学习 在本文中&#xff0c;DL指的是Deduction Learning&#xff0c;即演绎学习方法。该方法是一种机器学习方法&#xff0c;通过使…

ServerPapers 开源轻量级服务器监控工具

ServerPapers 开源轻量级服务器监控工具 起因 之前用过一些服务器监控工具&#xff0c;但是有些配置复杂不够方便。也有些配置简单&#xff0c;但没有我想要显示的一些信息。所以我就花了三天时间自己写了一个开源的轻量级服务器监控工具。 项目 介绍 ServerPapers是一个基…

聚观早报|苹果版余额宝四天吸金69亿;​微软拟推出私有版ChatGPT

今日要闻&#xff1a;苹果版余额宝四天吸金69亿元&#xff1b;称微软拟推出私有版ChatGPT&#xff1b;特斯拉上调Model 3、Model Y售价&#xff1b;好莱坞编剧将举行15年来首次罢工&#xff1b;字节跳动要在美国卖书了 苹果版余额宝四天吸金69亿元 早些时候&#xff0c;苹果推…

自动驾驶TPM技术杂谈 ———— I-vista验收标准(试验规程)

文章目录 术语介绍试验准备场地要求环境要求精度要求边界车辆&路沿石 试验方法能力试验双边界车辆平行车位白色标线平行车位双边界车辆垂直车位白色标线垂直车位方柱垂直车位双边界车辆斜向车位白色标线斜向车位 新功能评价平行车位远程操控泊入泊出试验垂直车位远程操控泊…

用户界面对象的线程亲缘性第二篇: 设备上下文

在上一篇文章中&#xff0c;我们简单地介绍了控制窗口句柄的线程亲缘性规则。 今天&#xff0c;我们来讲讲设备上下文(Device Context, 简称 DC) 。 设备上下文也有一定程度的线程亲缘性。调用 DC 相关函数&#xff0c;例如 GetDC 的线程&#xff0c;必须在同一个线程中调用其…

VC++判断Windows系统是Win7、Win8,还是Win10系统(附源码)

有时候我们需要获取操作系统版本,比如win7、win8、win8.1、win10等,对不同版本的系统做特殊处理。有时我们还需要分辨当前系统是64位的,还是32位的。 1、系统API函数GetVersionEx已经被废弃,不能再使用了 以前我们一般使用系统API函数GetVersionEx去获取操作系统版本,但从…

B016_单行函数篇

2022年4月14日08:25:25 通过本章学习,您将可以: SQL中不同类型的函数 在 SELECT 语句中使用字符,数字,日期和转换函数 使用条件表达式术语 函数-预定义的接受参数的代码块单行函数-为每条记录返回一行结果多行函数-返回一个结果,每组数据处理什么是SQL函数 多行函数也叫…

【Redis—主从复制】

概念 如果把数据都存储到一台服务器上&#xff0c;当服务器出现宕机后&#xff0c;数据会丢失。而把数据备份到多台服务器上&#xff0c;那么当一台服务器发生故障后&#xff0c;其他服务器仍然可以继续提供服务。由于是多台服务器&#xff0c;所以服务器之间的数据要保持一致…

SwiftUI 如何动态条件显示和隐藏 Toolbar 按钮且不做无谓刷新

功能需求 在 SwiftUI 中我们可以非常容易的定制导航栏 Toolbar 中按钮的显示,包括折叠、分组和按条件动态显示和隐藏等。 如上图所示,我们仅用寥寥几行代码就实现了 SwiftUI 导航栏 Toolbar 按钮的折叠、分组和按条件动态显示隐藏等功能。 在本篇博文中,您将学到以下内容:…

Spring Cache的使用

目录 一、前言二、什么是Spring Cache&#xff1f;三、Spring Cache常用注解四、使用方法1.导入依赖2.开启缓存注解3.Cacheables4.CachePut5.CacheEvict6.Caching 一、前言 在日常开发工作中&#xff0c;缓存是一个很常见的技术手段&#xff0c;它可以有效地提高系统性能。当系…

6.1.1 图:基本概念

一&#xff0c;基本概念 1.基本定义 &#xff08;1&#xff09;图的定义 顶点集不可以是空集&#xff0c;但边集可以是空集。 &#xff08;2&#xff09; 有向图的表示&#xff1a; 圆括号 无向图的表示&#xff1a; 尖括号 简单图、多重图&#xff1a; 简单图&#xff1a;…

Java中变量的学习

目录 概述&#xff1a;Java中的成员包含五部分 第一部分&#xff1a;变量 &#xff08;1&#xff09;Java中的变量分类 &#xff08;2&#xff09;成员变量和局部变量的位置区别 &#xff08;3&#xff09;Java中成员变量作用域/Java权限修饰符 &#xff08;4&#xff09;…

IntelliJ IDEA 社区版2021.3配置SpringBoot项目详细教程及错误解决方法

目录 一、SpringBoot的定义 二、Spring Boot 优点 三、创建一个springboot的项目 四、使用IDEA创建SpringBoot失败案例 一、SpringBoot的定义 Spring 的诞⽣是为了简化 Java 程序的开发的&#xff0c;⽽ Spring Boot 的诞⽣是为了简化 Spring 程序开发的。 Spring Boot 翻…

maven从入门到精通 第一章 Maven核心程序解压与配置

这里写自定义目录标题 一 为什么要使用Maven1 依赖管理 帮助管jar包2 构建管理 脱离IDE进行运行2.1 传统方式&#xff0c;就是打包成war包&#xff0c;然后放在tomacat上运行2.2 一个程序的运行步骤 二 maven的工作机制1 配置maven1.1 关注 Maven 的核心配置文件&#xff1a;co…

Android Glide加载图片、网络监听、设置资源监听

再搞事情之前首先创建一个项目&#xff0c;就命名为GlideDemo吧。    一、项目配置 创建好之后&#xff0c;在app模块下build.gradle的dependencies闭包中添加如下依赖&#xff1a; //glide//glideimplementation com.github.bumptech.glide:glide:4.11.0annotationProcess…

mysql的一次死锁记录

表结构 create table lzy_test.test_lzy (id int not null primary key,name varchar(128) default null,age int default 0 null,constraint key_name unique (name) );表中数据 idnameage1lzy104lzy412336lzy609lzy90 事务死锁的过程 隔离级别RC 事务A…

【沐风老师】3dMax创建缝线插件StitchLines使用方法详解

3dMax创建缝线插件使用方法详解 3dMax创建缝线插件StitchLines&#xff0c;一键生成车缝线建模&#xff0c;该脚本与可编辑多边形、可编辑样条线或 编辑多边形修改器一起使用&#xff0c;创建一条样条曲线&#xff08;车缝线&#xff09;&#xff0c;它将以几何体形式在视口中和…

云时通OMS:为零售品牌商打造高效的全渠道订单管理!

传统的零售企业围绕“人、货、场” 三要素来展开营销&#xff0c;其目标是基于“场”将货销售给更多的人。随着数字技术的应用&#xff0c;新零售模式下的“场”除了传统的线下店铺外&#xff0c;还拓展了多元化的线上渠道&#xff0c;比如小程序、企业APP、第三方平台、电商直…

学系统集成项目管理工程师(中项)系列17a_范围管理(上)

1. 包括确保项目做且只做所需的全部工作&#xff0c;以成功完成项目的各个过程 2. 项目工作明确划定边界 2.1. 什么是包括在项目之内的 2.2. 什么是不包括在项目之内的 3. 项目其他各方面管理的基础 4. 编制范围管理计划过程 4.1. 对如何定义、确认和控制项目范围的过程进…

归一化处理(2023寒假每日一题 14)

在机器学习中&#xff0c;对数据进行归一化处理是一种常用的技术。 将数据从各种各样分布调整为平均值为 0 0 0、方差为 1 1 1 的标准分布&#xff0c;在很多情况下都可以有效地加速模型的训练。 这里假定需要处理的数据为 n n n 个整数 a 1 , a 2 , ⋯ , a n a_1,a_2,⋯…