通信工程原理之基于COM的MatIab的參數(shù)處理[1]

互聯(lián)網(wǎng)技術(shù) 責(zé)任編輯:chenzhip_1 2012-03-20

摘要:基于COM組件的Matlab與C++混合編程方式因擁有獨立的運行環(huán)境和兩種語言的互補(bǔ)優(yōu)勢而被眾多科研人員和編程人員所接受,同時也是MathWorks公司推薦使用的混編方式。但在程序設(shè)計過程中,通常會遇到兩個難點問題:(1)二維數(shù)組參數(shù)的傳遞與輸出;(2)Matlab生成圖形嵌入VC工程界面中。對于第一個問題,BruceMcKinney[1]在MSDN上指出;

基于COM組件的Matlab與C++混合編程方式因擁有獨立的運行環(huán)境和兩種語言的互補(bǔ)優(yōu)勢而被眾多科研人員和編程人員所接受,同時也是MathWorks公司推薦使用的混編方式。但在程序設(shè)計過程中,通常會 遇到兩個難點問題:(1)二維數(shù)組參數(shù)的傳遞與輸出; (2)Matlab生成圖形嵌入VC工程界面中。對于第一個問題,Bruce McKinney[1]在MSDN上指出;“如果對一維數(shù)組進(jìn)行操作,則SAFEARRAY函數(shù)變的簡單且易操作。但是對于多維數(shù)組,同樣的操作要復(fù)雜得多”,造成這一問題的根源在于Matlab與C++對多維數(shù)組元素的存儲方式不同。而在本項目開發(fā)過程中回避了這個復(fù)雜的過程,轉(zhuǎn)而利用Matlab強(qiáng)大的數(shù)組處理功能將其解決。Matlab完善的圖形處理功能是其被科研人員所推崇的原因之一,但因其圖形擁有獨立的窗口,嚴(yán)重影響了整體界面美觀和用戶交互體驗,所以Matlab圖形嵌入是混合編程中不可回避的問題。對此將通過實例介紹兩種圖形嵌入方法并分析說明其優(yōu)缺點和相關(guān)細(xì)節(jié)。

本文示例均在Matlab R2008a和VC 6.0平臺下完成,且通過調(diào)試能夠正常運行。

1 Excel文件讀取方法

VC平臺下的Excel文件讀取方式復(fù)雜難懂,但如果使用Matlab與VC的混合編程方式編寫將更加簡便,而且擁有較強(qiáng)的可擴(kuò)展性。下面代碼詳細(xì)講解了該過程。

(1)在Matlab平臺下建立CExcelRead.m文件,代碼如下:

function [output,row,col] = CExcelRead(filePath)

//filePath包含了指定文件的路徑和文件名,由VC平臺函數(shù)GetPathName()獲取

[typ, desc] = xlsfinfo(filePath);

//xlsfinfo()可獲取指定Excel文件中各個sheet工作區(qū)的名稱,返回值存入名為desc的cell數(shù)組中

sheet1 = cell2mat(desc(1));

//默認(rèn)打開“sheet1”(名稱任意),并將其轉(zhuǎn)換為字符串

output = xlsread(filePath,sheet1);

//返回該Excel文件中的數(shù)據(jù),返回值存入output數(shù)組中

[row,col] = size(output);

//獲取錄入數(shù)據(jù)的行列值,返回到VC平臺以供其拷貝指定內(nèi)存大小的數(shù)據(jù)

output = reshape(output,row*col,1);

//將該二維數(shù)組轉(zhuǎn)換為一維。這是第二部分二維數(shù)組處理的第一步

保存文件后,使用deploytool工具將其制作成名為FileOpen的COM(封裝MCR),注冊該控件并將相應(yīng)的文件拷貝到MFC的工程中,對于基礎(chǔ)操作此處不再贅述。

[1]  [2]  [3]  [4]  [5]  

更多資料
更多課程
更多真題
溫馨提示:因考試政策、內(nèi)容不斷變化與調(diào)整,本網(wǎng)站提供的以上信息僅供參考,如有異議,請考生以權(quán)威部門公布的內(nèi)容為準(zhǔn)!

通信工程師備考資料免費領(lǐng)取

去領(lǐng)取

距離2025 通信工程師考試

還有
  • 3
  • 1
  • 2
專注在線職業(yè)教育23年

項目管理

信息系統(tǒng)項目管理師

廠商認(rèn)證

信息系統(tǒng)項目管理師

信息系統(tǒng)項目管理師

學(xué)歷提升

!
咨詢在線老師!