///////////////////////////////////////////////////////////////////////////////// // // 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. // ///////////////////////////////////////////////////////////////////////////////// #include "RicShowContributingWellsFeatureImpl.h" #include "RigFlowDiagResultAddress.h" #include "RigSingleWellResultsData.h" #include "RimEclipseCellColors.h" #include "RimEclipsePropertyFilter.h" #include "RimEclipsePropertyFilterCollection.h" #include "RimEclipseResultCase.h" #include "RimEclipseView.h" #include "RimEclipseWell.h" #include "RimEclipseWellCollection.h" #include "RimFlowDiagSolution.h" #include "RimFaultCollection.h" #include "RiuMainWindow.h" #include "cafAssert.h" #include "cafCmdFeature.h" #include "cafCmdFeatureManager.h" //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicShowContributingWellsFeatureImpl::modifyViewToShowContributingWells(RimEclipseView* viewToModify, const QString& wellName) { CAF_ASSERT(selectedWell); RimEclipseView* eclipseView = viewToModify; RimEclipseWell* selectedWell = nullptr; for (RimEclipseWell* w : eclipseView->wellCollection()->wells()) { if (w->name() == wellName) { selectedWell = w; } } CAF_ASSERT(selectedWell); RimEclipseResultCase* eclipseResultCase = nullptr; selectedWell->firstAncestorOrThisOfTypeAsserted(eclipseResultCase); // Use the active flow diag solutions, or the first one as default RimFlowDiagSolution* flowDiagSolution = eclipseView->cellResult()->flowDiagSolution(); if (!flowDiagSolution) { std::vector flowSolutions = eclipseResultCase->flowDiagSolutions(); if (flowSolutions.size()) flowDiagSolution = flowSolutions.front(); } CAF_ASSERT(flowDiagSolution); int timeStep = eclipseView->currentTimeStep(); RimFlowDiagSolution::TracerStatusType tracerStatus = flowDiagSolution->tracerStatusInTimeStep(selectedWell->name(), timeStep); if (!(tracerStatus == RimFlowDiagSolution::INJECTOR || tracerStatus == RimFlowDiagSolution::PRODUCER)) { return; } eclipseView->cellResult()->setResultType(RimDefines::FLOW_DIAGNOSTICS); eclipseView->cellResult()->setResultVariable("MaxFractionTracer"); switch (tracerStatus) { case RimFlowDiagSolution::PRODUCER: eclipseView->cellResult()->setFlowDiagTracerSelectionType(RimEclipseResultDefinition::FLOW_TR_INJECTORS); break; case RimFlowDiagSolution::INJECTOR: eclipseView->cellResult()->setFlowDiagTracerSelectionType(RimEclipseResultDefinition::FLOW_TR_PRODUCERS); break; default: CVF_ASSERT(false); break; } eclipseView->cellResult()->loadDataAndUpdate(); eclipseView->cellResult()->updateConnectedEditors(); std::vector tracerNames = findContributingTracerNames(flowDiagSolution, selectedWell->wellResults(), timeStep); for (RimEclipseWell* w : eclipseView->wellCollection()->wells()) { if (std::find(tracerNames.begin(), tracerNames.end(), w->name()) != tracerNames.end() || selectedWell->name() == w->name()) { w->showWell = true; } else { w->showWell = false; } } // Disable all existing property filters, and // create a new property filter based on TOF for current well RimEclipsePropertyFilterCollection* propertyFilterCollection = eclipseView->eclipsePropertyFilterCollection(); for (RimEclipsePropertyFilter* f : propertyFilterCollection->propertyFilters()) { f->isActive = false; } RimEclipsePropertyFilter* propertyFilter = new RimEclipsePropertyFilter(); propertyFilterCollection->propertyFilters().push_back(propertyFilter); propertyFilter->resultDefinition()->setEclipseCase(eclipseView->eclipseCase()); propertyFilter->resultDefinition()->setTofAndSelectTracer(selectedWell->name()); propertyFilter->resultDefinition()->loadDataAndUpdate(); propertyFilterCollection->updateConnectedEditors(); RiuMainWindow::instance()->setExpanded(propertyFilterCollection, true); eclipseView->faultCollection()->showFaultCollection = false; eclipseView->faultCollection()->updateConnectedEditors(); eclipseView->scheduleCreateDisplayModelAndRedraw(); auto* feature = caf::CmdFeatureManager::instance()->getCommandFeature("RicShowMainWindowFeature"); feature->actionTriggered(false); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- std::vector RicShowContributingWellsFeatureImpl::contributingTracers(RimEclipseWell* well) { CAF_ASSERT(well); RimEclipseView* eclipseView = nullptr; well->firstAncestorOrThisOfTypeAsserted(eclipseView); RimEclipseResultCase* eclipseResultCase = nullptr; well->firstAncestorOrThisOfTypeAsserted(eclipseResultCase); // Use the active flow diag solutions, or the first one as default RimFlowDiagSolution* flowDiagSolution = eclipseView->cellResult()->flowDiagSolution(); if (!flowDiagSolution) { std::vector flowSolutions = eclipseResultCase->flowDiagSolutions(); if (flowSolutions.size()) flowDiagSolution = flowSolutions.front(); } CAF_ASSERT(flowDiagSolution); int timeStep = eclipseView->currentTimeStep(); return findContributingTracerNames(flowDiagSolution, well->wellResults(), timeStep); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- std::vector RicShowContributingWellsFeatureImpl::findContributingTracerNames( const RimFlowDiagSolution* flowDiagSolution, const RigSingleWellResultsData* wellResults, int timeStep) { std::vector tracerCellFractionValues; if (flowDiagSolution && wellResults->hasWellResult(timeStep)) { RimFlowDiagSolution::TracerStatusType requestedTracerType = RimFlowDiagSolution::UNDEFINED; const RigWellResultFrame::WellProductionType prodType = wellResults->wellProductionType(timeStep); if ( prodType == RigWellResultFrame::PRODUCER || prodType == RigWellResultFrame::UNDEFINED_PRODUCTION_TYPE) { requestedTracerType = RimFlowDiagSolution::INJECTOR; } else { requestedTracerType = RimFlowDiagSolution::PRODUCER; } std::vector tracerNames = flowDiagSolution->tracerNames(); for (const QString& tracerName : tracerNames) { if (flowDiagSolution->tracerStatusInTimeStep(tracerName, timeStep) == requestedTracerType) { tracerCellFractionValues.push_back(tracerName); } } } return tracerCellFractionValues; }