///////////////////////////////////////////////////////////////////////////////// // // 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 "RifEclipseSummaryAddress.h" #include "cafPdmChildArrayField.h" #include "cafPdmField.h" #include "cafPdmObject.h" #include "cafPdmProxyValueField.h" #include #include #include class RimSummaryCase; //================================================================================================== /// //================================================================================================== class EnsembleParameter { public: typedef std::pair NameParameterPair; enum Type { TYPE_NONE, TYPE_NUMERIC, TYPE_TEXT }; enum Bins { LOW_VARIATION, MEDIUM_VARIATION, HIGH_VARIATION, NR_OF_VARIATION_BINS }; QString name; Type type; std::vector values; double minValue; double maxValue; int variationBin; EnsembleParameter() : type(TYPE_NONE), minValue(std::numeric_limits::infinity()), maxValue(-std::numeric_limits::infinity()), variationBin(static_cast(MEDIUM_VARIATION)) {} bool isValid() const { return !name.isEmpty() && type != TYPE_NONE; } bool isNumeric() const { return type == TYPE_NUMERIC; } bool isText() const { return type == TYPE_TEXT; } double normalizedStdDeviation() const; static void sortByBinnedVariation(std::vector& parameterVector); private: double stdDeviation() const; }; //================================================================================================== /// //================================================================================================== class RimSummaryCaseCollection : public caf::PdmObject { CAF_PDM_HEADER_INIT; public: RimSummaryCaseCollection(); ~RimSummaryCaseCollection() override; void removeCase(RimSummaryCase* summaryCase); void addCase(RimSummaryCase* summaryCase, bool updateCurveSets = true); virtual std::vector allSummaryCases() const; void setName(const QString& name); QString name() const; bool isEnsemble() const; void setAsEnsemble(bool isEnsemble); virtual std::set ensembleSummaryAddresses() const; EnsembleParameter ensembleParameter(const QString& paramName) const; void calculateEnsembleParametersIntersectionHash(); void clearEnsembleParametersHashes(); void loadDataAndUpdate(); static bool validateEnsembleCases(const std::vector cases); bool operator<(const RimSummaryCaseCollection& rhs) const; private: 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; protected: virtual void onLoadDataAndUpdate(); void updateReferringCurveSets(); void defineUiOrdering(QString uiConfigName, caf::PdmUiOrdering& uiOrdering) override; void setNameAsReadOnly(); caf::PdmChildArrayField m_cases; private: caf::PdmField m_name; caf::PdmProxyValueField m_nameAndItemCount; caf::PdmField m_isEnsemble; size_t m_commonAddressCount; // if different address count among cases, set to 0 };