mirror of
https://github.com/Unidata/netcdf-c.git
synced 2024-12-09 08:11:38 +08:00
227 lines
7.8 KiB
C
227 lines
7.8 KiB
C
/* This is part of the netCDF package.
|
|
Copyright 2005 University Corporation for Atmospheric Research/Unidata
|
|
See COPYRIGHT file for conditions of use.
|
|
|
|
Test even more data conversions.
|
|
|
|
$Id: tst_converts2.c,v 1.14 2010/06/01 15:34:51 ed Exp $
|
|
*/
|
|
|
|
#include <nc_tests.h>
|
|
#include "err_macros.h"
|
|
#include "netcdf.h"
|
|
#include <math.h>
|
|
|
|
#define FILE_NAME "tst_converts2.nc"
|
|
#define VAR_NAME "Monkey"
|
|
#define DIM_NAME "n"
|
|
#define DIM_LEN 5
|
|
|
|
int
|
|
main(int argc, char **argv)
|
|
{
|
|
int ncid, varid;
|
|
signed char schar_in, schar = -2;
|
|
char var_name[NC_MAX_NAME+1];
|
|
int ndims, natts, int_in;
|
|
long long_in;
|
|
nc_type var_type;
|
|
|
|
printf("\n*** Testing more netcdf-4 data conversion.\n");
|
|
printf ("*** Testing NC_BYTE conversions...");
|
|
{
|
|
/* Write a scalar NC_BYTE with value -2. */
|
|
if (nc_create(FILE_NAME, NC_NETCDF4, &ncid)) ERR;
|
|
if (nc_def_var(ncid, VAR_NAME, NC_BYTE, 0, NULL, &varid)) ERR;
|
|
if (nc_put_var_schar(ncid, varid, &schar)) ERR;
|
|
if (nc_close(ncid)) ERR;
|
|
|
|
/* Now open the file and check it. */
|
|
if (nc_open(FILE_NAME, NC_NOWRITE, &ncid)) ERR;
|
|
if (nc_inq_var(ncid, 0, var_name, &var_type, &ndims, NULL, &natts)) ERR;
|
|
if (strcmp(var_name, VAR_NAME) || natts !=0 || ndims != 0 ||
|
|
var_type != NC_BYTE) ERR;
|
|
if (nc_get_var_schar(ncid, varid, &schar_in)) ERR;
|
|
if (schar_in != schar) ERR;
|
|
if (nc_get_var_int(ncid, varid, &int_in)) ERR;
|
|
if (int_in != schar) ERR;
|
|
if (nc_get_var_long(ncid, varid, &long_in)) ERR;
|
|
if (long_in != schar) ERR;
|
|
if (nc_close(ncid)) ERR;
|
|
}
|
|
SUMMARIZE_ERR;
|
|
printf ("*** Testing NC_USHORT conversions...");
|
|
{
|
|
/* Write a scalar NC_USHORT, converted from various types, testing a bug fix. */
|
|
unsigned short usval = 65535;
|
|
int ival = 65535;
|
|
long lval = 65535;
|
|
float fval = 65535;
|
|
double dval = 65535;
|
|
int dimid;
|
|
size_t coord[1];
|
|
unsigned short ushort_in;
|
|
int int_in;
|
|
long long_in;
|
|
float float_in;
|
|
double double_in;
|
|
|
|
if (nc_create(FILE_NAME, NC_NETCDF4, &ncid)) ERR;
|
|
if (nc_def_dim(ncid, DIM_NAME, DIM_LEN, &dimid)) ERR;
|
|
if (nc_def_var(ncid, VAR_NAME, NC_USHORT, 1, &dimid, &varid)) ERR;
|
|
coord[0] = 0;
|
|
if (nc_put_var1_ushort(ncid, varid, coord, &usval)) ERR;
|
|
coord[0] = 1;
|
|
if (nc_put_var1_int(ncid, varid, coord, &ival)) ERR;
|
|
coord[0] = 2;
|
|
if (nc_put_var1_float(ncid, varid, coord, &fval)) ERR;
|
|
coord[0] = 3;
|
|
if (nc_put_var1_double(ncid, varid, coord, &dval)) ERR;
|
|
coord[0] = 4;
|
|
if (nc_put_var1_long(ncid, varid, coord, &lval)) ERR;
|
|
|
|
if (nc_close(ncid)) ERR;
|
|
|
|
/* Now open the file and check it. */
|
|
if (nc_open(FILE_NAME, NC_NOWRITE, &ncid)) ERR;
|
|
if (nc_inq_var(ncid, 0, var_name, &var_type, &ndims, NULL, &natts)) ERR;
|
|
if (strcmp(var_name, VAR_NAME) || natts !=0 || ndims != 1 ||
|
|
var_type != NC_USHORT) ERR;
|
|
coord[0] = 0;
|
|
if (nc_get_var1_ushort(ncid, varid, coord, &ushort_in)) ERR;
|
|
if (ushort_in != usval) ERR;
|
|
coord[0] = 1;
|
|
if (nc_get_var1_int(ncid, varid, coord, &int_in)) ERR;
|
|
if (int_in != ival) ERR;
|
|
coord[0] = 2;
|
|
if (nc_get_var1_float(ncid, varid, coord, &float_in)) ERR;
|
|
if (float_in != fval) ERR;
|
|
coord[0] = 3;
|
|
if (nc_get_var1_double(ncid, varid, coord, &double_in)) ERR;
|
|
if (double_in != dval) ERR;
|
|
coord[0] = 4;
|
|
if (nc_get_var1_long(ncid, varid, coord, &long_in)) ERR;
|
|
if (long_in != lval) ERR;
|
|
|
|
/* This should fail. */
|
|
coord[0] = 5;
|
|
if (nc_get_var1_ushort(ncid, varid, coord,
|
|
&ushort_in) != NC_EINVALCOORDS) ERR;
|
|
|
|
if (nc_close(ncid)) ERR;
|
|
}
|
|
{
|
|
/* Write a scalar NC_USHORT that's not default fill value,
|
|
* converted from various types. */
|
|
unsigned short usval = 65534;
|
|
int ival = 65534;
|
|
long lval = 65534;
|
|
float fval = 65534;
|
|
double dval = 65534;
|
|
int dimid;
|
|
size_t coord[1];
|
|
unsigned short ushort_in;
|
|
int int_in;
|
|
long long_in;
|
|
float float_in;
|
|
double double_in;
|
|
|
|
if (nc_create(FILE_NAME, NC_NETCDF4, &ncid)) ERR;
|
|
if (nc_def_dim(ncid, DIM_NAME, DIM_LEN, &dimid)) ERR;
|
|
if (nc_def_var(ncid, VAR_NAME, NC_USHORT, 1, &dimid, &varid)) ERR;
|
|
coord[0] = 0;
|
|
if (nc_put_var1_ushort(ncid, varid, coord, &usval)) ERR;
|
|
coord[0] = 1;
|
|
if (nc_put_var1_int(ncid, varid, coord, &ival)) ERR;
|
|
coord[0] = 2;
|
|
if (nc_put_var1_float(ncid, varid, coord, &fval)) ERR;
|
|
coord[0] = 3;
|
|
if (nc_put_var1_double(ncid, varid, coord, &dval)) ERR;
|
|
coord[0] = 4;
|
|
if (nc_put_var1_long(ncid, varid, coord, &lval)) ERR;
|
|
|
|
if (nc_close(ncid)) ERR;
|
|
|
|
/* Now open the file and check it. */
|
|
if (nc_open(FILE_NAME, NC_NOWRITE, &ncid)) ERR;
|
|
if (nc_inq_var(ncid, 0, var_name, &var_type, &ndims, NULL, &natts)) ERR;
|
|
if (strcmp(var_name, VAR_NAME) || natts !=0 || ndims != 1 ||
|
|
var_type != NC_USHORT) ERR;
|
|
coord[0] = 0;
|
|
if (nc_get_var1_ushort(ncid, varid, coord, &ushort_in)) ERR;
|
|
if (ushort_in != usval) ERR;
|
|
coord[0] = 1;
|
|
if (nc_get_var1_int(ncid, varid, coord, &int_in)) ERR;
|
|
if (int_in != ival) ERR;
|
|
coord[0] = 2;
|
|
if (nc_get_var1_float(ncid, varid, coord, &float_in)) ERR;
|
|
if (float_in != fval) ERR;
|
|
coord[0] = 3;
|
|
if (nc_get_var1_double(ncid, varid, coord, &double_in)) ERR;
|
|
if (double_in != dval) ERR;
|
|
coord[0] = 4;
|
|
if (nc_get_var1_long(ncid, varid, coord, &long_in)) ERR;
|
|
if (long_in != lval) ERR;
|
|
|
|
/* This should fail. */
|
|
coord[0] = 5;
|
|
if (nc_get_var1_ushort(ncid, varid, coord,
|
|
&ushort_in) != NC_EINVALCOORDS) ERR;
|
|
|
|
if (nc_close(ncid)) ERR;
|
|
}
|
|
SUMMARIZE_ERR;
|
|
printf ("*** Testing MAX_INT conversions...");
|
|
{
|
|
#define X_INT_MAX 2147483647 /* from libsrc4/nc4internal.h */
|
|
int ivalue = X_INT_MAX, ivalue_in;
|
|
unsigned char uchar_in;
|
|
unsigned int uivalue_in;
|
|
short svalue_in;
|
|
unsigned short usvalue_in;
|
|
long long int64_in;
|
|
unsigned long long uint64_in;
|
|
float float_in;
|
|
double double_in;
|
|
|
|
/* Write a scalar NC_INT with value X_MAX_INT. */
|
|
if (nc_create(FILE_NAME, NC_NETCDF4, &ncid)) ERR;
|
|
if (nc_def_var(ncid, VAR_NAME, NC_INT, 0, NULL, &varid)) ERR;
|
|
if (nc_put_var_int(ncid, varid, &ivalue)) ERR;
|
|
if (nc_close(ncid)) ERR;
|
|
|
|
/* Now open the file and check it. */
|
|
if (nc_open(FILE_NAME, NC_NOWRITE, &ncid)) ERR;
|
|
if (nc_inq_var(ncid, 0, var_name, &var_type, &ndims, NULL, &natts)) ERR;
|
|
if (strcmp(var_name, VAR_NAME) || natts !=0 || ndims != 0 ||
|
|
var_type != NC_INT) ERR;
|
|
if (nc_get_var_schar(ncid, varid, &schar_in) != NC_ERANGE) ERR;
|
|
if (schar_in != (signed char)ivalue) ERR;
|
|
if (nc_get_var_uchar(ncid, varid, &uchar_in) != NC_ERANGE) ERR;
|
|
if (uchar_in != (unsigned char)ivalue) ERR;
|
|
if (nc_get_var_short(ncid, varid, &svalue_in) != NC_ERANGE) ERR;
|
|
if (svalue_in != (short)ivalue) ERR;
|
|
if (nc_get_var_ushort(ncid, varid, &usvalue_in) != NC_ERANGE) ERR;
|
|
if (usvalue_in != (unsigned short)ivalue) ERR;
|
|
if (nc_get_var_int(ncid, varid, &ivalue_in)) ERR;
|
|
if (ivalue_in != ivalue) ERR;
|
|
if (nc_get_var_uint(ncid, varid, &uivalue_in)) ERR;
|
|
if (uivalue_in != (unsigned int)ivalue) ERR;
|
|
if (nc_get_var_long(ncid, varid, &long_in)) ERR;
|
|
if (long_in != ivalue) ERR;
|
|
if (nc_get_var_longlong(ncid, varid, &int64_in)) ERR;
|
|
if (int64_in != ivalue) ERR;
|
|
if (nc_get_var_ulonglong(ncid, varid, &uint64_in)) ERR;
|
|
if (uint64_in != ivalue) ERR;
|
|
if (nc_get_var_float(ncid, varid, &float_in)) ERR;
|
|
|
|
if(fabs( (float_in-X_INT_MAX) - ((float)ivalue - X_INT_MAX)) > 1) ERR;
|
|
|
|
if (nc_get_var_double(ncid, varid, &double_in)) ERR;
|
|
if (double_in != (double)ivalue) ERR;
|
|
if (nc_close(ncid)) ERR;
|
|
}
|
|
SUMMARIZE_ERR;
|
|
FINAL_RESULTS;
|
|
}
|