當(dāng)前位置:首頁 > 嵌入式 > 嵌入式硬件
[導(dǎo)讀] 在開發(fā)DSP數(shù)據(jù)采集和處理系統(tǒng)的過程中.通常需要采用DSP匯編語言開發(fā)一些復(fù)雜的算法(如FFT分析、相關(guān)分析等),但是,實(shí)現(xiàn)這些算法的程序一般都很復(fù)雜,尤其需要圖形顯示時(shí),程序的編寫.

前言

在開發(fā)DSP數(shù)據(jù)采集和處理系統(tǒng)的過程中.通常需要采用DSP匯編語言開發(fā)一些復(fù)雜的算法(如FFT分析、相關(guān)分析等),但是,實(shí)現(xiàn)這些算法的程序一般都很復(fù)雜,尤其需要圖形顯示時(shí),程序的編寫就更復(fù)雜了。此外,這些程序還將占用DSP的內(nèi)存資源。Matlab提供了矩陣處理、數(shù)值計(jì)算、圖形顯示等強(qiáng)大功能,同時(shí)還帶有功能豐富的軟件工具箱.若能把Matlab的高效、便捷算法和圖形顯示工具應(yīng)用于DSP數(shù)據(jù)采集和處理系統(tǒng).即把采集到的數(shù)據(jù)上傳到Matlab平臺(tái)進(jìn)行相應(yīng)的處理和圖形顯示.這樣.不僅減少了DSP的負(fù)荷和開銷.而且還可以加快系統(tǒng)的研發(fā)進(jìn)度。

1 系統(tǒng)設(shè)計(jì)

基于Matlab平臺(tái)的DSP數(shù)據(jù)采集和處理系統(tǒng)的主要功能是:在Matlab平臺(tái)上控制底層DSP目標(biāo)板進(jìn)行數(shù)據(jù)的采集和處理,并把采集到的數(shù)據(jù)上傳到Matlab平臺(tái)上進(jìn)行相應(yīng)的數(shù)值處理和圖形顯示然后再把處理后的數(shù)據(jù)回傳給底層DSP目標(biāo)板,完成后續(xù)任務(wù)。

1.1硬件結(jié)構(gòu)

DSP數(shù)據(jù)采集系統(tǒng)主要由PC計(jì)算機(jī)、TMS320C6202 DSP目標(biāo)板、AD16模塊、MOT模塊、數(shù)字I/O口和Timer模塊組成,如圖1所示。

①DSP目標(biāo)板選用ll(Innovative Integration)公司M6x系列的TMS320C6202開發(fā)板。DSP目標(biāo)板通過計(jì)算機(jī)主板上的PCI插槽裝在計(jì)算機(jī)內(nèi)部,DSP程序通過JTAG進(jìn)行在線調(diào)試:DSP目標(biāo)板提供了許多動(dòng)態(tài)連接庫函數(shù).可直接完成對(duì)目標(biāo)板的底層操作,如Target_Open()--打開目標(biāo)板驅(qū)動(dòng)、iicoffld()--下載程序列DSP中、Target_Close()--關(guān)閉目標(biāo)板驅(qū)動(dòng)等;

②AD16是Ⅱ公司的16通道16位的數(shù)據(jù)采集模塊.雙端差動(dòng)輸入,輸入范圍是-10V至+10V,可同時(shí)采集16路外部模擬信號(hào),采樣頻率為5~195KHz;



圖1系統(tǒng)硬件結(jié)構(gòu)

③MOT是一個(gè)集成有4個(gè)16位DA轉(zhuǎn)換器的信號(hào)產(chǎn)生模塊,DA輸出電壓范圍是-10V到+10V.可輸出4路測(cè)試需要的模擬信號(hào).DA轉(zhuǎn)換頻率最高可達(dá)200KHz:

④數(shù)字I/O模塊是一個(gè)32位數(shù)字I/O連接端口。系統(tǒng)可以通過這個(gè)數(shù)字I/O接口與外界進(jìn)行數(shù)字通信:

⑤Timer模塊提供了三個(gè)外部定時(shí)器,其定時(shí)參考時(shí)鐘可以是DSP目標(biāo)板上的時(shí)鐘,也可以是外部提供的時(shí)鐘。其定時(shí)輸出信號(hào)可滿足系統(tǒng)測(cè)試的定時(shí)要求。

1.2軟件設(shè)計(jì)

圖2是DSP數(shù)據(jù)采集和處理系統(tǒng)的軟件設(shè)計(jì)模塊圖。其中:Matlab平臺(tái)主要完成對(duì)目標(biāo)板的操作和控制,處理DSP目標(biāo)板上傳的數(shù)據(jù).再回傳給DSP目標(biāo)板,并進(jìn)行圖形顯示。



圖2系統(tǒng)的軟件模塊圖

visual C++平臺(tái)作為Matlab與底層DSP目標(biāo)板的連接中介,主要完成對(duì)DSP目標(biāo)板的具體操作。由于DSP目標(biāo)板自帶了對(duì)板卡進(jìn)行操作的動(dòng)態(tài)連接庫函數(shù),因此在Vishal C++平臺(tái)中就可利用這些函數(shù),完成對(duì)目標(biāo)板的一些控制和操作。例如:用戶界面(圖4)上的Open按鈕就是在Visual C++中利用Target_Open()函數(shù)完成目標(biāo)板驅(qū)動(dòng)的打開。

DSP數(shù)據(jù)采集和處理程序主要控制AD16采集外界模擬信號(hào),并經(jīng)過相應(yīng)處理之后.上傳到Matlab平臺(tái),然后再從Matlab平臺(tái)接收處理后的數(shù)據(jù).控制MOT模塊輸出系統(tǒng)所需的模擬信號(hào)。完成一個(gè)完整的數(shù)據(jù)采集—數(shù)據(jù)處理一系統(tǒng)控制的全過程。

2 系統(tǒng)實(shí)現(xiàn)的關(guān)鍵技術(shù)

Matlab作為高級(jí)應(yīng)用程序語言.并不能直接控制和操作所有的底層板卡。Matlab仿真模塊里面帶有一些可以直接控制和操作的DSP板卡.但是這些板卡都是一些固定型號(hào)的DSP板卡,而對(duì)用戶自行設(shè)計(jì)和其它一些型號(hào)的DSP板卡并沒提供這種功能.因此要實(shí)現(xiàn)在Matlab平臺(tái)上控制一般的DSP板卡進(jìn)行數(shù)據(jù)的采集和處理還必須借助中介軟件.這個(gè)中介軟件就是Visual C++。這樣便可實(shí)現(xiàn)Matlab與DSP底層板卡的無縫連接。具體技術(shù)包括:DSP目標(biāo)板和主機(jī)的數(shù)據(jù)交換,Matlab與Visual C++的接口。

2.1 DSP目標(biāo)板和豐機(jī)的數(shù)據(jù)交換

TI公司提供DSP與PC主機(jī)之間的實(shí)時(shí)數(shù)據(jù)傳輸技術(shù)RTDX(Real Time Data Exchange)協(xié)議.并在主機(jī)中提供了工業(yè)標(biāo)準(zhǔn)的目標(biāo)連接與嵌入應(yīng)用程序接口OLE API(Application Program Interface).因而能方便地與符合OLE API標(biāo)準(zhǔn)的第三方軟件接口。實(shí)現(xiàn)與DSP的數(shù)據(jù)交換。完整的RTDX協(xié)議包含4個(gè)部分:主機(jī)應(yīng)用程序、主機(jī)軟件庫、目標(biāo)機(jī)軟件庫和目標(biāo)機(jī)程序。圖3是實(shí)現(xiàn)計(jì)算機(jī)和DSP之間數(shù)據(jù)傳輸?shù)年P(guān)系圖。



圖3 RTDX數(shù)據(jù)傳輸關(guān)系

微軟公司(Microsoft)提供的Visual C++軟件開發(fā)環(huán)境封裝了,TI公司的RTDX協(xié)議,配合DSP程序可方便、實(shí)時(shí)地與Pc主機(jī)進(jìn)行數(shù)據(jù)通信。因此通過visual c++軟件就有可能實(shí)現(xiàn)在MATLAB平臺(tái)上完成對(duì)DSP數(shù)據(jù)采集和處理的控制。實(shí)現(xiàn)PC主機(jī)與DSP目標(biāo)板的數(shù)據(jù)交換。

PC主機(jī)和DSP目標(biāo)板通過RTDX協(xié)議實(shí)現(xiàn)數(shù)據(jù)交換需要在PC主機(jī)程序和DSP程序中定義同名的一條RTDX通道,數(shù)據(jù)通過該通道在PC主機(jī)和DSP目標(biāo)板之間傳輸。PC主機(jī)程序和目標(biāo)板上的DSP程序需要嚴(yán)格的配合,PC主機(jī)的讀操作和DSP目標(biāo)板的寫操作通過定義一個(gè)“寫RTDX”通道實(shí)現(xiàn):而PC主機(jī)的寫操作與DSP目標(biāo)板的讀操作通過定義一個(gè)“讀RTDX”通道實(shí)現(xiàn).必須一一對(duì)應(yīng),這樣才能實(shí)現(xiàn)主機(jī)與DSP目標(biāo)板的數(shù)據(jù)交換。

2.2 Matlab與Visual C++的接口

Matlab作為一種工具軟件.通常是不能直接控制DSP目標(biāo)板。但是Matlab軟件為了擴(kuò)充自身軟件的功能,提供了一種與其它開發(fā)工具或開發(fā)語言進(jìn)行交互的應(yīng)用程序接口 (API)。其中.MEX文件就是MATLAB軟件提供的一種與Visual c++溝通的接口文件。

在MEX文件中使用c語言編寫以mexFunction (int nlhs,mxArray *nlhs[ ],int nrhs,const mxArray * plhs[ ])函數(shù)為主函數(shù)的動(dòng)態(tài)連接庫程序(*.dll).然后只需在Matlab命令提示符下鍵入此MEX文件名(*.dll)即可完成調(diào)用.這與Matlab的內(nèi)建函數(shù)的調(diào)用方式完全相同。mexFunction函數(shù)中的參數(shù)說明如下:

①int nlhs是左邊輸出參數(shù)的個(gè)數(shù),即visual c++向Matlab傳遞的參數(shù)個(gè)數(shù);

②mxArray *nlhs [ ]是左邊參數(shù)的數(shù)組。它是一個(gè)mxArray結(jié)構(gòu)體類型的指針數(shù)組.這個(gè)數(shù)組的元素按順序(nlhs[0].nlhs[1]?)指向所有的輸出參數(shù):

③int nrhs是右邊輸入?yún)?shù)的個(gè)數(shù),即Matlab向VisualC++傳遞的參數(shù)個(gè)數(shù);

④const mxArray *plhs [ ]是右邊參數(shù)的數(shù)組,它是一個(gè)mxArray結(jié)構(gòu)體類型的指針數(shù)組,這個(gè)數(shù)組的元素按順序(plhs[0],plhs[1]??)指向所有的輸入?yún)?shù)。

在MEX文件中.利用DSP目標(biāo)板提供的動(dòng)態(tài)連接庫函數(shù),編寫對(duì)目標(biāo)板進(jìn)行操作的動(dòng)態(tài)連接庫程序.然后在Matlab平臺(tái)上調(diào)用這些動(dòng)態(tài)連接庫函數(shù)既町實(shí)現(xiàn)Matlab和底層DSP目標(biāo)板的無縫連接。



圖4系統(tǒng)測(cè)試結(jié)果

具體過程是:在Matlab平臺(tái)上.以傳遞參數(shù)的形式調(diào)用動(dòng)態(tài)連接庫程序。把需要傳送給DSP目標(biāo)板處理的數(shù)據(jù),通過mexFunction函數(shù)的右邊參數(shù)數(shù)組先傳送給動(dòng)態(tài)連接庫程序。然后通過Visual C++程序和DSP程序共同定義的“寫RTDX通道”把數(shù)據(jù)傳送給DSP目標(biāo)板:需要上傳到Matlab平臺(tái)的數(shù)據(jù),首先被DSP應(yīng)用程序?qū)懭氲?ldquo;讀RTDX通道”中.然后在Visual C++中的動(dòng)態(tài)連接庫程序讀取該R31DX通道中的數(shù)據(jù),再經(jīng)過MexFunction函數(shù)的左邊參數(shù)數(shù)組把數(shù)據(jù)上傳到Matlab平臺(tái)。這樣.就實(shí)現(xiàn)了在Matlab平臺(tái)上控制和操作DSP目標(biāo)板,并與之進(jìn)行數(shù)據(jù)交換。

圖4是按照上述方法編寫的軟件界面和對(duì)系統(tǒng)進(jìn)行測(cè)試所得到的結(jié)果。

3 結(jié)束語

基于Matlab平臺(tái)的DSP數(shù)據(jù)采集和處理系統(tǒng),在Matlab強(qiáng)大的數(shù)據(jù)分析和繪圖功能的基礎(chǔ)上,結(jié)合了Visual c++易于實(shí)現(xiàn)操作和控制的性能。改善了Matlab在控制底層板卡方面的不足。該系統(tǒng)的研究不僅是把Matlab應(yīng)用于DSP數(shù)據(jù)采集和處理系統(tǒng)的一次嘗試.也為一些半實(shí)物仿真系統(tǒng)提供了新的思路。Matlab/Simulink本身就是一種功能強(qiáng)大的系統(tǒng)仿真工具,因此,如果能在該系統(tǒng)的基礎(chǔ)上把Matlat/Simulink的仿真功能添加上來。則可實(shí)現(xiàn)硬件在環(huán)的半實(shí)物仿真。相信Matlab豐富的函數(shù)庫和眾多的專業(yè)工具箱.必會(huì)為今后系統(tǒng)的完善以及擴(kuò)展提供充分的條件。

本文作者創(chuàng)新點(diǎn):通過在Matlab平臺(tái)上直接控制DSP數(shù)據(jù)采集系統(tǒng).把Matlab的優(yōu)良算法應(yīng)用于系統(tǒng)中。簡化了系統(tǒng)的數(shù)據(jù)處理過程。提高了,系統(tǒng)數(shù)據(jù)處理速度,縮短了系統(tǒng)設(shè)計(jì)周期,具有廣泛的應(yīng)用前景。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉