如下为本人亲证代码:
一:
编译器的安装与配置(环境不同,显示结果不同)
要使用MATLAB编译器,用户计算机上应用事先安装与MATLAB适配的以下任何一种ANSI C/C++编译器:
5.0、6.0版的MicroSoft Visual C++(MSVC)
5.0、5.2、5.3、5.4、5.5版的Borland C++
LCC(由MATLAB自带,只能用来产生MEX文件)
下面是安装与配置MATLAB编译器应用程序MEX的设置的步骤:
(1)在MATLAB命令窗口中运行mex –setup,出现下列提示:
Please choose your compiler for building external interface (MEX) files:
Would you like mex to locate installed compilers [y]/n?
(2)选择y,MATLAB将自动搜索计算机上已安装的外部编译器的类型、版本及所在路径,并列出来让用户选择:
Select a compiler:
[1] Borland C++Builder version 6.0 in C:\Program Files\Borland
[2] Digital Visual Fortran version 6.0 in C:\Program Files\Microsoft Visual Studio
[3] Lcc C version 2.4 in D:\MATLAB6P5P1\sys\lcc
[4] Microsoft Visual C/C++ version 6.0 in C:\Program Files\Microsoft Visual Studio
[0] None
Compiler:
(3)选择其中一种(在这里选择了3),MATLAB让用户进行确认:
Please verify your choices:
Compiler: Lcc C 2.4
Location: D:\MATLAB6P5P1\sys\lcc
Are these correct?([y]/n):
(4)选择y,结束MATLAB编译器的配置。
二在matlab当前目录下新建 add.c文件。输入
#include "mex.h" //使用MEX文件必须包含的头文件 //mex 通过 //a=add(b,c) double add(double x,double y) { return x+y; } //MEX文件接口函数 void mexFunction(int nlhs,mxArray *plhs[],int nrhs,const mxArray *prhs[]) { //步骤一:声明 // 源文件名后缀为.c时,所有变量声明必须一次性完成,且放在最前面, 否则mex编译错误 // 源文件名后缀为.cpp时,没有上面的问题,...- -|| double b,c; double *a; //步骤二:操作输入数据 //对输入数据进行操作,根据需要选择这几个函数mxGetPr指针指向参数的数据地址、 mxGetM 、 mxGetN 得到矩阵数据的行和列 (返回整数)。 b=*(mxGetPr(prhs[0]));//*代表取地址的内容 c=*(mxGetPr(prhs[1])); //步骤三:操作输出数据, //对于输出数据,需要首先用专门的mex函数分配内存空间 plhs[0] = mxCreateDoubleMatrix(1, 1, mxREAL); //同输入数据一样,要对输出数据操作,我们也需要一个指向数据的指针变量 a=mxGetPr(plhs[0]); //步骤四:调用add *a=add(b,c); }
三、C文件已写好,名为add.c。那么在Matlab中,输入:
>> mex add.c
就能把add.c编译为MEX文件(编译器的设置使用指令mex -setup),在Windows多出MEX文件
>> output = add(1.1,5)
五、得到输出结果
output =
6.1000
案例二:
在matlab中建立EstabHibert.cpp的文件,并插入如下代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
|
//Matlab以MEX方式调用C代码示例二 //功能:建立一个n*n的Hibert
矩阵 ,n存放输入值,y存放输出的矩阵 //
【例1】用m文件建立一个1000×1000的Hilbert矩阵代码如下。 // //
tic // //
m=1000; // //
n=1000; // //
a=zeros(m,n); // //
for i=1:1000 // //
for j=1:1000 // //
a(i,j)=1/(i+j); // //
end // //
end // //
toc #include
"mex.h" //计算过程,该过程包含了MEX文件实现计算功能的代码,是标准的C语言子程序。 void hilb( double *y, int n) { int i,j; for (i=0;i<n;i++){ for (j=0;j<n;j++){ *(y+j+i*n)=1/(( double )i+( double )j+2); } } } //接口过程 void mexFunction( int nlhs,mxArray
*plhs[], int nrhs, const mxArray
*prhs[]) { //步骤一:声明 //
源文件名后缀为.c时,所有变量声明必须一次性完成,且放在最前面, 否则mex编译错误 //
源文件名后缀为.cpp时,没有上面的问题,...- -|| //double
x,*y; //
int n; double *
y; int n; //检测输入、输出参数个数和类型的正确性 if (nrhs!=1) mexErrMsgTxt( "One
inputs required." ); if (nlhs!=1) mexErrMsgTxt( "One
output required." ); if (!mxIsDouble(prhs[0])||mxGetN(prhs[0])*mxGetM(prhs[0])!=1) mexErrMsgTxt( "input
must be scalars" ); //scalars
代表标量,double型是标量的一种哦 n=mxGetScalar(prhs[0]); plhs[0]=mxCreateDoubleMatrix(n,n,mxREAL); //
n=mxGetM(plhs[0]); //get rows y=mxGetPr(plhs[0]); hilb(y,n); } |
mex EstabHibert.cpp
a= EstabHibert(1000);