IDataSeries.h
96 lines
| 3.3 KiB
| text/x-c
|
CLexer
Alexandre Leroux
|
r125 | #ifndef SCIQLOP_IDATASERIES_H | ||
#define SCIQLOP_IDATASERIES_H | ||||
Alexandre Leroux
|
r308 | #include <Common/MetaTypes.h> | ||
Alexandre Leroux
|
r597 | #include <Data/DataSeriesIterator.h> | ||
r539 | #include <Data/SqpRange.h> | |||
Alexandre Leroux
|
r858 | #include <Data/Unit.h> | ||
Alexandre Leroux
|
r125 | |||
#include <memory> | ||||
r233 | #include <QString> | |||
Alexandre Leroux
|
r125 | template <int Dim> | ||
class ArrayData; | ||||
/** | ||||
* @brief The IDataSeries aims to declare a data series. | ||||
* | ||||
* A data series is an entity that contains at least : | ||||
* - one dataset representing the x-axis | ||||
* - one dataset representing the values | ||||
* | ||||
* Each dataset is represented by an ArrayData, and is associated with a unit. | ||||
* | ||||
* An ArrayData can be unidimensional or two-dimensional, depending on the implementation of the | ||||
* IDataSeries. The x-axis dataset is always unidimensional. | ||||
* | ||||
* @sa ArrayData | ||||
*/ | ||||
class IDataSeries { | ||||
public: | ||||
virtual ~IDataSeries() noexcept = default; | ||||
/// Returns the x-axis dataset | ||||
virtual std::shared_ptr<ArrayData<1> > xAxisData() = 0; | ||||
Alexandre Leroux
|
r310 | /// Returns the x-axis dataset (as const) | ||
virtual const std::shared_ptr<ArrayData<1> > xAxisData() const = 0; | ||||
Alexandre Leroux
|
r177 | virtual Unit xAxisUnit() const = 0; | ||
Alexandre Leroux
|
r125 | |||
Alexandre Leroux
|
r177 | virtual Unit valuesUnit() const = 0; | ||
r233 | ||||
virtual void merge(IDataSeries *dataSeries) = 0; | ||||
Alexandre Leroux
|
r676 | /// Removes from data series all entries whose value on the x-axis is not between min and max | ||
virtual void purge(double min, double max) = 0; | ||||
Alexandre Leroux
|
r554 | /// @todo Review the name and signature of this method | ||
virtual std::shared_ptr<IDataSeries> subDataSeries(const SqpRange &range) = 0; | ||||
Alexandre Leroux
|
r310 | |||
virtual std::unique_ptr<IDataSeries> clone() const = 0; | ||||
Alexandre Leroux
|
r717 | |||
/// @return the total number of points contained in the data series | ||||
virtual int nbPoints() const = 0; | ||||
Alexandre Leroux
|
r597 | // ///////// // | ||
// Iterators // | ||||
// ///////// // | ||||
virtual DataSeriesIterator cbegin() const = 0; | ||||
virtual DataSeriesIterator cend() const = 0; | ||||
Alexandre Leroux
|
r673 | virtual DataSeriesIterator begin() = 0; | ||
virtual DataSeriesIterator end() = 0; | ||||
Alexandre Leroux
|
r597 | |||
Alexandre Leroux
|
r599 | /// @return the iterator to the first entry of the data series whose x-axis data is greater than | ||
/// or equal to the value passed in parameter, or the end iterator if there is no matching value | ||||
Alexandre Leroux
|
r604 | virtual DataSeriesIterator minXAxisData(double minXAxisData) const = 0; | ||
Alexandre Leroux
|
r599 | |||
Alexandre Leroux
|
r600 | /// @return the iterator to the last entry of the data series whose x-axis data is less than or | ||
/// equal to the value passed in parameter, or the end iterator if there is no matching value | ||||
Alexandre Leroux
|
r604 | virtual DataSeriesIterator maxXAxisData(double maxXAxisData) const = 0; | ||
Alexandre Leroux
|
r600 | |||
Alexandre Leroux
|
r605 | /// @return the iterators pointing to the range of data whose x-axis values are between min and | ||
/// max passed in parameters | ||||
virtual std::pair<DataSeriesIterator, DataSeriesIterator> | ||||
xAxisRange(double minXAxisData, double maxXAxisData) const = 0; | ||||
Alexandre Leroux
|
r597 | |||
Alexandre Leroux
|
r608 | /// @return two iterators pointing to the data that have respectively the min and the max value | ||
/// data of a data series' range. The search is performed for a given x-axis range. | ||||
/// @sa xAxisRange() | ||||
virtual std::pair<DataSeriesIterator, DataSeriesIterator> | ||||
valuesBounds(double minXAxisData, double maxXAxisData) const = 0; | ||||
Alexandre Leroux
|
r597 | // /////// // | ||
// Mutexes // | ||||
// /////// // | ||||
r364 | virtual void lockRead() = 0; | |||
virtual void lockWrite() = 0; | ||||
virtual void unlock() = 0; | ||||
Alexandre Leroux
|
r125 | }; | ||
r233 | // Required for using shared_ptr in signals/slots | |||
Alexandre Leroux
|
r308 | SCIQLOP_REGISTER_META_TYPE(IDATASERIES_PTR_REGISTRY, std::shared_ptr<IDataSeries>) | ||
r233 | ||||
Alexandre Leroux
|
r125 | #endif // SCIQLOP_IDATASERIES_H | ||