mex_eigens.c
来自「本人收集的一些有关matlab的代码程序设计 也不知道改选什么分类」· C语言 代码 · 共 22 行
C
22 行
#include "matrix.h"
/*Function mex_eigens*/
void mexFunction( int nlhs, mxArray *plhs[],
int nrhs, const mxArray *prhs[])
{
mxArray *xp[1], *lhs[2];
int n,m, i;
double *A, *pA, *pB1, *pB2, *pB3, *pA1;
if (nrhs!=2) mexErrMsgTxt("Wrong number of input arguments!");
if (nlhs>3) mexErrMsgTxt("Too many output arguments!");
m=mxGetM(prhs[0]); n=mxGetN(prhs[0]);
mexCallMATLAB(1,xp,2,prhs,"mpower");
pA1=mxGetPr(xp[0]);
plhs[0]=mxCreateDoubleMatrix(m,n,mxREAL); pB1=mxGetPr(plhs[0]);
plhs[1]=mxCreateDoubleMatrix(m,1,mxREAL); pB2=mxGetPr(plhs[1]);
plhs[2]=mxCreateDoubleMatrix(m,n,mxREAL); pB3=mxGetPr(plhs[2]);
for (i=0; i<m*n; i++) pB1[i]=pA1[i];
mexCallMATLAB(2,lhs,1,xp,"eig");
pA1=mxGetPr(lhs[0]); for (i=0; i<m*n; i++) pB3[i]=pA1[i];
pA1=mxGetPr(lhs[1]); for (i=0; i<m; i++) pB2[i]=pA1[i+i*m];
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?