-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmexutil.c
executable file
·43 lines (40 loc) · 1.13 KB
/
mexutil.c
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
#include "mexutil.h"
/* Functions to create uninitialized arrays. */
mxArray *mxCreateNumericArrayE(int ndim, const int *dims,
mxClassID class, mxComplexity ComplexFlag)
{
mxArray *a;
int i, *dims1 = mxMalloc(ndim*sizeof(int));
size_t sz = 1;
for(i=0;i<ndim;i++) {
sz *= dims[i];
dims1[i] = 1;
}
a = mxCreateNumericArray(ndim,dims1,class,ComplexFlag);
sz *= mxGetElementSize(a);
mxSetDimensions(a, dims, ndim);
mxFree(dims1);
mxSetData(a, mxRealloc(mxGetData(a), sz));
if(ComplexFlag == mxCOMPLEX) {
mxSetPi(a, mxRealloc(mxGetPi(a),sz));
}
return a;
}
mxArray *mxCreateNumericMatrixE(int m, int n, mxClassID class,
mxComplexity ComplexFlag)
{
size_t sz = m*n*sizeof(double);
mxArray *a = mxCreateNumericMatrix(1, 1, class, ComplexFlag);
mxSetM(a,m);
mxSetN(a,n);
mxSetPr(a, mxRealloc(mxGetPr(a),sz));
if(ComplexFlag == mxCOMPLEX) {
mxSetPi(a, mxRealloc(mxGetPi(a),sz));
}
return a;
}
mxArray *mxCreateDoubleMatrixE(int m, int n,
mxComplexity ComplexFlag)
{
return mxCreateNumericMatrixE(m,n,mxDOUBLE_CLASS,ComplexFlag);
}