File: temporalRepresentation2TimeSeries.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 (72 lines) | stat: -rw-r--r-- 2,469 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
/***********************************************/
/**
* @file temporalRepresentation2TimeSeries.cpp
*
* @brief Design matrix of temporal representation.
*
* @author Torsten Mayer-Guerr
* @date 2015-07-07
*/
/***********************************************/

// Latex documentation
#define DOCSTRING docstring
static const char *docstring = R"(
This program computes the design matrix of temporal representation at a given time series.
The output matrix contains the time steps in MJD in the first column, the other columns contain the design matrix.
The intention of this program is to visualize the parametrization together with \program{PlotGraph}.
)";

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

#include "programs/program.h"
#include "files/fileMatrix.h"
#include "classes/timeSeries/timeSeries.h"
#include "classes/parametrizationTemporal/parametrizationTemporal.h"

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

/** @brief Design matrix of temporal representation.
* @ingroup programsGroup */
class TemporalRepresentation2TimeSeries
{
public:
  void run(Config &config, Parallel::CommunicatorPtr comm);
};

GROOPS_REGISTER_PROGRAM(TemporalRepresentation2TimeSeries, SINGLEPROCESS, "Design matrix of temporal representation.", Misc, TimeSeries)

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

void TemporalRepresentation2TimeSeries::run(Config &config, Parallel::CommunicatorPtr /*comm*/)
{
  try
  {
    FileName                   fileNameMatrix;
    TimeSeriesPtr              timeSeries;
    ParametrizationTemporalPtr temporal;

    readConfig(config, "outputfileMatrix", fileNameMatrix, Config::MUSTSET, "", "Time (MJD) in first column, design matrix follows");
    readConfig(config, "timeSeries",       timeSeries,     Config::MUSTSET,  "", "");
    readConfig(config, "temporal",         temporal,       Config::MUSTSET,  "", "");
    if(isCreateSchema(config)) return;

    logStatus<<"Compute design matrix"<<Log::endl;
    std::vector<Time> times = timeSeries->times();
    Matrix A(times.size(), 1+temporal->parameterCount());
    for(UInt i=0; i<times.size(); i++)
    {
      A(i,0) = times.at(i).mjd();
      copy(temporal->factors(times.at(i)).trans(), A.slice(i,1,1,temporal->parameterCount()));
    }

    logStatus<<"write matrix to file <"<<fileNameMatrix<<">"<<Log::endl;
    writeFileMatrix(fileNameMatrix, A);
  }
  catch(std::exception &e)
  {
    GROOPS_RETHROW(e)
  }
}

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