grid.h 5.36 KB
Newer Older
Uwe Schulzweida's avatar
Uwe Schulzweida committed
1
2
3
#ifndef _GRID_H
#define _GRID_H

4
#include "cdi.h"
5
#include <stdbool.h>
6

Uwe Schulzweida's avatar
Uwe Schulzweida committed
7
typedef unsigned char mask_t;
Uwe Schulzweida's avatar
Uwe Schulzweida committed
8

9
10
11
12
13
typedef struct grid_t grid_t;

struct gridVirtTable
{
  void (*destroy)(grid_t *gridptr);
Thomas Jahns's avatar
Thomas Jahns committed
14
15
16
  grid_t *(*copy)(grid_t *gridptr);
  void (*copyScalarFields)(grid_t *gridptrOrig, grid_t *gridptrDup);
  void (*copyArrayFields)(grid_t *gridptrOrig, grid_t *gridptrDup);
17
18
19
20
21
22
23
24
25
26
27
28
29
  void (*defXVals)(grid_t *gridptr, const double *xvals);
  void (*defYVals)(grid_t *gridptr, const double *yvals);
  void (*defMask)(grid_t *gridptr, const int *mask);
  void (*defMaskGME)(grid_t *gridptr, const int *mask);
  void (*defXBounds)(grid_t *gridptr, const double *xbounds);
  void (*defYBounds)(grid_t *gridptr, const double *ybounds);
  void (*defArea)(grid_t *gridptr, const double *area);
  double (*inqXVal)(grid_t *gridptr, int index);
  double (*inqYVal)(grid_t *gridptr, int index);
  int (*inqXVals)(grid_t *gridptr, double *xvals);
  int (*inqYVals)(grid_t *gridptr, double *yvals);
  const double *(*inqXValsPtr)(grid_t *gridptr);
  const double *(*inqYValsPtr)(grid_t *gridptr);
30
  /* return if for both grids, all xval and all yval are equal */
31
  bool (*compareXYFull)(grid_t *gridRef, grid_t *gridTest);
32
33
  /* return if for both grids, x[0], y[0], x[size-1] and y[size-1] are
   * respectively equal */
34
  bool (*compareXYAO)(grid_t *gridRef, grid_t *gridTest);
35
  void (*inqArea)(grid_t *gridptr, double *area);
36
  const double *(*inqAreaPtr)(grid_t *gridptr);
Thomas Jahns's avatar
Thomas Jahns committed
37
  int (*hasArea)(grid_t *gridptr);
38
39
40
41
42
43
44
45
  int (*inqMask)(grid_t *gridptr, int *mask);
  int (*inqMaskGME)(grid_t *gridptr, int *mask_gme);
  int (*inqXBounds)(grid_t *gridptr, double *xbounds);
  int (*inqYBounds)(grid_t *gridptr, double *ybounds);
  const double *(*inqXBoundsPtr)(grid_t *gridptr);
  const double *(*inqYBoundsPtr)(grid_t *gridptr);
};

46
47
48
49
struct gridaxis_t {
  char    name[CDI_MAX_NAME];
};

50
struct grid_t {
Uwe Schulzweida's avatar
Uwe Schulzweida committed
51
52
53
  int     self;
  int     type;                   /* grid type                      */
  int     prec;                   /* grid precision                 */
54
  int     proj;                   /* grid projection                */
Uwe Schulzweida's avatar
Uwe Schulzweida committed
55
56
  mask_t *mask;
  mask_t *mask_gme;
Uwe Schulzweida's avatar
Uwe Schulzweida committed
57
58
59
60
61
62
63
64
  double *xvals;
  double *yvals;
  double *area;
  double *xbounds;
  double *ybounds;
  double  xfirst, yfirst;
  double  xlast, ylast;
  double  xinc, yinc;
65
  double  lcc_originLon;          /* Lambert Conformal Conic        */
Uwe Schulzweida's avatar
Uwe Schulzweida committed
66
67
68
69
70
71
  double  lcc_originLat;
  double  lcc_lonParY;
  double  lcc_lat1;
  double  lcc_lat2;
  double  lcc_xinc;
  double  lcc_yinc;
72
73
  int     lcc_projflag;
  int     lcc_scanflag;
74
75
76
  short   lcc_defined;
  short   lcc2_defined;
  int     laea_defined;
77
78
79
80
81
  double  lcc2_lon_0;             /* Lambert Conformal Conic 2      */
  double  lcc2_lat_0;
  double  lcc2_lat_1;
  double  lcc2_lat_2;
  double  lcc2_a;
82
83
84
  double  laea_lon_0;             /* Lambert Azimuthal Equal Area   */
  double  laea_lat_0;
  double  laea_a;
Uwe Schulzweida's avatar
Uwe Schulzweida committed
85
  double  xpole, ypole, angle;    /* rotated north pole             */
86
87
88
89
  short   isCyclic;               /* TRUE for global cyclic grids   */
  short   isRotated;              /* TRUE for rotated grids         */
  short   xdef;                   /* 0: undefined 1:xvals 2:x0+xinc */
  short   ydef;                   /* 0: undefined 1:yvals 2:y0+yinc */
Uwe Schulzweida's avatar
Uwe Schulzweida committed
90
  int     nd, ni, ni2, ni3;       /* parameter for GRID_GME         */
91
  int     number, position;       /* parameter for GRID_REFERENCE   */
Uwe Schulzweida's avatar
Uwe Schulzweida committed
92
93
  int     trunc;                  /* parameter for GRID_SPECTEAL    */
  int     nvertex;
94
95
  char   *reference;
  unsigned char uuid[CDI_UUID_SIZE]; /* uuid for grid reference        */
Uwe Schulzweida's avatar
Uwe Schulzweida committed
96
97
98
  int    *rowlon;
  int     nrowlon;
  int     size;
99
100
101
  int     xsize;                  /* number of values along X */
  int     ysize;                  /* number of values along Y */
  int     np;                     /* number of parallels between a pole and the equator */
Thomas Jahns's avatar
Thomas Jahns committed
102
103
  short   lcomplex;
  short   hasdims;
104
105
  const char *xstdname;
  const char *ystdname;
106
107
  char    xdimname[CDI_MAX_NAME];
  char    ydimname[CDI_MAX_NAME];
108
  char    vdimname[CDI_MAX_NAME];
109
110
  //  char    xname[CDI_MAX_NAME];
  //  char    yname[CDI_MAX_NAME];
Uwe Schulzweida's avatar
Uwe Schulzweida committed
111
112
113
114
  char    xlongname[CDI_MAX_NAME];
  char    ylongname[CDI_MAX_NAME];
  char    xunits[CDI_MAX_NAME];
  char    yunits[CDI_MAX_NAME];
Uwe Schulzweida's avatar
Uwe Schulzweida committed
115
  char   *name;
116
117
  struct gridaxis_t x;
  struct gridaxis_t y;
118
119
120
  const struct gridVirtTable *vtable;
  void *extraData;
};
Uwe Schulzweida's avatar
Uwe Schulzweida committed
121
122


Uwe Schulzweida's avatar
Uwe Schulzweida committed
123
void grid_init(grid_t *gridptr);
124
125
void
cdiGridTypeInit(grid_t *gridptr, int gridtype, int size);
Uwe Schulzweida's avatar
Uwe Schulzweida committed
126
void grid_free(grid_t *gridptr);
127
grid_t *gridID2Ptr(int gridID);
128
extern const struct gridVirtTable cdiGridVtable;
Uwe Schulzweida's avatar
Uwe Schulzweida committed
129

Thomas Jahns's avatar
Thomas Jahns committed
130
unsigned cdiGridCount(void);
131

Uwe Schulzweida's avatar
Uwe Schulzweida committed
132
133
134
const double *gridInqXvalsPtr(int gridID);
const double *gridInqYvalsPtr(int gridID);

135
136
const double *gridInqXboundsPtr(int gridID);
const double *gridInqYboundsPtr(int gridID);
Uwe Schulzweida's avatar
Uwe Schulzweida committed
137
138
const double *gridInqAreaPtr(int gridID);

139
140
141
const char *gridInqXnamePtr(int gridID);
const char *gridInqYnamePtr(int gridID);

142
143
const char *gridInqReferencePtr(int gridID);

144
int gridGenerate(const grid_t *grid);
Uwe Schulzweida's avatar
Uwe Schulzweida committed
145

Thomas Jahns's avatar
Thomas Jahns committed
146
void cdiGridGetIndexList(unsigned, int * );
Uwe Schulzweida's avatar
Uwe Schulzweida committed
147

148
149
void
gridUnpack(char * unpackBuffer, int unpackBufferSize,
150
           int * unpackBufferPos, int originNamespace, void *context,
151
152
           int force_id);

153
154
155
156
157
158
159
struct addIffNewRes
{
  int Id;
  int isNew;
};

struct addIffNewRes cdiVlistAddGridIfNew(int vlistID, grid_t *grid, int mode);
160

Uwe Schulzweida's avatar
Uwe Schulzweida committed
161
#endif
162
163
164
165
166
167
168
169
170
/*
 * Local Variables:
 * c-file-style: "Java"
 * c-basic-offset: 2
 * indent-tabs-mode: nil
 * show-trailing-whitespace: t
 * require-trailing-newline: t
 * End:
 */