///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2022 Equinor // // 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 "RiaDateTimeDefines.h" #include "RifEclipseSummaryAddress.h" #include class RimSummaryCurve; class RimGridTimeHistoryCurve; class RimAsciiDataCurve; struct CurveData { QString name; RifEclipseSummaryAddress address; std::vector values; }; enum class SummaryCurveType { CURVE_TYPE_GRID = 0x1, CURVE_TYPE_OBSERVED = 0x2 }; enum class ResampleAlgorithm { NONE, DATA_DECIDES, PERIOD_END }; class RimSummaryCurvesData { public: RimSummaryCurvesData(); void clear(); void addCurveData( const QString& caseName, const QString& ensembleName, const std::vector& curvetimeSteps, const CurveData& curveData ); void addCurveDataNoSearch( const QString& caseName, const QString& ensembleName, const std::vector& curvetimeSteps, const std::vector& curveDataVector ); static QString createTextForExport( const std::vector& curves, const std::vector& asciiCurves, const std::vector& gridCurves, RiaDefines::DateTimePeriod resamplingPeriod, bool showTimeAsLongString ); private: static void populateSummaryCurvesData( std::vector curves, SummaryCurveType curveType, RimSummaryCurvesData* curvesData ); static void populateTimeHistoryCurvesData( std::vector curves, RimSummaryCurvesData* curvesData ); static void populateAsciiDataCurvesData( std::vector curves, RimSummaryCurvesData* curvesData ); static void prepareCaseCurvesForExport( RiaDefines::DateTimePeriod period, ResampleAlgorithm algorithm, const RimSummaryCurvesData& inputCurvesData, RimSummaryCurvesData* resultCurvesData ); static void appendToExportDataForCase( QString& out, const std::vector& timeSteps, const std::vector& curveData ); static void appendToExportData( QString& out, const std::vector& curvesData, bool showTimeAsLongString ); RimSummaryCurvesData static concatCurvesData( const std::vector& curvesData ); private: size_t findCaseIndexForCaseId( const QString& caseId, size_t timeStepCount ); QString createCaseId( const QString& caseName, const QString& ensembleName ); public: RiaDefines::DateTimePeriod resamplePeriod; std::vector caseIds; std::vector> timeSteps; std::vector> allCurveData; };