【数字图像处理4】小波变换 处理图像

一、前言

实验目的

用小波变换对图像去噪。

简单回顾一下小波变换:

数学公式我就不上了,估计上了也没人会认真看…

小波变换之所以诞生,是由于之前使用的傅里叶变换有一些缺点:

  • 傅立叶变换提取信号的频谱,需要利用信号的全部时域信息。
  • 傅立叶变换,没有随着时间的变化信号频率成分的变化情况。
  • 傅立叶变换积分作用平滑了非平稳信号的突变成分。

用大白话说就是:

  • 前两点:因为傅里叶变换是统计一段时间内的图像频率变化(高频低频波普啊什么的),他本身是不具备时间属性的,用户只知道这一段时间里面频域率总共发生了什么,但是先后顺序啊这种时间信息一概不知。
  • 第三点:傅里叶变换由于本身性质,对于偶然出现的一个超大值点,会被其影响整个时间段的频率图像分布,但是小波变换由于具有时间属性,就能够锁定这个突变点(再进行什么操作那是后话,反正是知道这个突变点是什么时候出现的)

傅里叶变换:
在这里插入图片描述
但是在这种情况,如图所示,傅里叶变换不能区分这两种图像区别:
在这里插入图片描述
自然界的大量信号几乎都是非平稳的,所以在比如生物医学信号分析等领域的论文中,基本看不到单纯傅里叶变换这样naive的方法。所以就引出了小波变换:

  • 首先,顾名思义,小波变换是对波进行了一些处理,把大波变成了小波的操作将无限长的三角函数基换成了有限长的会衰减的小波基。
  • 这就是为什么它叫“小波”,因为是很小的一个波嘛~
    在这里插入图片描述
  • 小波还有一些好处,比如,我们知道对于突变信号,傅里叶变换存在吉布斯效应,我们用无限长的三角函数怎么也拟合不好突变信号:
  • 在这里插入图片描述

二、环境配置

python 小波库PyWavelets 直接在cmd中输入:

pip install PyWavelets

在这里插入图片描述

要运行PyWavelets所有测试还需要安装 Matplotlib 包

pip install Matplotlib.

如果已经安装,则会出现如下图示:
在这里插入图片描述

三、实验思路及过程(附图)

  1. 首先,用小波变换(随便选去一个小波基,我用的哈尔)对图像进行分解,得到高低频分量(其中高频有三个分量)。
#读取灰度图
img = cv2.imread('pic/house.jpg',0)

#cA,cH,cV,cD 分别为近似分量(低频分量)、水平细节分量、垂直细节分量和对角细节分量
cA,(cH,cV,cD)=dwt2(img,'haar')#dwt2函数第二个参数指定小波基

#打印语句
plt.subplot(232), plt.imshow(cA, 'gray'), plt.title('cA')
plt.subplot(233), plt.imshow(cH, 'gray'), plt.title('cH')
plt.subplot(234), plt.imshow(cV, 'gray'), plt.
  • 19
    点赞
  • 107
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值