#ifndef SCIQLOP_DATASERIES_H #define SCIQLOP_DATASERIES_H #include #include #include #include Q_DECLARE_LOGGING_CATEGORY(LOG_DataSeries) Q_LOGGING_CATEGORY(LOG_DataSeries, "DataSeries") /** * @brief The DataSeries class is the base (abstract) implementation of IDataSeries. * * It proposes to set a dimension for the values ​​data * * @tparam Dim The dimension of the values data * */ template class DataSeries : public IDataSeries { public: /// @sa IDataSeries::xAxisData() std::shared_ptr > xAxisData() override { return m_XAxisData; } /// @sa IDataSeries::xAxisUnit() Unit xAxisUnit() const override { return m_XAxisUnit; } /// @return the values dataset std::shared_ptr > valuesData() const { return m_ValuesData; } /// @sa IDataSeries::valuesUnit() Unit valuesUnit() const override { return m_ValuesUnit; } /// @sa IDataSeries::merge() void merge(IDataSeries *dataSeries) override { if (auto dimDataSeries = dynamic_cast *>(dataSeries)) { m_XAxisData->merge(*dimDataSeries->xAxisData()); m_ValuesData->merge(*dimDataSeries->valuesData()); } else { qCWarning(LOG_DataSeries()) << QObject::tr("Dection of a type of IDataSeries we cannot merge with !"); } } protected: /// Protected ctor (DataSeries is abstract) explicit DataSeries(std::shared_ptr > xAxisData, const Unit &xAxisUnit, std::shared_ptr > valuesData, const Unit &valuesUnit) : m_XAxisData{xAxisData}, m_XAxisUnit{xAxisUnit}, m_ValuesData{valuesData}, m_ValuesUnit{valuesUnit} { } private: std::shared_ptr > m_XAxisData; Unit m_XAxisUnit; std::shared_ptr > m_ValuesData; Unit m_ValuesUnit; }; #endif // SCIQLOP_DATASERIES_H