[matlab]计算给定字符串的字母和数字的个数。
计算给定字符串中字母的个数:pr
一、功能:
查找非零元素的索引和值
二、相关函数语法:
ind查找(x)
indfind(x,k)
indfind(x,k,first)
indfind(x,k,last)
[行,列]查找(x,...)
[row,col,v]find(x...)
三。描述:
索引查找(x)
找出矩阵x中所有非零元素,并将这些元素的线性索引(按列)返回给向量索引。
如果x是行向量,那么index是行向量;否则,index是一个列向量。
如果x不包含非零元素或空矩阵,则index是空矩阵。
索引查找(x,k)或3。索引查找(x,k,first)。
查找不为0的前k个线性索引值。k必须是正数,但可以是任何数字类型。
索引查找(x,k,last)
求最后k个非零元素的线性索引值。
[行,列]查找(x,...)
返回矩阵x中非零元素的行和列的索引值。该语法在处理稀疏矩阵时特别有用。
如果x是n(n2)维矩阵,col包括列的线性索引。
[row,col,v]find(x...)
返回x中非零元素的列或行向量v,并返回行和列的索引值。如果x是逻辑表示,那么v是逻辑矩阵。输出向量v包含通过评估x表示获得的逻辑矩阵的非零元素。
如果我有一个用c语言写的函数,实现了一个函数,比如一个简单的函数:
doubleadd(doublex,doubley){
returnxy;
}
现在我想在matlab中使用它,比如输入:
aadd(1.1,2.2)
3.3000
要达到以上效果,应该怎么做?
解决方法之一是使用mex文件,使得调用c函数,调用matlab。的内置函数一样方便。mex文件由原c代码和mex文件的特殊接口函数编译而成。
可以理解为mex文件实现了一个接口,通过特定的接口将matlab中调用函数时输入的自变量转换成c函数,得到的结果通过这个接口传回matlab。这个特定接口的操作包含在mexfunction函数中,由用户具体设置。
所以现在我们需要写一个包含add和mexfunction的c文件。matlab调用函数,将自变量(上例中的1.1和2.2)传递给mexfunction的一个参数。mexfunction传递要添加的值,并将获得的结果返回给mexfunction的另一个参数。通过此参数调用matlab语句中的函数时,matlab给出输出值(上例中的a)。
例如,已经编写了c文件并命名为add.c,然后在matlab中输入:
mexadd.c
可以将add.c编译成mex文件(编译器设置使用命令mex-setup)。在windows中,mex文件类型是mexw32,也就是现在我们得到的文件。现在,我们可以像调用m函数一样调用mex文件,就像上面提到的例子一样。所以通过mex文件,使用c函数和使用m函数是一样的。
现在让我们让我们来谈谈如何编写mexfunction。
mexfunction定义为:
voidmexfunction(
intnlhs,
mxarray*plhs[],
intnrhs,
constmxarray*prhs[]){
}
可以看到,mexfunction没有返回值。它不是通过返回值,而是通过给参数plhs赋值,将结果发送回matlab。mexfunction的四个参数都是matlab调用mex文件时需要解释的具体信息。例如,当像这样调用函数时:
b1.1c2.2
aadd(b,c)
mexfunction的四个参数表示:
nlhs1,表示调用语句的lhs-lefthandside上有一个变量,即a。
nrhs2,这意味着调用语句的rhs-righthandside有两个自变量,分别是b和c。
plhs是一个数组,指针指向数据类型mxarray。因为左手边只有一个变量,也就是数组只有一个指针,plhs[0]指向的结果会赋给a。
prhs和plhs类似,因为右边有两个独立变量,也就是数组有两个指针,prhs[0]指向b,prhs[1]指向c。请注意,prhs是一个指向const的指针数组,也就是说,您不能更改它所指向的内容。
因为matlab最基本的单元是数组,不管什么类型,比如doublearray,cellarray,structarray……...所以a,b,c都是数组,b1.1是1x1doublearray。在c语言中,matlab的数组用mxarray类型表示。所以不难理解为什么plhs和prhs都是指向mxarray类型的指针数组。
完整的add.c如下所示:
//add.c
#includemex.h//使用mex文件必须包含的头文件。
//c函数来执行特定的工作
doubleadd(doublex,doubley){
returnxy;
}
//mex文件接口函数
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的内容是什么意思?我们知道如果函数被这样调用:
outputadd(1.1,2.2);
当不涉及具体计算时,产出的价值是未知和未分配的。所以在具体的程序中,我们构建一个1x1的实双矩阵(使用mxcreatedoublematrix函数,该函数返回一个指向新创建的mxarray的指针),然后让plhs[0]指向它。然后使指针指向plhs[0]指向的mxarray的第一个元素(使用mxgetpr函数返回指向mxarray第一个元素的指针)。同样,我们把prhs[0]和prhs[1]所指向的元素(也就是1.1和2.2)取出来,赋给b和c,这样我们就可以把b和c作为独立变量传递给函数add,得到的结果赋给指针a所指向的mxarray中的元素,因为a是指向plhs[0]所指向的mxarray的元素,所以最后输出的时候,plhs[0]所指向的mxarray被赋给output,output就是计算的结果。
上面说的很多东西都是点这里点那里,还有mxarray,新手肯定会晕。我对不起,要理解这些乱七八糟的关系,我们必须多看多练。
其实mexfunction没这么简单。我们需要测试用户输入自变量的数量和类型,以确保。
输入是正确的。例如,在add函数的示例中,用户输入chararray是错误的。
从上面的描述我们可以得出结论,mex文件实现了一个接口,将c语言中的计算结果恰当地返回给matlab。当我们有一个用c语言编写的大程序时,我们不会。;不需要在matlab中重写,只需写一个接口,使它成为一个mex文件。另外,matlab程序中的一些计算瓶颈(如循环)可以通过mex文件用c语言实现,提高计算速度。