comparison Problems/private/ompmex.c @ 51:217a33ac374e

(none)
author idamnjanovic
date Mon, 14 Mar 2011 16:52:27 +0000
parents
children
comparison
equal deleted inserted replaced
50:d5155eaa3f68 51:217a33ac374e
1 /**************************************************************************
2 *
3 * File name: ompmex.c
4 *
5 * Ron Rubinstein
6 * Computer Science Department
7 * Technion, Haifa 32000 Israel
8 * ronrubin@cs
9 *
10 * Last Updated: 18.8.2009
11 *
12 *************************************************************************/
13
14 #include "ompcore.h"
15 #include "omputils.h"
16 #include "mexutils.h"
17
18
19 /* Input Arguments */
20
21 #define IN_D prhs[0]
22 #define IN_X prhs[1]
23 #define IN_DtX prhs[2]
24 #define IN_G prhs[3]
25 #define IN_T prhs[4]
26 #define IN_SPARSE_G prhs[5]
27 #define IN_MSGDELTA prhs[6]
28 #define IN_PROFILE prhs[7]
29
30
31 /* Output Arguments */
32
33 #define GAMMA_OUT plhs[0]
34
35
36 /***************************************************************************************/
37
38
39 void mexFunction(int nlhs, mxArray *plhs[], int nrhs, const mxArray*prhs[])
40
41 {
42 double *D, *x, *DtX, *G, msgdelta;
43 int gmode, profile, T;
44 mwSize m, n, L; /* D is n x m , X is n x L, DtX is m x L */
45
46
47 /* check parameters */
48
49 checkmatrix(IN_D, "OMP", "D");
50 checkmatrix(IN_X, "OMP", "X");
51 checkmatrix(IN_DtX, "OMP", "DtX");
52 checkmatrix(IN_G, "OMP", "G");
53
54 checkscalar(IN_T, "OMP", "T");
55 checkscalar(IN_SPARSE_G, "OMP", "sparse_g");
56 checkscalar(IN_MSGDELTA, "OMP", "msgdelta");
57 checkscalar(IN_PROFILE, "OMP", "profile");
58
59
60 /* get parameters */
61
62 x = D = DtX = G = 0;
63
64 if (!mxIsEmpty(IN_D))
65 D = mxGetPr(IN_D);
66
67 if (!mxIsEmpty(IN_X))
68 x = mxGetPr(IN_X);
69
70 if (!mxIsEmpty(IN_DtX))
71 DtX = mxGetPr(IN_DtX);
72
73 if (!mxIsEmpty(IN_G))
74 G = mxGetPr(IN_G);
75
76 T = (int)(mxGetScalar(IN_T)+1e-2);
77 if ((int)(mxGetScalar(IN_SPARSE_G)+1e-2)) {
78 gmode = SPARSE_GAMMA;
79 }
80 else {
81 gmode = FULL_GAMMA;
82 }
83 msgdelta = mxGetScalar(IN_MSGDELTA);
84 profile = (int)(mxGetScalar(IN_PROFILE)+1e-2);
85
86
87 /* check sizes */
88
89 if (D && x) {
90 n = mxGetM(IN_D);
91 m = mxGetN(IN_D);
92 L = mxGetN(IN_X);
93
94 if (mxGetM(IN_X) != n) {
95 mexErrMsgTxt("D and X have incompatible sizes.");
96 }
97
98 if (G) {
99 if (mxGetN(IN_G)!=mxGetM(IN_G)) {
100 mexErrMsgTxt("G must be a square matrix.");
101 }
102 if (mxGetN(IN_G) != m) {
103 mexErrMsgTxt("D and G have incompatible sizes.");
104 }
105 }
106 }
107
108 else if (DtX) {
109 m = mxGetM(IN_DtX);
110 L = mxGetN(IN_DtX);
111
112 n = T; /* arbitrary - it is enough to assume signal length is T */
113
114 if (mxGetN(IN_G)!=mxGetM(IN_G)) {
115 mexErrMsgTxt("G must be a square matrix.");
116 }
117 if (mxGetN(IN_G) != m) {
118 mexErrMsgTxt("DtX and G have incompatible sizes.");
119 }
120 }
121
122 else {
123 mexErrMsgTxt("Either D and X, or DtX, must be specified.");
124 }
125
126
127 /* Do OMP! */
128
129 GAMMA_OUT = ompcore(D, x, DtX, 0, G, n, m, L, T, 0, gmode, profile, msgdelta, 0);
130
131 return;
132 }
133