///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2016- 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 "RiaDefines.h" #include "RifEclipseSummaryAddress.h" #include "RigEnsembleParameter.h" #include "RimObjectiveFunction.h" #include "cafPdmChildArrayField.h" #include "cafPdmChildField.h" #include "cafPdmField.h" #include "cafPdmObject.h" #include "cafPdmProxyValueField.h" #include "cvfObject.h" #include #include #include #include class RifReaderRftInterface; class RifReaderEnsembleStatisticsRft; class RimSummaryCase; class RimSummaryAddressCollection; class RiaSummaryAddressAnalyzer; //================================================================================================== /// //================================================================================================== class RimSummaryCaseCollection : public caf::PdmObject { CAF_PDM_HEADER_INIT; public: caf::Signal<> caseNameChanged; caf::Signal caseRemoved; public: RimSummaryCaseCollection(); ~RimSummaryCaseCollection() override; void removeCase( RimSummaryCase* summaryCase, bool notifyChange = true ); void addCase( RimSummaryCase* summaryCase ); virtual std::vector allSummaryCases() const; RimSummaryCase* firstSummaryCase() const; void setName( const QString& name ); QString name() const; bool isEnsemble() const; void setAsEnsemble( bool isEnsemble ); virtual std::set ensembleSummaryAddresses() const; virtual std::set ensembleTimeSteps() const; std::set wellsWithRftData() const; std::set rftTimeStepsForWell( const QString& wellName ) const; RifReaderRftInterface* rftStatisticsReader(); void setEnsembleId( int ensembleId ); int ensembleId() const; bool hasEnsembleParameters() const; std::vector variationSortedEnsembleParameters( bool excludeNoVariation = false ) const; std::vector> correlationSortedEnsembleParameters( const RifEclipseSummaryAddress& address ) const; std::vector> correlationSortedEnsembleParameters( const RifEclipseSummaryAddress& address, time_t selectedTimeStep ) const; std::vector> parameterCorrelations( const RifEclipseSummaryAddress& address, time_t selectedTimeStep, const std::vector& selectedParameters = {}, const std::set& selectedCases = {} ) const; std::vector> parameterCorrelationsAllTimeSteps( const RifEclipseSummaryAddress& address, const std::vector& selectedParameters = {} ) const; std::vector alphabeticEnsembleParameters() const; RigEnsembleParameter ensembleParameter( const QString& paramName ) const; void calculateEnsembleParametersIntersectionHash(); void clearEnsembleParametersHashes(); void loadDataAndUpdate(); static bool validateEnsembleCases( const std::vector cases ); bool operator<( const RimSummaryCaseCollection& rhs ) const; RiaDefines::EclipseUnitSystem unitSystem() const; void refreshMetaData(); void updateReferringCurveSets(); RiaSummaryAddressAnalyzer* addressAnalyzer(); void computeMinMax( const RifEclipseSummaryAddress& address ); void setMinMax( const RifEclipseSummaryAddress& address, double min, double max ); std::pair minMax( const RifEclipseSummaryAddress& address ); private: RigEnsembleParameter createEnsembleParameter( const QString& paramName ) const; static void sortByBinnedVariation( std::vector& parameterVector ); friend class RimSummaryCaseCollection_TESTER; caf::PdmFieldHandle* userDescriptionField() override; QString nameAndItemCount() const; void updateIcon(); void initAfterRead() override; void fieldChangedByUi( const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue ) override; void onCaseNameChanged( const SignalEmitter* emitter ); void buildChildNodes(); void clearChildNodes(); protected: virtual void onLoadDataAndUpdate(); void defineUiOrdering( QString uiConfigName, caf::PdmUiOrdering& uiOrdering ) override; void defineUiTreeOrdering( caf::PdmUiTreeOrdering& uiTreeOrdering, QString uiConfigName = "" ) override; void setNameAsReadOnly(); caf::PdmChildArrayField m_cases; private: caf::PdmField m_name; caf::PdmProxyValueField m_nameAndItemCount; caf::PdmField m_isEnsemble; caf::PdmChildField m_dataVectorFolders; cvf::ref m_statisticsEclipseRftReader; caf::PdmField m_ensembleId; size_t m_commonAddressCount; // if different address count among cases, set to 0 mutable std::vector m_cachedSortedEnsembleParameters; std::unique_ptr m_analyzer; std::map> m_minMaxValues; };