annotate DL/RLS-DLA/private/im2colstep.c @ 63:e08af264ef93

(none)
author idamnjanovic
date Tue, 15 Mar 2011 12:23:35 +0000
parents ad36f80e2ccf
children
rev   line source
idamnjanovic@60 1 /**************************************************************************
idamnjanovic@60 2 *
idamnjanovic@60 3 * File name: im2colstep.c
idamnjanovic@60 4 *
idamnjanovic@60 5 * Ron Rubinstein
idamnjanovic@60 6 * Computer Science Department
idamnjanovic@60 7 * Technion, Haifa 32000 Israel
idamnjanovic@60 8 * ronrubin@cs
idamnjanovic@60 9 *
idamnjanovic@60 10 * Last Updated: 31.8.2009
idamnjanovic@60 11 *
idamnjanovic@60 12 *************************************************************************/
idamnjanovic@60 13
idamnjanovic@60 14
idamnjanovic@60 15 #include "mex.h"
idamnjanovic@60 16 #include <string.h>
idamnjanovic@60 17
idamnjanovic@60 18
idamnjanovic@60 19 /* Input Arguments */
idamnjanovic@60 20
idamnjanovic@60 21 #define X_IN prhs[0]
idamnjanovic@60 22 #define SZ_IN prhs[1]
idamnjanovic@60 23 #define S_IN prhs[2]
idamnjanovic@60 24
idamnjanovic@60 25
idamnjanovic@60 26 /* Output Arguments */
idamnjanovic@60 27
idamnjanovic@60 28 #define B_OUT plhs[0]
idamnjanovic@60 29
idamnjanovic@60 30
idamnjanovic@60 31 void mexFunction(int nlhs, mxArray *plhs[],
idamnjanovic@60 32 int nrhs, const mxArray*prhs[])
idamnjanovic@60 33
idamnjanovic@60 34 {
idamnjanovic@60 35 double *x, *b, *s;
idamnjanovic@60 36 mwSize sz[3], stepsize[3], n[3], ndims;
idamnjanovic@60 37 mwIndex i, j, k, l, m, blocknum;
idamnjanovic@60 38
idamnjanovic@60 39
idamnjanovic@60 40 /* Check for proper number of arguments */
idamnjanovic@60 41
idamnjanovic@60 42 if (nrhs < 2 || nrhs > 3) {
idamnjanovic@60 43 mexErrMsgTxt("Invalid number of input arguments.");
idamnjanovic@60 44 } else if (nlhs > 1) {
idamnjanovic@60 45 mexErrMsgTxt("Too many output arguments.");
idamnjanovic@60 46 }
idamnjanovic@60 47
idamnjanovic@60 48
idamnjanovic@60 49 /* Check the the input dimensions */
idamnjanovic@60 50
idamnjanovic@60 51 ndims = mxGetNumberOfDimensions(X_IN);
idamnjanovic@60 52
idamnjanovic@60 53 if (!mxIsDouble(X_IN) || mxIsComplex(X_IN) || ndims>3) {
idamnjanovic@60 54 mexErrMsgTxt("X should be a 2-D or 3-D double matrix.");
idamnjanovic@60 55 }
idamnjanovic@60 56 if (!mxIsDouble(SZ_IN) || mxIsComplex(SZ_IN) || mxGetNumberOfDimensions(SZ_IN)>2 || mxGetM(SZ_IN)*mxGetN(SZ_IN)!=ndims) {
idamnjanovic@60 57 mexErrMsgTxt("Invalid block size.");
idamnjanovic@60 58 }
idamnjanovic@60 59 if (nrhs == 3) {
idamnjanovic@60 60 if (!mxIsDouble(S_IN) || mxIsComplex(S_IN) || mxGetNumberOfDimensions(S_IN)>2 || mxGetM(S_IN)*mxGetN(S_IN)!=ndims) {
idamnjanovic@60 61 mexErrMsgTxt("Invalid step size.");
idamnjanovic@60 62 }
idamnjanovic@60 63 }
idamnjanovic@60 64
idamnjanovic@60 65
idamnjanovic@60 66 /* Get parameters */
idamnjanovic@60 67
idamnjanovic@60 68 s = mxGetPr(SZ_IN);
idamnjanovic@60 69 if (s[0]<1 || s[1]<1 || (ndims==3 && s[2]<1)) {
idamnjanovic@60 70 mexErrMsgTxt("Invalid block size.");
idamnjanovic@60 71 }
idamnjanovic@60 72 sz[0] = (mwSize)(s[0] + 0.01);
idamnjanovic@60 73 sz[1] = (mwSize)(s[1] + 0.01);
idamnjanovic@60 74 sz[2] = ndims==3 ? (mwSize)(s[2] + 0.01) : 1;
idamnjanovic@60 75
idamnjanovic@60 76 if (nrhs == 3) {
idamnjanovic@60 77 s = mxGetPr(S_IN);
idamnjanovic@60 78 if (s[0]<1 || s[1]<1 || (ndims==3 && s[2]<1)) {
idamnjanovic@60 79 mexErrMsgTxt("Invalid step size.");
idamnjanovic@60 80 }
idamnjanovic@60 81 stepsize[0] = (mwSize)(s[0] + 0.01);
idamnjanovic@60 82 stepsize[1] = (mwSize)(s[1] + 0.01);
idamnjanovic@60 83 stepsize[2] = ndims==3 ? (mwSize)(s[2] + 0.01) : 1;
idamnjanovic@60 84 }
idamnjanovic@60 85 else {
idamnjanovic@60 86 stepsize[0] = stepsize[1] = stepsize[2] = 1;
idamnjanovic@60 87 }
idamnjanovic@60 88
idamnjanovic@60 89 n[0] = (mxGetDimensions(X_IN))[0];
idamnjanovic@60 90 n[1] = (mxGetDimensions(X_IN))[1];
idamnjanovic@60 91 n[2] = ndims==3 ? (mxGetDimensions(X_IN))[2] : 1;
idamnjanovic@60 92
idamnjanovic@60 93 if (n[0]<sz[0] || n[1]<sz[1] || (ndims==3 && n[2]<sz[2])) {
idamnjanovic@60 94 mexErrMsgTxt("Block size too large.");
idamnjanovic@60 95 }
idamnjanovic@60 96
idamnjanovic@60 97
idamnjanovic@60 98 /* Create a matrix for the return argument */
idamnjanovic@60 99
idamnjanovic@60 100 B_OUT = mxCreateDoubleMatrix(sz[0]*sz[1]*sz[2], ((n[0]-sz[0])/stepsize[0]+1)*((n[1]-sz[1])/stepsize[1]+1)*((n[2]-sz[2])/stepsize[2]+1), mxREAL);
idamnjanovic@60 101
idamnjanovic@60 102
idamnjanovic@60 103 /* Assign pointers */
idamnjanovic@60 104
idamnjanovic@60 105 x = mxGetPr(X_IN);
idamnjanovic@60 106 b = mxGetPr(B_OUT);
idamnjanovic@60 107
idamnjanovic@60 108
idamnjanovic@60 109 /* Do the actual computation */
idamnjanovic@60 110
idamnjanovic@60 111 blocknum = 0;
idamnjanovic@60 112
idamnjanovic@60 113 /* iterate over all blocks */
idamnjanovic@60 114 for (k=0; k<=n[2]-sz[2]; k+=stepsize[2]) {
idamnjanovic@60 115 for (j=0; j<=n[1]-sz[1]; j+=stepsize[1]) {
idamnjanovic@60 116 for (i=0; i<=n[0]-sz[0]; i+=stepsize[0]) {
idamnjanovic@60 117
idamnjanovic@60 118 /* copy single block */
idamnjanovic@60 119 for (m=0; m<sz[2]; m++) {
idamnjanovic@60 120 for (l=0; l<sz[1]; l++) {
idamnjanovic@60 121 memcpy(b + blocknum*sz[0]*sz[1]*sz[2] + m*sz[0]*sz[1] + l*sz[0], x+(k+m)*n[0]*n[1]+(j+l)*n[0]+i, sz[0]*sizeof(double));
idamnjanovic@60 122 }
idamnjanovic@60 123 }
idamnjanovic@60 124 blocknum++;
idamnjanovic@60 125
idamnjanovic@60 126 }
idamnjanovic@60 127 }
idamnjanovic@60 128 }
idamnjanovic@60 129
idamnjanovic@60 130 return;
idamnjanovic@60 131 }