///////////////////////////////////////////////////////////////////////////////// // // 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 "RifEclipseSummaryAddress.h" #include #include #include #include class RimSummaryCase; class RimSummaryCaseCollection; //================================================================================================== /// //================================================================================================== class RiaSummaryCurveDefinition { public: RiaSummaryCurveDefinition(); explicit RiaSummaryCurveDefinition( gsl::not_null summaryCase, const RifEclipseSummaryAddress& summaryAddress, bool isEnsembleCurve ); explicit RiaSummaryCurveDefinition( gsl::not_null ensemble, const RifEclipseSummaryAddress& summaryAddress ); RimSummaryCase* summaryCase() const; const RifEclipseSummaryAddress& summaryAddress() const; RimSummaryCaseCollection* ensemble() const; bool isEnsembleCurve() const; bool operator<( const RiaSummaryCurveDefinition& other ) const; // TODO: Consider moving to a separate tools class static void resultValues( const RiaSummaryCurveDefinition& curveDefinition, gsl::not_null*> values ); static const std::vector& timeSteps( const RiaSummaryCurveDefinition& curveDefinition ); QString curveDefinitionText() const; static QString curveDefinitionText( const QString& caseName, const RifEclipseSummaryAddress& summaryAddress ); private: RimSummaryCase* m_summaryCase; RifEclipseSummaryAddress m_summaryAddress; RimSummaryCaseCollection* m_ensemble; bool m_isEnsembleCurve; }; class RiaSummaryCurveDefinitionAnalyser { public: RiaSummaryCurveDefinitionAnalyser() = default; void setCurveDefinitions( const std::vector& curveDefs ); std::set m_singleSummaryCases; // All summary cases used std::set m_ensembles; // All the ensembles referenced by the summary cases std::set m_summaryAdresses; std::set m_quantityNames; // Quantity names from the addresses };