comparison Problems/private/mexutils.c @ 15:51b76c31c93d

(none)
author idamnjanovic
date Thu, 25 Mar 2010 14:05:27 +0000
parents
children
comparison
equal deleted inserted replaced
14:a0571bf2ff54 15:51b76c31c93d
1 /**************************************************************************
2 *
3 * File name: mexutils.c
4 *
5 * Ron Rubinstein
6 * Computer Science Department
7 * Technion, Haifa 32000 Israel
8 * ronrubin@cs
9 *
10 * Last Updated: 15.8.2009
11 *
12 *************************************************************************/
13
14 #include "mexutils.h"
15 #include <math.h>
16
17
18
19 /* verify that the mxArray contains a double matrix */
20
21 void checkmatrix(const mxArray *param, char *fname, char *pname)
22 {
23 char errmsg[100];
24 sprintf(errmsg, "%.15s requires that %.25s be a double matrix.", fname, pname);
25 if (!mxIsDouble(param) || mxIsComplex(param) || mxGetNumberOfDimensions(param)>2) {
26 mexErrMsgTxt(errmsg);
27 }
28 }
29
30
31 /* verify that the mxArray contains a 1-D double vector */
32
33 void checkvector(const mxArray *param, char *fname, char *pname)
34 {
35 char errmsg[100];
36 sprintf(errmsg, "%.15s requires that %.25s be a double vector.", fname, pname);
37 if (!mxIsDouble(param) || mxIsComplex(param) || mxGetNumberOfDimensions(param)>2 || (mxGetM(param)!=1 && mxGetN(param)!=1)) {
38 mexErrMsgTxt(errmsg);
39 }
40 }
41
42
43 /* verify that the mxArray contains a double scalar */
44
45 void checkscalar(const mxArray *param, char *fname, char *pname)
46 {
47 char errmsg[100];
48 sprintf(errmsg, "%.15s requires that %.25s be a double scalar.", fname, pname);
49 if (!mxIsDouble(param) || mxIsComplex(param) || mxGetNumberOfDimensions(param)>2 ||
50 mxGetM(param)!=1 || mxGetN(param)!=1)
51 {
52 mexErrMsgTxt(errmsg);
53 }
54 }
55
56
57 /* verify that the mxArray contains a sparse matrix */
58
59 void checksparse(const mxArray *param, char *fname, char *pname)
60 {
61 char errmsg[100];
62 sprintf(errmsg, "%.15s requires that %.25s be sparse.", fname, pname);
63 if (!mxIsSparse(param)) {
64 mexErrMsgTxt(errmsg);
65 }
66 }
67
68
69 /* verify that the mxArray contains a 1-dimensional cell array */
70
71 void checkcell_1d(const mxArray *param, char *fname, char *pname)
72 {
73 char errmsg[100];
74 sprintf(errmsg, "%.15s requires that %.25s be a 1-D cell array.", fname, pname);
75 if (!mxIsCell(param) || mxGetNumberOfDimensions(param)>2 || (mxGetM(param)!=1 && mxGetN(param)!=1)) {
76 mexErrMsgTxt(errmsg);
77 }
78 }
79