///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2017 Statoil ASA // // ResInsight is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // ResInsight is distributed in the hope that it will be useful, but WITHOUT ANY // WARRANTY; without even the implied warranty of MERCHANTABILITY or // FITNESS FOR A PARTICULAR PURPOSE. // // See the GNU General Public License at // for more details. // ///////////////////////////////////////////////////////////////////////////////// #pragma once #include "RiaCurveDataTools.h" #include "RiaDateTimeDefines.h" #include //================================================================================================== /// //================================================================================================== class RiaTimeHistoryCurveResampler { public: RiaTimeHistoryCurveResampler(); void setCurveData( const std::vector& values, const std::vector& timeSteps ); void resampleAndComputePeriodEndValues( RiaDefines::DateTimePeriod period ); void resampleAndComputeWeightedMeanValues( RiaDefines::DateTimePeriod period ); const std::vector& resampledTimeSteps() const; const std::vector& resampledValues() const; static std::vector timeStepsFromTimeRange( RiaDefines::DateTimePeriod period, time_t minTime, time_t maxTime ); private: void computeWeightedMeanValues( RiaDefines::DateTimePeriod period ); void computePeriodEndValues( RiaDefines::DateTimePeriod period ); void clearData(); void computeResampledTimeSteps( RiaDefines::DateTimePeriod period ); static QDateTime firstResampledTimeStep( const QDateTime& firstTimestep, RiaDefines::DateTimePeriod period ); inline double interpolatedValue( time_t t, time_t t1, double v1, time_t t2, double v2 ); private: std::pair, std::vector> m_originalValues; std::vector m_timeSteps; std::vector m_values; };