所有系統,包括濾波器,都是因果關系。這意味著它們不能在激勵源激勵之前對激勵(不可預知)做出任何反應。那么,又該如何設計一款可“預測”的濾波器呢?好吧,這一切都取決于你對品質的期待有多高以及這一預測的相關性。
那么,我們再次祭起曾非常流行的“五件你應該知道的事”這一招式之旗,我們提出五個核心問題,其答案可以幫助我們繞過這個“濾波器”陷阱。
濾波器如何延緩信號?
信息可以通過多種方式加載于信號,它總是需要一段限定的時間來通過處理系統。你可能很熟悉數字模塊的傳輸延遲概念。延遲,就是在輸入發生某些狀態變化到輸出發生相應狀態變化這段時間差。有數字概念的讀者首先想到的可能是一個‘1’和‘0’的碼流,以作為不同電壓或電流水平的物理表述。對于這樣的信號,傳輸延遲沒有害處;但當我們考慮到模擬信號(實際上,沒有確定的特性對應特定的時間點)時,就不是那么簡單了。
我們經常對信號和數據序列進行低通濾波以消除“噪聲”--高頻率變異,我們已確定其沒有任何意義,且它還是我們要觀察的更重要的基本頻點的障礙。雖然濾波過程對我們的觀察影響巨大,但它絕對是一個影響觀察的案例。當我們查看響應圖形時,傳統濾波方式最明顯的后果是,在輸入信號的變化和濾波后輸出的相應變化之間有明確的時間延遲。當我們看一些例子時,我們將在某一時刻借助測試信號清楚地看到這點。
我們如何量化這種形式的延遲?
濾波器(或任何其它線性信號處理模塊)輸入信號和相應輸出之間的這種“滯后”,
與組延遲緊密相關,組延遲相當于(或略低于)相位響應與派生頻率。為此應選用明智的單位;如果你用弧度測量相位,以其每秒弧度的角形式表達頻率,那么,(弧度)除以(弧度每秒),你就可得到以秒表示的答案。或者你可以使用“周期”—— 一個周期,是一個完整旋環,或360度。相位差以周期表示,除以赫茲(與每秒的周期數相同)表示的常規頻率差,也會給出以秒表述的答案。
我們可能忍不住要問:如果要避免這種滯后,為什么不設計一款沒有任何組延遲的濾波器?如果你以前讀過我的專欄,你可能會認識到這句話中的“危險成分”。因為,你猜對了——它并非這么容易。如果你查找或計算“標準”的低通濾波器響應,你會發現,他們的組延時是總是正向的,一直降到零頻率。這里,我們需要來點別出心裁。
我們可以消除(或者不僅僅是消除)這種延遲嗎?
如果你想讓延遲在任一頻率都為零,那嚴格的答案是‘不能‘。但確實有種技術可用以開發補償濾波器,當其與原來的濾波器級聯時,可以給你零延遲;當DC時,甚至是負的組延遲。正如我們將看到的,這可能非常有用。你不需要進行任何試錯——現在,可將麻煩扼殺在未發。
比方說,某種低通傳遞函數H,它們在DC時有整體增益。可以容易地論證:新傳遞函數H’ = 2-H,在DC時也是整體增益,且在DC時的組延遲具有與H相同的
幅值,但卻是負值。如果你級聯H和H‘(即串聯它們),你會得到一個整體傳遞函數,我們稱其為H1,它具有DC整體增益和DC零組延時。對于S或Z域的任何線性傳遞函數來說,H1就等于HH’,即H1 = H(2-H)。無論哪類濾波器,只要H是可實現的,這也就可以實現。
這看起來似乎很怪誕。因為函數H‘與H的階相同(無論使用模擬或數字濾波器),你可以看到,將其組合起來會使濾波器的尺寸加倍,因此實現其所需的資源也要加倍。也許不太容易想象的是,它可能會大大降低濾波器的衰減性能。如果H是一個具有DC整體增益的低通函數,而在所有其它頻率也具有整體增益(或小于整體增益),那么函數2-H就有一個會在1和3之間振蕩的值,也就是說,它可以在響應中引入一個高達9.5dB的“凸點”。如果該凸點落于整體濾波器的阻帶內,那么所發生的一切就只是衰減功能的惡化。如果凸點落在通帶內,那么該級聯的整個通帶內的響應會與單個H時的大相徑庭。
這里有個簡單例子。對以100kps采樣率數字方式實現的H,在10kHz時,以n=2的巴特沃斯濾波器開始。為了設計濾波器并獲得圖表,我使用了新版(2012年2月發布)的PSoC Creator濾波器工具,它為H給出了以下系數,幅度和組延時曲線在圖1表示。
雙二階濾波器的最終系數:
系數序列為A0,A1,A2,B1和B2
0.0674552917480469
0.134910583496094
0.0674552917480469
-1.14298057556152
0.412801742553711
圖1:0.01 Fs時,N=2的巴特沃斯濾波器的幅度和組延時。
補償濾波器H’與H同分母,而分子等于兩個負數(H的分子)。我用快速電子表格進行了計算,并將結果反饋給PSoC Creator濾波器工具。工具為這兩個雙二階部分給出了最好的排序和增益;它獲得了4dB增益,以確保凸點響應不高于0dB,見圖2:
雙二階濾波器的最終系數:
系數序列為:A0,A1,A2,B1和B2
0.216065168380737
-0.2706618309021
0.0847635269165039
-1.14298057556152
0.412801742553711
0.372884273529053
0.745768547058105
0.372884273529053
-1.14298057556152
0.412801742553711
圖2:帶補償濾波器的N=2巴特沃斯級聯;零DC組延遲
在通帶內,頻率響應明顯是非平坦(內有凹凸)的,而且已經放棄了一些相對阻帶抑制。如果你熟悉控制系統理論,你馬上會看到,我們得到的是增加的傳遞函數零,其組延時的貢獻準確取消了原始的濾波器極點(以及新極點也會出現)。但它并非太過糟糕的一個響應——它仍能去掉數據序列的高頻率噪聲——如圖3所示,某些神秘數據(哇!):
圖3:某些數據(藍色),巴特沃斯響應(粉紅色)和補償(綠色)
我們不必使用相同的函數H來構造補償濾波器。如果兩個傳遞函數HA和HB都具有整體單位DC增益和相同的DC組延遲值,則H1 =HA(2-HB)也有整體DC增益和零DC組延遲。
特別是,如果HB是T值的純時間延遲(相等于HA的DC組延遲),我們可以得到FIR實現的漂亮簡化。就T恰好等于N個采樣周期的傳遞函數來說,我們得到H1 = HA(2-Z^- N),幾乎所有的數字濾波器結構都能很容易地實現它,因為Z圖的
這些負值直接作用于單位采樣延遲。而2N+1階的對稱FIR濾波器總能滿足該條件;如果多做點工作,它就可以適應不對稱的情況,其中N不是整數。
因此,無論我們選擇工作在S域或Z域,我們都可以構建零DC組延時的低通傳遞函數。但我們沒必要在零組延時停止;雖然我們可以很容易地使其為負,我們也在此進入預測域。在采樣系統中,有一個其輸出是輸入信號在下一個采樣時刻可以預測的濾波器,會很方便。換句話說,一個濾波器的DC組延遲是負一個采樣周期。在上面提到的FIR的情況,它簡單得幾乎難以置信。我們只須使用2-z^-(N+1),而不是2-z^-N的補償函數。
現在,如果在有能量進入濾波器之前,它就實際輸出了一些能量,那就破壞了因果律。所以包含信息的任何信號不可能以負延遲的形式出現在輸出。但有些信號不包含任何信息——如果一些觀察家對其有心理上的期盼,則無論他們怎么想
——所以當組延遲為負時,就沒有因果關系可去違反。
這種濾波器的表現如何?
這些功能有個有用的屬性。顯然,對常數(即DC)輸入,輸出電壓等于輸入,與普通低通濾波器的一樣。但現在當輸入以恒定速率變化時,輸出也可以等于輸入。與“標準”低通傳輸函數不同,在階梯變化激勵下,濾波器的輸出和輸入信號間沒有“滯后”。我們設計另外一個例子,并更加仔細地檢驗其屬性。
這次,我們以FIR為例。我們HA的起始濾波器是一個對稱的9階FIR濾波器,(因此有4個采樣周期的恒定組延遲)。這是為陷波60Hz左右有不小變化的AC線頻而設計的。我會解釋理由,且在以后的Filter Wizard中,明確如何設計這樣一款“撥空號(dial-a-null)”濾波器,但眼下,我們只是看一看。對于我們的HB,為得到零延遲濾波器,我們使用了4個采樣周期的簡單延遲。這使2-HB看起來像一個系數為(2,0,0,0,-1)的5階FIR濾波器。級聯的HAHB做成一款單一FIR濾波器,將兩個Z平面序列卷積在一起,獲得一個13階的濾波器。HA和HAHB的幅度和組延時如圖4所示,這次是用LTspice仿真的。圖中,有相當奇怪的頻率和時間,是因為這個濾波器是按工作在220個采樣/每秒設計的。再次,我們得到一個凹凸不平的通帶并失去了一些阻帶響應。
現在,我們可以進入預測領域。如果我們把HB‘的延遲設為5個采樣周期而不是4個,然后重新計算該級聯(現在是14個階遞),我們得到的HAHB如圖4(綠色線段)所示。與期望的一樣,現在,你可以看到DC組延遲是負4.5ms左右。
圖4:FIR例子,正延遲和負一個采樣周期的情況
那么這里回報是什么?好,我們看看時間域的行為。三個濾波器的激勵源都是上升又下降的三角形信號。激勵和響應如圖5所示。
圖5:無補償和有補償FIR濾波器對三角波激勵的響應
由最初的低通濾波器HA引起的“滯后”顯而易見。如果你試圖檢測信號通過某些極限點的哪個點,你會清楚地體驗到在檢測響應時的延遲。HAHB線段顯示我們零DC組延遲濾波器的輸出——它具有零延遲!這突顯了對于一般低通濾波器來說極為重要的一個事實:這種濾波器的輸出和輸入之間的斜坡滯后在數值上等于DC組延遲值。因此,如果我們補償濾波器的設計,使DC組延遲為零,我們就得以消除滯后。當然,代價總是有的,我們可以看到,在輸入波形斜坡發生突變后,這種濾波器有些疲于應付。
如果你放大HAHB曲線,你會看到,每個新采樣都正好在輸入斜坡曲線上。預測版本HAHB的輸出值移動到斜坡將在下一個采樣周期開始時該有的那個值,我猜,會與我們預測的一樣。
這種濾波器可在哪里派上用場?
有許多工業監測應用,其“正常”行為意味著信號穩定(但嘈雜,信號可以是溫度、壓力、物理結構內的應力等)。 所謂“異常”行為,是指一些被測的系統參數變得不可控,并不按規矩“出牌”。
在反饋路徑需要濾波的控制系統,這種零延遲類型的濾波器很有用。消除很低頻率下的組延時,可以顯著增加抑制這些頻率上某些感知行為的控制回路的功效。工程師習慣于操控系統傳遞函數的零以強迫實施所需的回路行為,這正是我們在此以更具分析的意蘊所做的。我們的傳遞函數算法生成取消極點DC組延遲特性的零。我已經說過,不是嗎!
這種零或負延遲濾波器通常還用來處理非電子信號。例如,如果一種金融工具(如股票)的價格被認為呈斜坡線性變化,但該斜坡被短期交易噪聲破壞,零延遲濾波器就可用于有效地提取基本行為。雖然,如圖5所示,當三角形改變方向時,你可以從濾波器的行為進行推斷,但一段時間內,這種濾波器會給出極不準確的結果,直到價格行為再次按平穩的斜坡變化。圖3的神秘數據,事實上是個股票價值序列。
這些金融工具的交易員實際上對其價格數據序列使用了一些相當復雜的濾波流程。我常常被告知,若電子市場股價暴跌,在金融部門,濾波器向導肯定會有份工作,用來從巨大的價格數據集中梳理出有趣信號。但讓我們繞過暗礁險灘,戴上安全的堅固工程的護身符,并重回正軌!
諸如此類的延遲操控可以大有作為的一個工程應用是補償數字D類放大器的電源電壓變化。對于給定的分度:間隙因數由輸出開關輸出,其放大器的平均輸出電壓與電源電壓成正比——即,它沒有電源抑制。當人們似乎不想在消費類音頻設備的電源上下大本錢的時候,這并非好事。
我們可以測量瞬時的電源電壓,并將其回饋到開關控制算法中。但由于濾波器延遲與測量此類放大器的電源電壓相關,并將數據回饋至控制系統,所以,你最終糾錯的并非此時此地的電源電壓,而是前一段時間的電源電壓。這種差異限制了我們可以用這種回路實現電源抑制。如果我們采用有適當的DC負組延時的低通濾波器濾除所測量的電源電壓(并不過分強調出現的高頻噪聲),我們就可以彌補這種效果(至少在相對的極低頻如此,如AC線頻的諧波頻率)。這種技術可以對數字功率放大器AC線的紋波抑制產生重大影響,在一些商業數字放大器設計中就采用了該方法。
評論
查看更多