IIR濾波器零相位數字濾波器設計及其應用
(3) 對原輸入序列x(n)的首尾進(jìn)行擴展,在x(n)的前面添加3N個(gè)數,在后面添加3N個(gè)數,擴展后的序列記為x′(n),n=0,1,…,P+6N。
x′(n)=2x(0)-x(3N-n)
x(n-3N)
2x(P)-x(P-1-(n-P-3N-n))
n<3N
3Nn<P+3N
P+3NnP+6N(4)
(4) 進(jìn)行正向濾波:先用b,a和x′(n)調用DiffFilter(b,a,x)函數,計算x′(n)通過(guò)
H(z)=∑Mm=0b(m)z-m/(1+∑Mm=1a(m)z-m)(5)
的輸出y′(n),然后生成一長(cháng)度為P+6N+1的單位脈沖信號h(n),用z,a和h(n)調用DiffFilter(b,a,x)函數,計算h(n)通過(guò)
H(z)=∑M-1m=0y′(0)e(m)z-m/(1+∑Mm=1a(m)z-m)(6)
的輸出y′(n),并記y(n)=y′(n)+y″(n)。
(5) 進(jìn)行反向濾波:將正向濾波結果反轉,記x′(n)=y(P+6N-n),重復步驟4°,得到反向濾波后的結果。
(6) 將反向濾波的結果反轉,并刪除首尾的擴展部分,即可得到最后的濾波結果。
Borland公司推出的Delphi編程語(yǔ)言,具有合理的單元化結構、優(yōu)化的編譯環(huán)境,開(kāi)發(fā)速度快、編程效率高。在實(shí)現同樣功能的情況下與其它語(yǔ)言相比,不僅編寫(xiě)的代碼量少、程序可移植性強,而且還有許多優(yōu)秀的組件包可供使用。最為方便的是可以使用動(dòng)態(tài)數組,隨時(shí)能夠改變數組的長(cháng)度,這一點(diǎn)非常適合數字信號處理。
作者利用Delphi7編寫(xiě)了利用雙線(xiàn)性Z變換法設計Butterworth型IIR濾波器和利用窗函數法設計FIR濾波器,以及差分數字濾波算法和零相位數字濾波算法應用程序,并作為集成測試軟件平臺的一個(gè)虛擬儀器。其中零相位數字濾波算法程序設計流程如圖6所示。
圖6零相位數字濾波算法的流程圖
電源濾波器相關(guān)文章:電源濾波器原理
電能表相關(guān)文章:電能表原理
評論