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