File: CdiInfo.cpp

package info (click to toggle)
cdo 2.5.4-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 49,964 kB
  • sloc: cpp: 180,221; ansic: 95,352; sh: 7,292; f90: 6,089; makefile: 1,975; ruby: 1,078; csh: 1,020; python: 995; fortran: 319; pascal: 219; perl: 9
file content (140 lines) | stat: -rw-r--r-- 6,558 bytes parent folder | download
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
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
#include <stdlib.h>
#include <stdio.h>
#include <iostream>
#include "cdi.hpp"

int
main(int argc, char *argv[])
{
  int varno;
  std::string _name;
  CdiVariable var;

  Cdi info(argc > 1 ? argv[1] : "testdata/mulval.nc");

  std::cout << "#===============================" << std::endl;
  for (int i = 0; i < info.nvars; i++) std::cout << info.codes[i] << ' ';
  std::cout << std::endl;
  for (int i = 0; i < info.nvars; i++) std::cout << info.varnames[i] << ' ';
  std::cout << std::endl;

  std::cout << "#===============================" << std::endl;
  std::cout << "#= Available GridIDs are: ";
  for (std::map<int, CdiGrid>::iterator iter = info.grids.begin(); iter != info.grids.end(); ++iter)
  {
    std::cout << (*iter).first << ' ';
  };
  std::cout << std::endl;
  std::cout << "first grid:" << info.grids[0].size << std::endl;
  if (info.grids[0].hasXValues)
    for (int k = 0; k < info.grids[0].xsize; k++) std::cout << info.grids[0].xvalues[k] << ' ';
  else
    std::cout << "No XValues!" << std::endl;
  std::cout << std::endl;
  std::cout << "second grid:" << info.grids[1].size << std::endl;
  if (info.grids[1].hasXValues)
    for (int k = 0; k < info.grids[1].xsize; k++) std::cout << info.grids[1].xvalues[k] << ' ';
  else
    std::cout << "No XValues!" << std::endl;
  std::cout << std::endl;
  std::cout << "#===============================" << std::endl;
  varno = 4;
  info.variables[varno].sinfo();
  var = info.variables[varno];
  var = info.var["tsurf"];
  // var = info.varByCode[176];
  var.sinfo();
  std::cout << "#===============================" << std::endl;
  std::cout << "Gridname:" << var.grid.name << std::endl;
  std::cout << "GridBounds: NumberOfCorners = " << var.grid.ncorner << std::endl;
  if (var.grid.hasYValues)
  {
    float *xvals = (float *) malloc(var.grid.xsize * sizeof(float));
    float *yvals = (float *) malloc(var.grid.ysize * sizeof(float));
    var.grid.getFloatVals(xvals, yvals);
    std::cout << "xvals " << xvals[0] << std::endl;
    std::cout << "yvals " << yvals[0] << std::endl;
    std::cout << "xvalues " << var.grid.xvalues[0] << std::endl;
    std::cout << "xvalues " << var.grid.xvalues.front() << std::endl;
    std::cout << "xvalues " << var.grid.xvalues.back() << std::endl;
  }
  else
    std::cout << "no grid values available" << std::endl;
  if (var.grid.hasBounds)
  {
    float *xbnds = (float *) malloc(var.grid.size * var.grid.ncorner * sizeof(float));
    float *ybnds = (float *) malloc(var.grid.size * var.grid.ncorner * sizeof(float));
    var.grid.getFloatBounds(xbnds, ybnds);
    std::cout << "xbnds " << xbnds[var.grid.size * var.grid.ncorner - 1] << std::endl;
    std::cout << "ybnds " << ybnds[var.grid.size * var.grid.ncorner - 1] << std::endl;
    std::cout << "xbounds " << var.grid.xbounds[0] << std::endl;
    std::cout << "xbounds " << var.grid.xbounds.front() << std::endl;
    std::cout << "xbounds " << var.grid.xbounds.back() << std::endl;
  }
  else
    std::cout << "no grid bounds available" << std::endl;
  {
    std::cout << "#===============================" << std::endl;
    printf("Stream:%d\n", var.streamID);
    printf("Taxis (unit):%d\n", var.taxis.unit);
    printf("Taxis (ntsteps):%d\n", var.taxis.ntsteps);
    printf("Taxis (type):%d\n", var.taxis.type);
    printf("Zaxis (unit):%d\n", var.taxis.unit);
    printf("Zaxis (levels):%d\n", var.zaxis.size);
    printf("Zaxis (type):%d\n", var.zaxis.type);
    printf("Zaxis (ltype):%d\n", var.zaxis.ltype);
    printf("Zaxis (prec):%d\n", var.zaxis.prec);
    printf("Zaxis (levels): varno:%f -1:%f\n", var.zaxis.levels[varno], var.zaxis.levels[var.zaxis.size - 1]);
  }
  std::cout << "# field values ================" << std::endl;
  var.getValues();
  std::cout << "values[0]  = " << var.values[0] << std::endl;
  std::cout << "values.back() = " << var.values.back() << std::endl;
  std::cout << "# field values on different levels ================" << std::endl;
  var.getValuesWithLevel();
  for (int ilev = 0; ilev < var.zaxis.size; ilev++)
  {
    std::cout << "Level:" << ilev << std::endl;
    std::cout << "valuesWithLevel[" << ilev << "][0]  = " << var.valuesWithLevel[ilev][0] << ' ';
    std::cout << "valuesWithLevel[" << ilev << "][-1] = " << var.valuesWithLevel[ilev][var.grid.size - 1] << std::endl;
  }
  std::cout << "# field values (FLOAT) ================" << std::endl;
  std::vector<float> floats;
  floats = var.getFValues();
  std::cout << "floats[0]  = " << floats[0] << std::endl;
  std::cout << "floats.back() = " << floats.back() << std::endl;

  std::cout << "# field values on different levels (FLOAT) ================" << std::endl;
  std::vector<std::vector<float>> floatsWithLevel;
  floatsWithLevel = var.getFValuesWithLevel();
  for (int i = 0; i < floatsWithLevel.size(); ++i)
  {
    std::cout << "floatsWithLevel[" << i << "] = " << floatsWithLevel[i].front() << ' ' << floatsWithLevel[i].back() << std::endl;
  }

  std::cout << "#===============================" << std::endl;
  std::cout << "#== Reading from the var map ===" << std::endl;
  _name = info.variables[varno + 10].name;
  std::cout << "#== Use var: " << _name << " ==== (code " << info.variables[varno + 10].code << ")" << std::endl;
  var = info.var[_name];
  std::cout << "#==== longname: " << var.longname << std::endl;
  std::cout << "#==== code:     " << var.code << std::endl;
  std::cout << "#==== size:     " << var.size << std::endl;
  std::cout << "#==== gridtype: " << var.grid.type << std::endl;
  std::cout << "#==== unit:     " << var.units << std::endl;
  std::cout << "#==== zdim Name:" << var.zaxis.name << std::endl;
  std::cout << "#==== zlevels:  " << var.zaxis.size << std::endl;
  std::cout << "#===============================" << std::endl;

  /*   var = infot.varByCode[176];
   *   std::cout << var.name << std::endl;
   *   std::cout << "grid XValues: "; std::vector<double> xv = var.grid.xvalues; for (int k = 0; k < xv.size(); k++) { std::cout <<
   * xv[k] << " ";} std::cout << std::endl; std::cout << "grid YValues: "; std::vector<double> yv = var.grid.yvalues; for (int k =
   * 0; k < yv.size(); k++) { std::cout << yv[k] << " ";} std::cout << std::endl; var = infoz.varByCode[176]; std::cout << var.name
   * << std::endl; std::cout << "grid XValues: "; xv = var.grid.xvalues; for (int k = 0; k < xv.size(); k++) { std::cout << xv[k] <<
   * " ";} std::cout << std::endl; std::cout << "grid YValues: "; yv = var.grid.yvalues; for (int k = 0; k < yv.size(); k++) {
   * std::cout << yv[k] << " ";} std::cout << std::endl;
   */

  return 0;
}