基于STM32的MIT-BIH心電數(shù)據(jù)D/A回放設(shè)計(jì)
基于STM32的MIT-BIH心電數(shù)據(jù)D/A回放設(shè)計(jì),對(duì)整體設(shè)計(jì)方案、硬件組成、軟件設(shè)計(jì)等進(jìn)行了介紹。通過讀取心電數(shù)據(jù)將其進(jìn)行D/A轉(zhuǎn)換,輸出波形與原始波形進(jìn)行比較,較好地實(shí)現(xiàn)了回放功能。由此可見,該系統(tǒng)的性能指標(biāo)達(dá)到了設(shè)計(jì)要求。能很好地實(shí)現(xiàn)心電數(shù)據(jù)回放,為一系列心電算法的仿真實(shí)踐及實(shí)時(shí)心電監(jiān)護(hù)儀的研制打好了基礎(chǔ)。
心電信號(hào)是人類最早開展研究并應(yīng)用于臨床醫(yī)學(xué)的生物電信號(hào)之一,通過對(duì)心電信號(hào)的分析處理能有效地預(yù)測(cè)心臟疾病。如何利用心電數(shù)據(jù)開發(fā)研究相關(guān)的醫(yī)療設(shè)備是對(duì)科研人員至關(guān)重要。心電數(shù)據(jù)的回放就是將原有的存儲(chǔ)的MIT-BIH心電數(shù)據(jù),根據(jù)其存儲(chǔ)的格式,利用設(shè)計(jì)的系統(tǒng)通過D/A轉(zhuǎn)換最終從終端回放出模擬信號(hào)。本文介紹基于ARM Cortex-M3內(nèi)核的STM32微控制器作為主控嵌入式芯片的心電信號(hào)數(shù)據(jù)回放的設(shè)計(jì)方法。
1 工作原理和硬件設(shè)計(jì)
上位機(jī)應(yīng)用程序讀取心電數(shù)據(jù)庫(kù)中一文件,利用設(shè)備驅(qū)動(dòng)程序與D/A回放模塊設(shè)備進(jìn)行通信。通過USB總線不斷向硬件設(shè)備發(fā)送數(shù)據(jù),設(shè)備接收到的原始數(shù)據(jù),利用DMA傳輸方式,連續(xù)、不丟失地傳送到DAC模塊中,在定時(shí)器的觸發(fā)下,DAC模塊完成數(shù)據(jù)的D/A轉(zhuǎn)換,最后在終端設(shè)備即示波器上回放出模擬信號(hào)。
D/A回放硬件結(jié)構(gòu)框圖如圖1所示。
1.1 STM32F103XX微處理器簡(jiǎn)介
系統(tǒng)硬件采用意法半導(dǎo)體公司開發(fā)的基于Cortex-M3內(nèi)核的新型32位微控制器STM32F103RE作為主控芯片,工作頻率高達(dá)72 MHz,內(nèi)部集成了RAM、全速USB 2.0設(shè)備接口模塊和雙通道的12位高精度D/A轉(zhuǎn)換模塊等豐富的外設(shè)。在結(jié)合了高性能、低功耗和低電壓的同時(shí),保持了高度的集成性能和簡(jiǎn)易的開發(fā)特性。應(yīng)用開發(fā)時(shí),只需連接少量的外圍電路即可使電路結(jié)構(gòu)簡(jiǎn)單緊湊。
1.2 D/A轉(zhuǎn)換模塊
D/A轉(zhuǎn)換模塊(DAC)是12位數(shù)字輸入,電壓輸出的D/A轉(zhuǎn)換器。DAC可以配置成8位或12位模式,也可以與DMA控制器配合使用。DAC有2個(gè)輸出通道,每個(gè)通道都有單獨(dú)的轉(zhuǎn)換器,可以工作在雙DAC模式下,DAC集成了2個(gè)輸出緩存,可以用來減少輸出阻抗,無需外部運(yùn)放,即可直接驅(qū)動(dòng)外部負(fù)載。DAC轉(zhuǎn)換可以選擇外部事件觸發(fā)(定時(shí)器計(jì)數(shù)器,外部中斷線)和軟件觸發(fā)。
使能DAC通道后,STM32F103XX相應(yīng)的GPIO管腳(PA4或PA5)會(huì)自動(dòng)與DAC的模擬輸出相聯(lián)系。為避免寄生干擾和額外功耗,管腳PA4和PA5配置成模擬輸入(AIN),如圖2所示。
1.3 USB全速設(shè)備接口
USB外設(shè)接口實(shí)現(xiàn)了USB 2.0全速總線和APB1總線間的接口,為PC主機(jī)和微控制器所實(shí)現(xiàn)的功能之間提供了符合USB規(guī)范的通信連接。PC主機(jī)和微控制器之間通過共享USB端點(diǎn)緩沖區(qū)來實(shí)現(xiàn)數(shù)據(jù)的傳輸。
STM32芯片內(nèi)部集成了USB外設(shè),大大減輕了USB電路的設(shè)計(jì)負(fù)擔(dān),只需設(shè)計(jì)USB接口電路,就可以實(shí)現(xiàn)STM32芯片的電路板的USB通信設(shè)計(jì)。D/A回放系統(tǒng)選用的USB硬件接口電路如圖3所示:USB上拉電壓接在D+線上,所以本設(shè)計(jì)USB實(shí)現(xiàn)全速通信,PC機(jī)為USB接口供電。USB+連接在GPIO管腳PA11,USB-連接在GPIO管腳PA12,如圖2所示:
2 固件程序設(shè)計(jì)
固件程序是運(yùn)行于USB設(shè)備中的程序代碼,用于輔助硬件完成USB的功能。該系統(tǒng)固件程序選用的是STM提供的The USB-FS-DevICe Libra ry固件程序庫(kù)。主要完成如下功能:一是處理USB標(biāo)準(zhǔn)請(qǐng)求和用戶自定義請(qǐng)求;二是根據(jù)USB規(guī)范設(shè)置設(shè)備的各種描述符;三是初始化系統(tǒng)得各級(jí)中斷和內(nèi)部端點(diǎn)的配置。在Keil編譯環(huán)境下,利用現(xiàn)成固件程序框架函數(shù),根據(jù)設(shè)備需求在STM提供的固件程序的框架中添加相應(yīng)的程序代碼,完成本回放系統(tǒng)的功能目的。
2.1 STM32F103xxUSB固件程序庫(kù)簡(jiǎn)介
STM32F103xxUSB固件程序庫(kù)是意法半導(dǎo)體公司專為STM32F103XX系列ARM微處理器提供的固件程序庫(kù),主要分為內(nèi)核層和應(yīng)用接口層,結(jié)構(gòu)框圖如圖4所示。
內(nèi)核層:該層管理使用USB IP硬件與USB標(biāo)準(zhǔn)協(xié)議兩者間的直接通信。USB庫(kù)內(nèi)核遵從USB 2.0標(biāo)準(zhǔn)并和標(biāo)準(zhǔn)的STM32F103XX固件庫(kù)分離。
應(yīng)用程序接口層:該層為用戶提供了內(nèi)核和最終應(yīng)用程序之間的完整接口。應(yīng)用接口層和最終應(yīng)用與固件庫(kù)通信來管理應(yīng)用的硬件需求。
2.2 固件程序的設(shè)計(jì)
在本系統(tǒng)的開發(fā)中,沒有對(duì)內(nèi)核層進(jìn)行深入研究和修改,僅對(duì)應(yīng)用接口層進(jìn)行完成設(shè)備功能需要的設(shè)計(jì)。應(yīng)用層的開發(fā)主要包括:系統(tǒng)初始化,主要開啟系統(tǒng)和所用外設(shè)的時(shí)鐘;USB時(shí)鐘配置,設(shè)置并使能USB時(shí)鐘,為48 MHz;USB初始化主要是完成USB設(shè)備的枚舉;定時(shí)器模塊配置、DAC和DMA模塊配置主要是完成所用外設(shè)的初始化;最后配置好標(biāo)志位后等待上位機(jī)發(fā)送數(shù)據(jù)。所有代碼都是用庫(kù)函數(shù)來完成的,主程序流程圖如圖5所示。
插入U(xiǎn)SB設(shè)備時(shí),主機(jī)輪回查詢各個(gè)USB端口,檢測(cè)到D+和D-之間有電壓差,會(huì)識(shí)別出有USB設(shè)備的插入,然后對(duì)設(shè)備進(jìn)行枚舉。在設(shè)計(jì)的D/A回放系統(tǒng)中,枚舉過程的實(shí)現(xiàn)主要是對(duì)USB設(shè)備的設(shè)備描述符、配置描述符、端口描述符和端點(diǎn)描述符的配置來實(shí)現(xiàn)的。USB設(shè)備枚舉的過程就是通過讀取各個(gè)描述符來獲取USB設(shè)備的信息,然后將它配置為其中的一種功能。
D/A回放系統(tǒng)模塊設(shè)計(jì)中,共使用了3個(gè)端點(diǎn),分別為端點(diǎn)0,2和3。端點(diǎn)0為USB設(shè)備默認(rèn)的控制端點(diǎn),采用了控制傳輸方式,主要完成設(shè)備的枚舉。端點(diǎn)2、3均為批量傳輸端點(diǎn),數(shù)據(jù)傳輸采用的是批量傳輸方式,分別接收上位機(jī)發(fā)送來的心電信號(hào)數(shù)據(jù)和呼吸信號(hào)數(shù)據(jù)。定時(shí)器是一節(jié)拍發(fā)生器,作為DAC的外部事件觸發(fā)源。定時(shí)時(shí)鐘的預(yù)裝載值和時(shí)鐘分頻系數(shù)由原數(shù)字信號(hào)的抽樣頻率來決定。在D/A回放系統(tǒng)中,使用了兩個(gè)通用定時(shí)器3,4,分別作為心電信號(hào)和呼吸信號(hào)數(shù)據(jù)DA數(shù)模轉(zhuǎn)換的觸發(fā)源。DAC的配置為12位數(shù)據(jù)右對(duì)齊輸入,電壓輸出的雙通道模式。其中,通道1完成心電信號(hào)數(shù)據(jù)的D/A,通道2完成呼吸信號(hào)數(shù)據(jù)的D/A,選擇定時(shí)器作為外部事件觸發(fā)源,在一個(gè)定時(shí)周期內(nèi)完成一次數(shù)據(jù)的DA實(shí)現(xiàn)。DMA模塊主要是完成數(shù)據(jù)的轉(zhuǎn)移,USB模塊接收端點(diǎn)中斷接受的數(shù)據(jù),利用DMA方式從端點(diǎn)緩存中送入DAC的DAC_DHRyyD寄存器中,經(jīng)過相應(yīng)的移位后,寫入的數(shù)據(jù)被轉(zhuǎn)存到DHR1和DHR2寄存器中,隨后通過定時(shí)器的外部事件觸發(fā)傳輸?shù)紻ORx寄存器中,在經(jīng)過時(shí)間tsetting后,輸出即有效。在數(shù)據(jù)傳輸過程中,采用了雙緩沖機(jī)制,在RAM中開辟了2個(gè)緩存buffer,USB模塊接收數(shù)據(jù)放在一個(gè)buffer中,DMA傳輸即DAC階段,處理的數(shù)據(jù)是另一個(gè)buffer中的數(shù)據(jù),這樣,使接收數(shù)據(jù)和處理數(shù)據(jù)并行進(jìn)行,保證了轉(zhuǎn)換后波形的連續(xù)不間斷性。雙緩沖的實(shí)現(xiàn)大致如下(以心電信號(hào)數(shù)據(jù)為例):初始化空閑buffer位為buffer1,DMA源初始化配置為buffer1。端點(diǎn)2接收一數(shù)據(jù)包放入buffer1中,判斷是否為第一次接收數(shù)據(jù),如果是第一次接收,改變空閑buffer位為buffer2,并允許下一數(shù)據(jù)包的接收;如果不是第一次,中斷直接返回。繼續(xù)接收第二個(gè)數(shù)據(jù)包,放入buffer2中,判斷是否第一次DMA傳輸,如果是,改變空閑buffer位為buffer1,開啟DMA傳輸,并使能定時(shí)器;如果不是,中斷返回。當(dāng)DMA傳輸完成進(jìn)入中斷時(shí),首先判斷空閑buffer位,再重新配置DMA,包括DMA源和傳輸數(shù)目的改變,最后改變空閑buffer位,并允許端點(diǎn)的繼續(xù)接收。心電信號(hào)數(shù)據(jù)接收處理流程圖如圖6所示。對(duì)于呼吸信號(hào)數(shù)據(jù),做同樣的處理。
3 設(shè)備驅(qū)動(dòng)和應(yīng)用程序的設(shè)計(jì)
本系統(tǒng)的USB驅(qū)動(dòng)程序采用WDM模型,選用的開發(fā)工具是WindowsXP DDK(Build 2600),Driver Studio 3.2和VC 6.0。驅(qū)動(dòng)程序開發(fā)平臺(tái)搭建成功后,根據(jù)實(shí)際需要,用DriverWorks自帶的DriverWizard生成驅(qū)動(dòng)程序框架和Read,Write函數(shù),在DevICeIoControl函數(shù)中添加設(shè)備控制程序,完成自定義的功能。
上位機(jī)應(yīng)用程序是采用VC 6.0創(chuàng)建的一個(gè)基于MFC的多文檔界面應(yīng)用程序,主要分為數(shù)據(jù)管理模塊,回放模塊等基本模塊。Win32應(yīng)用程序與設(shè)備驅(qū)動(dòng)程序之間的通信是通過接口(API)函數(shù)來實(shí)現(xiàn)的,應(yīng)用程序不需要為了和USB設(shè)備通信去了解復(fù)雜的USB協(xié)議,把USB接口當(dāng)做文件來操作,從而輕而易舉的實(shí)現(xiàn)USB接口通信。
4 系統(tǒng)回放結(jié)果分析
按照固件程序的設(shè)計(jì)寫入U(xiǎn)SB設(shè)備,插入主機(jī)并加載相應(yīng)的驅(qū)動(dòng)程序,打開上位機(jī)程序,讀取數(shù)據(jù)庫(kù)中220.dat文件,傳輸?shù)絊TM32完成D/A,原始心電信號(hào)波形與示波器回放波形的比較如圖7所示。
D/A模塊較好的完成了回放功能。通過示波器實(shí)時(shí)分析,回放波形周期及幅度亦滿足要求,即時(shí)序性滿足要求。
5 結(jié)語
基于STM32的MIT-BIH心電數(shù)據(jù)D/A回放的設(shè)計(jì),在硬件和固件應(yīng)用程序兩方面實(shí)現(xiàn)了比較完美的結(jié)合,對(duì)原始數(shù)據(jù)的D/A回放取得了良好的運(yùn)行效果。同時(shí)主控芯片STM32F103RE內(nèi)部集成的豐富的功能模塊,降低了開發(fā)的難度,也保證了系統(tǒng)的