///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2022 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. // ///////////////////////////////////////////////////////////////////////////////// #include "RicNewMultiPhaseRftSegmentPlotFeature.h" #include "RicNewRftSegmentWellLogPlotFeature.h" #include "RicNewWellLogPlotFeatureImpl.h" #include "RicWellLogPlotCurveFeatureImpl.h" #include "RicWellLogTools.h" #include "RiaApplication.h" #include "RiaLogging.h" #include "RiaPlotWindowRedrawScheduler.h" #include "RiaRftDefines.h" #include "RifReaderOpmRft.h" #include "RimFileSummaryCase.h" #include "RimRftCase.h" #include "RimRftTopologyCurve.h" #include "RimSummaryCase.h" #include "RimWellLogPlot.h" #include "RimWellLogRftCurve.h" #include "RimWellLogTrack.h" #include "RiuPlotMainWindowTools.h" #include "cafSelectionManager.h" #include CAF_CMD_SOURCE_INIT( RicNewMultiPhaseRftSegmentPlotFeature, "RicNewMultiPhaseRftSegmentPlotFeature" ); //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RicNewMultiPhaseRftSegmentPlotFeature::isCommandEnabled() { return true; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicNewMultiPhaseRftSegmentPlotFeature::onActionTriggered( bool isChecked ) { auto fileSummaryCase = dynamic_cast( RicNewRftSegmentWellLogPlotFeature::getSelectedOrFirstRftCase() ); if ( !fileSummaryCase ) return; fileSummaryCase->searchForWseglinkAndRecreateRftReader(); auto rftReader = fileSummaryCase->rftReader(); if ( !rftReader ) { RiaLogging::error( "Could not open RFT file or no RFT file present. " ); return; } auto plot = RicNewWellLogPlotFeatureImpl::createRftSegmentPlot(); QString wellName = "Unknown"; auto wellNames = rftReader->wellNames(); if ( !wellNames.empty() ) wellName = *wellNames.begin(); const auto allBranchTypes = { RiaDefines::RftBranchType::RFT_ANNULUS, RiaDefines::RftBranchType::RFT_DEVICE, RiaDefines::RftBranchType::RFT_TUBING }; for ( auto branchType : allBranchTypes ) { QString trackName = "Reservoir Rates - " + caf::AppEnum::uiText( branchType ); appendTrackAndCurveForBranchType( plot, trackName, { "CONGRAT", "CONORAT", "CONWRAT" }, wellName, branchType, fileSummaryCase ); } for ( auto branchType : allBranchTypes ) { QString trackName = caf::AppEnum::uiText( branchType ); trackName += " Rates"; appendTrackAndCurveForBranchType( plot, trackName, { "SEGGRAT", "SEGORAT", "SEGWRAT" }, wellName, branchType, fileSummaryCase ); } RicNewRftSegmentWellLogPlotFeature::appendPressureTrack( plot, wellName, fileSummaryCase ); RicNewRftSegmentWellLogPlotFeature::appendConnectionFactorTrack( plot, wellName, fileSummaryCase ); RicNewRftSegmentWellLogPlotFeature::appendTopologyTrack( plot, wellName, fileSummaryCase ); plot->loadDataAndUpdate(); plot->updateTrackVisibility(); RiaPlotWindowRedrawScheduler::instance()->performScheduledUpdatesAndReplots(); plot->updateLayout(); RiuPlotMainWindowTools::onObjectAppended( plot ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicNewMultiPhaseRftSegmentPlotFeature::appendTrackAndCurveForBranchType( RimWellLogPlot* plot, const QString& trackName, const std::vector& resultNames, const QString& wellName, RiaDefines::RftBranchType branchType, RimSummaryCase* summaryCase ) { auto plotTrack = RicNewWellLogPlotFeatureImpl::createWellLogTrackWithAutoUpdate(); plot->addPlot( plotTrack ); plotTrack->setDescription( trackName ); for ( const auto& resultName : resultNames ) { auto curve = RicWellLogTools::addSummaryRftSegmentCurve( plotTrack, resultName, wellName, branchType, summaryCase ); curve->setNamingMethod( RiaDefines::ObjectNamingMethod::TEMPLATE ); QString templateText = RiaDefines::namingVariableResultName() + ", " + RiaDefines::namingVariableResultType(); curve->setCurveNameTemplateText( templateText ); if ( resultName == "SEGGRAT" || resultName == "CONGRAT" ) { curve->setScaleFactor( 1e-3 ); } curve->setFillStyle( Qt::SolidPattern ); curve->setIsStacked( true ); curve->updateAllRequiredEditors(); } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicNewMultiPhaseRftSegmentPlotFeature::setupActionLook( QAction* actionToSetup ) { actionToSetup->setText( "Create Multi Phase Segment Plot" ); actionToSetup->setIcon( QIcon( ":/WellLogCurve16x16.png" ) ); }