日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當前位置:首頁 > 電源 > 數(shù)字電源
[導讀]本文結合具體例證,介紹基于MATLAB 的DSP 應用程序調(diào)試方法。 MATLAB 具有強大的分析、計算和可視化功能,利用MATLAB 提供的數(shù)十個專業(yè)工具箱,可以方便、靈活地實現(xiàn)對自動控制、信號處理、通信系統(tǒng)等的算法分析和仿

本文結合具體例證,介紹基于MATLAB 的DSP 應用程序調(diào)試方法。

MATLAB 具有強大的分析、計算和可視化功能,利用MATLAB 提供的數(shù)十個專業(yè)工具箱,可以方便、靈活地實現(xiàn)對自動控制、信號處理、通信系統(tǒng)等的算法分析和仿真,是算法設計人員和工程技術人員必不可少的軟件工具。
    數(shù)字信號處理器(DSP)作為一種可編程專用芯片,是數(shù)字信號處理理論實用化過程的重要技術工具,在語音處理、圖像處理等技術領域得到了廣泛的應用。但對于算法設計人員來講,利用匯編語言或C 語言進行DSP 功能開發(fā),對于具有周期長、效率低的缺點,不利于算法驗證和產(chǎn)品的快速開發(fā)。
    由MathWorks 公司和TI 公司聯(lián)合開發(fā)的MATLAB Link for CCS Development Tools(簡稱CCSLink)是MATLAB6.5 版本(Release13)中增加的一個全新的工具箱,它提供了MATLAB、CCS 和DSP 目標板的接口,利用此工具可以像操作MATLAB變量一樣來操作DSP 器件的存儲器和寄存器,使開發(fā)人員在MATLAB 環(huán)境下完成對DSP 的操作,從而極大地提高DSP 應用系統(tǒng)的開發(fā)進程。

1 CCSLink 初步
    CCSLink 工具通過雙向連接將MATLAB、CCS 和DSP 目標板聯(lián)系起來,允許開發(fā)者利用MATLAB 強大的可視化、數(shù)據(jù)處理和分析函數(shù)對來自CCS 的數(shù)據(jù)進行分析和處理,極大地簡化TI 公司DSP 軟件的分析、調(diào)試和驗證過程。三者關系如圖1示。
 
圖1 CCSLink連接關系
    CCSLink 的主要特點為:在MATLAB 環(huán)境下完成對DSP器件的調(diào)試、數(shù)據(jù)傳遞和驗證;在MATLAB 和DSP 之間實現(xiàn)數(shù)據(jù)實時傳遞;支持XDS510 和XDS560 仿真器;提供嵌入式對象,可以訪問C/C++變量;擴展了MATLAB 和eXpressDSP工具調(diào)試能力。
    MATLAB 6.5 版集成了CCSLink1.0 工具,支持CCS 能識別的所有板卡及硬件DSP,包括TIC2000、C5000、C6000 DSP及EVM 板、DSK 板、simulator 及任何符合標準的用戶板和第三方板。CCSLink 正常工作除了需要MATLAB 及其信號處理工具箱外,還需要TI 的編譯器(compiler)、匯編器(assembler)、鏈接器(linker)、CCS IDE2.1、CCS 配置工具信其他軟件工具。
在MATLAB 環(huán)境下輸入命令
help ccslink
若CCSLink 已正確安裝,則會顯示產(chǎn)品信息及進行CCS 和RTDX 操作的函數(shù)列表:
MATLAB Link for Code Composer Studio(tm)
Version 1.0 (R13) 28-Jun-2002。
若MATLAB 不能返回信息,則表明CCSLink 未安裝成功,需進行重新安裝。

2 CCSLink 對象的建立
    在對DSP 進行操作之前,應該首先建立一個DSP 目標。對于配置了多DSP 系統(tǒng)的用戶,CCSLink 提供了兩種選擇DSP目標的工具:ccsboardinfo 函數(shù)和boardprosel 圖形用戶界面,用戶可以根據(jù)返回值和自己需求選擇相應的對象。以采用圖形用戶界面為例,若配置有XDS510 Emulator 和C5416 Simulator 二種DSP 系統(tǒng),運行[boardNum,procNum] = boardprocsel,則MATLAB 通過對CCS 配置的自動檢測,出現(xiàn)圖2 所示的目標選擇界面。本文根據(jù)需要選擇硬件仿真器C54xxXDS510Emulator 并點擊Done,則可返回板卡編號和處理器編號:
boardNum=1,procNum=0。
 
圖2 CCSLink對象選擇
    利用ccsdsp 函數(shù)可以確立一個DSP 對象。ccsdsp 以板卡編號和處理器編號為參數(shù),并在建立鏈接對象后返回其它屬性,如處理器型號、處理器名稱等。例如,運行cc=ccsdsp('boardnum',boardNum, 'procnum', procNum),則建立起一個CCS IDE 對象的句柄cc。從而可以通過cc,在MATLAB 下實現(xiàn)對CCS 的操作并控制DSP 芯片。

3 CCSLink 調(diào)試DSP 代碼實例
    建立起MATLAB 鏈接之后,就可以通過CCS 為DSP 目標產(chǎn)生可執(zhí)行代碼,并進行編譯、調(diào)試和分析。在以下的介紹中,均以MATLAB 自帶的工程文件為例。
3.1 加載DSP 目標板
    在MATLAB 環(huán)境執(zhí)行以下代碼:
projfile = fullfile( matlabroot, 'toolbox', 'ccslink', 'ccsdemos', 'ccstutorial','ccstut_54xx.pjt')%選擇工程文件
projpath = fileparts(projfile) %指定工程文件路徑
open(cc,projfile)%打開工程文件
visible(cc,1)%使CCS IDE 前臺可見
cd(cc,projpath)%改變MATLAB 工作路徑
build(cc,'all',60)%編譯工程
load(cc,'ccstut_54xx.out',30)%加載可執(zhí)行文件
    則如代碼注釋所示,在MATLAB 環(huán)境下完成了對工程文件的調(diào)入、編譯,生成可執(zhí)行文件并將其加載到DSP 目標板。利用鼠標操作切換到CCS 界面,可以看到在MATLAB 下已經(jīng)完成了對CCS 的各種操作過程,如圖3 所示。
  
圖3 CCSLink調(diào)試DSP代碼實例[!--empirenews.page--]
3.2 利用CCSLink 連接調(diào)試訪問DSP 內(nèi)存
    在編譯并加載.out 文件后,可以直接由CCSLink 讀取目標符號表并獲取變量在DSP 內(nèi)存中的地址。如輸入ddatA =dec2hex(address(cc,'ddat')),將返回變量ddat 的地址和所在頁:
23AC,0000。
    在MATLAB 中,可以控制CCS IDE 中程序的顯示及斷點的增加和刪除,并控制程序代碼的執(zhí)行和暫停,讀寫DSP 的內(nèi)存變量。例如,執(zhí)行以下程序:
open(cc,'ccstut.c','text')%在CCS 中打開ccstut.c 文件
open(cc,'ccstut_54xx.cmd','text')%在CCS 中打開ccstut_54xx.cmd 文件
activate(cc,'ccstut.c','text')%將ccstut.c 作為當前的活動文件
insert(cc,'ccstut.c',64)%在第64 行加入斷點
halt(cc)%暫停CPU
restart(cc) %繼續(xù)與CCS 保持聯(lián)系
run(cc,'runtohalt',20)%DSP 程序執(zhí)行到斷點
ddatV = read(cc,address(cc,'ddat'),'single',4) %(1)讀取C 代碼初始化數(shù)據(jù)ddat
idatV = read(cc,address(cc,'idat'),'int16',4) %(2)讀取C代碼初始化數(shù)據(jù)idat
write(cc,address(cc,'ddat'),single([pi, 12.3, exp(-1), sin(pi/4)])) % (3)修改DSP 內(nèi)存中的數(shù)據(jù)ddat
write(cc,address(cc,'idat'),int16([1:4]))% (4)修改DSP 內(nèi)存中的數(shù)據(jù)idat
run(cc,'runtohalt',20) %從斷點處繼續(xù)執(zhí)行
ddatV = read(cc,address(cc,'ddat'),'single',4)% (5)讀取修改后的數(shù)據(jù)ddat
idatV = read(cc,address(cc,'idat'),'int16',4) %(6)讀取修改后的數(shù)據(jù)idat
    閱讀本例工程文件可知,在C 代碼中,變量初始化值為ddat=[16.3,-2.13,5.1,11.8],idat=[1,508,647,7000]。執(zhí)行上述(1)、(2)兩語句,在MATLAB 中獲得了這兩個變量的值ddatV 和idatV。經(jīng)過(3)、(4)兩語句的修改,ddat 和idat 分別改為了新值ddat=[3.1416,12.3,0.3679,0.7071]和idat=[1,2,3,4]。這一修改,可從(5)、(6)兩語句的執(zhí)行在MATLAB 中得到驗證,同時也可在CCS IDE 下通過變量觀測器進行證實。
    在MATLAB 下,同樣可以通過regread 和regwrite 來對CPU寄存器進行讀寫操作。如
tReg = regread(cc,'AL','2scomp') % 按二進制補碼方式讀取AL
regread(cc,'TRN','binary') % 按無符號二進制數(shù)讀取TRN
regwrite(cc,'AH','FFFF','binary') % 按無符號二進制數(shù)讀寫AH
3.3 利用CCSLink 嵌入式對象調(diào)試訪問DSP 內(nèi)存
    利用MATLAB 的面向對象編程技術和CSLink,可以為目標程序中的所有C 符號創(chuàng)建嵌入式對象,并通過對象來操作該C 符號。
    仍以上述程序為例,首先復位DSP,并創(chuàng)建一個嵌入式對象:
restart(cc) % 復位程序,使PC 指向程序入口處
goto(cc,'main') %將PC 定位到C 主程序入口
cvar = createobj(cc,'idat') %(7)為操作嵌入式對象idat 創(chuàng)建MATLAB 對象
cvar
    語句(7)創(chuàng)建了指向DSP 中C 符號的MATLAB 對象,從而可以在MATLAB 環(huán)境下實現(xiàn)對其全部或部分讀取和修改。
read(cvar)%(8)將嵌入式數(shù)組讀入到MATLAB 工作空間
read(cvar,2)%只讀取第2 個元素
write(cvar,4,7001)%(9)將第4 個元素修改為7001
set(cvar,'size',[2])%(10)將對象減小到2 個元素
    語句(8)將指向idat 的嵌入式數(shù)組cvar 讀入MATLAB,在語句(9)中對其第4 個元素進行了修改,而在語句(10)中對數(shù)組的大小進行了改變。
    通過CCSLink,不僅可以為數(shù)組變量創(chuàng)建對象,而且也可以為結構體變量創(chuàng)建對象并進行相應的操作,如:
cvar = createobj(cc,'myStruct')%創(chuàng)建指向C 結構體的MATLAB 對象
write(cvar,'iz', 'Simulink') %修改結構體的字符串iz 域為Simulink
cstring = getmember(cvar,'iz')%讀取該域到MATLAB
write(cstring,1,'s')%該寫字符串的首字符
readnumeric(cstring)%按數(shù)值方式讀取字符串
    上述5 條語句,均通過MATLAB 環(huán)境下的對象cvar,實現(xiàn)了對DSP 的C 語言程序中結構體變量myStruct 的讀寫操作和修改,具有很大的方便性。
    通過CCSlink,無論對CCS IDE 建立了連接對象還是嵌入式對象,均可在MATLAB 環(huán)境下進行操作,達到了DSP 內(nèi)部各種變量的讀寫和修改,并進行相關的調(diào)試過程,具有很大的方便性。對于上述示例所有的操作執(zhí)行結果,均可以在MATLAB和CCS IDE 環(huán)境下進行觀測和驗證。

 

4 結束語
    本文簡要討論了基于MATLAB 的DSP 程序調(diào)試方法,描述了CCSLink 與CCS IDE 的基本概念,介紹了建立CCS 對象的過程,并以MATLAB 提供的實際工程文件為例,演示了利用CCSLink 連接和嵌入式對象進行C 變量操作的實際過程,并對其執(zhí)行過程和結果進行了簡要解釋。
    應該說明的是,MATLAB提供了大量的進行DSP程序調(diào)試的函數(shù),本文只涉及到了其中極少的一部分。要充分利用MATLAB的強大功能進行更深層次的DSP程序調(diào)試,應進一步參考MathWorks公司提供的技術資料MATLAB Link for Code Composer Studio Development Tools。

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

多數(shù)受訪粉絲認為,AI驅動的功能會對他們觀看體育賽事的方式產(chǎn)生重大影響 超過半數(shù)的受訪者希望通過AI技術獲得對過去、現(xiàn)在和未來體育賽事的評論和分析 移動體育應用...

關鍵字: IBM AI 應用程序 移動

隨著在線會議、直播和游戲語音交流的普及,高質(zhì)量的音頻輸入設備變得越來越重要。為此,邊緣AI和智能音頻專家XMOS攜手其全球首家增值分銷商飛騰云科技,利用其集邊緣AI、DSP、MCU和靈活I/O于一顆芯片的xcore處理器...

關鍵字: AI DSP MCU

多DSP集群的實時信號處理系統(tǒng),通信拓撲的優(yōu)化直接決定任務調(diào)度效率與系統(tǒng)吞吐量。RapidIO與SRIO作為嵌入式領域的主流互連協(xié)議,其帶寬利用率差異與QoS配置策略對集群性能的影響尤為顯著。以無線基站、雷達陣列等典型應...

關鍵字: DSP 通信拓撲優(yōu)化

隨著5G網(wǎng)絡普及與物聯(lián)網(wǎng)設備爆發(fā)式增長,邊緣計算正從概念驗證走向規(guī)模化部署。據(jù)IDC預測,2025年全球邊緣數(shù)據(jù)量將占總體數(shù)據(jù)量的50%,這對邊緣節(jié)點的實時處理能力提出嚴苛要求。在此背景下,AI加速器的DSP化趨勢與可重...

關鍵字: AI加速器 DSP

在工業(yè)控制領域,數(shù)字信號處理器(DSP)的性能直接決定了系統(tǒng)的實時控制能力和可靠性。德州儀器(TI)的C2000系列芯片憑借其卓越的采樣、控制和功率管理能力,長期以來在全球工業(yè)控制市場占據(jù)絕對領導地位,廣泛應用于能源、電...

關鍵字: TI C2000 DSP 格見半導體 芯來 RISC-V 工控

2025年7月16日 – 專注于引入新品的全球電子元器件和工業(yè)自動化產(chǎn)品授權代理商貿(mào)澤電子 (Mouser Electronics) 持續(xù)供貨Texas Instruments (TI) 的新產(chǎn)品和解決方案。作為一家授權...

關鍵字: 線性穩(wěn)壓器 柵極驅動器 DSP

在當今數(shù)字化浪潮的推動下,數(shù)據(jù)流量呈爆炸式增長,數(shù)據(jù)中心、5G通信網(wǎng)絡以及云計算等領域對高速光通信的需求愈發(fā)迫切。800G光模塊作為高速光通信的關鍵組件,其性能直接影響著整個通信系統(tǒng)的傳輸效率和可靠性。數(shù)字信號處理(DS...

關鍵字: 800G DSP PAM4均衡算法

以氫燃料電池空壓機為研究對象 ,開發(fā)超高速永磁同步電機控制器 ,采用傳統(tǒng)的IGBT主功率器件 ,且為兩電平主回 路結構形式 ,通過改進的V/F控制算法 ,完成了控制器的設計。搭建了試驗平臺進行測試 ,結果表明 ,控制器能...

關鍵字: 超高速永磁同步電機 V/F控制 DSP

青島 2025年5月23日 /美通社/ -- 全球領先的消費電子和家電品牌海信今天宣布將谷歌全新Home API集成至其ConnectLife應用程序。今年秋季前,用戶可通過該應用程序將第三方智能家居設備接入Conne...

關鍵字: API NEC 海信 應用程序

醫(yī)療設備智能化進程,數(shù)字信號處理器(DSP)作為核心計算單元,承擔著實時處理生物電信號、醫(yī)學影像等敏感數(shù)據(jù)的重任。然而,隨著醫(yī)療設備與網(wǎng)絡互聯(lián)的深化,數(shù)據(jù)泄露風險顯著增加。美國《健康保險流通與責任法案》(HIPAA)明確...

關鍵字: 醫(yī)療設備 DSP
關閉