CosinusProvider.cpp
47 lines
| 1.4 KiB
| text/x-c
|
CppLexer
Alexandre Leroux
|
r128 | #include "CosinusProvider.h" | ||
#include <Data/DataProviderParameters.h> | ||||
#include <Data/ScalarSeries.h> | ||||
r135 | #include <cmath> | |||
r298 | #include <QDateTime> | |||
r231 | Q_LOGGING_CATEGORY(LOG_CosinusProvider, "CosinusProvider") | |||
Alexandre Leroux
|
r310 | std::shared_ptr<IDataSeries> | ||
Alexandre Leroux
|
r128 | CosinusProvider::retrieveData(const DataProviderParameters ¶meters) const | ||
{ | ||||
r191 | auto dateTime = parameters.m_Time; | |||
r298 | auto dataIndex = 0; | |||
r231 | ||||
// Gets the timerange from the parameters | ||||
r298 | double freq = 100.0; | |||
double start = dateTime.m_TStart * freq; // 100 htz | ||||
double end = dateTime.m_TEnd * freq; // 100 htz | ||||
r231 | ||||
// 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 | ||||
= std::make_shared<ScalarSeries>(end - start, Unit{QStringLiteral("t"), true}, Unit{}); | ||||
for (auto time = start; time < end; ++time, ++dataIndex) { | ||||
r298 | const auto timeOnFreq = time / freq; | |||
scalarSeries->setData(dataIndex, timeOnFreq, std::cos(timeOnFreq)); | ||||
r231 | } | |||
Alexandre Leroux
|
r128 | return scalarSeries; | ||
} | ||||
Alexandre Leroux
|
r310 | |||
void CosinusProvider::requestDataLoading(const QVector<SqpDateTime> &dateTimeList) | ||||
{ | ||||
// NOTE: Try to use multithread if possible | ||||
for (const auto &dateTime : dateTimeList) { | ||||
auto scalarSeries = this->retrieveData(DataProviderParameters{dateTime}); | ||||
emit dataProvided(scalarSeries, dateTime); | ||||
} | ||||
} | ||||