gribapi.h 3.66 KB
Newer Older
Uwe Schulzweida's avatar
Uwe Schulzweida committed
1
2
3
#ifndef _GRIBAPI_H
#define _GRIBAPI_H

4
#ifdef HAVE_LIBGRIB_API
5
6
7
8
#  include "error.h"
#  include <grib_api.h>
#endif

9
10
#include "cdi_int.h"

Uwe Schulzweida's avatar
Uwe Schulzweida committed
11
12
#define  GRIBAPI_MISSVAL  -9.E33

Uwe Schulzweida's avatar
Uwe Schulzweida committed
13
14
/* GRIB2 Level Types */
#define  GRIB2_LTYPE_SURFACE               1
15
16
#define  GRIB2_LTYPE_CLOUD_BASE            2
#define  GRIB2_LTYPE_CLOUD_TOP             3
17
#define  GRIB2_LTYPE_ISOTHERM0             4
18
#define  GRIB2_LTYPE_TOA                   8
19
20
#define  GRIB2_LTYPE_SEA_BOTTOM            9
#define  GRIB2_LTYPE_ATMOSPHERE           10
Uwe Schulzweida's avatar
Uwe Schulzweida committed
21
22
23
24
25
26
27
28
#define  GRIB2_LTYPE_ISOBARIC            100
#define  GRIB2_LTYPE_MEANSEA             101
#define  GRIB2_LTYPE_ALTITUDE            102
#define  GRIB2_LTYPE_HEIGHT              103
#define  GRIB2_LTYPE_SIGMA               104
#define  GRIB2_LTYPE_HYBRID              105
#define  GRIB2_LTYPE_LANDDEPTH           106
#define  GRIB2_LTYPE_ISENTROPIC          107
29
#define  GRIB2_LTYPE_SNOW                114
Uwe Schulzweida's avatar
Uwe Schulzweida committed
30
#define  GRIB2_LTYPE_REFERENCE           150
31
32
33
34
35
36
#define  GRIB2_LTYPE_SEADEPTH            160  /* Depth Below Sea Level                                 */
#define  GRIB2_LTYPE_LAKE_BOTTOM         162  /* Lake or River Bottom                                  */
#define  GRIB2_LTYPE_SEDIMENT_BOTTOM     163  /* Bottom Of Sediment Layer                              */
#define  GRIB2_LTYPE_SEDIMENT_BOTTOM_TA  164  /* Bottom Of Thermally Active Sediment Layer             */
#define  GRIB2_LTYPE_SEDIMENT_BOTTOM_TW  165  /* Bottom Of Sediment Layer Penetrated By Thermal Wave   */
#define  GRIB2_LTYPE_MIX_LAYER           166  /* Mixing Layer                                          */
Uwe Schulzweida's avatar
Uwe Schulzweida committed
37

Uwe Schulzweida's avatar
Uwe Schulzweida committed
38
/* GRIB2 Data representation type (Grid Type) */
39
40
41
42
43
44
45
46
47
48
49
#define  GRIB2_GTYPE_LATLON                0  /*  latitude/longitude                                   */
#define  GRIB2_GTYPE_LATLON_ROT            1  /*  rotated latitude/longitude                           */
#define  GRIB2_GTYPE_LATLON_STR            2  /*  stretched latitude/longitude                         */
#define  GRIB2_GTYPE_LATLON_ROTSTR         3  /*  rotated and stretched latitude/longitude             */
#define  GRIB2_GTYPE_GAUSSIAN             40  /*  gaussian grid                                        */
#define  GRIB2_GTYPE_GAUSSIAN_ROT         41  /*  rotated gaussian grid                                */
#define  GRIB2_GTYPE_GAUSSIAN_STR         42  /*  stretched gaussian grid                              */
#define  GRIB2_GTYPE_GAUSSIAN_ROTSTR      43  /*  rotated and stretched gaussian grid                  */
#define  GRIB2_GTYPE_LCC                  30  /*  Lambert conformal                                    */
#define  GRIB2_GTYPE_SPECTRAL             50  /*  spherical harmonics                                  */
#define  GRIB2_GTYPE_GME                 100  /*  hexagonal GME grid                                   */
50
#define  GRIB2_GTYPE_UNSTRUCTURED        101  /*  General Unstructured Grid                            */
Uwe Schulzweida's avatar
Uwe Schulzweida committed
51

52
const char *gribapiLibraryVersionString(void);
53
54
void gribContainersNew(stream_t * streamptr);
void gribContainersDelete(stream_t * streamptr);
55

56
#ifdef HAVE_LIBGRIB_API
57
58
static inline void *gribHandleNew(int editionNumber)
{
59
  void *gh = (void *)grib_handle_new_from_samples(NULL, (editionNumber == 1) ? "GRIB1" : "GRIB2");
60
61

  if ( gh == NULL ) Error("grib_handle_new_from_samples failed!");
62

63
64
65
66
67
68
69
70
71
72
73
  return gh;
}

static inline void gribHandleDelete(void *gh)
{
  grib_handle_delete(gh);
}
#else
#define gribHandleNew(editionNumber) (NULL)
#define gribHandleDelete(gh)
#endif
Uwe Schulzweida's avatar
Uwe Schulzweida committed
74

Uwe Schulzweida's avatar
Uwe Schulzweida committed
75
76
77
78
79
80
typedef struct {
  int init;
  void *gribHandle;
}
gribContainer_t;

Uwe Schulzweida's avatar
Uwe Schulzweida committed
81
#endif  /* _GRIBAPI_H */
82
83
84
85
86
87
88
89
90
/*
 * Local Variables:
 * c-file-style: "Java"
 * c-basic-offset: 2
 * indent-tabs-mode: nil
 * show-trailing-whitespace: t
 * require-trailing-newline: t
 * End:
 */