2023-01-18 02:18:00 -06:00
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// 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 <http://www.gnu.org/licenses/gpl.html>
|
|
|
|
// for more details.
|
|
|
|
//
|
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#include "RimWellAllocationTools.h"
|
|
|
|
|
|
|
|
#include "RiaDefines.h"
|
|
|
|
|
|
|
|
#include "RigFlowDiagResults.h"
|
|
|
|
#include "RigSimWellData.h"
|
|
|
|
|
|
|
|
#include "RimFlowDiagSolution.h"
|
|
|
|
|
2023-03-21 02:32:38 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2023-01-18 02:18:00 -06:00
|
|
|
std::map<QString, const std::vector<double>*>
|
|
|
|
RimWellAllocationTools::findOrCreateRelevantTracerCellFractions( const RigSimWellData* simWellData,
|
|
|
|
RimFlowDiagSolution* flowDiagSolution,
|
|
|
|
int timeStepIndex )
|
2023-03-21 02:32:38 -05:00
|
|
|
{
|
|
|
|
return findOrCreateRelevantTracerCellFractions( simWellData, flowDiagSolution, RigFlowDiagResultAddress::PHASE_ALL, timeStepIndex );
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
std::map<QString, const std::vector<double>*>
|
|
|
|
RimWellAllocationTools::findOrCreateRelevantTracerCellFractions( const RigSimWellData* simWellData,
|
|
|
|
RimFlowDiagSolution* flowDiagSolution,
|
|
|
|
RigFlowDiagResultAddress::PhaseSelection phaseSelection,
|
|
|
|
int timeStepIndex )
|
2023-01-18 02:18:00 -06:00
|
|
|
{
|
|
|
|
std::map<QString, const std::vector<double>*> tracerCellFractionValues = {};
|
|
|
|
if ( flowDiagSolution && simWellData->hasWellResult( timeStepIndex ) )
|
|
|
|
{
|
|
|
|
RimFlowDiagSolution::TracerStatusType requestedTracerType = RimFlowDiagSolution::TracerStatusType::UNDEFINED;
|
|
|
|
|
|
|
|
const RiaDefines::WellProductionType prodType = simWellData->wellProductionType( timeStepIndex );
|
2023-02-26 03:48:40 -06:00
|
|
|
if ( prodType == RiaDefines::WellProductionType::PRODUCER || prodType == RiaDefines::WellProductionType::UNDEFINED_PRODUCTION_TYPE )
|
2023-01-18 02:18:00 -06:00
|
|
|
{
|
|
|
|
requestedTracerType = RimFlowDiagSolution::TracerStatusType::INJECTOR;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
requestedTracerType = RimFlowDiagSolution::TracerStatusType::PRODUCER;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::vector<QString> tracerNames = flowDiagSolution->tracerNames();
|
|
|
|
for ( const QString& tracerName : tracerNames )
|
|
|
|
{
|
|
|
|
if ( flowDiagSolution->tracerStatusInTimeStep( tracerName, timeStepIndex ) == requestedTracerType )
|
|
|
|
{
|
2023-04-13 00:05:53 -05:00
|
|
|
RigFlowDiagResultAddress resAddr( RIG_FLD_CELL_FRACTION_RESNAME, phaseSelection, tracerName.toStdString() );
|
2023-02-26 03:48:40 -06:00
|
|
|
const std::vector<double>* tracerCellFractions = flowDiagSolution->flowDiagResults()->resultValues( resAddr, timeStepIndex );
|
2023-01-18 02:18:00 -06:00
|
|
|
if ( tracerCellFractions )
|
|
|
|
{
|
|
|
|
tracerCellFractionValues[tracerName] = tracerCellFractions;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return tracerCellFractionValues;
|
|
|
|
}
|