基于LabVIEW虛擬濾波器去除噪聲VI設(shè)計(jì)
引言
在振動(dòng)、聲學(xué)、地震、通訊、雷達(dá)、控制系統(tǒng)和生物醫(yī)學(xué)工程等廣泛的科學(xué)技術(shù)領(lǐng)域中都對實(shí)際所觀察的信號(hào)提出了濾波和頻譜分析的要求。以數(shù)字形式對它們進(jìn)行處理的內(nèi)容,就構(gòu)成了數(shù)字信號(hào)處理的基本研究內(nèi)容。在虛擬儀器中濾波技術(shù)有著廣泛的應(yīng)用。從測試現(xiàn)場采集到的信號(hào)中包含有對數(shù)據(jù)處理有用的信號(hào)、無用信號(hào)和噪聲,濾波的目的是從信號(hào)中提取有用的信號(hào)。在虛擬儀器系統(tǒng)中,將信號(hào)采集到電腦中,通常還需要利用軟件完成復(fù)雜的分析和信號(hào)處理工作,LabVIEW 提供了大量的分析工具,成熟的算法,方便了軟件的開發(fā)?;诖吮疚脑赑C機(jī)LabVIEW軟件中模擬產(chǎn)生一個(gè)接近于實(shí)際信號(hào)的帶噪聲的信號(hào),生成一個(gè)帶噪聲的信號(hào)發(fā)生裝置。選擇濾波速度較快的無限沖激響應(yīng)濾波器IIR,對虛擬濾波器去除噪聲進(jìn)行設(shè)計(jì)。
1、設(shè)計(jì)思路
在信號(hào)傳輸過程中,經(jīng)常會(huì)混入高頻噪聲,噪聲的能量甚至?xí)^信號(hào)能量。因此接收端收到信號(hào)后,通常首先要進(jìn)行低通濾波,然后才能對信號(hào)做進(jìn)一步處理。 設(shè)計(jì)的流程圖圖1所示:
2.虛擬濾波器去除噪聲VI設(shè)計(jì)原理
2.1 生成濾波器的自選信號(hào)
自選信號(hào)是信號(hào)發(fā)生器發(fā)出的信號(hào)加上噪聲信號(hào)來實(shí)現(xiàn)的。在信號(hào)發(fā)生器部分應(yīng)用Basic Function Generator.vi產(chǎn)生正弦波、方波、三角波、鋸齒波等標(biāo)準(zhǔn)信號(hào),噪聲部分我使用了Uniform White Noise Waveform.vi生成均勻分布的偽隨機(jī)的白噪聲,然后一起相加生成自選信號(hào)。
圖1 虛擬濾波器去除噪聲VI流程圖
在本程序中,設(shè)定Fs(采樣頻率)和#s(采樣點(diǎn)數(shù))均為1000,根據(jù)奈奎斯特抽樣定理生成信號(hào)的頻率小于Fs/2,頻譜就不會(huì)失真,所以Basic Function Generator.vi生成信號(hào)的頻率最好不要超過500Hz。但經(jīng)過試驗(yàn)在LabVIEW中采樣頻率如果越接近Fs/2頻譜很容易失真。所以Basic Function Generator.vi生成信號(hào)的頻率一定要根據(jù)實(shí)際使用情況選擇。
噪聲的幅度值在[-a,a]之間,a是幅度的絕對值,本次設(shè)的是默認(rèn)值0.10。由于生成的噪聲輸出信號(hào)要和Basic Function Generator.vi的生成信號(hào)相加,所以Sampling info(采樣信息)和Basic Function Generator.vi的Sampling info一致。輸出的signal out同樣也是一個(gè)簇,包含了to,Y,dt三個(gè)數(shù)據(jù),各個(gè)數(shù)據(jù)的作用和Basic Function Generator.vi中的signal out是一樣的。Basic Function Generator.vi和Uniform White Noise Waveform.vi的signal out輸出的信號(hào)各自經(jīng)過一個(gè)get waveform component.vi得到波形成分Y。最后兩者生成的信號(hào)經(jīng)過get waveform component.vi后再經(jīng)過一個(gè)Add得到模仿的真實(shí)信號(hào),如圖2所示,在連線時(shí)可以將兩者的error in(out)相連以備最后總程序產(chǎn)生報(bào)錯(cuò)系統(tǒng)。
圖2 自選信號(hào)部分程序圖
2.2. 濾波部分
濾波部分是本程序的核心部分。選用濾波速度快,對相位沒有要求的IIR濾波器,本程序采用Butterworth濾波器和Chebyshev濾波器。巴特沃斯濾波器擁有最平滑的頻率響應(yīng),在截?cái)囝l率以外,頻率響應(yīng)單調(diào)下降。在通帶中是理想的單位響應(yīng),在阻帶中響應(yīng)為零,過渡帶的陡峭成度正比于濾波器的階數(shù),所以通過提高階數(shù)可以明顯的提高濾波效果。并且可以選擇低通濾波,高通濾波,帶通濾波或者帶阻濾波,用戶可以根據(jù)自己的濾波要求選擇合適的濾波模式。這個(gè)功能的實(shí)現(xiàn)是用一個(gè)case選擇結(jié)構(gòu)完成的。
在程序的前面板,用一個(gè)下拉框表來實(shí)現(xiàn)選擇不同濾波器模式的功能,總共設(shè)置了九種不同的模式,當(dāng)我們要觀察自選信號(hào)不經(jīng)過濾波的形狀時(shí)我們可以選擇關(guān)閉濾波器,當(dāng)我們觀察在不同濾波器下的濾波效果時(shí)可以切換到不同的模式觀察,濾波部分的程序圖表如圖3所示。
圖3 濾波部分
2.3.顯示部分
顯示部分是本程序面向用戶的一個(gè)關(guān)鍵部分,最終的成果是通過它呈現(xiàn)出來。我們要顯示的波形圖分為濾波前的自選信號(hào)和濾波后的信號(hào)。
時(shí)域信號(hào)的顯示:從濾波部分以數(shù)組方式輸出的信號(hào)即為濾波結(jié)果的時(shí)域信號(hào),這里通過一個(gè)Build Waveform.vi來恢復(fù)波形并連接Waveform Graph(波形圖)這樣就可以在前面板上顯示濾波后的信號(hào)波形了。在本程序中,Y就是從濾波器輸出的數(shù)組元素,dt是在生成自選信號(hào)時(shí)設(shè)定的Fs的倒數(shù)。to為默認(rèn)值0,相當(dāng)于從坐標(biāo)軸的原點(diǎn)開始顯示波形。