///////////////////////////////////////////////////////////////////////////////// // // 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 "RimPlotWindow.h" #include "RigFlowDiagResultAddress.h" #include "cafPdmField.h" #include "cafPdmPtrField.h" #include #include #include class RimEclipseResultCase; class RimEclipseView; class RimFlowDiagSolution; class RimRegularLegendConfig; class RimSimWellInView; class RigWellAllocationOverTime; class RiuMatrixPlotWidget; class RigSimWellData; class RigAccWellFlowCalculator; //================================================================================================== /// //================================================================================================== class RimWellConnectivityTable : public RimPlotWindow { CAF_PDM_HEADER_INIT; public: enum class ViewFilterType { CALCULATE_BY_VISIBLE_CELLS, FILTER_BY_VISIBLE_PRODUCERS, FILTER_BY_VISIBLE_INJECTORS, }; enum class TimeStepSelection { SINGLE_TIME_STEP, TIME_STEP_RANGE, }; enum class TimeSampleValueType { FLOW_RATE, FLOW_RATE_FRACTION, FLOW_RATE_PERCENTAGE, }; enum class TimeRangeValueType { ACCUMULATED_FLOW_VOLUME, ACCUMULATED_FLOW_VOLUME_FRACTION, ACCUMULATED_FLOW_VOLUME_PERCENTAGE, }; enum class TimeStepRangeFilterMode { NONE, TIME_STEP_COUNT, }; public: RimWellConnectivityTable(); ~RimWellConnectivityTable() override; void setFromSimulationWell( RimSimWellInView* simWell ); private: void cleanupBeforeClose(); void onLoadDataAndUpdate() override; void fieldChangedByUi( const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue ) override; void childFieldChangedByUi( const caf::PdmFieldHandle* changedChildField ) override; void defineUiOrdering( QString uiConfigName, caf::PdmUiOrdering& uiOrdering ) override; void defineEditorAttribute( const caf::PdmFieldHandle* field, QString uiConfigName, caf::PdmUiEditorAttribute* attribute ) override; QList calculateValueOptions( const caf::PdmFieldHandle* fieldNeedingOptions ) override; // Inherited via RimPlotWindow QString description() const override; void doRenderWindowContent( QPaintDevice* paintDevice ) override; // Inherited via RimViewWindow QWidget* viewWidget() override; QImage snapshotWindowContent() override; void zoomAll() override; QWidget* createViewWidget( QWidget* mainWindowParent ) override; void deleteViewWidget() override; int axisTitleFontSize() const; int axisLabelFontSize() const; int valueLabelFontSize() const; private: std::map createProductionWellsAllocationOverTimeMap( const std::set& selectedProductionWells ) const; RigWellAllocationOverTime createWellAllocationOverTime( const RigSimWellData* simWellData ) const; void createAndEmplaceTimeStepAndCalculatorPairInMap( std::map& rTimeStepAndCalculatorPairs, const QDateTime timeStep, int timeStepIndex, const RigSimWellData* simWellData ) const; std::set getSelectedTimeSteps( const std::vector& timeSteps ) const; QString dateFormatString() const; std::vector getProductionWellNames() const; std::vector getProductionWellNamesAtTimeSteps( const std::set& timeSteps ) const; QString createTableTitle() const; std::pair createLegendMinMaxValues( const double maxTableValue ) const; void setValidTimeStepSelectionsForCase(); void setValidSingleTimeStepForCase(); void setValidTimeStepRangeForCase(); bool isTimeStepInCase( const QDateTime& timeStep ) const; int getTimeStepIndex( const QDateTime timeStep, const std::vector timeSteps ) const; void setSelectedProducersAndInjectorsForSingleTimeStep(); void setSelectedProducersAndInjectorsForTimeStepRange(); void syncSelectedInjectorsFromProducerSelection(); void syncSelectedProducersFromInjectorSelection(); void setProducerSelectionFromViewFilterAndSynchInjectors(); void setInjectorSelectionFromViewFilterAndSynchProducers(); void setWellSelectionFromViewFilter(); std::vector getViewFilteredWellNamesFromFilterType( ViewFilterType filterType ) const; void onCellVisibilityChanged( const SignalEmitter* emitter ); void connectViewCellVisibilityChangedToSlot( RimEclipseView* view ); void disconnectViewCellVisibilityChangedFromSlots( RimEclipseView* view ); private: // Matrix plot for visualizing table data QPointer m_matrixPlotWidget; caf::PdmPtrField m_case; caf::PdmPtrField m_cellFilterView; caf::PdmField> m_viewFilterType; caf::PdmPtrField m_flowDiagSolution; caf::PdmField> m_timeStepSelection; caf::PdmField> m_timeSampleValueType; caf::PdmField> m_timeRangeValueType; caf::PdmField m_selectProducersAndInjectorsForTimeSteps; caf::PdmField m_thresholdValue; // For single time sample caf::PdmField m_selectedTimeStep; // For time step range caf::PdmField m_selectedFromTimeStep; caf::PdmField m_selectedToTimeStep; caf::PdmField> m_timeStepFilterMode; caf::PdmField m_timeStepCount; caf::PdmField> m_excludeTimeSteps; caf::PdmField m_applyTimeStepSelections; caf::PdmChildField m_legendConfig; caf::PdmField> m_selectedInjectorTracersUiField; caf::PdmField> m_selectedProducerTracersUiField; caf::PdmField m_syncSelectedProducersFromInjectorSelection; caf::PdmField m_syncSelectedInjectorsFromProducerSelection; caf::PdmField m_applySelectedInectorProducerTracers; caf::PdmField m_axisTitleFontSize; caf::PdmField m_axisLabelFontSize; caf::PdmField m_valueLabelFontSize; caf::PdmField m_showValueLabels; const int m_initialNumberOfTimeSteps = 10; };