Exemplo n.º 1
0
/***********************************************************************
 *
 * HANDLE_NC_INQ_FORMAT:
 *
 * EXTERNL int
 * nc_inq_format(int ncid, int *formatp);
 **********************************************************************/
void handle_nc_inq_format ( int nlhs, mxArray *plhs[], int nrhs, const mxArray *prhs[], op *nc_op ) {

    int ncid, format, status;

    /*
     * Make sure that the inputs are the right type.
     * */
    check_numeric_argument_type ( prhs, nc_op->opname, 1 );

	status = nc_inq_format(ncid, &format);
    switch(format) {
        case NC_FORMAT_CLASSIC:
			plhs[0] = mxCreateString ( "FORMAT_CLASSIC" );
            break;

        case NC_FORMAT_64BIT:
			plhs[0] = mxCreateString ( "FORMAT_64BIT" );
            break;

        case NC_FORMAT_NETCDF4:
			plhs[0] = mxCreateString ( "FORMAT_NETCDF4" );
            break;

        case NC_FORMAT_NETCDF4_CLASSIC:
			plhs[0] = mxCreateString ( "FORMAT_NETCDF4_CLASSIC" );
            break;

    }
    plhs[1] = mexncCreateDoubleScalar ( status );

    return;
}
Exemplo n.º 2
0
/***********************************************************************
 *
 * HANDLE_NC_DEF_VAR_FILL:
 *
 * EXTERNL int
 * nc_def_var_fill(int ncid, int varid, int no_fill, const void *fill_value);
 **********************************************************************/
void handle_nc_def_var_fill ( int nlhs, mxArray *plhs[], int nrhs, const mxArray *prhs[], op *nc_op ) {

    int ncid, varid, no_fill;
    void *fill_value;
	
    /*
     * Pointer shortcut to matrix data.
     * */
    double *pr;

    int      status;

    /*
     * Make sure that the inputs are the right type.
     * */
    check_numeric_argument_type ( prhs, nc_op->opname, 1 );
    check_numeric_argument_type ( prhs, nc_op->opname, 2 );
    check_numeric_argument_type ( prhs, nc_op->opname, 3 );
    check_numeric_argument_type ( prhs, nc_op->opname, 4 );

    pr = mxGetData ( prhs[1] );
    ncid = (int)(pr[0]);
    pr = mxGetData ( prhs[2] );
    varid = (int)(pr[0]);
    pr = mxGetData ( prhs[3] );
    no_fill = (int)(pr[0]);

    fill_value = mxGetData(prhs[4]);

	status = nc_def_var_fill(ncid,varid,no_fill,fill_value);
    plhs[0] = mexncCreateDoubleScalar ( status );

    return;
}
Exemplo n.º 3
0
/***********************************************************************
 *
 * HANDLE_NC_DEF_VAR_DEFLATE:
 *
 * code for handling the nc_def_var_chunking routine.
 *
 * status = mexnc('def_var_deflate',ncid,varid,shuffle,deflate,deflate_level);
 *
 **********************************************************************/
void handle_nc_def_var_deflate 
( 
    int            nlhs, 
    mxArray       *plhs[], 
    int            nrhs, 
    const mxArray *prhs[], 
    op            *nc_op 
) 
{

    int ncid;
    int varid;
    int shuffle = 0;
    int deflate = 0;
    int deflate_level;
	

    /*
     * Pointer shortcut to matrix data.
     * */
    double *pr;


    /* 
     * Return status from netcdf operation.  
     * */
    int      status;


    /*
     * Make sure that the inputs are the right type.
     * */
    check_numeric_argument_type ( prhs, nc_op->opname, 1 );
    check_numeric_argument_type ( prhs, nc_op->opname, 2 );
    check_numeric_argument_type ( prhs, nc_op->opname, 3 );
    check_numeric_argument_type ( prhs, nc_op->opname, 4 );
    check_numeric_argument_type ( prhs, nc_op->opname, 5 );

    
    pr = mxGetData ( prhs[1] );
    ncid = (int)(pr[0]);
    pr = mxGetData ( prhs[2] );
    varid = (int)(pr[0]);
    pr = mxGetData ( prhs[3] );
    shuffle = (int)(pr[0]);
    pr = mxGetData ( prhs[4] );
    deflate = (int)(pr[0]);
    pr = mxGetData ( prhs[5] );
    deflate_level = (int)(pr[0]);

    status = nc_def_var_deflate(ncid,varid,shuffle,deflate,deflate_level);
    plhs[0] = mexncCreateDoubleScalar ( status );


    return;

}
Exemplo n.º 4
0
/***********************************************************************
 *
 * HANDLE_NC_DEF_VAR_CHUNKING:
 *
 * code for handling the nc_def_var_chunking routine.
 *
 * status = mexnc('def_var_chunking',ncid,varid,storage,chunksize);
 *
 **********************************************************************/
void handle_nc_def_var_chunking ( int nlhs, mxArray *plhs[], int nrhs, const mxArray *prhs[], op *nc_op ) {

	int ncid;
	int varid;
	int storage;
	size_t chunksize[NC_MAX_DIMS];
	

	double *pr;	/* Pointer shortcut to matrix data. */
	int  status;	/* Return status from netcdf operation. */
	int j;
	int ndims;	/* Number of dimensions (inferred from length of chunk argument) */
	mwSize nelts;	/* number of elements in chunking parameter. */


    /*
     * Make sure that the inputs are the right type.
     * */
    check_numeric_argument_type ( prhs, nc_op->opname, 1 );
    check_numeric_argument_type ( prhs, nc_op->opname, 2 );

    if ( !((mxIsChar(prhs[3]) == false) || (mxIsDouble(prhs[3]) == false )) ) {
        sprintf ( error_message, 
                "datatype argument must be matlab native double precision (<== that one, please) or character, operation \"%s\", line %d file \"%s\"\n", 
                nc_op->opname, __LINE__, __FILE__ );
            mexErrMsgTxt ( error_message );
            return;
    }

    check_numeric_argument_type ( prhs, nc_op->opname, 4 );
    
    
    pr = mxGetData ( prhs[1] );
    ncid = (int)(pr[0]);
    pr = mxGetData ( prhs[2] );
    varid = (int)(pr[0]);

    if ( mxIsChar ( prhs[3] ) ) {

        /*
         * This one is for backwards compatibility.  I really 
         * wish people would not do this...
         * */
        storage = interpret_char_parameter  ( prhs[3] );

    } else {
        pr = mxGetData ( prhs[3] );
        storage = (int) (pr[0]);
    }


	status = nc_inq_varndims(ncid,varid,&ndims);
	if ( status != NC_NOERR ) {
        sprintf ( error_message, 
                 "Internal call to nc_inq_varndims failed, operation \"%s\", line %d file \"%s\"\n", 
                  nc_op->opname, __LINE__, __FILE__ );
        mexErrMsgTxt ( error_message );
        return;
	}

	nelts = mxGetNumberOfElements(prhs[4]);


    /*
     * Make sure the user didn't do something really stupid like give too many dimensions.
     * */
    if ( nelts > NC_MAX_VAR_DIMS ) {
            sprintf ( error_message, 
                "given number of chunk elements (%d) exceeds preset maximum of %d, operation \"%s\", line %d file \"%s\"\n", 
                nelts, NC_MAX_VAR_DIMS, nc_op->opname, __LINE__, __FILE__ );
            mexErrMsgTxt ( error_message );
            return;
    }


	/*
	 * Tell the user not to provide a chunksize argument for contiguous storage.
	 * */
	
	if ( ( storage == NC_CONTIGUOUS ) && (nelts > 0) ) {
        sprintf ( error_message, 
                "If the storage type is NC_CONTIGUOUS, then the chunksize parameter must be [], line %d file \"%s\"",
                __LINE__, __FILE__ );
        mexErrMsgTxt ( error_message );
        return;
	}


    pr = mxGetData ( prhs[4] );
	for ( j = 0; j < nelts; ++j ) {
		chunksize[j] = pr[j];
	}

    status = nc_def_var_chunking ( ncid, varid, storage, chunksize );
    plhs[0] = mexncCreateDoubleScalar ( status );

    return;

}
Exemplo n.º 5
0
/***********************************************************************
 *
 * HANDLE_NC_INQ_VAR_CHUNKING:
 *
 * code for handling the nc_inq_var_chunking routine.
 *
 * [storage,chunksize,status] = mexnc('inq_var_chunking',ncid,varid);
 *
 **********************************************************************/
void handle_nc_inq_var_chunking ( int nlhs, mxArray *plhs[], int nrhs, const mxArray *prhs[], op *nc_op ) {

    int ncid;
    int varid;
    int storage;
	size_t chunksize[NC_MAX_DIMS];

    /*
     * Pointer shortcut to matrix data.
     * */
    double *pr;

	mwSize mxsize[2];	/* Size of chunking matrix. */

	int status, j;

	/*
	 * Number of dimensions (inferred from length of chunk argument)
	 * */
	int ndims;

	/*
	 * File format.  
	 * */
	int format;

    /*
     * Make sure that the inputs are the right type.
     * */
    check_numeric_argument_type ( prhs, nc_op->opname, 1 );
    check_numeric_argument_type ( prhs, nc_op->opname, 2 );

    pr = mxGetData ( prhs[1] );
    ncid = (int)(pr[0]);
    pr = mxGetData ( prhs[2] );
    varid = (int)(pr[0]);

	status = nc_inq_format(ncid,&format);
	if ( status != NC_NOERR ) {
        sprintf ( error_message, 
                 "Internal call to nc_inq_format failed, operation \"%s\", line %d file \"%s\"\n", 
                  nc_op->opname, __LINE__, __FILE__ );
        mexErrMsgTxt ( error_message );
        return;
	}

	switch(format){
		case NC_FORMAT_CLASSIC:
		case NC_FORMAT_64BIT:
			plhs[0] = mxCreateString ( "contiguous" );
			plhs[1] = mxCreateNumericArray(0,0, mxDOUBLE_CLASS, mxREAL );
			plhs[2] = mxCreateNumericArray(0,0, mxDOUBLE_CLASS, mxREAL );
			return;
	}

	status = nc_inq_varndims(ncid,varid,&ndims);
	if ( status != NC_NOERR ) {
        sprintf ( error_message, 
                 "Internal call to nc_inq_varndims failed, operation \"%s\", line %d file \"%s\"\n", 
                  nc_op->opname, __LINE__, __FILE__ );
        mexErrMsgTxt ( error_message );
        return;
	}

    status = nc_inq_var_chunking ( ncid, varid, &storage, chunksize );
    plhs[2] = mexncCreateDoubleScalar ( status );

	if ( storage == NC_CONTIGUOUS ) {
		plhs[0] = mxCreateString ( "contiguous" );

		/*
		 * Return [] for the chunksize
		 * */
		mxsize[0] = 0;
		mxsize[1] = 0;
		plhs[1] = mxCreateNumericArray ( 2, mxsize, mxDOUBLE_CLASS, mxREAL );

		return;
	}

	plhs[0] = mxCreateString ( "chunked" );

	mxsize[0] = 1;
	mxsize[1] = ndims;
	plhs[1] = mxCreateNumericArray ( 2, mxsize, mxDOUBLE_CLASS, mxREAL );
	pr = mxGetData ( plhs[1] );
	for ( j = 0; j < ndims; ++j ) {
		pr[j] = chunksize[j];
	}

    return;
}