///////////////////////////////////////////////////////////////////////////////// // // 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 "RimWellLogCurve.h" #include "RifEclipseRftAddress.h" #include "cafAppEnum.h" #include "cafPdmField.h" #include "cafPdmPtrField.h" #include "cvfObject.h" #include #include class RifReaderRftInterface; class RigEclipseWellLogExtractor; class RimEclipseResultCase; class RimObservedFmuRftData; class RimSummaryCase; class RimSummaryCaseCollection; class RimWellPath; class RimPressureDepthData; //================================================================================================== /// /// //================================================================================================== class RimWellLogRftCurve : public RimWellLogCurve { CAF_PDM_HEADER_INIT; public: enum class RftDataType { RFT_DATA, RFT_SEGMENT_DATA }; private: enum class DerivedMDSource { NO_SOURCE, WELL_PATH, SEGMENT, OBSERVED_DATA }; public: RimWellLogRftCurve(); ~RimWellLogRftCurve() override; void setWellName( const QString& wellName ); QString wellName() const override; QString wellLogChannelUiName() const override; QString wellLogChannelUnits() const override; void setTimeStep( const QDateTime& dateTime ); QDateTime timeStep() const; void setSegmentBranchIndex( int branchIndex ); void setSegmentBranchType( RiaDefines::RftBranchType branchType ); void setEclipseResultCase( RimEclipseResultCase* eclipseResultCase ); RimEclipseResultCase* eclipseResultCase() const; void setSummaryCase( RimSummaryCase* summaryCase ); RimSummaryCase* summaryCase() const; void setEnsemble( RimSummaryCaseCollection* ensemble ); RimSummaryCaseCollection* ensemble() const; void setObservedFmuRftData( RimObservedFmuRftData* observedFmuRftData ); RimObservedFmuRftData* observedFmuRftData() const; void setPressureDepthData( RimPressureDepthData* observedFmuRftData ); RimPressureDepthData* pressureDepthData() const; void setRftAddress( RifEclipseRftAddress address ); RifEclipseRftAddress rftAddress() const; void setDefaultAddress( QString wellName ); void setSimWellBranchData( bool branchDetection, int branchIndex ); void enableColorFromResultName( bool enable ); void assignColorFromResultName( const QString& resultName ); void setScaleFactor( double factor ); protected: QString createCurveAutoName() override; QString createCurveNameFromTemplate( const QString& templateText ) override; QStringList supportedCurveNameVariables() const override; void onLoadDataAndUpdate( bool updateParentPlot ) override; RiaDefines::PhaseType phaseType() const override; // Pdm overrrides void defineUiOrdering( QString uiConfigName, caf::PdmUiOrdering& uiOrdering ) override; QList calculateValueOptions( const caf::PdmFieldHandle* fieldNeedingOptions ) override; void fieldChangedByUi( const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue ) override; std::vector perPointLabels() const; private: RifReaderRftInterface* rftReader() const; RigEclipseWellLogExtractor* extractor(); bool createWellPathIdxToRftFileIdxMapping(); size_t rftFileIndex( size_t wellPathIndex ); std::vector sortedIndicesInRftFile(); void updateWellChannelNameAndTimeStep(); std::map createCurveNameKeyValueMap() const; std::vector xValues(); std::vector errorValues(); std::vector tvDepthValues(); std::vector measuredDepthValues(); bool deriveMeasuredDepthValuesFromWellPath( const std::vector& tvDepthValues, std::vector& derivedMDValues ); bool deriveMeasuredDepthFromObservedData( const std::vector& tvDepthValues, std::vector& derivedMDValues ); int segmentBranchIndex() const; static bool isSegmentResult( const QString& resultName ); private: caf::PdmPtrField m_eclipseResultCase; caf::PdmPtrField m_summaryCase; caf::PdmPtrField m_ensemble; caf::PdmPtrField m_observedFmuRftData; caf::PdmPtrField m_pressureDepthData; caf::PdmField m_timeStep; caf::PdmField m_wellName; caf::PdmField m_branchIndex; caf::PdmField m_branchDetection; caf::PdmField m_curveColorByPhase; caf::PdmField m_scaleFactor; caf::PdmField> m_rftDataType; caf::PdmField m_segmentResultName; caf::PdmField m_segmentBranchIndex; caf::PdmField> m_segmentBranchType; std::map m_idxInWellPathToIdxInRftFile; caf::PdmField> m_wellLogChannelName; };