利用虛擬儀器進行數(shù)字信號處理設計
工程設計可以從虛擬儀器中獲得什么?即便您對虛擬儀器并不熟悉,了解儀器如何影響工程設計也十分自然的。例如示波器等傳統(tǒng)儀器在測試和測量應用中的不同階段及電子系統(tǒng)的設計、驗證和測試階段都被廣泛地應用。但是,憑借快速開發(fā)工具、交互式設計功能以及與實際信號的自然關聯(lián)特性,虛擬儀器可以將工程設計帶入到一個新的時代。
例如數(shù)字信號處理(DSP)以及它與儀器之間的關系。數(shù)字信號處理器 (DSP),是一種針對數(shù)字信號進行實時數(shù)學運算的微處理器。要使用DSP處理模擬信號,首先要用抗鋸齒濾波器和模擬數(shù)字轉換器(ADC)對模擬信號進行數(shù)字化,并將它送入到傳入DSP的數(shù)據流中。之后,DSP會以某種方式修改數(shù)據流,并通過數(shù)字模擬轉換器(DAC)以及抗假象濾波器將信號轉回模擬信號。通常而言,類似示波器等傳統(tǒng)獨立儀器會使用定制的固定嵌入式DSP系統(tǒng)。除此之外,示波器其實還可以通過虛擬儀器技術在個人電腦(PC)上實現(xiàn)。利用PC的強大性能,使用PCI數(shù)據采集設備對實際輸入信號進行數(shù)字化,然后使用PC對信號進行處理。這種虛擬儀器的方式可以使用戶依靠自行開發(fā)的軟件程序和在PC或者實時操作系統(tǒng)上完成自定義的儀器功能。
虛擬儀器提供的強大設計工具使得具有不同技能層次和不同教育背景的人都可以快速設計并開發(fā)自定義測試和測量系統(tǒng)。相反,過去的工程設計要求開發(fā)人員使用不相關的開發(fā)工具,還需要在領域設計和實現(xiàn)都具備一定的工程專業(yè)知識。本文描述了如何將虛擬儀器設計工具應用到信號處理工程設計中,從而消除在設計和最終系統(tǒng)實現(xiàn)之間的障礙。我們將通過研究數(shù)字信號處理的設計與發(fā)布,并作為工程實例,來進一步討論這個問題。
數(shù)字信號處理與虛擬儀器
首先,我們來討論一下虛擬儀器的概念,它的出現(xiàn)是為了解決傳統(tǒng)獨立儀器的局限性。過去,測試和測量工具通常由例如示波器和波形發(fā)生器等獨立儀器組成,它們?yōu)橛邢薜臏y量應用提供了有限的功能集合。這種傳統(tǒng)儀器具有三個基本局限性:1)硬件對信號采集提供有限的精度與速度;2)儀器中內建的廠商定義的有限的測量與分析函數(shù);3)用戶操作界面的局限性。如果這些局限性中有任何一點無法滿足項目規(guī)范的要求,那么就需要一個新的獨立儀器,這樣會大大增加最終系統(tǒng)成本。
自1976年以來,NI通過將傳統(tǒng)的獨立儀器分成兩個基本部分為儀器帶入了一種新的觀念,這兩個部分是:對信號進行數(shù)字化所需的硬件和分析顯示結果所需的軟件。允許最終用戶使用用戶定義的軟件為其應用建立最終儀器,這樣儀器的局限性就被解決了,虛擬儀器的概念就是這樣誕生的。將軟件作為儀器,儀器就可以擴展到測試、控制和設計中。
相對于傳統(tǒng)的獨立儀器而言,虛擬儀器的優(yōu)點與數(shù)字信號處理相對于模擬信號處理而言的優(yōu)點是相似的。例如,模擬濾波器通常使用運算放大器、電容和電阻等模擬電子元件實現(xiàn),相對于使用浮點或定點機器實現(xiàn)的數(shù)字濾波器而言靈活性十分有限。盡管模擬濾波器比較便宜、易于建立,模擬濾波器的標定和維護十分困難。要對設計進行修改也十分難以實現(xiàn)。例如,如果后來發(fā)現(xiàn)需要一個更高階的濾波器,就必須改動硬件實現(xiàn)新的設計。由于數(shù)字濾波器是用軟件建立的,并沒有這個問題,從而在單一硬件上提供了可以實現(xiàn)多種應用的靈活平臺。
除了虛擬儀器和數(shù)字信號處理都發(fā)揮了基于軟件平臺的優(yōu)點,虛擬儀器通過利用圖形化編程開發(fā)環(huán)境NI LabVIEW使得易用性的優(yōu)點得到進一步的發(fā)展,它能夠讓更多人參與到軟件開發(fā)和儀器設計中去。LabVIEW不僅提供了完全與傳統(tǒng)的基于文本的編程語言所不同的圖形化編程方式,使得編程過程變得更加直觀與方便,同時還通過自帶的Mathscript兼容了文本的編程語言,使得用戶可以兼容已有的算法,或者根據實際應用來選擇合適的編程方式。這樣大大節(jié)省了需要熟悉編程環(huán)境和語法所需要的大量的時間。
這也是缺乏足夠的設計工具對數(shù)字信號處理所產生的影響?對于DSP工程師而言,使用傳統(tǒng)工具實現(xiàn)基于軟件的解決方案十分痛苦。典型的開發(fā)過程從算法設計開始,它需要使用多種數(shù)學建模環(huán)境,這要求對基于文本的命令和語法有著足夠的熟悉程度。在完成算法之后,嵌入式系統(tǒng)的實現(xiàn)帶來了新的困難。嵌入式系統(tǒng)設計需要對實時處理概念、板載內存可用性以及在軟件開發(fā)中所需的基于文本的編程語言和語法有深入的知識。
在傳統(tǒng)的基于文本的設計工具中,調試又是相當困難的。如果嵌入式系統(tǒng)沒有能夠按照期望的方式進行工作,如何才能找出數(shù)學設計的錯誤如何對應到具體的嵌入式系統(tǒng)代碼呢?例如量化、下溢出和上溢出等關于定點設計的問題很難進行跟蹤,因為他們常常在實時執(zhí)行的前幾個循環(huán)中出現(xiàn)。例如斷點、單步執(zhí)行、監(jiān)視可用寄存器和變量等常用的簡單調試工具是不夠的,因為他們需要用戶舍棄實時執(zhí)行,這樣也就無法使得問題重現(xiàn)。
在最近20年中,來自成千上萬家公司的工程師、科學家和技術員通過使用LabVIEW加速并簡化了開發(fā)過程,LabVIEW相比傳統(tǒng)設計工具而言更加強大,更加易于使用。LabVIEW具有通用編程語言所有的廣度和深度,其易用性提高了用戶效率,縮短了開發(fā)應用程序所需的時間。
簡化DSP設計的參數(shù)選擇
以數(shù)字濾波器設計為例,它是用NI LabVIEW和數(shù)字濾波器設計工具包進行開發(fā)與實現(xiàn)的。在這個應用和其他應用中,虛擬儀器方法的一個優(yōu)點是提供了交互性——可以直接看到制定修改設計參數(shù)的結果。
數(shù)字濾波器設計首先要為濾波器類型(低通、帶通、帶阻和高通)定義濾波器規(guī)范,確定是有限脈沖響應(FIR)或是無限脈沖響應(IIR),確定采樣速率以及浮點機器上所需的濾波器響應。圖1給出了用于設計典型濾波器的交互式界面,例如巴特沃斯、切比雪夫、反切比雪夫、橢圓、凱塞窗、多爾夫—切比雪夫窗以及等波紋FIR設計方法。圖1所示的設計是8 kHz采樣速率、1 kHz帶通、2 kHz帶阻、60 dB帶阻衰減的低通數(shù)字濾波器。在設計這些參數(shù)的時候,可以立刻看到當前設計的幅度響應和零極點圖,以及產生濾波器的階數(shù)。在圖1中,選擇了反切比雪夫濾波器因為它具有較好的過度帶特性和相對較低的濾波器階數(shù)。[!--empirenews.page--]
圖1 典型濾波器設計Express VI提供了用于交互式設計探索的界面,可以使用教科書中的巴特沃斯、切比雪夫以及等波紋FIR等濾波器
基于虛擬儀器的信號處理設計所具有的另一個優(yōu)點是圖形化的編程方式,類似流程圖式的圖形化編程方式使得程序更加直觀。同時,要嘗試一個新的算法只需要替換成所需要的函數(shù)圖標即可。例如,反切比雪夫濾波器設計可以方便地替換成雷米茲濾波器設計方法或是最小P階規(guī)范設計方法。實際上,在表1中所列的一系列編程設計選擇都可以用于設計中。雷米茲設計方法生成了FIR濾波器,可以將期望頻率響應和實際設計濾波器頻率響應之間的最大誤差降到最小。這種設計規(guī)范產生的濾波器具有“等波紋”特性,即“切比雪夫”誤差行為。雷米茲工具產生的濾波器設計適用于類型I-IV線性相位、任意形狀FIR、最優(yōu)幅度近似(最大或最小相位)、單點帶規(guī)范(谷或峰)以及精確增益控制。最小P階規(guī)范方法可以用于設計帶有任意幅度和相位約束的FIR和IIR濾波器。使用數(shù)字濾波器設計工具包,最小P階規(guī)范方法使用牛頓法或迭代重賦權最小二乘(IRLS)法開發(fā)解決方案。
表1 數(shù)字濾波器設計工具包提供了從傳統(tǒng)應用到現(xiàn)代應用所需的程序化的濾波器設計工具套件
群延遲補償器
在對定點濾波器進行設計和發(fā)布的過程中,有一種特性的重要性是不言而喻的,就是需要能夠直接、交互式地查看設計結果。傳統(tǒng)的通過文本軟件定點實現(xiàn)的方法往往效率高、成本低,但是由于算法精度較低,其設計過程也更為復雜。
使用LabVIEW和數(shù)字濾波器設計工具包,定點數(shù)字濾波器設計過程首先是對浮點濾波器進行原型設計,并轉換成定點設計。轉換成定點設計會大大改變?yōu)V波器的特性和性能。實現(xiàn)了指定定長寄存器的整數(shù)字長、濾波器拓撲等其他參數(shù),這些對于確保濾波器按照設計期望進行工作是十分關鍵的。對定點設計進行適當?shù)姆抡婧头治隹梢员苊庵笤谡{試設計的時候,在千萬行嵌入式系統(tǒng)代碼中進行調試查找。集成在VI設計環(huán)境中的定點建模、仿真和分析工具簡化了從浮點設計到定點設計之間的過渡。
另外一個使得定點數(shù)字濾波設計非常困難的原因是,參數(shù)量化、中間運算和結果向系統(tǒng)引入了噪聲。此外,如果在數(shù)據存儲中沒有足夠的空間,就會發(fā)生上溢出。LabVIEW數(shù)字濾波器設計工具包中的定點建模、仿真和分析功能能夠在設計階段找出實現(xiàn)的錯誤源頭。例如,對于圖1設計的低通濾波器進行定點實現(xiàn)。用戶使用定點建模VI,就可以在多個設計方案中選擇定點系統(tǒng)、指定字長、整數(shù)字長以及設計中關鍵位置的舍入和溢出模式。為了對最終實現(xiàn)進行進一步控制,還提供了超過23種不同的濾波器拓撲,從FIR直接形式1到IIR級聯(lián)二階部分(形式I或II、轉置),直至網格ARMA(基本、一個乘法器或歸一化部分)。
圖2展示了包含選擇濾波器拓撲、定點設計工具以及用于定點和浮點設計仿真與分析的范例VI。這個VI提供了能夠隨著仿真運行對實現(xiàn)參數(shù)進行交互式修改的接口。首先,可以保持定點建模參數(shù)不變,使用默認的濾波器拓撲,使用正態(tài)分布的白噪聲信號作為濾波器輸入,測試濾波器在所有頻率下的響應。圖3給出了仿真結果。很明顯,定點濾波器并沒有給出與浮點仿真相同的結果,盡管設計的濾波器具有幾乎相同的幅度、相位和零極點圖。濾波器分析報告指出由于在乘法、加法、延遲中產生了上溢出和下溢出,因此得到的結果不夠理想。利用在VI環(huán)境中給出的信息,用戶可以對定點實現(xiàn)進行運行時修改,例如增加問題區(qū)域中的整數(shù)字長、嘗試其他濾波器拓撲或是修改定點建模的其他屬性。對于這個設計而言,提高乘法、加法和延遲的整數(shù)字長就可以得到希望的定點設計結果,如圖4所示。
圖2 程序框圖展示了濾波器的設計,可以修改濾波器拓撲、整數(shù)字長、對正態(tài)分步的白噪聲進行定點和浮點設計仿真以及仿真分析[!--empirenews.page--]
圖3 前面板顯示了定點濾波器設計和浮點濾波器設計的幅度、相位和零極點圖特性以及仿真結果和第一個測試的分析
圖4 根據在濾波器分析報告中提供的信息,增加了加法、乘法和延遲的整數(shù)字長,現(xiàn)在定點設計和浮點設計的仿真結果能夠匹配
設計驗證與發(fā)布
虛擬儀器通過與測試測量應用中所需的硬件自然整合在一起,改進了工程設計。在上述數(shù)字濾波器設計中, PCI數(shù)據采集設備能夠獲得實際信號,將它與仿真信號進行比較,就更加能確保濾波器設計的正確性。由于LabVIEW與NI以及眾多第三方廠家的數(shù)據采集硬件緊密整合,這點在工程設計中又是一個重要的優(yōu)點。
許多測試與測量應用需要具有能夠在包括實時系統(tǒng)與嵌入式系統(tǒng)在內的多平臺之間的可移植性。這點又是與工程設計相關的,其中VI需要可以被用于各種通用操作系統(tǒng),包括Windows、Mac、Linux,以及支持LabVIEW的FPGA、DSP和任何32位微處理器等嵌入式系統(tǒng)。數(shù)字濾波器設計工具包是LabVIEW的一個附件,它提供了定點建模工具和LabVIEW FPGA以及ANSI-C代碼生成。DSP工程師現(xiàn)在可以利用LabVIEW的強大功能進行完整的數(shù)字濾波器開發(fā),從設計到驗證直至嵌入式系統(tǒng)發(fā)布。
數(shù)字濾波器設計工具包為學術應用和工業(yè)應用都提供了發(fā)布方案。一種是將濾波器參數(shù)保存到文件中,這也是最簡單的發(fā)布方式,它將所有實現(xiàn)細節(jié)保存到文件中,供以后使用。使用LabVIEW DSP模塊,可以讀取過去保存在文件中的濾波器參數(shù),并在DSP上實時實現(xiàn)。LabVIEW DSP將圖形化編程帶入到多個硬件平臺上,能夠廣泛地應用于學術中,其中包括了NI SPEEDY-33和Texas Instruments C6711、C6713、C6416 DSK,用于對DSP進行設計、快速原型開發(fā)和發(fā)布。它很好地支持了快速VI(Express VIs),可以加速開發(fā)速度,能夠對板卡上的模擬及數(shù)字IO進行直接存取,并支持圖形編程環(huán)境的調試。
另一種方案是FPGA發(fā)布,數(shù)字濾波器設計工具包能根據定點數(shù)字濾波器設計生成LabVIEW FPGA代碼,并在LabVIEW FPGA模塊中使用生成的代碼,它利用Xilinx編譯器直接同步位于NI可重配置I/O(RIO)硬件上的FPGA。具有RIO技術的設備有著多種外形規(guī)格,包括PCI、PXI以及CompactRIO可編程自動化控制器。LabVIEW FPGA提供了在數(shù)字濾波器應用中 對數(shù)字I/O線路和模擬I/O線路的直接訪問。
ANSI-C代碼生成是另一種發(fā)布數(shù)字濾波器設計的選擇。LabVIEW嵌入式開發(fā)模塊利用第三方嵌入式工具鏈和操作系統(tǒng),能對LabVIEW 生成的C代碼進行編譯、連接,并下載到任何32位微處理器目標中。使用LabVIEW嵌入式模塊,您可以在前面板和程序框圖中交互式地調試程序,訪問板卡的外圍I/O,使用任何用于嵌入式應用的1000個內置數(shù)字處理和信號處理VI。
圖5 LabVIEW DSP、LabVIEW FPGA和LabVIEW嵌入式模塊將圖形化編程的強大功能引入到無限的硬件平臺中
虛擬儀器是用于測試和測量系統(tǒng)設計與實現(xiàn)的可行方法。虛擬儀器思想所采用的獨特方法可以應用到工程設計應用和信號處理開發(fā)中,并且實現(xiàn)在理論設計、分析測試與發(fā)布實現(xiàn)中使用同一工具。