wolffd@0: /* C mex version of subv2ind*/ wolffd@0: /* 2 inputs, 1 output */ wolffd@0: /* siz, subv */ wolffd@0: /* ndx */ wolffd@0: #include "mex.h" wolffd@0: wolffd@0: void mexFunction(int nlhs, mxArray *plhs[], int nrhs, const mxArray *prhs[]){ wolffd@0: int i, j, k, nCol, nRow, binary, temp; wolffd@0: double *pSize, *pSubv, *pr; wolffd@0: int *cumprod; wolffd@0: wolffd@0: pSize = mxGetPr(prhs[0]); wolffd@0: pSubv = mxGetPr(prhs[1]); wolffd@0: nCol = mxGetNumberOfElements(prhs[0]); wolffd@0: nRow = mxGetM(prhs[1]); wolffd@0: wolffd@0: wolffd@0: if(mxIsEmpty(prhs[1])){ wolffd@0: plhs[0] = mxCreateDoubleMatrix(0, 0, mxREAL); wolffd@0: return; wolffd@0: } wolffd@0: wolffd@0: if(mxIsEmpty(prhs[0])){ wolffd@0: plhs[0] = mxCreateDoubleMatrix(1, 1, mxREAL); wolffd@0: *mxGetPr(plhs[0]) = 1; wolffd@0: return; wolffd@0: } wolffd@0: wolffd@0: binary = 2; wolffd@0: for (i = 0; i < nCol; i++){ wolffd@0: if (pSize[i] > 2.0){ wolffd@0: binary = 0; wolffd@0: break; wolffd@0: } wolffd@0: else if(pSize[i] == 1.0){ wolffd@0: binary = 1; wolffd@0: } wolffd@0: } wolffd@0: wolffd@0: plhs[0] = mxCreateDoubleMatrix(nRow, 1, mxREAL); wolffd@0: pr = mxGetPr(plhs[0]); wolffd@0: for(i=0; i