隨著全球經(jīng)濟的飛速發(fā)展,,對能源的需求逐日增加,以往以煤,、石油等非再生的古老能源已經(jīng)不能滿足現(xiàn)在社會對能源的需求,。我國有著廣闊的海岸線,對海浪能的開發(fā)利用成為目前開發(fā)新能源的重要方式,。
在眾多海浪發(fā)電裝置設備中均存在著對海浪能量的轉(zhuǎn)換效率低下的問題,。針對效率轉(zhuǎn)換問題,蔡元奇教授提出了利用實時調(diào)節(jié)海浪發(fā)電裝置中擺子的固有自振頻率與海浪頻率相同的方法,,進而與海浪產(chǎn)生諧振,,從而減少了發(fā)電裝置的能量損耗,提高轉(zhuǎn)換效率[1-2]。因此,,需要實時掌握海浪的頻率參數(shù),,要保證得到的海浪頻率的準確可靠。
本文設計了多功能海浪識別儀,,以Cortex-A8作為主處理器,,基于Linux操作系統(tǒng),有很強的可移植性與擴展性,。通過加速度傳感器采集浮標的加速度,,對此信號采取EMD處理,并對分解之后的IMF進行閾值篩選,,獲得有效分量,,然后對該分量進行希爾伯特黃變換,從而準確計算出海浪的實時頻率[3],。通過陀螺儀,、電子羅盤、GPS可以精確定位波浪識別儀的準確方位以及姿態(tài),。通信網(wǎng)絡采用GPRS網(wǎng)絡,,實時將采集到的數(shù)據(jù)傳輸?shù)桨哆叡O(jiān)控中心。
1 系統(tǒng)總體結構及功能
海浪數(shù)據(jù)采集傳輸系統(tǒng)主要由數(shù)據(jù)采集,、數(shù)據(jù)傳輸及數(shù)據(jù)處理三部分[4]組成,,系統(tǒng)框圖如圖1所示。數(shù)據(jù)采集部分由加速度傳感器,、陀螺儀,、電子羅盤及GPS組成,主要作用是采集浮體的線加速度,、角加速度,、方位角以及GPS坐標。數(shù)據(jù)傳輸部分由GSM/GPRS收發(fā)模塊組成,,能夠通過網(wǎng)絡使手機短信實時接收現(xiàn)場數(shù)據(jù),。數(shù)據(jù)處理部分由S5PV210處理器完成數(shù)據(jù)篩選、算法及處理,。
2 系統(tǒng)硬件設計
2.1 S5PV210處理器
S5PV210是三星公司推出的高性能應用處理器,,采用了Cortex-A8內(nèi)核,,運行主頻可達1 GHz,,可搭載Linux系統(tǒng),帶有2路SPI,、4路I2C與4路UART接口,。
2.2 加速度傳感器
選用基于VTI的3D-MEMS電容傳感技術的高性能低功耗的SCA3060三軸加速度傳感器,±2 g的測量量程,、精度可達1 mg,,完全滿足設備測量環(huán)境的客觀要求,。將采集到的三個軸方向上的加速度數(shù)據(jù)通過SPI總線傳輸給處理器。電路圖如圖2所示,。
2.3 陀螺儀模塊
選用L3GD20三軸陀螺儀芯片,。它提供了較寬的測量量程,用戶有足夠的選擇空間,。為了滿足測量所需,,同時保證測量精度,該系統(tǒng)中選用±500°/s量程,,測量精度可達±0.015°/s,。該芯片采用I2C總線方式與處理器進行數(shù)據(jù)傳輸。
2.4 GPS模塊
采用Gstar GS-87模塊,,它是一個高效能,、低功耗的智能型衛(wèi)星接收模塊。其工作電壓為3.3 V,,定位精度可達10 m以內(nèi),通過串口與處理器進行通訊,,通過GPRS網(wǎng)絡將所需數(shù)據(jù)傳回監(jiān)控中心。
2.5 GSM/GPRS模塊
選用中興的MF210模塊,,本設計中利用SIM卡通過聯(lián)通網(wǎng)絡進行實時數(shù)據(jù)傳輸,,外圍電路圖如圖3所示。
2.6 電子羅盤
選用SCH9005集成電路模塊,,該芯片集成了高精度氣壓傳感器和高精度磁傳感器,,且具有溫度測量、氣壓測量,、指南針方位測量功能,。氣壓測量分辨率為±1 hPa,測量范圍是300 hPa~1 000 hPa,,羅盤精度為±2°,,分辨率為1°,以地磁的正北角為0°,,模塊采用I2C接口將數(shù)據(jù)傳送給處理器,。
3 系統(tǒng)軟件設計
3.1 數(shù)據(jù)采集部分
Linux操作系統(tǒng)中,上層用戶空間通過調(diào)用內(nèi)核空間的系統(tǒng)接口函數(shù)來完成對底層硬件的操作,。因而要完成芯片的功能,,首先需要編寫底層的驅(qū)動程序,其次是上層的應用程序,。本設計中所選芯片運用到了I2C,、SPI、UART 3種通信協(xié)議方式。雖然Linux系統(tǒng)內(nèi)核一般自帶有3種總線的驅(qū)動程序,,但是其總線子系統(tǒng)框架復雜,,不易移植,且編寫應用程序時不方便,,因而考慮重新編寫基于對GPIO端口操作的字符設備驅(qū)動來完成對傳感芯片的數(shù)據(jù)操作[5],。
S5PV210芯片帶有3路I2C、兩路SPI接口和4路UART接口,。電子羅盤和陀螺儀選用I2C方式通信,,在I2C字符驅(qū)動程序中,直接通過地址映射對寄存器進行操作,,配置寄存器I2CCON,、I2CSTAT,設置其工作方式為主機模式,使能I2C中斷,,設定其工作頻率為400 kHz,。
GPS和GPRS的串口傳輸選用“dev/ttyS0”和“dev/ttyS1”,在上層用戶空間中直接編寫應用程序,,設置串口波特率為9 600 bit/s,,8 bit數(shù)據(jù)傳輸,無奇偶校驗位,。程序讀取GPS返回的GPRMC(推薦定位信息),,該信息包含了UTC時間,定位狀態(tài),,經(jīng)緯度,,地面速率以及航向角。
3.2 數(shù)據(jù)傳輸部分
系統(tǒng)采用GPRS網(wǎng)絡傳輸方式實現(xiàn)現(xiàn)場和岸邊通信,。
對于GPRS網(wǎng)絡傳輸時,,處理器將經(jīng)過處理后得到的海浪頻率、儀器的傾斜角,、GPS地理方位等數(shù)據(jù)發(fā)送給GPRS網(wǎng)絡,,GPRS網(wǎng)絡提供通信鏈路,將這些信息發(fā)送給固定IP地址,,在監(jiān)控中心的上位機程序需要進行socket網(wǎng)絡編程,,通過靜態(tài)IP地址看到數(shù)據(jù)。
在ARM發(fā)送端,,Linux系統(tǒng)啟動之后,,首先要對串口進行初始化,配置串口參數(shù),,其次,,對GSM模塊設置AT指令,主要用到的指令有AT+CGDCONT=1,,“IP”,,“CMNET”接入網(wǎng)絡;AT+TCPSERV設置上位機IP地址,,AT+TCPPORT配置上位機監(jiān)聽端口設置,。然后,通過AT+CONNETCIONSTART請求建立網(wǎng)絡連接,,再通過AT+OTCP登陸網(wǎng)絡,,數(shù)據(jù)傳輸時,將數(shù)據(jù)打包封裝直接發(fā)送到GPRS網(wǎng)絡,,流程如圖4所示,。
3.3 數(shù)據(jù)處理
3.3.1 海浪頻率的提取
以所測得的三軸加速度為數(shù)據(jù)分析對象推算出海浪頻率,由于海浪波形具有隨機性,,混亂性,,而且在測量加速度信號時,采集系統(tǒng)的測量誤差,、外界環(huán)境的干擾或其他因素的影響,,使得測量到的加速度信號包含大量的噪聲。這些噪聲理論上可以使用傅里葉變換和小波變換進行分析處理,,可是在實測數(shù)據(jù)中,,發(fā)現(xiàn)所測信號為非平穩(wěn)非線性信號,而傅里葉變化并只能處理平穩(wěn)信號,,雖然小波變換在理論上能夠處理非平穩(wěn)非線性信號,,但是在實際實踐過程中,發(fā)現(xiàn)處理效果并不理想,,所以引入了希爾伯特黃變換算法,。
該算法可以簡單的表示為兩個步驟,首先需對原始信號進行EMD分解,。EMD分解主要目的是將原始信號分解為多個IMF分量,。IMF具有以下兩個特點:其極點數(shù)個數(shù)和零點數(shù)個數(shù)最多相差一個;其極大值點確定的包絡線與極小值點確定的包絡線的和必須為零,。
(1)將信號x(t)的極大值與極小值形成的包絡線取平均得到均值曲線l(t),,之后用原始信號x(t)減去均值曲線l(t)得到l1(t),判斷l(xiāng)1(t)是否滿足IMF分量的兩個條件,,若滿足則得到第一個IMF,,若不滿足,則將l1(t)視為新的原始信號繼續(xù)重復以上步驟,。最后得到n個IMF與一個殘余分量r,。
在n個IMF中,,為了獲取原始信號中的主要成分信號分量,將分量信號與原始信號的相關系數(shù)設為篩選參考量,,當相關系數(shù)大于0.7時,,可確定該IMF為原始信號主要成分,篩選閾值設為0.7,。
(2)進行Hilbert變換,。對于信號x(t),Hilbert變換定義為:
對每一個IMF進行Hilbert變換,,從而得到了信號的瞬時頻率,。借助Hilbert變換,可得到x(t)的解析信號:
3.3.2 浮體傾角的提取
L3GD20陀螺儀可以測得三個方向上的角加速度,,對各方向上的角加速度積分即可得到該方向上的傾角度數(shù),。由于陀螺儀在輸出時,會存在數(shù)據(jù)漂移,,如果直接對數(shù)據(jù)積分會造成偏移誤差越來越大,,最后導致數(shù)據(jù)無法使用。因此,,用卡爾曼濾波對數(shù)據(jù)進行處理[7],,卡爾曼濾波實質(zhì)上是依據(jù)實測數(shù)據(jù)對隨機量進行最小二乘估計,可以對物體的實時運行狀態(tài)進行估計和預測,。
3.4 軟件整體流程
海洋波浪作為觀測對象,,其頻率很低不會超過5 Hz,根據(jù)采樣定理,,將三軸加速度傳感器的采樣頻率設定為10 Hz,。采樣點數(shù)為2 048,采樣時間為3.5 min,。將陀螺儀采樣頻率設為20 Hz,。軟件整體流程如圖5所示。
4 實驗條件及結果
為了較為準確地測試系統(tǒng)采集數(shù)據(jù)的穩(wěn)定性及準確性,,將測試地點選為湖水面積為33 km2的東湖內(nèi),,湖面的波浪相比于海浪,沒有海風的作用,、氣壓變化,、地形因素等客觀條件影響,其波浪形成條件雖然不如海浪嚴苛和復雜,,且波浪振幅和頻率均比海浪小,。但是,兩者之間具有波浪的共性,,均是由風產(chǎn)生的水面波動,,均可視作由無限多個振幅不同,、頻率不同、方向不同,、相位雜亂的波組成,,因此可以作為測試場地達到我們測量波浪頻率的目的。
試驗現(xiàn)場平均波高為3~5 cm,,頻率為1 Hz左右,但是由于試驗期間受到?jīng)_鋒舟的影響,,致使波高有時達到10 cm左右,,頻率降低到0.5 Hz左右。
利用MATLAB對采集到的角度與線加速度進行分析,,其角度曲線圖如6所示,,經(jīng)過卡爾曼濾波之后的角加速度進行積分,不會再產(chǎn)生多大的漂移與誤差,,效果良好,,其波形近似正弦曲線,間接反映出良好的波浪震蕩特性,。角度的大小可近似反應波浪振幅的強度,,當角度震蕩越大,波浪振幅強度越強,。
由希爾伯特算法計算得到的頻率數(shù)據(jù)如表1所示,,算法處理時間約為10 s,能夠很迅速地處理數(shù)據(jù),,分析得出波浪頻率,,保證實時性。計算所得頻率與實際頻率相符,,經(jīng)多次驗證,,該算法能夠很好地從非平穩(wěn)非線性的隨機信號中,獲取信號主要成分,,能夠保證數(shù)據(jù)輸出的可靠性,。
本文借助ARM及Linux開發(fā)平臺完成了對波浪頻率、溫度及氣壓的測量,,實現(xiàn)了浮標的姿態(tài)及定位,,通過GPRS網(wǎng)絡實時地將數(shù)據(jù)反饋到監(jiān)控中心,達到了遠程海浪數(shù)據(jù)監(jiān)測的目的,。
該設計具有良好的實時性,、可靠性及準確性。其創(chuàng)新點在于將希爾伯特算法運用于加速度信號的分析當中,,并且通過希爾伯特變換計算出了波浪的瞬時頻率,,同時以Linux系統(tǒng)為平臺,,具有很強的擴展性,方便波浪浮標采集系統(tǒng)的二次開發(fā),。
參考文獻
[1] 蔡元奇.共振波力發(fā)電裝置:中國,,CN201110233308.7[P].2011-08-16.
[2] 蔡元奇.共振波力發(fā)電裝置:中國,CN201120295878.4[P].2011-08-16.
[3] 文圣常.海浪理論與計算原理[M],,北京:科學出版社,,1984.
[4] 劉國棟.波浪浮標數(shù)據(jù)處理方法研究[D].天津:天津大學,2011.
[5] 徐海林.基于ARM-Linux的IIC串行通信[J].微處理器與可編程控制器,,2013(20):85-86.
[6] 賈瑋.基于DSP的EMD算法實現(xiàn)[D].太原:中北大學,,2009.
[7] 張杰.基于MEMS陀螺儀和加速度計的動態(tài)傾角傳感器[J].2012(9):141-142.