热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

[CV]小波变换

小波变换函数空间$f(x)\\inV$\\[V\\overline{SPAN\\varphi_{k}(x)}\\]所有构成函数空间$V$的基函数都是归一化正交的(or

小波变换

函数空间\(f(x)\in V\)

\[V=\overline{S P A N \varphi_{k}(x)} \]

所有构成函数空间\(V\)的基函数都是归一化正交的(orthonormal basis),即任意两个基函数之间都是归一化正交的(orthonormal)

正交:https://zh.wikipedia.org/wiki/正交

尺度函数

母函数

\[\varphi_{j, k}(x)=2^{j / 2} \varphi\left(2^{j} x-k\right) \]

  • k是平移,沿着x轴的位置
  • j是尺度,沿着x轴的宽度

每个尺度j都有对应的子空间

\[V_{j}=\overline{S P A N \varphi_{j, k}(x)} \quad \text { if } f(x) \in V_{j}, \quad f(x)=\sum_{k} \alpha_{k} \varphi_{j, k}(x) \]

同时:

\[\varphi_{j, k}(x)=\sum_{n} \alpha_{n} \varphi_{j+1, n}(x) \]

而小波函数(wavelet function):

相邻两个尺度之间的\(V_j\)\(V_{j+1}\)的差异区域

\[\psi_{j, k}(x)=2^{j / 2} \psi\left(2^{j} x-k\right) \]

函数空间可以通过至少一个尺度函数和小波函数来表达

\[L^{2}(\mathbf{R})=V_{j_{0}} \oplus W_{j_{0}} \oplus W_{j_{0}+1} \oplus \cdots \]

小波函数系数:

\[\psi(x)=\sum_{n} h_{\psi}(n) \sqrt{2} \varphi(2 x-n) \]

哈尔(Haar)小波

尺度函数:

\[\varphi(x)=\left\{\begin{array}{ll} 1 & 0 \leq x<1 \\ 0 & \text { otherwise } \end{array}\right. \]

小波函数:

\[\psi(x)=\left\{\begin{array}{ll} 1 & 0 \leq x<0.5 \\ -1 & 0.5 \leq x<1 \\ 0 & \text { elsewhere } \end{array}\right. \]

哈尔小波生成函数:

\[\psi_{j, k}(x)=2^{j / 2} \psi\left(2^{j} x-k\right) \]

函数\(f(x)\)的小波序列展开(wavelet series expansion)

\[f(x)=\sum_{k} c_{j_{0}}(k) \varphi_{j_{0}, k}(x)+\sum_{j=j_{0}}^{\infty} \sum_{k} d_{j}(k) \psi_{j, k}(x) \]

例子:

\[f(x)=\left\{\begin{array}{ll} x^{2} & 0 \leq x<1 \\ 0 & \text { otherwise } \end{array}\right. \]

计算系数:计算\(f(x)\)\([0,1)\)区间的初始尺度系数和二次方展开每层的小波系数

哈尔小波序列展开估计原函数:

\[f(x)=\frac{1}{3} \varphi_{0,0}(x)+\left[-\frac{1}{4} \psi_{0.0}(x)\right]+\left[-\frac{\sqrt{2}}{32} \psi_{1,0}(x)-\frac{3 \sqrt{2}}{32} \psi_{1,1}(x)\right]+\ldots \]

小波变换(discrete wavelet transform)

正变换

\[W_{\varphi}\left(j_{0}, k\right)=\frac{1}{\sqrt{M}} \sum_{x} f(x) \varphi_{j_{0}, k}(x) \]

\[W_{\psi}(j, k)=\frac{1}{\sqrt{M}} \sum_{x} f(x) \psi_{j, k}(x), \quad j \geq j_{0} \]

\(j_0=0\),\(j\)的取值范围\([0,J-1]\),\(k\)的取值范围\([0,2^{j}-1]\),\(x\)的取值范围\([0,M-1]\)

反变换

\[f(x)=\frac{1}{\sqrt{M}} \sum_{k} W_{\varphi}\left(j_{0}, k\right) \varphi_{j_{0}, k}(x)+\frac{1}{\sqrt{M}} \sum_{j=j_{0}}^{\infty} \sum_{k} W_{\psi}(j, k) \psi_{j, k}(x) \]

快速小波变换(后续补充)

二维小波变换

\[\begin{array}{l} \varphi(x, y)=\varphi(x) \varphi(y) \\ \psi^{H}(x, y)=\psi(x) \varphi(y) \\ \psi^{V}(x, y)=\varphi(x) \psi(y) \\ \psi^{D}(x, y)=\psi(x) \psi(y) \end{array} \]

\[\begin{aligned} \varphi_{j, m, n}(x, y) &=2^{j / 2} \varphi\left(2^{j} x-m, 2^{j} y-n\right) \\ \psi_{j, m, n}^{i}(x, y) &=2^{j / 2} \psi^{i}\left(2^{j} x-m, 2^{j} y-n\right), \quad i=\{H, V, D\} \end{aligned} \]

\[\begin{aligned} W_{\varphi}\left(j_{0}, m, n\right) &=\frac{1}{\sqrt{M N}} \sum_{x=0}^{M-1} \sum_{y=0}^{N-1} f(x, y) \varphi_{j_{0}, m, n}(x, y) \\ W_{\psi}^{i}(j, m, n) &=\frac{1}{\sqrt{M N}} \sum_{x=0}^{M-1} \sum_{y=0}^{N-1} f(x, y) \psi_{j, m, n}^{i}(x, y) \end{aligned} \]

小波变换可分离,因此可以先进行行变换后对结果再进行列变换

实践

Python对应的库https://pywavelets.readthedocs.io/en/latest/

二维离散对应函数小波变换正变换dwt2,小波逆变换idwt2

原图:

fzuimage2

img = cv2.imread(path.join(resource_path,"fzuimage2.jpg"),cv2.IMREAD_GRAYSCALE)
# import pywt.data
# img = pywt.data.camera()
img = img[:256,:256]
C0,C1,C2 = pywt.wavedec2(img,\'haar\',level=2)
trans = np.vstack((np.hstack((np.vstack((np.hstack((C0,C1[0])),np.hstack(tuple(C1[1:])))),C2[0])),np.hstack(tuple(C2[1:]))))
plt.figure(1)
plt.imshow(trans,cmap="gray")
plt.figure(2)
plt.imshow(pywt.waverec2((C0,C1,C2),\'haar\'),cmap="gray")
plt.show()

fzuimage_wave_transform

fzuimage_rev_transform


推荐阅读
  • 第四章高阶函数(参数传递、高阶函数、lambda表达式)(python进阶)的讲解和应用
    本文主要讲解了第四章高阶函数(参数传递、高阶函数、lambda表达式)的相关知识,包括函数参数传递机制和赋值机制、引用传递的概念和应用、默认参数的定义和使用等内容。同时介绍了高阶函数和lambda表达式的概念,并给出了一些实例代码进行演示。对于想要进一步提升python编程能力的读者来说,本文将是一个不错的学习资料。 ... [详细]
  • 本文介绍了机器学习手册中关于日期和时区操作的重要性以及其在实际应用中的作用。文章以一个故事为背景,描述了学童们面对老先生的教导时的反应,以及上官如在这个过程中的表现。同时,文章也提到了顾慎为对上官如的恨意以及他们之间的矛盾源于早年的结局。最后,文章强调了日期和时区操作在机器学习中的重要性,并指出了其在实际应用中的作用和意义。 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • javascript  – 概述在Firefox上无法正常工作
    我试图提出一些自定义大纲,以达到一些Web可访问性建议.但我不能用Firefox制作.这就是它在Chrome上的外观:而那个图标实际上是一个锚点.在Firefox上,它只概述了整个 ... [详细]
  • 本文介绍了计算机网络的定义和通信流程,包括客户端编译文件、二进制转换、三层路由设备等。同时,还介绍了计算机网络中常用的关键词,如MAC地址和IP地址。 ... [详细]
  • 展开全部下面的代码是创建一个立方体Thisexamplescreatesanddisplaysasimplebox.#Thefirstlineloadstheinit_disp ... [详细]
  • 闭包一直是Java社区中争论不断的话题,很多语言都支持闭包这个语言特性,闭包定义了一个依赖于外部环境的自由变量的函数,这个函数能够访问外部环境的变量。本文以JavaScript的一个闭包为例,介绍了闭包的定义和特性。 ... [详细]
  • 本文详细介绍了如何使用MySQL来显示SQL语句的执行时间,并通过MySQL Query Profiler获取CPU和内存使用量以及系统锁和表锁的时间。同时介绍了效能分析的三种方法:瓶颈分析、工作负载分析和基于比率的分析。 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • Voicewo在线语音识别转换jQuery插件的特点和示例
    本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
  • 在重复造轮子的情况下用ProxyServlet反向代理来减少工作量
    像不少公司内部不同团队都会自己研发自己工具产品,当各个产品逐渐成熟,到达了一定的发展瓶颈,同时每个产品都有着自己的入口,用户 ... [详细]
  • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
  • 利用Visual Basic开发SAP接口程序初探的方法与原理
    本文介绍了利用Visual Basic开发SAP接口程序的方法与原理,以及SAP R/3系统的特点和二次开发平台ABAP的使用。通过程序接口自动读取SAP R/3的数据表或视图,在外部进行处理和利用水晶报表等工具生成符合中国人习惯的报表样式。具体介绍了RFC调用的原理和模型,并强调本文主要不讨论SAP R/3函数的开发,而是针对使用SAP的公司的非ABAP开发人员提供了初步的接口程序开发指导。 ... [详细]
author-avatar
翟志军2502905177
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有