File: gravityfield2GriddedData.cpp

package info (click to toggle)
groops 0%2Bgit20250907%2Bds-1
  • links: PTS, VCS
  • area: non-free
  • in suites: forky, sid
  • size: 11,140 kB
  • sloc: cpp: 135,607; fortran: 1,603; makefile: 20
file content (94 lines) | stat: -rw-r--r-- 4,188 bytes parent folder | download | duplicates (2)
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
/***********************************************/
/**
* @file gravityfield2GriddedData.cpp
*
* @brief Values of a gravity field on a grid.
*
* @author Torsten Mayer-Guerr
* @date 2002-03-19
*/
/***********************************************/

// Latex documentation
#define DOCSTRING docstring
static const char *docstring = R"(
This program computes values of a \configClass{gravityfield}{gravityfieldType} on a given \configClass{grid}{gridType}.
The type of value (e.g gravity anomalies or geoid heights) can be choosen with \configClass{kernel}{kernelType}.
If a time is given the gravity field will be evaluated at this point of time otherwise only the static part will be used.
The values will be saved together with points expressed as ellipsoidal coordinates (longitude, latitude, height)
based on a reference ellipsoid with parameters \config{R} and \config{inverseFlattening}.
To speed up the computation the gravity field can be converted to spherical harmonics before the computation
with \config{convertToHarmonics}.

To visualize the results use \program{PlotMap}.
)";

/***********************************************/

#include "programs/program.h"
#include "files/fileGriddedData.h"
#include "classes/grid/grid.h"
#include "classes/kernel/kernel.h"
#include "classes/gravityfield/gravityfield.h"
#include "misc/miscGriddedData.h"

/***** CLASS ***********************************/

/** @brief Values of a gravity field on a grid.
* @ingroup programsGroup */
class Gravityfield2GriddedData
{
public:
  void run(Config &config, Parallel::CommunicatorPtr comm);
};

GROOPS_REGISTER_PROGRAM(Gravityfield2GriddedData, PARALLEL, "values of a gravity field on a grid.", Gravityfield, Grid, Covariance)

/***********************************************/

void Gravityfield2GriddedData::run(Config &config, Parallel::CommunicatorPtr comm)
{
  try
  {
    FileName          fileNameGrid;
    GridPtr           grid;
    KernelPtr         kernel;
    GravityfieldPtr   gravityfield;
    Time              time;
    Double            a, f;
    Bool              convertToHarmonics;

    readConfig(config, "outputfileGriddedData", fileNameGrid,       Config::MUSTSET,  "", "");
    readConfig(config, "grid",                  grid,               Config::MUSTSET,  "", "");
    readConfig(config, "kernel",                kernel,             Config::MUSTSET,  "", "");
    readConfig(config, "gravityfield",          gravityfield,       Config::MUSTSET,  "", "");
    readConfig(config, "convertToHarmonics",    convertToHarmonics, Config::DEFAULT,   "1", "gravityfield is converted to spherical harmonics before evaluation, may accelerate the computation");
    readConfig(config, "time",                  time,               Config::OPTIONAL,  "", "at this time the gravity field will be evaluated");
    readConfig(config, "R",                     a,                  Config::DEFAULT,   STRING_DEFAULT_GRS80_a, "reference radius for ellipsoidal coordinates on output");
    readConfig(config, "inverseFlattening",     f,                  Config::DEFAULT,   STRING_DEFAULT_GRS80_f, "reference flattening for ellipsoidal coordinates on output, 0: spherical coordinates");
    if(isCreateSchema(config)) return;

    // Create values on grid
    // ---------------------
    logStatus<<"create values on grid"<<Log::endl;
    std::vector<Double> field(grid->points().size());
    if(!convertToHarmonics) // All representations, all point distributions
      Parallel::forEach(field, [&](UInt i){return gravityfield->field(time, grid->points().at(i), *kernel);}, comm);
    else // fast version
      field = MiscGriddedData::synthesisSphericalHarmonics(gravityfield->sphericalHarmonics(time), grid->points(), kernel, comm);

    if(Parallel::isMaster(comm))
    {
      logStatus<<"save values to file <"<<fileNameGrid<<">"<<Log::endl;
      GriddedData griddedData(Ellipsoid(a,f), grid->points(), grid->areas(), {field});
      writeFileGriddedData(fileNameGrid, griddedData);
      MiscGriddedData::printStatistics(griddedData);
    } // if(Parallel::isMaster(comm))
  }
  catch(std::exception &e)
  {
    GROOPS_RETHROW(e)
  }
}

/***********************************************/