time_series_custom.cpp

Example for the RDM::TIME_SERIES::custom template class. This example needs a compiled schema, time_series_custom.sdl.

This example also uses the RDM::TIME_SERIES::stat and RDM::TIME_SERIES::insert_row classes. If you are interesed in how to use those classes we suggest that you instead look at the time_series_stat.cpp example.

Here we use a scema with a table that have some of the required columns for a stat result set as produced by the RDM::TIME_SERIES::stat class stripped away. We therefor explicitly declate the needed type for the RDM::TIME_SERIES::stat class and use an extension of the RDM::TIME_SERIES::custom class that can do the convert. This convert class has only one method. We have crafted it as a template methode making it slightly more general. However, in our case here, it would have been sufficient to use a normal method.

#include "rdmtimeseries.h"
#include "time_series_custom_structs.h"
#include <math.h>
typedef struct
{
uint64_t time_stamp_first;
uint64_t time_stamp_last;
uint64_t n;
double value_sum;
double value_sum2;
} MEASUREMENT_STAT;
using namespace RDM_CPP::TIME_SERIES_CUSTOM;
using namespace RDM::TIME_SERIES;
template <class NEXT>
class strip : public RDM::TIME_SERIES::custom<NEXT>
{
public:
template <class SOURCE_STAT_T>
RDM_RETCODE put_stat (SOURCE_STAT_T *source_stat,
)
{
MEASUREMENT_STAT_CUSTOM custom_stat =
{source_stat->time_stamp_last,
source_stat->n,
source_stat->value_sum};
RDM_RETCODE rc = custom<NEXT>::put_stat (&custom_stat, transactional);
return rc;
}
};
static RDM_RETCODE timeSeriesCustom (RDM_DB db)
{
stat <32, MEASUREMENT_STAT,
strip <insert_row <TABLE_MEASUREMENT_STAT_CUSTOM>>>
ts_chain;
RDM_RETCODE rc = ts_chain.init (db);
for (uint64_t time_stamp = 0; rc == sOKAY && time_stamp < 128; time_stamp++)
{
const double tau = 6.283185307179586;
const double signal = sin (tau * time_stamp / 50);
MEASUREMENT measurement = {time_stamp, signal};
rc = ts_chain.put_value (&measurement);
}
return rc;
}