///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2023- Equinor 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 "RimPlotCurve.h" //================================================================================================== /// /// //================================================================================================== class RimGridCrossPlotRegressionCurve : public RimPlotCurve { CAF_PDM_HEADER_INIT; public: enum class RegressionType { LINEAR, POLYNOMIAL, POWER_FIT, EXPONENTIAL, LOGARITHMIC, LOGISTIC }; RimGridCrossPlotRegressionCurve(); ~RimGridCrossPlotRegressionCurve() override = default; void setGroupingInformation( int dataSetIndex, int groupIndex ); void setSamples( const std::vector& xValues, const std::vector& yValues ); void setRangeDefaults( const std::vector& xValues, const std::vector& yValues ); void updateCurveAppearance() override; void setCurveAutoAppearance(); int groupIndex() const; size_t sampleCount() const; void determineLegendIcon(); void setBlackAndWhiteLegendIcons( bool blackAndWhite ); QString getRegressionTypeString() const; void swapAxis(); protected: void updateZoomInParentPlot() override; QString createCurveAutoName() override; void onLoadDataAndUpdate( bool updateParentPlot ) override; void defineUiOrdering( QString uiConfigName, caf::PdmUiOrdering& uiOrdering ) override; void defineObjectEditorAttribute( QString uiConfigName, caf::PdmUiEditorAttribute* attribute ) override; void defineEditorAttribute( const caf::PdmFieldHandle* field, QString uiConfigName, caf::PdmUiEditorAttribute* attribute ) override; void fieldChangedByUi( const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue ) override; void updateRectAnnotation(); std::tuple, std::vector, QString> calculateRegression( RimGridCrossPlotRegressionCurve::RegressionType regressionType, const std::vector& xValues, const std::vector& yValues, const std::vector& outputXValues ) const; static std::pair, std::vector> getPositiveValues( const std::vector& xValues, const std::vector& yValues ); private: caf::PdmField> m_regressionType; caf::PdmField m_minRangeX; caf::PdmField m_maxRangeX; caf::PdmField m_minRangeY; caf::PdmField m_maxRangeY; caf::PdmField m_showDataSelectionInPlot; caf::PdmField m_polynomialDegree; caf::PdmField m_expressionText; caf::PdmField m_minExtrapolationRangeX; caf::PdmField m_maxExtrapolationRangeX; std::pair m_dataRangeX; std::pair m_dataRangeY; int m_dataSetIndex; int m_groupIndex; };