基于Android的低功耗移動心電監(jiān)控系統(tǒng)的設(shè)計(jì)方案
1.引言
隨著當(dāng)前信息技術(shù)和醫(yī)療水平的不斷發(fā)展以及人們生活水平的不斷提高,越來越多的人們對個人及家庭的健康護(hù)理提出了更高的要求,希望能夠隨時了解自己的身體健康狀況,并盡早發(fā)現(xiàn)病癥、解決問題。目前傳統(tǒng)的Holter系統(tǒng)體積大,使用不便的缺點(diǎn)也給人們的日常使用帶來了很大不便。因此,利用最新的無線傳感網(wǎng)與微處理器技術(shù),設(shè)計(jì)實(shí)現(xiàn)一個可長期在線且具有無線移動監(jiān)控能力的移動心電信息采集監(jiān)控系統(tǒng)具有很高的實(shí)用價值和市場潛力。
本文通過研究人體心電信號的各項(xiàng)主要特征和實(shí)際監(jiān)測應(yīng)用需求,設(shè)計(jì)開發(fā)了一套無線傳感心電信息監(jiān)測系統(tǒng),該系統(tǒng)通過嵌入內(nèi)衣穿戴的智能電極對心電信號進(jìn)行采集處理,并通過目前已成為移動設(shè)備標(biāo)配的藍(lán)牙無線數(shù)據(jù)網(wǎng)絡(luò)將心電數(shù)據(jù)發(fā)送至Android智能監(jiān)控終端進(jìn)行接收數(shù)據(jù)的存儲、管理和分析。
2.系統(tǒng)設(shè)計(jì)的總體結(jié)構(gòu)
系統(tǒng)總體結(jié)構(gòu)框圖如圖1所示,包括嵌入內(nèi)衣的心電圖導(dǎo)聯(lián)、智能電極信號處理電路模塊、以及配置有藍(lán)牙的智能Android終端應(yīng)用,其中智能電極信號處理模塊包括模擬信號調(diào)理電路、微處理器電路和無線藍(lán)牙網(wǎng)絡(luò)模塊以及可在模塊上擴(kuò)展體溫傳感器和血氧探頭等,進(jìn)而擴(kuò)展生命健康監(jiān)測參數(shù)。
圖1 系統(tǒng)總體結(jié)構(gòu)
本系統(tǒng)首先將嵌入內(nèi)衣的導(dǎo)聯(lián)電極采集的心電信號送往智能電極中信號處理電路模塊中,由模擬信號調(diào)理電路進(jìn)行濾波放大。
信號經(jīng)調(diào)理之后經(jīng)A/D轉(zhuǎn)換送給主控微處理器分析預(yù)處理。之后經(jīng)無線藍(lán)牙網(wǎng)絡(luò)通過無線信道送給配置有藍(lán)牙的智能Android終端應(yīng)用進(jìn)行診斷分析以及監(jiān)控顯示。當(dāng)發(fā)現(xiàn)異常時,終端應(yīng)用發(fā)出警報并可將結(jié)果通過移動互聯(lián)網(wǎng)發(fā)送至遠(yuǎn)程醫(yī)療中心。
由于智能電極中模擬信號調(diào)理電路不是本文對系統(tǒng)設(shè)計(jì)所要重點(diǎn)闡述的部分,所以本文主要對數(shù)據(jù)分析預(yù)處理、無線藍(lán)牙通信和Android終端應(yīng)用程序設(shè)計(jì)做介紹。
3.智能電極控制軟件設(shè)計(jì)
本系統(tǒng)采用TI公司MSP430G2553超低功耗微處理器構(gòu)建中心處理單元。MSP430單片機(jī)在低功耗方面表現(xiàn)出色,支持快速休眠,大量節(jié)省系統(tǒng)能耗,并且在惡劣條件下工作性能穩(wěn)定。所采用的G2553型號單片機(jī)加載有自主設(shè)計(jì)的危急特征提取算法,能夠滿足設(shè)計(jì)的需求。
如圖2所示為智能電極控制軟件流程圖。
圖2 智能控制軟件流程圖
主要過程為在信號調(diào)理電路預(yù)處理心電模擬信號之后,超低功耗微處理器通過內(nèi)置的10位AD轉(zhuǎn)換模塊(采樣精度為3mV)對模擬數(shù)據(jù)進(jìn)行采集和轉(zhuǎn)換,采樣周期為5ms,并將轉(zhuǎn)換后的數(shù)據(jù)取高8位后通過與異步串口(UART)交由藍(lán)牙模塊通過無線藍(lán)牙網(wǎng)絡(luò)發(fā)出。
4.Android終端應(yīng)用程序設(shè)計(jì)
4.1藍(lán)牙數(shù)據(jù)接收模塊設(shè)計(jì)
現(xiàn)代社會智能移動終端已經(jīng)成為人們生活中不可或缺的一部分,而目前大部分以手機(jī)為代表智能移動終端都是以Android系統(tǒng)為操作平臺并配置有藍(lán)牙裝置,因此為了滿足人們?nèi)粘I钍褂玫男枨笠耘渲糜兴{(lán)牙的智能Android移動終端為數(shù)據(jù)處理和診斷平臺來開發(fā)應(yīng)用程。該應(yīng)用程序以Java語言為主來進(jìn)行開發(fā)。如圖3所示為Android設(shè)備藍(lán)牙數(shù)據(jù)接收模塊設(shè)計(jì)。
圖3 Android設(shè)備藍(lán)牙數(shù)據(jù)接收模塊框圖
4.2 Android設(shè)備藍(lán)牙傳輸?shù)膶?shí)現(xiàn)方案
藍(lán)牙通信采用C / S通信模式。在設(shè)計(jì)時將接收端(Android設(shè)備)的藍(lán)牙作為客戶端,發(fā)送端(智能電極)藍(lán)牙作為服務(wù)器端。
在藍(lán)牙進(jìn)行相互連接時,利用了數(shù)據(jù)通信中常用的Socket(套接字)機(jī)制。當(dāng)兩端的套接字相互連接好以后,收發(fā)雙方的應(yīng)用就可以將數(shù)據(jù)發(fā)送給自己的套接字,并從套接字處獲取數(shù)據(jù),雙方的套接字則作為連接中轉(zhuǎn)站一樣,相互收發(fā)數(shù)據(jù)。下面對Android設(shè)備上藍(lán)牙接收軟件實(shí)現(xiàn)過程詳細(xì)闡述。
首先開啟A n d r o i d終端的藍(lán)牙功能,Android終端藍(lán)牙設(shè)備作為客戶端需要主動搜索周圍的藍(lán)牙設(shè)備。這個搜索過程需要用到廣播機(jī)制,即搜索發(fā)起端需要一個廣播接收器,用于接收搜索信息。其建立的具體步驟為,首先定義一個繼承BroadcastReceicer的類,用這個類生成的實(shí)例就具備了對接收信息的操作能力,可以獲取需要的信息,比如藍(lán)牙設(shè)備名稱和MAC地址。經(jīng)過設(shè)置,該廣播接收器只對發(fā)現(xiàn)了藍(lán)牙設(shè)備這一消息和藍(lán)牙搜索結(jié)束這兩條消息響應(yīng),并且完成了廣播接收器在本應(yīng)用中的注冊。用戶在使用時,只需要點(diǎn)擊“搜索”按鈕,終端設(shè)備開始搜索周圍藍(lán)牙設(shè)備,整個搜索過程將耗時12秒。這個過程中,本地藍(lán)牙適配器會搜索到周圍所有可以連接的藍(lán)牙設(shè)備,將這些搜索結(jié)果以列表的形式呈現(xiàn)在屏幕上,供選擇。連接開始前,首先關(guān)閉藍(lán)牙搜索功能。
在系統(tǒng)庫中有BluetoothSocket類,利用這個類生成相應(yīng)的實(shí)例便是接收端藍(lán)牙的套接字,如果該藍(lán)牙是作為服務(wù)器來連接的,則利用系統(tǒng)類BluetoothServerSocket來生成套接字對象。在連接之前需要預(yù)先設(shè)置好UUID,然后由Android智能終端發(fā)起連接請求,這里需要調(diào)用BluetoothSocket類中的connect()方法,作為服務(wù)器端的藍(lán)牙設(shè)備監(jiān)聽到連接請求后會驗(yàn)證其UUID是否與自己的一致,驗(yàn)證通過后便可以完成連接了。需要特別注意的是,在這個過程中,連接過程是一個阻塞調(diào)用過程,為不影響主線程的工作,需要一個單獨(dú)的線程來進(jìn)行連接工作。
等待藍(lán)牙連接完成后,便可以進(jìn)行數(shù)據(jù)傳輸。在藍(lán)牙間的數(shù)據(jù)傳輸是由藍(lán)牙模塊自動按照藍(lán)牙協(xié)議棧的要求進(jìn)行的,而在智能電極端從微控制器到藍(lán)牙模塊以及在Android終端從藍(lán)牙設(shè)備到應(yīng)用程序的數(shù)據(jù)傳輸都是按照URAT異步串口通信方式進(jìn)行的數(shù)據(jù)傳輸。在設(shè)計(jì)中所設(shè)置的數(shù)據(jù)傳輸格式是以一個字節(jié)長度為一幀來傳輸?shù)?,其中?位數(shù)據(jù)位和1位奇偶校驗(yàn)位共同組成。所以接收端所接收的數(shù)據(jù)都是以字節(jié)為單位來存儲的。在這個通信系統(tǒng)中,還加入了對接收數(shù)據(jù)的另一數(shù)據(jù)檢錯方案。數(shù)據(jù)的收發(fā)并不是將采集數(shù)據(jù)直接轉(zhuǎn)換成二進(jìn)制的串行數(shù)據(jù)進(jìn)行傳輸?shù)模菍⑦@些數(shù)據(jù)轉(zhuǎn)換成所對應(yīng)的ASCII碼再轉(zhuǎn)成串行數(shù)據(jù)再進(jìn)行數(shù)據(jù)的發(fā)送,這樣在接收端接收到數(shù)據(jù)后,會將這些數(shù)據(jù)轉(zhuǎn)為ASCII碼,如果這些ASCII對應(yīng)的不是數(shù)字或是已超出ASCII碼范圍,則認(rèn)為是錯誤的數(shù)據(jù),將其丟棄。這樣做了之后,結(jié)合奇偶校驗(yàn),只有低三位同時有兩位都傳輸錯誤的數(shù)據(jù)不能被監(jiān)測出來,出現(xiàn)這種情況的概率比較小,并且藍(lán)牙傳輸距離短,傳輸環(huán)境并不算惡劣,這樣的檢錯能力已經(jīng)足夠了。數(shù)據(jù)接收過程也是一個阻塞調(diào)用的過程,所以同樣需要一個單獨(dú)的線程來完成。
接收到的數(shù)據(jù),全部轉(zhuǎn)換為數(shù)字的形式(振幅信息)存儲起來,供心電圖的顯示提供數(shù)據(jù)支持。Android藍(lán)牙傳輸軟件流程如圖4所示。
圖4 Android藍(lán)牙傳輸軟件流程圖
評論