matlab中isletter函數(shù)怎么用?
[matlab]計(jì)算給定字符串的字母和數(shù)字的個(gè)數(shù)。
計(jì)算給定字符串中字母的個(gè)數(shù):Pr
find函數(shù)之后怎么返回矩陣真值怎么用matlab?
一、功能:
查找非零元素的索引和值
二、相關(guān)函數(shù)語法:
ind查找(X)
indfind(X,k)
indfind(X,k,first)
indfind(X,k,last)
[行,列]查找(X,...)
[row,col,v]find(X...)
三。描述:
索引查找(X)
找出矩陣X中所有非零元素,并將這些元素的線性索引(按列)返回給向量索引。
如果x是行向量,那么index是行向量;否則,index是一個(gè)列向量。
如果x不包含非零元素或空矩陣,則index是空矩陣。
索引查找(X,k)或3。索引查找(X,k,first)。
查找不為0的前k個(gè)線性索引值。k必須是正數(shù),但可以是任何數(shù)字類型。
索引查找(X,k,last)
求最后k個(gè)非零元素的線性索引值。
[行,列]查找(X,...)
返回矩陣x中非零元素的行和列的索引值。該語法在處理稀疏矩陣時(shí)特別有用。
如果X是N(N2)維矩陣,col包括列的線性索引。
[row,col,v]find(X...)
返回x中非零元素的列或行向量v,并返回行和列的索引值。如果x是邏輯表示,那么v是邏輯矩陣。輸出向量v包含通過評估x表示獲得的邏輯矩陣的非零元素。
matlab調(diào)用c語言?
如果我有一個(gè)用C語言寫的函數(shù),實(shí)現(xiàn)了一個(gè)函數(shù),比如一個(gè)簡單的函數(shù):
doubleadd(doublex,doubley){
returnxy;
}
現(xiàn)在我想在Matlab中使用它,比如輸入:
aadd(1.1,2.2)
3.3000
要達(dá)到以上效果,應(yīng)該怎么做?
解決方法之一是使用MEX文件,使得調(diào)用C函數(shù),調(diào)用Matlab。的內(nèi)置函數(shù)一樣方便。MEX文件由原C代碼和MEX文件的特殊接口函數(shù)編譯而成。
可以理解為MEX文件實(shí)現(xiàn)了一個(gè)接口,通過特定的接口將Matlab中調(diào)用函數(shù)時(shí)輸入的自變量轉(zhuǎn)換成C函數(shù),得到的結(jié)果通過這個(gè)接口傳回Matlab。這個(gè)特定接口的操作包含在mexFunction函數(shù)中,由用戶具體設(shè)置。
所以現(xiàn)在我們需要寫一個(gè)包含add和mexFunction的C文件。Matlab調(diào)用函數(shù),將自變量(上例中的1.1和2.2)傳遞給mexFunction的一個(gè)參數(shù)。mexFunction傳遞要添加的值,并將獲得的結(jié)果返回給mexFunction的另一個(gè)參數(shù)。通過此參數(shù)調(diào)用Matlab語句中的函數(shù)時(shí),Matlab給出輸出值(上例中的A)。
例如,已經(jīng)編寫了c文件并命名為add.c,然后在Matlab中輸入:
mexadd.c
可以將add.c編譯成MEX文件(編譯器設(shè)置使用命令mex-setup)。在Windows中,MEX文件類型是mexw32,也就是現(xiàn)在我們得到的文件。現(xiàn)在,我們可以像調(diào)用M函數(shù)一樣調(diào)用MEX文件,就像上面提到的例子一樣。所以通過MEX文件,使用C函數(shù)和使用M函數(shù)是一樣的。
現(xiàn)在讓我們讓我們來談?wù)勅绾尉帉憁exFunction。
MexFunction定義為:
voidmexFunction(
intnlhs,
mxArray*plhs[],
intnrhs,
constmxArray*prhs[]){
}
可以看到,mexFunction沒有返回值。它不是通過返回值,而是通過給參數(shù)plhs賦值,將結(jié)果發(fā)送回Matlab。mexFunction的四個(gè)參數(shù)都是Matlab調(diào)用MEX文件時(shí)需要解釋的具體信息。例如,當(dāng)像這樣調(diào)用函數(shù)時(shí):
b1.1c2.2
aadd(b,c)
mexFunction的四個(gè)參數(shù)表示:
Nlhs1,表示調(diào)用語句的lhs-lefthandside上有一個(gè)變量,即a。
Nrhs2,這意味著調(diào)用語句的rhs-righthandside有兩個(gè)自變量,分別是B和c。
Plhs是一個(gè)數(shù)組,指針指向數(shù)據(jù)類型mxArray。因?yàn)樽笫诌呏挥幸粋€(gè)變量,也就是數(shù)組只有一個(gè)指針,plhs[0]指向的結(jié)果會賦給a。
Prhs和plhs類似,因?yàn)橛疫呌袃蓚€(gè)獨(dú)立變量,也就是數(shù)組有兩個(gè)指針,prhs[0]指向B,prhs[1]指向c。請注意,prhs是一個(gè)指向const的指針數(shù)組,也就是說,您不能更改它所指向的內(nèi)容。
因?yàn)镸atlab最基本的單元是數(shù)組,不管什么類型,比如doublearray,cellarray,structarray……...所以A,B,C都是數(shù)組,b1.1是1x1doublearray。在c語言中,Matlab的數(shù)組用mxArray類型表示。所以不難理解為什么plhs和prhs都是指向mxArray類型的指針數(shù)組。
完整的add.c如下所示:
//add.c
#includemex.h//使用mex文件必須包含的頭文件。
//C函數(shù)來執(zhí)行特定的工作
doubleadd(doublex,doubley){
returnxy;
}
//MEX文件接口函數(shù)
voidmexFunction(
intnlhs,
mxArray*plhs[],
intnrhs,
constmxArray*prhs[]){
雙*a;
doubleb,c;
plhs[0]mxCreateDoubleMatrix(1,1,MXreal);
amxGetPr(plhs[0]);
b*(mxGetPr(prhs[0]);
c*(mxGetPr(prhs[1]);
*aadd(b,c);
}
mexFunction的內(nèi)容是什么意思?我們知道如果函數(shù)被這樣調(diào)用:
outputadd(1.1,2.2);
當(dāng)不涉及具體計(jì)算時(shí),產(chǎn)出的價(jià)值是未知和未分配的。所以在具體的程序中,我們構(gòu)建一個(gè)1x1的實(shí)雙矩陣(使用mxCreateDoubleMatrix函數(shù),該函數(shù)返回一個(gè)指向新創(chuàng)建的mxArray的指針),然后讓plhs[0]指向它。然后使指針指向plhs[0]指向的mxArray的第一個(gè)元素(使用mxGetPr函數(shù)返回指向mxArray第一個(gè)元素的指針)。同樣,我們把prhs[0]和prhs[1]所指向的元素(也就是1.1和2.2)取出來,賦給B和c,這樣我們就可以把B和c作為獨(dú)立變量傳遞給函數(shù)add,得到的結(jié)果賦給指針A所指向的mxArray中的元素,因?yàn)锳是指向plhs[0]所指向的mxArray的元素,所以最后輸出的時(shí)候,plhs[0]所指向的mxArray被賦給output,output就是計(jì)算的結(jié)果。
上面說的很多東西都是點(diǎn)這里點(diǎn)那里,還有mxArray,新手肯定會暈。我對不起,要理解這些亂七八糟的關(guān)系,我們必須多看多練。
其實(shí)mexFunction沒這么簡單。我們需要測試用戶輸入自變量的數(shù)量和類型,以確保。
輸入是正確的。例如,在add函數(shù)的示例中,用戶輸入chararray是錯(cuò)誤的。
從上面的描述我們可以得出結(jié)論,MEX文件實(shí)現(xiàn)了一個(gè)接口,將C語言中的計(jì)算結(jié)果恰當(dāng)?shù)胤祷亟oMatlab。當(dāng)我們有一個(gè)用C語言編寫的大程序時(shí),我們不會。;不需要在Matlab中重寫,只需寫一個(gè)接口,使它成為一個(gè)MEX文件。另外,Matlab程序中的一些計(jì)算瓶頸(如循環(huán))可以通過MEX文件用C語言實(shí)現(xiàn),提高計(jì)算速度。