test_resource_copy.c 6.57 KB
Newer Older
1
2
3
4
5
#if defined (HAVE_CONFIG_H)
#include "config.h"
#endif

#include <stdio.h>
6
#include <string.h>
7
8

#include "cdi.h"
9
#include "cdi_uuid.h"
10
#include "dmemory.h"
11
#include "error.h"
12
13
#include "resource_handle.h"
#include "resource_unpack.h"
14
15
16
17

#ifdef MPI_MARSHALLING
#include <mpi.h>
#include "cdipio.h"
18
#include "pio_serialize.h"
19
#include "pio_util.h"
20
21
22
#else
typedef int MPI_Comm;
#endif
23
24

enum {
Uwe Schulzweida's avatar
Uwe Schulzweida committed
25
  DOUBLE_PRECISION = CDI_DATATYPE_FLT64,
26
27
28
29
30
  nlon             = 12,
  nlat             = 6,
  nlev             = 5,
  ntsteps          = 3 };

31
32
33
static double lons[nlon] = {0, 30, 60, 90, 120, 150, 180, 210, 240, 270, 300, 330};
static double lats[nlat] = {-75, -45, -15, 15, 45, 75};
static double levs[nlev] = {101300, 92500, 85000, 50000, 20000};
34

35
static int defineGrid (void)
36
37
38
39
40
41
42
{
  int mask_vec[nlon*nlat];
  const int * mp = &mask_vec[0];
  double area_vec[nlon*nlat];
  const double * ap = &area_vec[0];
  int i;

43
  int gridID = gridCreate(GRID_LONLAT, nlon*nlat);
44
45
46
47
48
49
50
51
52
53
54
55
56
  gridDefXsize(gridID, nlon);
  gridDefYsize(gridID, nlat);
  gridDefXvals(gridID, lons);
  gridDefYvals(gridID, lats);
  gridDefNvertex ( gridID, 1 );
  gridDefXbounds ( gridID, lons );
  gridDefYbounds ( gridID, lats );
  for ( i = 0; i < nlon*nlat; i++ )
    mask_vec[i] = i % 2 ;
  gridDefMaskGME ( gridID, mp );
  for ( i = 0; i < nlon*nlat; i++ )
    mask_vec[i] = 1;
  gridDefMask ( gridID, mp );
57
58
59
60
61
62
63
64

  cdiDefKeyString(gridID, CDI_XAXIS, CDI_KEY_NAME, "myXname");
  cdiDefKeyString(gridID, CDI_YAXIS, CDI_KEY_NAME, "myYname");
  cdiDefKeyString(gridID, CDI_XAXIS, CDI_KEY_LONGNAME, "myXlongname");
  cdiDefKeyString(gridID, CDI_YAXIS, CDI_KEY_LONGNAME, "myYlongname");
  cdiDefKeyString(gridID, CDI_XAXIS, CDI_KEY_UNITS, "myXunits");
  cdiDefKeyString(gridID, CDI_YAXIS, CDI_KEY_UNITS, "myYunits");

Uwe Schulzweida's avatar
Uwe Schulzweida committed
65
  gridDefDatatype ( gridID, DOUBLE_PRECISION );
66
  gridDefTrunc ( gridID, 1 );
67
  gridDefParamGME ( gridID, 2, 3, 4, 5 );
68
69
70
71
72

  cdiDefKeyInt(gridID, CDI_GLOBAL, CDI_KEY_NUMBEROFGRIDUSED, 6);
  cdiDefKeyInt(gridID, CDI_GLOBAL, CDI_KEY_NUMBEROFGRIDINREFERENCE, 7);
  cdiDefKeyString(gridID, CDI_GLOBAL, CDI_KEY_REFERENCEURI, "myReference");

73
74
75
76
77
  for ( i = 0; i < nlon*nlat; i++ )
    area_vec[i] = 0.1 * i;
  gridDefArea ( gridID, ap );
  for ( i = 0; i < nlon*nlat; i++ )
    mask_vec[i] = i;
78
  gridDefReducedPoints ( gridID, nlon*nlat, mp );
79
  gridDefComplexPacking ( gridID, 1 );
80
81
  {
    unsigned char uuid[CDI_UUID_SIZE];
82
    cdiCreateUUID(uuid);
83
84
    gridDefUUID(gridID, uuid);
  }
85
86
87
88

  return gridID;
}

89
static int defineZaxis (void)
90
91
92
{
  double vct[3] = { 3.0, 3.3, 3.6 };

93
  int zaxisID = zaxisCreate(ZAXIS_PRESSURE, nlev);
94
95
96
97
98
  zaxisDefLevels(zaxisID, levs);
  zaxisDefLevel ( zaxisID, 2, 8507.3 );
  zaxisDefName ( zaxisID, "myName" );
  zaxisDefLongname ( zaxisID, "myLongname" );
  zaxisDefUnits ( zaxisID, "myUnits" );
Uwe Schulzweida's avatar
Uwe Schulzweida committed
99
  zaxisDefDatatype ( zaxisID, DOUBLE_PRECISION );
100
  cdiDefKeyInt(zaxisID, CDI_GLOBAL, CDI_KEY_TYPEOFFIRSTFIXEDSURFACE, 1);
101
102
103
104
  zaxisDefVct ( zaxisID, 3, vct );
  zaxisDefLbounds ( zaxisID, &levs[0] );
  zaxisDefUbounds ( zaxisID, &levs[0] );
  zaxisDefWeights ( zaxisID, &levs[0] );
105
106
  {
    unsigned char uuid[CDI_UUID_SIZE];
107
    cdiCreateUUID(uuid);
108
109
    zaxisDefUUID(zaxisID, uuid);
  }
110
111
112
113

  return zaxisID;
}

114
static int defineTaxis (void)
115
{
116
  int taxisID =  taxisCreate(TAXIS_ABSOLUTE);
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131

  taxisDefType  ( taxisID, 0 );
  taxisDefVdate ( taxisID, 1 );
  taxisDefVtime ( taxisID, 2 );
  taxisDefRdate ( taxisID, 3 );
  taxisDefRtime ( taxisID, 4 );
  taxisDefVdateBounds ( taxisID, 5, 6 );
  taxisDefVtimeBounds ( taxisID, 7, 8 );
  taxisDefCalendar ( taxisID, 1 );
  taxisDefTunit ( taxisID, 1 );
  taxisDefNumavg ( taxisID, 1 );

  return taxisID;
}

132
static void defineStream ( int streamID, int vlistID )
133
134
135
136
137
138
139
{
  streamDefByteorder ( streamID, 1 );
  streamDefCompType  ( streamID, 2 );
  streamDefCompLevel ( streamID, 3 );
  streamDefVlist(streamID, vlistID);
}

140
141
142
143
struct idPair {
  int id1, id2;
};

144
static struct idPair defineVlist ( int gridID, int zaxisID, int taxisID )
145
146
147
148
149
{
  int vlistID = CDI_UNDEFID;
  int zaxisID2 = zaxisCreate(ZAXIS_SURFACE, 1);

  vlistID = vlistCreate();
150
151
  int varID1 = vlistDefVar(vlistID, gridID, zaxisID, TIME_VARIABLE);
  int varID2 = vlistDefVar(vlistID, gridID, zaxisID2, TIME_VARIABLE);
152
153
154
  vlistDefVarName(vlistID, varID1, "varname1");
  {
    int globfac[] = { 23, 42 };
155
    cdiDefAttInt(vlistID, varID1, "seer's globule factors", CDI_DATATYPE_INT16, 2, globfac);
156
157
  }
  vlistDefVarName(vlistID, varID2, "varname2");
158
  cdiDefAttTxt(vlistID, varID2, "txt demo", 6, "banana");
159
  vlistDefTaxis(vlistID, taxisID);
Thomas Jahns's avatar
Thomas Jahns committed
160
161
162
  int vlistID2 = vlistCreate();
  vlistDefVar(vlistID2, gridID, zaxisID, TIME_VARIABLE);
  vlistCopy(vlistID2, vlistID);
163
  return (struct idPair){ vlistID, vlistID2 };
164
165
}

166
static int defineInstitute ()
167
{
168
  int instID = institutDef( 0, 0,"MYINSTITUTE", "myInstitute");
169
170
171
  return instID;
}

172
static int defineModel ( int instID )
173
{
174
  int modelID = modelDef(instID, 0, "resource_copy");
175
176
177
  return modelID;
}

178
179
static int destNamespace;

180
static int modelRun(MPI_Comm comm)
181
182
{
  char * recvBuffer, * sendBuffer;
183
  int bufferSize;
184

185
#ifdef MPI_MARSHALLING
186
  cdiPioSerializeSetMPI();
187
#endif
188

189
190
191
192
  int gridID  = defineGrid      ();
  int zaxisID = defineZaxis     ();
  int taxisID = defineTaxis     ();
  int instID  = defineInstitute ();
Thomas Jahns's avatar
Thomas Jahns committed
193
  defineModel(instID);
194
195
196
197
198
199
200
201

  struct idPair temp = defineVlist(gridID, zaxisID, taxisID);
  int vlistID = temp.id1;
  int streamID = streamOpenWrite("example.grb", CDI_FILETYPE_GRB);
  if ( streamID < 0 ) xabort ( "Could not open file" );
  defineStream ( streamID, vlistID );
  vlistDestroy(temp.id1);
  vlistDestroy(temp.id2);
202

203
  reshPackBufferCreate ( &sendBuffer, &bufferSize, &comm );
204
  recvBuffer = (char *)malloc((size_t)bufferSize);
205
#ifdef MPI_MARSHALLING
206
207
208
  xmpi(MPI_Sendrecv(sendBuffer, bufferSize, MPI_PACKED, 0, 0,
                    recvBuffer, bufferSize, MPI_PACKED, 0, 0,
                    MPI_COMM_SELF, MPI_STATUS_IGNORE));
209
#else
210
  memcpy(recvBuffer, sendBuffer, (size_t)bufferSize);
211
212
#endif
  namespaceSetActive(destNamespace);
213
  reshUnpackResources(recvBuffer, bufferSize, &comm);
214
215
  free(recvBuffer);
  reshPackBufferDestroy(&sendBuffer);
216

217
  int differ = reshListCompare ( 0, 1 );
218

219
  namespaceSetActive(0);
220
  streamClose(streamID);
221
  return differ;
222
223
224
225
}

int main (int argc, char *argv[])
{
226
  int exitCode = 77;
227
228
  MPI_Comm commModel;
#ifdef MPI_MARSHALLING
229
  MPI_Init(&argc, &argv);
230
231
  commModel = MPI_COMM_WORLD;
#else
232
  (void)argc; (void)argv;
233
234
235
  commModel = 0;
#endif
  destNamespace = namespaceNew();
236

237
  exitCode = modelRun(commModel);
238

239
#ifdef MPI_MARSHALLING
240
  xmpi(MPI_Finalize());
241
242
#endif

243
  return exitCode;
244
245
246
247
248
249
250
251
252
253
254
}

/*
 * Local Variables:
 * c-file-style: "Java"
 * c-basic-offset: 2
 * indent-tabs-mode: nil
 * show-trailing-whitespace: t
 * require-trailing-newline: t
 * End:
 */