最小均方滤波器

来自testwiki
跳转到导航 跳转到搜索

Template:NoteTA 最小均方濾波器(Least Mean Square Filter,或LMS Filter)是一類可通過最小化誤差訊號(error signal)之均方值(mean square)而修正濾波器係數,以模拟所需理想濾波器的自適應濾波器,其中作為修正依據的誤差訊號為理想參考訊號與實際輸出訊號之差。該種濾波器所用之最小均方法只以當前之訊號誤差值為準進行修正,是一種Template:Le。最小均方法係由斯坦福大學Bernard Widrow教授及他的首位博士班學生Marcian Hoff於1960年提出。最小均方濾波器屬於常見的自適應濾波器種類之一。

最小均方:問題起源

LMS filter


與最小平方濾波器的異同

因果維納濾波器(Causal Wiener Filter)的實現在形式上與最小平方法的實現非常相似,但在訊號處理這一方面卻有所不同。對於最小平方的實現,令輸入矩陣為𝐗,輸出矩陣為𝐲,有:

β^=(𝐗𝐓𝐗)1𝐗𝐓𝒚.

而有限脈衝響應(Finite Impulse Response)的最小均方濾波器卻類似Wiener濾波器,只是前者並不依賴計算互相關或自相關函數即可將誤差基準最小化,且其解將會收斂直至與Wiener濾波器的解重疊。大部分的線性可適性濾波問題均可以上圖中的架構進行模擬,即希望盡量準確地確認一未知系統𝐡(n),因此通過可適性濾波,僅以可觀測訊號x(n)d(n)e(n)產生對𝐡(n)的估計值𝐡^(n)並盡量使其接近𝐡(n)。上圖中的另幾個訊號y(n)v(n)h(n)卻不處於能直接被觀測到的範圍中。

變量之定義

n:當前輸入序列的樣本數(長度);
p:濾波器級數;
{}H埃爾米特轉置共軛轉置
𝐱(n)=[x(n),x(n1),,x(np+1)]T
𝐡(n)=[h0(n),h1(n),,hp1(n)]T,𝐡(n)p
y(n)=𝐡H(n)𝐱(n)
d(n)=y(n)+ν(n)
𝐡^(n):對h(n)的估計值,可理解為代表在n個觀測週期後對濾波器係數的估計;
e(n)=d(n)y^(n)=d(n)𝐡^H(n)𝐱(n)


最小均方濾波器的基本特點

最小均方濾波器所獲得的廣泛應用主要得益於其兩個特性:易於實作(Simplicity of implementation)與性能穩健(Robust performance)——後者主要得益於最小均方濾波器基本上不受模型影響(Model-independency)。 最小均方濾波器亦與梯度下降法(Method of steepest descent)不同:後者主要對隨機輸入訊號進行使用確定梯度的遞歸運算。此外,最小均方濾波器的實現亦不需要對相關函數取值進行測量或計算負矩陣。事實上,其他的各種線性可適性濾波演算法均廣泛地以最小均方濾波演算法為基準,以估量自身效能。


概覽與主要思想

最小均方濾波器的主旨是逐步進行修正,以逼近最佳的濾波係數;由Wiener–Hopf方程可解得,理想中的最佳濾波係數(所構成之向量)為w0=(R1p);其中R為輸入濾波器的輸入矩陣u(n)的(自)相關矩陣,p為u(n)與理想參考訊號d(n)之間的互相關向量。

基本而言,最小均方濾波演算法作為線性可適性濾波演算法的一種,包括有以下兩個基本步驟:

一、濾波步驟(filtering process):這一步驟包括了(a)計算一線性濾波器對一輸入訊號的響應輸出與(b)產生上一步中相應輸出和理想相應間的測量誤差值。 二、自適步驟(adaptive process):這一步驟中,以濾波步驟中得到的測量誤差值為根據,濾波器本身的參數取值將被自動更新(以便在下一個週期中產生的測量誤差值相對減小)。

上述兩個步驟被組合起來,形成一個反饋迴圈(feedback loop)。 最小均方演算法首先由一組很小的權重係數(常取零)開始,且在迴圈的每一步中找到均方誤差的斜率梯度,依據斜率梯度更新濾波器的權重係數。均方誤差的斜率梯度為正值即說明若保持現有的濾波器權重係數,誤差將在未來的迴圈中持續向正向增大——因此需要減小權重係數。同樣地,若均方誤差的斜率梯度為負值,就需要增大權重係數。因此,基本的權重係數遞歸方程為:

Wn+1=Wnμε[n]

其中ε代表了均方誤差之值,其係數之前的負號說明需要向斜率梯度的反方向調整濾波器係數。 上述的均方誤差作為以濾波器係數為自變量的函數,具有二次函數的形式;這說明僅存在一個極值能使均方誤差值最小,而這正對應了最佳的濾波器係數。因此,最小均方演算法可以通過調整均方誤差-濾波器係數平面上的曲線位置,來逐步迫近最適的濾波器係數取值。

演算法之實現

對於order=p的情形,可適性最小均方濾波器的演算法實現如下所示:

涉及參數之定義: p= 濾波器的階數
μ= 步長
初始化: 𝐡^(0)=zeros(p)
運算迴圈: For n=0,1,2,...

𝐱(n)=[x(n),x(n1),,x(np+1)]T

e(n)=d(n)𝐡^H(n)𝐱(n)
𝐡^(n+1)=𝐡^(n)+μe*(n)𝐱(n)

收斂效率與穩定性

由於最小均方演算法並不使用準確的期望值,濾波器的權重係數也就不會絕對地達到最佳取值,但是在總體上演算法仍然可以達到收斂——即實際權重係數將與最佳權重係數相比將或大或小,但誤差大小會相當有限。然而若權重係數變動時的方差(或標準差)過大,收斂的方向就可能錯誤。若演算法中的步長未經過謹慎的選擇,上述問題就很可能會發生。

如步長μ的取值較大,權重係數就會在更新迴圈中更快地向梯度估計值的方向改變,從而使得權重係數在每一次迴圈中的變動值更大——若開始時的梯度值為負,在更新權重後梯度便可能變為正值。亦即在「第二個」時刻,權重係數的值將因為負的梯度值向相反方向劇烈改變;此後,權重係數的值仍將以較大的幅度圍繞最佳取值上下波動。從另一方面來說,若μ的取值過小,要達成最佳權重係數便會需要過於漫長的收斂時間。因此,演算法的實現需要在兩種極端之間有所權衡與取捨。

因此,演算法步長μ應有一上限,如下: 0<μ<2λmax

其中λmax自相關矩陣𝐑=E{𝐱(n)𝐱H(n)}中的最大特徵值。當上式所述的條件未能達到時,系統將是非穩定的, h^(n)也不會收斂。 最快收斂速度的達成條件如下: μ=2λmax+λmin, 其中λmin是R的最小特徵值。 考慮到μ的值小於等於最佳值,收斂速度將會由λmin決定,其值越大,就會導致收斂速度越快。這就意味著最佳收斂速度可以在當λmax接近λmin時達成,即由𝐑的特徵值擴散度決定可達到的最高收斂速度。

一個白雜訊訊號的自相關矩陣為𝐑=σ2𝐈;其中σ2是訊號的方差。在這種情況下所有的特徵值都是相等的,且特徵值擴散度在所有的可能矩陣中為最小。

對於這上述結果的一種常見解釋是正因為如此,最小均方演算法才會對白訊號為輸入的情形收斂更快,而對如帶有低通或高通特性的有色訊號(均值不為零)輸入收斂得更慢。

值得注意的是前面闡述的μ值上限只在普遍意義上對可適性最小均方濾波器的穩定性存在影響,在單獨的實際情形中,h^(n)的係數仍然可能增長至至無限大,即濾波器權重係數仍可能發散而無法達到收斂。一個更為實際的上下限條件是 : 0<μ<2tr[𝐑], 其中tr[𝐑]表示𝐑的軌跡(trace)。上述上下限條件確保了h^(n)的係數將不會發散(在實際情況中,由於上述公式在推導過程中所假定的條件過於寬鬆,μ的值不應選取得過於接近上限)。

歸一化最小均方濾波器

對於基本的最小均方演算法來說,其最大的缺陷就是對於輸入x(n)振幅過於敏感。這就使得設計者難以選取能夠確保演算法穩定性的步長μ取值。因此,可運用歸一化最小均方濾波器——最小均方濾波器的一種變種,來將輸入訊號的功率歸一化,以解決這一問題。下面是對歸一化最小均方演算法的簡述:

參數定義 p= 濾波器級數
μ= 濾波器步長
初始化: 𝐡^(0)=zeros(p)
開始運算: For n=0,1,2,...

𝐱(n)=[x(n),x(n1),,x(np+1)]T

e(n)=d(n)𝐡^H(n)𝐱(n)
𝐡^(n+1)=𝐡^(n)+μe*(n)𝐱(n)𝐱H(n)𝐱(n)

最佳步長取值

若不存在干擾訊號v(n)=0,歸一化最小均方演算法可選取的最佳步長值為μopt=1,該值不受輸入訊號x(n)與實際響應𝐡(n)的影響。在存在干擾(v(n)0)的情形中,最佳步長值則為: μopt=E[|y(n)y^(n)|2]E[|e(n)|2]

上述結果是在假定訊號v(n)x(n)互不相關的前提下推導出的,該假設亦在大部分情形下符合現實。推導過程請參見[1] Template:Wayback

相關條目

參考文獻