連續小波變換(CWT)


整理下時頻分析變換的方法,遇見好的文章就記錄下來了,本篇博客參考知乎https://www.zhihu.com/topic/19621077/top-answers上的一個回答,自己手敲一遍,增強記憶

首先說明這里是連續小波變換,不會涉及離散小波變換,不涉及尺度函數。

對於一個morlet小波變換,其頻率成分分別是4、6、10,具體表達式如下:

 

經小波變換,得到如下時頻圖:

圖一、二維時頻圖

三維時頻圖

從圖中可以清晰辨認出原始信號含有的頻率成分及其個自對應的時間區間。如果你和我一樣認真的話,你會產生三個疑問?

(1)為什么小波變換能確定信號頻率和其對應的時間區間?
(2)為什么頻率小的條紋比頻率高的條紋要細?

(3)為什么三個條紋顏色的深淺不一樣 ?

其實第(1)個問題可以從上一篇的博客中總結出來。

第一個問題我們把它一分為二,為什么CWT能辨認出信號的頻率成分?為什么CWT能確定頻率對應的時間區間?

當然先看下公式。來一個morlet小波基函數表達式

 

 morlet小波的基函數是由復三角函數乘上一個指數衰減函數構成,這里表示中心頻率。還是先看圖(分別令

圖三

上圖左邊是基函數時域圖像,右邊是傅里葉變換圖像。可以看到基函數的頻率正是其中心頻率的值。這里給出morlet小波的傅里葉變換表達式

從表達式也可以看出當頻率等於其中心頻率時,取極大值。這里復三角函數可以辨認頻率,衰減函數可以保證其時域的有限支撐。只給一個固定的中心頻率可不能辨認信號的頻率,同樣,基函數只在【-2,2】之間也確定不了時間區間。所以這里的小波基函數需要平移和伸縮 。又是一個公式(按傳統,這個變大時前還有一個根號a,但我不討論這個)

繼續上圖,給出b=5(平移因子),a=2(尺度變量),即平移5個單位,縮小2倍的morlet小波基函數的圖像

圖四

相對圖三,時域可以明顯看出平移,從頻域也很明顯看出尺度伸縮當然從傅里葉變換的性質也可以推斷出來。

 好了,基函數算是告一段落,下面是激動人心的時刻,還是得有公式。

這算是morlet小波變換的公式了。

好,回到第一個問題,為什么小波變換能確定信號頻率和其對應時間區域?

從時頻圖一可以看到,能看出條紋的部分明顯是關於頻率的積分極大值。

所以,把問題轉換一下,為什么小波變換會在原始信號固有的頻率上產生極大值

而這極大值對應的區間正好是該頻率的時區。連續小波變換的運算是什么?

是積分,是原始信號與小波基函數乘積后積分的過程,而積分就是一個求和的過程

 舉個例子:

一個頻率為5的正弦函數,和乘積后積分,問當頻率為何值時,他們的乘積積分后結果最大。答案你肯定知道,當兩個正弦函數頻率相等的時候,而就是n=5的時候,他們的乘積積分后最大。有圖為證:

好,到這里你應該就明白了為什么小波變換會在原始信號固有的頻率上產生極大值。因為基函數里包含復三角函數

下面把換成小波基函數,換成morlet小波函數,去掉平移參數,並令初始中心頻率,令尺度參數

再次求其與y乘積積分后的最大值(這個得取模)。很明顯,當a=2的時候,也就是小波基函數頻率為5的時候,會取的極大值,如圖

 到這里,應該就很明朗了。小波小波,顧名思義,既要小又要有波動。morlet小波的波動性可以用復三角函數表達小則用衰減函數表達,數學上把這種小稱為有限支撐。即morlet小波的有限支撐是通過一個指數衰減函數實現的。復三角函數使其能分析頻率(和原始信號乘積積分求極大值)衰減函數使其可以定位時間,他們加起來,才使得morlet小波可以用來做時頻分析。

CWT就是選一個中心頻率然后通過尺度變換得到一大堆中心頻率,又通過時移得到一系列不同區間的基函數,分別和原始信號的某一段(對應基函數的區間)乘積再積分,產生的極值對應的頻率就是原始信號這一區間含有的頻率。

 

你不想換個角度看看嗎?

換個角度,我們來從頻域看看,好嗎?根據傅里葉變化的性質Parseval公式可知:

兩信號乘積后時域的積分等於其 傅里葉變換后頻率的積分。好,換成信號和小波基函數

時域里面乘積積分看的不明顯,頻域里看就一目了然了,還是那個頻率為5的原始信號,看看他的頻域圖像

再看看五個中心頻率不同的小波基函數

好了,兩個函數再頻域乘積再積分,又一次很明顯,只有當小波中心頻率為5的時候,小波基函數和原始信號乘積的積分才會取得極大值。其他的好像都是0啊

所以,小波可以認為是一個帶通濾波器,只允許頻率和小波中心頻率(經過尺度伸縮后)相近的信號的通過

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM