CosinusProvider.cpp
32 lines
| 871 B
| text/x-c
|
CppLexer
Alexandre Leroux
|
r120 | #include "CosinusProvider.h" | ||
#include <Data/DataProviderParameters.h> | ||||
#include <Data/ScalarSeries.h> | ||||
r127 | #include <cmath> | |||
Alexandre Leroux
|
r120 | std::unique_ptr<IDataSeries> | ||
CosinusProvider::retrieveData(const DataProviderParameters ¶meters) const | ||||
{ | ||||
r177 | auto dateTime = parameters.m_Time; | |||
Alexandre Leroux
|
r120 | // Gets the timerange from the parameters | ||
r177 | auto start = dateTime.m_TStart; | |||
auto end = dateTime.m_TEnd; | ||||
Alexandre Leroux
|
r120 | |||
// We assure that timerange is valid | ||||
if (end < start) { | ||||
std::swap(start, end); | ||||
} | ||||
// Generates scalar series containing cosinus values (one value per second) | ||||
auto scalarSeries | ||||
Alexandre Leroux
|
r164 | = std::make_unique<ScalarSeries>(end - start, Unit{QStringLiteral("t"), true}, Unit{}); | ||
Alexandre Leroux
|
r120 | |||
Alexandre Leroux
|
r129 | auto dataIndex = 0; | ||
for (auto time = start; time < end; ++time, ++dataIndex) { | ||||
Alexandre Leroux
|
r120 | scalarSeries->setData(dataIndex, time, std::cos(time)); | ||
} | ||||
return scalarSeries; | ||||
} | ||||