File: create_grib.c

package info (click to toggle)
eccodes 2.44.2-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 150,256 kB
  • sloc: cpp: 163,056; ansic: 26,308; sh: 21,602; f90: 6,854; perl: 6,363; python: 5,087; java: 2,226; javascript: 1,427; yacc: 854; fortran: 543; lex: 359; makefile: 274; xml: 183; awk: 66
file content (122 lines) | stat: -rw-r--r-- 2,815 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
/*
 * C Implementation: create_grib
 *
 * Description:
 *
 *
 * Author: Enrico Fucile <enrico.fucile@ecmwf.int>, (C) 2006
 *
 * Copyright: See COPYING file that comes with this distribution
 *
 */
#include <stdio.h>

#include "grib_api_internal.h"

int main(int argc, char *argv[])
{

  FILE* of=NULL;
  const void* buffer=NULL;
  int ret=0;
  size_t size;
  double* values=NULL;
  long numberOfPointsAlongAParallel=0;
  long numberOfPointsAlongAMeridian=0;
  long numberOfPoints = 0,i = 0,j = 0,k = 0;
  grib_context* c=NULL;
  grib_handle* h=NULL;

  char* outfilename="out.grib";
  long missing=9999;
#if 0
  FILE *f=NULL;
  char* infilename="../data/sample_grib.txt";
  f = fopen(infilename,"r");
  if(!f) {
    perror(argv[i]);
    exit(1);
  }

  h=grib_handle_new_from_text_file(c,f);

  fclose(f);
#endif

#if 0
  FILE *f=NULL;
  char* infilename="../data/sample_grib.txt";
  f = fopen(infilename,"r");
  if(!f) {
    perror(argv[i]);
    exit(1);
  }

    h=grib_handle_new(c);
  GRIB_CHECK(grib_load_from_text_file(h,f),0);

  fclose(f);
#endif

#if 1
  h=grib_handle_new(c);
  GRIB_CHECK(grib_set_type(h,"grib1"),0);
  GRIB_CHECK(grib_set_type(h,"ecmwf"),0);
  GRIB_CHECK(grib_set_type(h,"geopotential"),0);
#endif

  GRIB_CHECK(grib_set_long(h,"generatingProcessIdentifier",127),0);

  GRIB_CHECK(grib_set_double(h,"latitudeOfFirstGridPointInDegrees",10),0);
  GRIB_CHECK(grib_set_double(h,"longitudeOfFirstGridPointInDegrees",-10),0);

  GRIB_CHECK(grib_set_double(h,"latitudeOfLastGridPointInDegrees",-10),0);
  GRIB_CHECK(grib_set_double(h,"longitudeOfLastGridPointInDegrees",10),0);

  GRIB_CHECK(grib_set_double(h,"jDirectionIncrementInDegrees",0.5),0);
  GRIB_CHECK(grib_set_double(h,"iDirectionIncrementInDegrees",0.5),0);

  GRIB_CHECK(grib_set_long(h,"section3Present",1),0);
  GRIB_CHECK(grib_set_long(h,"missingValue",missing),0);

  GRIB_CHECK(grib_get_long( h,"numberOfPointsAlongAParallel",&numberOfPointsAlongAParallel),0);
  GRIB_CHECK(grib_get_long( h,"numberOfPointsAlongAMeridian",&numberOfPointsAlongAMeridian),0);

  numberOfPoints=numberOfPointsAlongAMeridian*numberOfPointsAlongAParallel;
  values=(double*)malloc(numberOfPoints*sizeof(double));


  for (j=0;j<numberOfPointsAlongAMeridian;j++) {
    for (i=0;i<numberOfPointsAlongAParallel;i++) {
      k=i+numberOfPointsAlongAParallel*j;
      if (i==j) values[k]=missing;
      else values[k]=50;
    }
  }

  grib_set_data_array( h,values,numberOfPoints);

  if (h) {
    grib_dump_content(h,stdout,"debug",0,NULL);
  } else  {
    printf("Error: unable to create grib_handle\n");
  }

  of = fopen(outfilename,"w");
  if(!of) {
    perror(outfilename);
    exit(1);
  }

  grib_get_message(h,&buffer,&size);

  if(fwrite(buffer,1,size,of) != size) {
    perror(outfilename);
    exit(1);
  }

  fclose(of);

  return ret;

}