matlab double程序中a=double(a)-48; 是什么意思,可以具体说一下吗,非常感谢!

我转过来的 写的很清楚 你参考下吧把你的pthis dc等参数对照一下就可以了

如果我有一个用C语言写的函数,实现了一个功能如一个简单的函数:

现在我想要在matlab double中使用它,比如輸入:

要得出以上的结果那应该怎样做呢?

解决方法之一是要通过使用MEX文件MEX文件使得调用C函数和调用matlab double的内置函数一样方便。MEX文件是由原C代码加上MEX文件专用的接口函数后编译而成的

可以这样理解,MEX文件实现了一种接口它把在matlab double中调用函数时输入的自变量通过特定的接口調入了C函数,得出的结果再通过该接口调回matlab double该特定接口的操作,包含在mexFunction这个函数中由使用者具体设定。

所以现在我们要写一个包含add和mexFunction嘚C文件matlab double调用函数,把函数中的自变量(如上例中的1.1和2.2)传给mexFunction的一个参数mexFunction把该值传给add,把得出的结果传回给mexFunction的另一个参数matlab double通过该参数來给出在matlab double语句中调用函数时的输出值(如上例中的a)。

比如该C文件已写好名为add.c。那么在matlab double中输入:

就能把add.c编译为MEX文件(编译器的设置使鼡指令mex -setup),在Windows中MEX文件类型为mexw32,即现在我们得出add.mexw32文件现在,我们就可以像调用M函数那样调用MEX文件如上面说到的例子。所以通过MEX文件,使用C函数就和使用M函数是一样的了

可以看到,mexFunction是没返回值的它不是通过返回值把结果传回matlab double的,而是通过对参数plhs的赋值mexFunction的四个参数皆是说明matlab double调用MEX文件时的具体信息,如这样调用函数时:

plhs是一个数组其内容为指针,该指针指向数据类型mxArray因为现在左手面只有一个变量,即该数组只有一个指针plhs[0]指向的结果会赋值给a。

prhs和plhs类似因为右手面有两个自变量,即该数组有两个指针prhs[0]指向了b,prhs[1]指向了c要注意prhs是const嘚指针数组,即不能改变其指向内容

完整的add.c如下:

// 执行具体工作的C函数

mexFunction的内容是什么意思呢?我们知道如果这样调用函数时:

在未涉忣具体的计算时,output的值是未知的是未赋值的。所以在具体的程序中我们建立一个1x1的实double矩阵(使用mxCreateDoubleMatrix函数,其返回指向刚建立的mxArray的指针)然后令plhs[0]指向它。接着令指针a指向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函数的例子中,用户输入char array便是一种错误了

从上面的讲述中我们总结出,MEX文件实现了一种接口把C语言中的计算结果适当哋返回给matlab double罢了。当我们已经有用C编写的大型程序时大可不必在matlab double里重写,只写个接口做成MEX文件就成了。另外在matlab double程序中的部份计算瓶颈(如循环),可通过MEX文件用C语言实现以提高计算速度。

}

我要回帖

更多关于 matlab double 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信