然后mex文件调用头文件 能够头文件和源文件分开写 matlab调用c或c 源程序 (然后txt)
本文目录导航:
matlab调用c或c++源程序,能够头文件和源文件分开写,然后mex文件调用头文件
我转过来的 写的很清楚 你参考下吧,把你的pthis dc等参数对照一下就可以了如果我有一个用C语言写的函数,实现了一个功能,如一个简单的函数:double add(double x, double y) { return x + y;}现在我想要在Matlab中使用它,比如输入:>> a = add(1.1, 2.2) 3.3000要得出以上的结果,那应该怎样做呢?解决方法之一是要通过使用MEX文件,MEX文件使得调用C函数和调用Matlab的内置函数一样方便。
MEX文件是由原C代码加上MEX文件专用的接口函数后编译而成的。
可以这样理解,MEX文件实现了一种接口,它把在Matlab中调用函数时输入的自变量通过特定的接口调入了C函数,得出的结果再通过该接口调回Matlab。
该特定接口的操作,包含在mexFunction这个函数中,由使用者具体设定。
所以现在我们要写一个包含add和mexFunction的C文件,Matlab调用函数,把函数中的自变量(如上例中的1.1和2.2)传给mexFunction的一个参数,mexFunction把该值传给add,把得出的结果传回给mexFunction的另一个参数,Matlab通过该参数来给出在Matlab语句中调用函数时的输出值(如上例中的a)。
比如该C文件已写好,名为add.c。
那么在Matlab中,输入:>> mex add.c就能把add.c编译为MEX文件(编译器的设置使用指令mex -setup),在Windows中,MEX文件类型为mexw32,即现在我们得出32文件。
现在,我们就可以像调用M函数那样调用MEX文件,如上面说到的例子。
所以,通过MEX文件,使用C函数就和使用M函数是一样的了。
我们现在来说mexFunction怎样写。
mexFunction的定义为:void mexFunction( int nlhs, mxArray *plhs[], int nrhs, const mxArray *prhs[]) {}可以看到,mexFunction是没返回值的,它不是通过返回值把结果传回Matlab的,而是通过对参数plhs的赋值。
mexFunction的四个参数皆是说明Matlab调用MEX文件时的具体信息,如这样调用函数时:>> b = 1.1; c = 2.2;>> a = add(b, c)mexFunction四个参数的意思为:nlhs = 1,说明调用语句左手面(lhs-left hand side)有一个变量,即a。
nrhs = 2,说明调用语句右手面(rhs-right hand side)有两个自变量,即b和c。
plhs是一个数组,其内容为指针,该指针指向数据类型mxArray。
因为现在左手面只有一个变量,即该数组只有一个指针,plhs[0]指向的结果会赋值给a。
prhs和plhs类似,因为右手面有两个自变量,即该数组有两个指针,prhs[0]指向了b,prhs[1]指向了c。
要注意prhs是const的指针数组,即不能改变其指向内容。
因为Matlab最基本的单元为array,无论是什么类型也好,如有double array、 cell array、 struct array……所以a,b,c都是array,b = 1.1便是一个1x1的double array。
而在C语言中,Matlab的array使用mxArray类型来表示。
所以就不难明白为什么plhs和prhs都是指向mxArray类型的指针数组。
完整的add.c如下:// add.c#include mex.h // 使用MEX文件必须包含的头文件// 执行具体工作的C函数double add(double x, double y) { return x + y;}// MEX文件接口函数void mexFunction( int nlhs, mxArray *plhs[], int nrhs, const mxArray *prhs[]) { double *a; double b, c; plhs[0] = mxCreateDoubleMatrix(1, 1, mxREAL); a = mxGetPr(plhs[0]); b = *(mxGetPr(prhs[0])); c = *(mxGetPr(prhs[1])); *a = add(b, c);}mexFunction的内容是什么意思呢?我们知道,如果这样调用函数时:>> output = add(1.1, 2.2);在未涉及具体的计算时,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罢了。
当我们已经有用C编写的大型程序时,大可不必在Matlab里重写,只写个接口,做成MEX文件就成了。
另外,在Matlab程序中的部份计算瓶颈(如循环),可通过MEX文件用C语言实现,以提高计算速度。

C语言调用matlab函数
matlab中调用c语言函数:#include mex.h//头文件必须包含 mexSimpleDemo(double *y,double a,double b); //C语言算法程序声明,在最后调用时,第一// 个参数是返回结果//c语言到matlab变换,以mexFunction命名void mexFunction(int nlhs,mxArray *plhs[],int nrhs,const mxArray *prhs[]){double *y;double m,n;//获取输入变量的数值大小m=mxGetScalar(prhs[0]);n=mxGetScalar(prhs[1]);//获取输出变量的指针plhs[0]=mxCreateDoubleMatrix(1,1,mxREAL);y=mxGetPr(plhs[0]); //调用子函数mexSimpleDemo(y,m,n);}//C语言函数double mexSimpleDemo(double *y,double a,double b){return *y=(a>b)?a:b;}
matlab传换为C语言
方法如下:1)matlab要把n++写成n=n+12)printf在matlab中相近功能的命令有disp(),!echo,和sprintf(),其中最后一种最接近c中的printf。
有关具体用法,你可以在matlab主命令窗口输入:helpsprintf来查阅这个命令的帮助和例子。
比如:sprintf(thearrayis%dx%d.,2,3),其输出是thearrayis2x33)头文件的include是不用的,因为matlab的常用库里是包含了这些函数的。
顺带一提,matlab里对函数的定义,开头要用functionxxx。
继续浏览有关 源程序能够头文件和源文件分开写matlab调用c或c然后mex文件调用头文件 的文章
相关文章
- c语言头文件怎么写呀 (c语言头文件后缀名)
- 单片机自己写头文件应该注意什么 (单片机自己写头文件函数声明)
- created keil不能编译了 not 提示Target (create的中文翻译)
- stdio.h> < 含义 include (stdio.h的含义)
- 两个头文件互相包含 怎样实现 (两个头文件互相引用)
- c语言中如何定义 添加头文件 (c语言中如何判断一个数是素数)
- linux下编写c include的那些头文件在什么地方 (linux消息队列)
- C (cba赛程)
- 在头文件之前包含其他头文件与在源文件前包含头文件有什么区别 (使用头文件)
- 一个头文件可以包含另一头文件吗 (一个头文件可以被多个实现文件包含)
猜你喜欢
-
使用Java语言编写的源程序保存时的文件扩展名解析
使用Java语言编写的源程序保存时的文件扩展名是什么 用Java语言编写的源程序,保存时文件扩展名是“.java”,经过编译后,会生成以“.class”为后缀的文件...

请小编喝杯咖啡吧!