/* Simple test of using initialized vs. uninitialized arrays. 
 * The uninitialized version runs nearly twice as fast.
 */
/*
mex -c mexutil.c
mex xones.c mexutil.obj
*/

#include "mexutil.h"

void mexFunction(int nlhs, mxArray *plhs[],
                 int nrhs, const mxArray *prhs[])
{
  int m,n,i,sz;
  double *p;
  if(nrhs != 2) mexErrMsgTxt("xones(m,n)");
  if(mxGetNumberOfElements(prhs[0]) != 1)
    mexErrMsgTxt("m is not scalar");
  if(mxGetNumberOfElements(prhs[1]) != 1)
    mexErrMsgTxt("n is not scalar");
  m = (int)*mxGetPr(prhs[0]);
  n = (int)*mxGetPr(prhs[1]);
  sz = m*n;
#if 0
  plhs[0] = mxCreateDoubleMatrix(m,n,mxREAL);
  p = (double*)mxGetPr(plhs[0]);
#else
  plhs[0] = mxCreateDoubleMatrixE(m,n,mxREAL);
  p = (double*)mxGetPr(plhs[0]);
#endif
  for(i=0;i<sz;i++) *p++ = 1;
}
