深入理解小波变换:信号处理的强大工具

引言

在科学与工程领域,信号处理一直是关键环节,傅里叶变换与小波变换作为重要的分析工具,在其中发挥着重要作用。本文将深入探讨小波变换,阐述其原理、优势以及与傅里叶变换的对比,并通过具体案例展示其应用价值。

在这里插入图片描述

一、傅里叶变换的局限性

傅里叶变换是一种经典的信号分析方法,能将时域信号转换为频域信号,让我们清晰了解信号包含的频率成分。在分析一段音乐信号时,傅里叶变换可揭示其中的各种音调(频率)。然而,傅里叶变换存在明显不足,它假设信号是由无限延伸的正弦波或余弦波组成,在将信号从时域转换到频域的过程中,完全丢失了时间信息。这意味着,使用傅里叶变换虽能知晓信号中有哪些频率,但无法确定这些频率在何时出现。比如在分析包含多个乐器演奏的音乐信号时,我们无法得知每种乐器声音在哪个时刻响起;在分析地震信号时,无法确定不同地震波(如 P 波和 S 波)出现的具体时刻,这在很多实际应用场景中是远远不够的。

二、小波变换的原理

(一)基本概念

小波变换的核心是通过对一个母小波函数进行伸缩和平移操作,生成一系列小波基函数。假设有一个满足特定条件的母小波函数 ψ ( t ) \psi(t) ψ(t),通过尺度参数 a a a和平移参数 b b b,可得到一族小波基函数 ψ a , b ( t ) = 1 a ψ ( t − b a ) \psi_{a,b}(t)=\frac{1}{\sqrt{a}}\psi(\frac{t - b}{a}) ψa,b(t)=a 1ψ(atb)尺度参数 a a a控制着小波函数的伸缩程度,大尺度对应信号的低频特征,就像大梳子能梳理出信号中比较慢、比较低沉的部分;小尺度对应信号的高频细节,类似小梳子能捕捉到信号中比较快、比较尖锐的部分。平移参数 b b b则用于在时间轴上移动小波函数,以匹配信号不同位置的特征。

(二)信号分解与重构

对于给定的信号 f ( t ) f(t) f(t),其小波变换 W f ( a , b ) W_{f}(a,b) Wf(a,b)定义为 W f ( a , b ) = ∫ − ∞ ∞ f ( t ) ψ a , b ∗ ( t ) d t W_{f}(a,b)=\int_{-\infty}^{\infty}f(t)\psi_{a,b}^*(t)dt Wf(a,b)=f(t)ψa,b(t)dt其中 ψ a , b ∗ ( t ) \psi_{a,b}^*(t) ψa,b(t) ψ a , b ( t ) \psi_{a,b}(t) ψa,b(t)的共轭函数。这个积分运算实际上是计算信号 f ( t ) f(t) f(t)与小波基函数 ψ a , b ( t ) \psi_{a,b}(t) ψa,b(t)的内积,得到的小波系数 W f ( a , b ) W_{f}(a,b) Wf(a,b)表示了信号 f ( t ) f(t) f(t)在尺度 a a a和平移 b b b下与小波基函数的相似程度。在实际应用中,不仅可以对信号进行分解,还能通过这些小波系数进行信号重构,将分解后的信号还原。

三、小波变换的优势

(一)时频局部化特性

与傅里叶变换不同,小波变换能同时在时间域和频率域对信号进行局部化分析。在分析音乐信号时,它能准确捕捉到像鼓点、吉他拨弦等瞬间出现的声音,并在时频域中精确定位,让我们清楚知道这些声音在何时出现以及对应的频率。在地震信号分析中,可清晰展示 P 波和 S 波在不同时刻的频率特征,有助于地震学家深入研究地震的传播过程。

(二)多分辨率分析

小波变换具有多分辨率特性,可将信号分解为不同尺度下的分量,从粗到细逐步分析信号的细节。以图像分析为例,大尺度下能把握图像的整体轮廓,如一幅风景图像中的山脉、河流等大致形状;小尺度下能关注到图像的细微纹理,如树叶的脉络、岩石的纹理等。这种多分辨率分析就如同用不同倍数的放大镜观察物体,从宏观到微观全面了解信号或图像的特征。

(三)基函数的灵活性

小波变换拥有多种不同类型的母小波函数,并且可以根据信号的特点进行选择和定制。对于具有明显非平稳、非线性特征的信号,小波变换能够通过选取合适的母小波函数,更好地匹配和表示这些信号。而傅里叶变换的基函数只有固定的正弦函数和余弦函数,形式较为单一,在处理这类复杂信号时往往力不从心。

(四)计算复杂度和效率

在处理一些长度较长、复杂度较高的信号时,傅里叶变换可能需要较高的计算成本和时间。而小波变换在处理具有局部特征和稀疏性的信号时,能够利用这些特性,采用快速算法,降低计算复杂度,提高计算效率。在处理大规模图像数据或长时间的生理信号时,小波变换的这一优势尤为明显。

四、小波变换的应用案例

(一)地震信号分析

如前文所述,在地震监测中,小波变换能够准确确定不同地震波出现的时刻和频率特征。通过对地震信号进行小波变换,地震学家可以更精确地判断地震的震级、震源深度以及地震波的传播路径等重要信息。在 2011 年日本东海岸发生的 9.0 级大地震中,科学家利用小波变换对地震信号进行分析,不仅快速确定了地震的基本参数,还通过对地震信号细节的分析,深入研究了地震的破裂过程和海啸的产生机制,为后续的灾害评估和预防提供了重要依据。

(二)图像压缩

在图像领域,小波变换被广泛应用于图像压缩。将图像进行小波变换后,图像的能量会集中在少数小波系数上。通过对这些系数进行量化和编码,可以实现高效的图像压缩。著名的 JPEG 2000 图像压缩标准就采用了小波变换技术,相比传统的 JPEG 压缩标准,JPEG 2000 在相同的压缩比下能够提供更好的图像质量,特别是在处理包含丰富纹理和细节的图像时,优势更加明显。例如,在对卫星遥感图像进行压缩时,JPEG 2000 能够在大幅减少数据量的同时,保留图像中的关键信息,如地形地貌、城市建筑等细节,方便数据的传输和存储。

(三)医学信号处理

在医学领域,小波变换常用于处理各种生理信号,如心电图(ECG)、脑电图(EEG)等。以心电图信号处理为例,医生需要从心电图中准确判断心脏的工作状态,识别出正常和异常的心跳模式。小波变换能够对心电图信号进行时频分析,突出信号中的特征点,如 P 波、QRS 波群等,帮助医生更准确地检测出心脏疾病。在实际临床应用中,通过小波变换对心电图信号进行预处理和特征提取,可以辅助医生快速诊断出心肌梗死、心律失常等疾病,提高诊断的准确性和效率。

(四)小波变换计算实例

下面以一维连续信号的小波变换为例,使用哈尔小波对一个简单的分段函数信号进行变换,并详细解释变换前后的情况。

1. 定义原始信号

假设我们有一个简单的一维连续信号 f ( t ) f(t) f(t),定义在区间 [ 0 , 4 ] [0, 4] [0,4] 上:
f ( t ) = { 2 , 0 ≤ t < 2 4 , 2 ≤ t < 4 f(t) = \begin{cases} 2, & 0\leq t < 2 \\ 4, & 2\leq t < 4 \end{cases} f(t)={2,4,0t<22t<4

2. 介绍哈尔小波

哈尔小波是一种最简单的小波函数,其尺度函数 φ ( t ) \varphi(t) φ(t) 和小波函数 ψ ( t ) \psi(t) ψ(t) 定义如下:

  • 尺度函数
    φ ( t ) = { 1 , 0 ≤ t < 1 0 , 其他 \varphi(t)= \begin{cases} 1, & 0\leq t < 1 \\ 0, & \text{其他} \end{cases} φ(t)={1,0,0t<1其他
  • 小波函数
    ψ ( t ) = { 1 , 0 ≤ t < 0.5 − 1 , 0.5 ≤ t < 1 0 , 其他 \psi(t)= \begin{cases} 1, & 0\leq t < 0.5 \\ -1, & 0.5\leq t < 1 \\ 0, & \text{其他} \end{cases} ψ(t)= 1,1,0,0t<0.50.5t<1其他
3. 连续小波变换公式

连续小波变换(CWT)的公式为:
W f ( a , b ) = 1 a ∫ − ∞ ∞ f ( t ) ψ ( t − b a ) d t W_f(a, b)=\frac{1}{\sqrt{a}}\int_{-\infty}^{\infty}f(t)\psi\left(\frac{t - b}{a}\right)dt Wf(a,b)=a 1f(t)ψ(atb)dt
其中, a a a 是尺度参数,控制小波的伸缩; b b b 是平移参数,控制小波的平移。

4. 具体计算示例

我们取几个特定的 ( a , b ) (a, b) (a,b) 值来计算小波变换结果。

情况一: a = 1 , b = 0 a = 1, b = 0 a=1,b=0

W f ( 1 , 0 ) = ∫ − ∞ ∞ f ( t ) ψ ( t ) d t = ∫ 0 1 f ( t ) ψ ( t ) d t W_f(1, 0)=\int_{-\infty}^{\infty}f(t)\psi(t)dt=\int_{0}^{1}f(t)\psi(t)dt Wf(1,0)=f(t)ψ(t)dt=01f(t)ψ(t)dt
因为在区间 [ 0 , 1 ] [0, 1] [0,1] 上, f ( t ) = 2 f(t) = 2 f(t)=2,所以:
W f ( 1 , 0 ) = ∫ 0 0.5 2 × 1 d t + ∫ 0.5 1 2 × ( − 1 ) d t = 2 × ( 0.5 − 0 ) − 2 × ( 1 − 0.5 ) = 1 − 1 = 0 W_f(1, 0)=\int_{0}^{0.5}2\times1dt+\int_{0.5}^{1}2\times(- 1)dt=2\times(0.5 - 0)-2\times(1 - 0.5)=1 - 1 = 0 Wf(1,0)=00.52×1dt+0.512×(1)dt=2×(0.50)2×(10.5)=11=0

情况二: a = 1 , b = 2 a = 1, b = 2 a=1,b=2

W f ( 1 , 2 ) = ∫ − ∞ ∞ f ( t ) ψ ( t − 2 ) d t = ∫ 2 3 f ( t ) ψ ( t − 2 ) d t W_f(1, 2)=\int_{-\infty}^{\infty}f(t)\psi(t - 2)dt=\int_{2}^{3}f(t)\psi(t - 2)dt Wf(1,2)=f(t)ψ(t2)dt=23f(t)ψ(t2)dt
因为在区间 [ 2 , 3 ] [2, 3] [2,3] 上, f ( t ) = 4 f(t) = 4 f(t)=4,所以:
W f ( 1 , 2 ) = ∫ 2 2.5 4 × 1 d t + ∫ 2.5 3 4 × ( − 1 ) d t = 4 × ( 2.5 − 2 ) − 4 × ( 3 − 2.5 ) = 2 − 2 = 0 W_f(1, 2)=\int_{2}^{2.5}4\times1dt+\int_{2.5}^{3}4\times(-1)dt=4\times(2.5 - 2)-4\times(3 - 2.5)=2 - 2 = 0 Wf(1,2)=22.54×1dt+2.534×(1)dt=4×(2.52)4×(32.5)=22=0

情况三: a = 2 , b = 0 a = 2, b = 0 a=2,b=0

此时 ψ ( t 2 ) \psi\left(\frac{t}{2}\right) ψ(2t) 为:
ψ ( t 2 ) = { 1 , 0 ≤ t < 1 − 1 , 1 ≤ t < 2 0 , 其他 \psi\left(\frac{t}{2}\right)= \begin{cases} 1, & 0\leq t < 1 \\ -1, & 1\leq t < 2 \\ 0, & \text{其他} \end{cases} ψ(2t)= 1,1,0,0t<11t<2其他

W f ( 2 , 0 ) = 1 2 ∫ − ∞ ∞ f ( t ) ψ ( t 2 ) d t = 1 2 ( ∫ 0 1 2 × 1 d t + ∫ 1 2 2 × ( − 1 ) d t ) = 0 W_f(2, 0)=\frac{1}{\sqrt{2}}\int_{-\infty}^{\infty}f(t)\psi\left(\frac{t}{2}\right)dt=\frac{1}{\sqrt{2}}\left(\int_{0}^{1}2\times1dt+\int_{1}^{2}2\times(-1)dt\right)=0 Wf(2,0)=2 1f(t)ψ(2t)dt=2 1(012×1dt+122×(1)dt)=0

情况四: a = 2 , b = 2 a = 2, b = 2 a=2,b=2

此时 ψ ( t − 2 2 ) \psi\left(\frac{t - 2}{2}\right) ψ(2t2) 为:
ψ ( t − 2 2 ) = { 1 , 2 ≤ t < 3 − 1 , 3 ≤ t < 4 0 , 其他 \psi\left(\frac{t - 2}{2}\right)= \begin{cases} 1, & 2\leq t < 3 \\ -1, & 3\leq t < 4 \\ 0, & \text{其他} \end{cases} ψ(2t2)= 1,1,0,2t<33t<4其他

W f ( 2 , 2 ) = 1 2 ∫ − ∞ ∞ f ( t ) ψ ( t − 2 2 ) d t = 1 2 ( ∫ 2 3 4 × 1 d t + ∫ 3 4 4 × ( − 1 ) d t ) = 0 W_f(2, 2)=\frac{1}{\sqrt{2}}\int_{-\infty}^{\infty}f(t)\psi\left(\frac{t - 2}{2}\right)dt=\frac{1}{\sqrt{2}}\left(\int_{2}^{3}4\times1dt+\int_{3}^{4}4\times(-1)dt\right)=0 Wf(2,2)=2 1f(t)ψ(2t2)dt=2 1(234×1dt+344×(1)dt)=0

5. 变换前后的解释

变换前(原始信号)

原始信号 f ( t ) f(t) f(t) 是一个分段常数函数,在区间 [ 0 , 2 ) [0, 2) [0,2) 上值为 2,在区间 [ 2 , 4 ) [2, 4) [2,4) 上值为 4。它描述了一个在不同时间段具有不同恒定值的现象。从时域角度看,我们可以直接观察到信号在不同区间的取值情况,但对于信号在不同尺度和位置上的变化特征并不容易直观分析。

变换后(小波变换结果)
  • 尺度参数 a a a 的意义:尺度参数 a a a 控制着小波函数的伸缩程度。较大的 a a a 值对应着较宽的小波,它可以检测信号中的低频成分,也就是信号的整体趋势;较小的 a a a 值对应着较窄的小波,它可以检测信号中的高频成分,也就是信号的局部变化。
  • 平移参数 b b b 的意义:平移参数 b b b 控制着小波函数在时间轴上的位置。通过改变 b b b,我们可以在不同的时间位置对信号进行分析。
  • 小波变换结果分析:在上述计算中,我们得到的小波变换结果大部分为 0。这是因为哈尔小波是一种非常简单的小波,对于这种分段常数信号,在特定的 ( a , b ) (a, b) (a,b) 组合下,信号与小波函数的乘积在积分区域内正负抵消。但如果信号存在突变或者局部变化,小波变换会在相应的 ( a , b ) (a, b) (a,b) 位置产生非零值,从而可以检测到信号的局部特征。

通过小波变换,我们将原始信号从时域转换到了尺度 - 平移域,能够更方便地分析信号在不同尺度和位置上的特征,这对于信号处理、图像分析、故障诊断等领域都具有重要意义。

五、总结

小波变换作为一种强大的信号处理工具,以其独特的时频局部化特性、多分辨率分析能力、灵活的基函数选择以及高效的计算性能,在众多领域展现出了巨大的优势。与傅里叶变换相比,小波变换能够更好地处理非平稳、非线性信号,为我们提供更丰富、更准确的信息。无论是在地震监测、图像压缩还是医学信号处理等领域,小波变换都发挥着不可或缺的作用,并且随着技术的不断发展,其应用前景将更加广阔。

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

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

相关文章

【数据结构】(7) 栈和队列

一、栈 Stack 1、什么是栈 栈是一种特殊的线性表&#xff0c;它只能在固定的一端&#xff08;栈顶&#xff09;进行出栈、压栈操作&#xff0c;具有后进先出的特点。 2、栈概念的例题 答案为 C&#xff0c;以C为例进行讲解&#xff1a; 第一个出栈的是3&#xff0c;那么 1、…

fastchat 部署大模型

大模型实战--Llama3.1大模型部署及启动Web UI、OpenAI API实操 - 简书一、背景 随着人工智能技术的飞速发展&#xff0c;大模型&#xff08;Large Language Models, LLMs&#xff09;已成为自然语言处理领域的核心工具。这些模型以其强大的语言理解和生成能力&#xff0c;...ht…

【R语言】卡方检验

一、定义 卡方检验是用来检验样本观测次数与理论或总体次数之间差异性的推断性统计方法&#xff0c;其原理是比较观测值与理论值之间的差异。两者之间的差异越小&#xff0c;检验的结果越不容易达到显著水平&#xff1b;反之&#xff0c;检验结果越可能达到显著水平。 二、用…

【deepSeek R1】Ollama 更改模型安装位置 以及应用安装位置

【deepSeek R1】Ollama 更改模型安装位置 以及应用安装位置 本地版部署deepSeek R1 可以参考文章 3分钟教你搭建属于自己的本地大模型 DeepSeek R1 Ollama 是一个开源工具&#xff0c;旨在帮助用户轻松在本地计算机上运行、部署和管理大型语言模型&#xff08;LLMs&#xff09;…

dijkstra算法类型题解

dijkstra算法&#xff08;有权图&#xff0c;无权图&#xff09;&#xff1a; 带权路径长度——当图是带权图时&#xff0c;一条路径上所有边的权值之和&#xff0c;称为该路径的带权路径长度 初始化三个数组&#xff0c;final标记各顶点是否已找到最短路径&#xff0c;dist最…

6.Centos7上部署flask+SQLAlchemy+python+达梦数据库

情况说明 前面已经介绍了window上使用pycharm工具开发项目时,window版的python连接达梦数据库需要的第三方包。 这篇文章讲述,centos7上的python版本连接达梦数据库需要的第三方包。 之前是在windows上安装达梦数据库的客户端,将驱动包安装到windows版本的python中。(开…

国产化创新 守护开放边界网络安全

当今数字化浪潮的席卷下&#xff0c;企业、医院、政府部门等各类机构的信息化建设正以前所未有的速度推进。 在这个数字化转型的关键时期&#xff0c;尤其是在涉及国家核心利益和敏感数据的领域&#xff0c;我们不仅要追求技术的先进性&#xff0c;更要确保安全性和自主可控性…

postgresql 游标(cursor)的使用

概述 PostgreSQL游标可以封装查询并对其中每一行记录进行单独处理。当我们想对大量结果集进行分批处理时可以使用游标&#xff0c;因为一次性处理可能造成内存溢出。 另外我们可以定义函数返回游标类型变量&#xff0c;这是函数返回大数据集的有效方式&#xff0c;函数调用者…

Linux 快速对比两个文件的差异值

Linux 快速对比两个文件的差异值&#xff08;无需排序、直接输出&#xff09; 在日常开发或数据处理中&#xff0c;若需快速对比两个文本文件中的差异值&#xff08;仅保留第一个文件中的独有内容&#xff09;&#xff0c;Linux 系统提供了两种高效方法。以下是具体操作及适用…

语言月赛 202308【小粉兔做麻辣兔头】题解(AC)

》》》点我查看「视频」详解》》》 [语言月赛 202308] 小粉兔做麻辣兔头 题目描述 粉兔喜欢吃麻辣兔头&#xff0c;麻辣兔头的辣度分为若干级&#xff0c;用数字表示&#xff0c;数字越大&#xff0c;兔头越辣。为了庆祝粉兔专题赛 #1 的顺利举行&#xff0c;粉兔要做一些麻…

C++20导出模块及使用

1.模块声明 .ixx文件为导入模块文件 math_operations.ixx export module math_operations;//模块导出 //导出命名空间 export namespace math_ {//导出命名空间中函数int add(int a, int b);int sub(int a, int b);int mul(int a, int b);int div(int a, int b); } .cppm文件…

使用redis实现 令牌桶算法 漏桶算法

流量控制算法&#xff0c;用于限制请求的速率。 可以应对缓存雪崩 令牌桶算法 核心思想是&#xff1a; 有一个固定容量的桶&#xff0c;里面存放着令牌&#xff08;token&#xff09;。每过一定时间&#xff08;如 1 秒&#xff09;&#xff0c;桶中会自动增加一定数量的令牌…

活动预告 | 解锁 Excel 新境界 —— AI 技术赋能下的数据分析超级引擎!

课程介绍 在 AI 技术的浪潮中&#xff0c;Microsoft Excel 已经焕然一新&#xff0c;它不再仅仅是海量复杂数据的处理中心&#xff0c;更是未来趋势的预测大师。智能 Copilot 副驾驶的加入&#xff0c;让 Excel 如虎添翼&#xff0c;成为每一位数据探索者梦寐以求的超级引擎。在…

在阿里云ECS上一键部署DeepSeek-R1

DeepSeek-R1 是一款开源模型&#xff0c;也提供了 API(接口)调用方式。据 DeepSeek介绍&#xff0c;DeepSeek-R1 后训练阶段大规模使用了强化学习技术&#xff0c;在只有极少标注数据的情况下提升了模型推理能力&#xff0c;该模型性能对标 OpenAl o1 正式版。DeepSeek-R1 推出…

如何通过Deepseek的API进行开发和使用(适合开发者和小白的学习使用教程)

目录 一,API创建与获取 二,直接进行API的调用 2.1 安装第三方库 2.2 官方支持的接口调用方式 2.3 编写的小tips 2.4 AI助手工具代码 三, 配置方面的说明 3.1 token价格和字符用量 3.2 响应错误码 最近在休息的时候也是一直会刷到关于deepseek,简单使用了一下,发现这…

unity学习33:角色相关2,碰撞检测,collider 和 rigidbody,测试一个简单碰撞爆炸效果

目录 1 给gameObject添加rigidbody 2 rigidbody的属性 2.1 基础属性 2.2 插值 详细 2.3 碰撞检测 2.4 constraints 冻结坐标轴的移动和旋转 2.5 layer Overrides 3 碰撞检测 collision Detection 3.1 每个gameObeject上都会创建时自带一个 Collider 3.2 Collider的绿…

【生成模型之十四】Visual Autoregressive Modeling

论文&#xff1a;Visual Autoregressive Modeling: Scalable Image Generation via Next-Scale Prediction code&#xff1a;GitHub - FoundationVision/VAR: [NeurIPS 2024 Best Paper][GPT beats diffusion&#x1f525;] [scaling laws in visual generation&#x1f4c8;]…

硬核技术:小程序能够调用手机的哪些传感器

一、加速度传感器 小程序可以调用手机的加速度传感器来检测设备的运动状态。加速度传感器能够测量设备在三个轴&#xff08;X、Y、Z&#xff09;上的加速度变化。通过分析这些数据&#xff0c;小程序可以实现一些功能&#xff0c;如运动检测、步数统计、游戏中的动作感应等。 健…

活动预告 |【Part 2】Microsoft 安全在线技术公开课:通过扩展检测和响应抵御威胁

课程介绍 通过 Microsoft Learn 免费参加 Microsoft 安全在线技术公开课&#xff0c;掌握创造新机遇所需的技能&#xff0c;加快对 Microsoft Cloud 技术的了解。参加我们举办的“通过扩展检测和响应抵御威胁”技术公开课活动&#xff0c;了解如何更好地在 Microsoft 365 Defen…

【WB 深度学习实验管理】利用 Hugging Face 实现高效的自然语言处理实验跟踪与可视化

本文使用到的 Jupyter Notebook 可在GitHub仓库002文件夹找到&#xff0c;别忘了给仓库点个小心心~~~ https://github.com/LFF8888/FF-Studio-Resources 在自然语言处理领域&#xff0c;使用Hugging Face的Transformers库进行模型训练已经成为主流。然而&#xff0c;随着模型复…