2019-01-11 06:03:46 -06:00
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// Copyright (C) 2018- 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 "RimEclipseContourMapProjection.h"
|
2018-10-16 02:53:30 -05:00
|
|
|
|
2018-11-01 09:21:35 -05:00
|
|
|
#include "RiaWeightedGeometricMeanCalculator.h"
|
|
|
|
#include "RiaWeightedHarmonicMeanCalculator.h"
|
2018-10-17 06:26:15 -05:00
|
|
|
#include "RiaWeightedMeanCalculator.h"
|
|
|
|
|
2018-10-16 02:53:30 -05:00
|
|
|
#include "RigActiveCellInfo.h"
|
2018-11-05 07:31:07 -06:00
|
|
|
#include "RigCaseCellResultsData.h"
|
2018-11-01 07:21:13 -05:00
|
|
|
#include "RigCell.h"
|
2018-11-06 06:14:13 -06:00
|
|
|
#include "RigCellGeometryTools.h"
|
2018-10-16 02:53:30 -05:00
|
|
|
#include "RigEclipseCaseData.h"
|
2018-10-17 06:26:15 -05:00
|
|
|
#include "RigHexIntersectionTools.h"
|
2018-10-16 02:53:30 -05:00
|
|
|
#include "RigMainGrid.h"
|
|
|
|
|
2018-10-30 05:43:50 -05:00
|
|
|
#include "RimCellRangeFilterCollection.h"
|
2019-04-25 00:42:38 -05:00
|
|
|
#include "RimEclipseCase.h"
|
2018-10-16 02:53:30 -05:00
|
|
|
#include "RimEclipseCellColors.h"
|
2019-04-25 00:42:38 -05:00
|
|
|
#include "RimEclipseContourMapView.h"
|
2018-11-09 08:25:35 -06:00
|
|
|
#include "RimEclipseResultDefinition.h"
|
2019-04-25 00:42:38 -05:00
|
|
|
#include "RimEclipseView.h"
|
2018-10-16 02:53:30 -05:00
|
|
|
#include "RimProject.h"
|
2018-10-30 05:43:50 -05:00
|
|
|
#include "RimRegularLegendConfig.h"
|
2018-12-20 03:38:20 -06:00
|
|
|
#include "RimTextAnnotation.h"
|
2018-10-16 02:53:30 -05:00
|
|
|
|
2018-10-30 05:43:50 -05:00
|
|
|
#include "cafContourLines.h"
|
2018-10-16 02:53:30 -05:00
|
|
|
#include "cafPdmUiDoubleSliderEditor.h"
|
|
|
|
#include "cafPdmUiTreeOrdering.h"
|
2018-10-30 05:43:50 -05:00
|
|
|
|
2018-10-17 06:26:15 -05:00
|
|
|
#include "cvfArray.h"
|
|
|
|
#include "cvfCellRange.h"
|
2018-11-15 14:40:10 -06:00
|
|
|
#include "cvfGeometryTools.h"
|
2019-01-02 08:53:13 -06:00
|
|
|
#include "cvfGeometryUtils.h"
|
2018-10-30 05:43:50 -05:00
|
|
|
#include "cvfScalarMapper.h"
|
2018-10-17 06:26:15 -05:00
|
|
|
#include "cvfStructGridGeometryGenerator.h"
|
|
|
|
|
2018-10-16 02:53:30 -05:00
|
|
|
#include <algorithm>
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
CAF_PDM_SOURCE_INIT( RimEclipseContourMapProjection, "RimEclipseContourMapProjection" );
|
2018-10-16 02:53:30 -05:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-01-11 06:03:46 -06:00
|
|
|
RimEclipseContourMapProjection::RimEclipseContourMapProjection()
|
2019-01-11 08:11:38 -06:00
|
|
|
: RimContourMapProjection()
|
2018-10-16 02:53:30 -05:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
CAF_PDM_InitObject( "RimEclipseContourMapProjection", ":/2DMapProjection16x16.png", "", "" );
|
2018-11-05 09:19:04 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
CAF_PDM_InitField( &m_weightByParameter, "WeightByParameter", false, "Weight by Result Parameter", "", "", "" );
|
|
|
|
CAF_PDM_InitFieldNoDefault( &m_weightingResult, "WeightingResult", "", "", "", "" );
|
|
|
|
m_weightingResult.uiCapability()->setUiHidden( true );
|
|
|
|
m_weightingResult.uiCapability()->setUiTreeChildrenHidden( true );
|
2018-11-09 08:25:35 -06:00
|
|
|
m_weightingResult = new RimEclipseResultDefinition;
|
2019-09-06 03:40:57 -05:00
|
|
|
m_weightingResult->findField( "MResultType" )->uiCapability()->setUiName( "Result Type" );
|
2018-12-20 03:38:20 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
setName( "Map Projection" );
|
|
|
|
nameField()->uiCapability()->setUiReadOnly( true );
|
2018-10-16 02:53:30 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2020-02-12 04:13:38 -06:00
|
|
|
RimEclipseContourMapProjection::~RimEclipseContourMapProjection()
|
|
|
|
{
|
|
|
|
}
|
2018-11-21 02:32:04 -06:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-01-11 06:03:46 -06:00
|
|
|
QString RimEclipseContourMapProjection::resultDescriptionText() const
|
2018-11-21 02:32:04 -06:00
|
|
|
{
|
|
|
|
QString resultText = resultAggregationText();
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( !isColumnResult() )
|
2018-11-21 02:32:04 -06:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
resultText += QString( ", %1" ).arg( view()->cellResult()->resultVariable() );
|
2018-11-21 02:32:04 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
return resultText;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-01-11 06:03:46 -06:00
|
|
|
QString RimEclipseContourMapProjection::weightingParameter() const
|
2018-11-21 02:32:04 -06:00
|
|
|
{
|
|
|
|
QString parameter = "None";
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( m_weightByParameter() && !m_weightingResult->isTernarySaturationSelected() )
|
2018-11-21 02:32:04 -06:00
|
|
|
{
|
|
|
|
parameter = m_weightingResult->resultVariableUiShortName();
|
|
|
|
}
|
|
|
|
return parameter;
|
|
|
|
}
|
|
|
|
|
2018-10-30 05:43:50 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-01-11 06:03:46 -06:00
|
|
|
RimRegularLegendConfig* RimEclipseContourMapProjection::legendConfig() const
|
2018-10-30 05:43:50 -05:00
|
|
|
{
|
2018-11-21 02:32:04 -06:00
|
|
|
return view()->cellResult()->legendConfig();
|
2018-10-30 05:43:50 -05:00
|
|
|
}
|
|
|
|
|
2018-11-09 08:25:35 -06:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-01-11 06:03:46 -06:00
|
|
|
void RimEclipseContourMapProjection::updateLegend()
|
2019-09-06 03:40:57 -05:00
|
|
|
{
|
2018-11-21 02:32:04 -06:00
|
|
|
RimEclipseCellColors* cellColors = view()->cellResult();
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
double minVal = minValue( m_aggregatedResults );
|
|
|
|
double maxVal = maxValue( m_aggregatedResults );
|
2019-01-11 09:06:08 -06:00
|
|
|
|
2019-01-18 06:32:05 -06:00
|
|
|
std::pair<double, double> minmaxValAllTimeSteps = minmaxValuesAllTimeSteps();
|
2018-11-21 02:32:04 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
legendConfig()->setAutomaticRanges( minmaxValAllTimeSteps.first, minmaxValAllTimeSteps.second, minVal, maxVal );
|
2018-11-21 02:32:04 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( m_resultAggregation() == RESULTS_OIL_COLUMN || m_resultAggregation() == RESULTS_GAS_COLUMN ||
|
|
|
|
m_resultAggregation() == RESULTS_HC_COLUMN )
|
2018-11-21 02:32:04 -06:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
legendConfig()->setTitle( QString( "Map Projection\n%1" ).arg( m_resultAggregation().uiText() ) );
|
2018-11-21 02:32:04 -06:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
QString projectionLegendText = QString( "Map Projection\n%1" ).arg( m_resultAggregation().uiText() );
|
|
|
|
if ( weightingParameter() != "None" )
|
2018-11-21 02:32:04 -06:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
projectionLegendText += QString( "(W: %1)" ).arg( weightingParameter() );
|
2018-11-21 02:32:04 -06:00
|
|
|
}
|
2019-09-06 03:40:57 -05:00
|
|
|
projectionLegendText += QString( "\nResult: %1" ).arg( cellColors->resultVariableUiShortName() );
|
2018-11-21 02:32:04 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
legendConfig()->setTitle( projectionLegendText );
|
2018-11-09 08:25:35 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-09-25 04:48:41 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
double RimEclipseContourMapProjection::sampleSpacing() const
|
|
|
|
{
|
|
|
|
if ( m_mainGrid.notNull() )
|
|
|
|
{
|
|
|
|
return m_relativeSampleSpacing * m_mainGrid->characteristicIJCellSize();
|
|
|
|
}
|
|
|
|
return 0.0;
|
|
|
|
}
|
|
|
|
|
2018-11-15 14:40:10 -06:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-01-11 06:03:46 -06:00
|
|
|
void RimEclipseContourMapProjection::updatedWeightingResult()
|
2018-11-15 14:40:10 -06:00
|
|
|
{
|
2019-01-11 05:32:46 -06:00
|
|
|
this->clearGridMapping();
|
2018-11-21 02:32:04 -06:00
|
|
|
this->updateConnectedEditors();
|
2019-09-06 03:40:57 -05:00
|
|
|
this->generateResultsIfNecessary( view()->currentTimeStep() );
|
2018-11-21 02:32:04 -06:00
|
|
|
this->updateLegend();
|
|
|
|
|
|
|
|
RimProject* proj;
|
2019-09-06 03:40:57 -05:00
|
|
|
this->firstAncestorOrThisOfTypeAsserted( proj );
|
2018-11-21 02:32:04 -06:00
|
|
|
proj->scheduleCreateDisplayModelAndRedrawAllViews();
|
2018-11-06 06:23:24 -06:00
|
|
|
}
|
|
|
|
|
2018-11-21 02:32:04 -06:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
std::vector<double> RimEclipseContourMapProjection::generateResults( int timeStep )
|
2018-11-21 02:32:04 -06:00
|
|
|
{
|
2019-01-11 08:11:38 -06:00
|
|
|
m_weightingResult->loadResult();
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
size_t nCells = numberOfCells();
|
2018-11-21 02:32:04 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
std::vector<double> aggregatedResults = std::vector<double>( nCells, std::numeric_limits<double>::infinity() );
|
2019-01-11 03:48:28 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
RimEclipseCellColors* cellColors = view()->cellResult();
|
|
|
|
RimEclipseCase* eclipseCase = this->eclipseCase();
|
2019-01-10 13:55:58 -06:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( !cellColors->isTernarySaturationSelected() )
|
2019-01-10 13:55:58 -06:00
|
|
|
{
|
2020-04-23 23:53:06 -05:00
|
|
|
RigCaseCellResultsData* resultData = eclipseCase->results( RiaDefines::PorosityModelType::MATRIX_MODEL );
|
2019-09-06 03:40:57 -05:00
|
|
|
std::vector<double> gridResultValues;
|
|
|
|
if ( isColumnResult() )
|
2019-01-11 03:48:28 -06:00
|
|
|
{
|
2019-01-11 08:11:38 -06:00
|
|
|
m_currentResultName = "";
|
2020-04-23 16:25:22 -05:00
|
|
|
resultData->ensureKnownResultLoaded(
|
|
|
|
RigEclipseResultAddress( RiaDefines::ResultCatType::STATIC_NATIVE, "PORO" ) );
|
|
|
|
resultData->ensureKnownResultLoaded(
|
|
|
|
RigEclipseResultAddress( RiaDefines::ResultCatType::STATIC_NATIVE, "NTG" ) );
|
|
|
|
resultData->ensureKnownResultLoaded(
|
|
|
|
RigEclipseResultAddress( RiaDefines::ResultCatType::STATIC_NATIVE, "DZ" ) );
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( m_resultAggregation == RESULTS_OIL_COLUMN || m_resultAggregation == RESULTS_HC_COLUMN )
|
2019-01-11 05:32:46 -06:00
|
|
|
{
|
2020-04-23 16:25:22 -05:00
|
|
|
resultData->ensureKnownResultLoadedForTimeStep( RigEclipseResultAddress( RiaDefines::ResultCatType::DYNAMIC_NATIVE,
|
2019-09-06 03:40:57 -05:00
|
|
|
"SOIL" ),
|
|
|
|
timeStep );
|
2019-01-11 05:32:46 -06:00
|
|
|
}
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( m_resultAggregation == RESULTS_GAS_COLUMN || m_resultAggregation == RESULTS_HC_COLUMN )
|
2019-01-11 05:32:46 -06:00
|
|
|
{
|
2020-04-23 16:25:22 -05:00
|
|
|
resultData->ensureKnownResultLoadedForTimeStep( RigEclipseResultAddress( RiaDefines::ResultCatType::DYNAMIC_NATIVE,
|
2019-09-06 03:40:57 -05:00
|
|
|
"SGAS" ),
|
|
|
|
timeStep );
|
2019-01-11 05:32:46 -06:00
|
|
|
}
|
2019-09-06 03:40:57 -05:00
|
|
|
gridResultValues = calculateColumnResult( m_resultAggregation() );
|
2019-01-11 08:11:38 -06:00
|
|
|
}
|
2019-09-06 03:40:57 -05:00
|
|
|
else if ( !( cellColors->hasStaticResult() && timeStep > 0 ) )
|
2019-01-11 08:11:38 -06:00
|
|
|
{
|
|
|
|
m_currentResultName = cellColors->resultVariable();
|
2019-09-10 02:18:40 -05:00
|
|
|
RigEclipseResultAddress resAddr( cellColors->resultType(),
|
|
|
|
cellColors->resultVariable(),
|
|
|
|
cellColors->timeLapseBaseTimeStep(),
|
|
|
|
cellColors->caseDiffIndex() );
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( resAddr.isValid() && resultData->hasResultEntry( resAddr ) )
|
2019-03-22 02:49:39 -05:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
gridResultValues = resultData->cellScalarResults( resAddr, timeStep );
|
2019-03-22 02:49:39 -05:00
|
|
|
}
|
2019-01-11 03:48:28 -06:00
|
|
|
}
|
2019-01-11 08:11:38 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( !gridResultValues.empty() )
|
2019-01-11 08:11:38 -06:00
|
|
|
{
|
2019-01-21 08:45:35 -06:00
|
|
|
#pragma omp parallel for
|
2019-09-06 03:40:57 -05:00
|
|
|
for ( int index = 0; index < static_cast<int>( nCells ); ++index )
|
2019-01-21 08:45:35 -06:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
cvf::Vec2ui ij = ijFromCellIndex( index );
|
|
|
|
aggregatedResults[index] = calculateValueInMapCell( ij.x(), ij.y(), gridResultValues );
|
2019-01-21 08:45:35 -06:00
|
|
|
}
|
2019-01-11 08:11:38 -06:00
|
|
|
}
|
2018-11-21 02:32:04 -06:00
|
|
|
}
|
|
|
|
}
|
2019-01-18 06:32:05 -06:00
|
|
|
return aggregatedResults;
|
2018-11-15 14:40:10 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-01-16 03:51:43 -06:00
|
|
|
bool RimEclipseContourMapProjection::resultVariableChanged() const
|
2019-09-06 03:40:57 -05:00
|
|
|
{
|
|
|
|
if ( !m_currentResultName.isEmpty() )
|
2019-01-11 05:32:46 -06:00
|
|
|
{
|
|
|
|
RimEclipseCellColors* cellColors = view()->cellResult();
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( cellColors->resultVariable() != m_currentResultName )
|
2019-01-11 05:32:46 -06:00
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
2019-01-11 09:06:08 -06:00
|
|
|
return false;
|
2018-10-16 02:53:30 -05:00
|
|
|
}
|
|
|
|
|
2019-01-10 13:55:58 -06:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-01-16 03:51:43 -06:00
|
|
|
void RimEclipseContourMapProjection::clearResultVariable()
|
2019-01-10 13:55:58 -06:00
|
|
|
{
|
2019-01-11 08:11:38 -06:00
|
|
|
m_currentResultName = "";
|
2018-10-16 02:53:30 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
std::vector<double> RimEclipseContourMapProjection::calculateColumnResult( ResultAggregation resultAggregation ) const
|
2019-01-11 09:06:08 -06:00
|
|
|
{
|
2020-04-23 23:53:06 -05:00
|
|
|
const RigCaseCellResultsData* resultData = eclipseCase()->results( RiaDefines::PorosityModelType::MATRIX_MODEL );
|
2020-04-23 16:25:22 -05:00
|
|
|
bool hasPoroResult =
|
|
|
|
resultData->hasResultEntry( RigEclipseResultAddress( RiaDefines::ResultCatType::STATIC_NATIVE, "PORO" ) );
|
|
|
|
bool hasNtgResult =
|
|
|
|
resultData->hasResultEntry( RigEclipseResultAddress( RiaDefines::ResultCatType::STATIC_NATIVE, "NTG" ) );
|
|
|
|
bool hasDzResult =
|
|
|
|
resultData->hasResultEntry( RigEclipseResultAddress( RiaDefines::ResultCatType::STATIC_NATIVE, "DZ" ) );
|
2019-01-11 09:06:08 -06:00
|
|
|
|
2020-04-10 01:05:06 -05:00
|
|
|
if ( !( hasPoroResult && hasNtgResult && hasDzResult ) )
|
2019-01-11 09:06:08 -06:00
|
|
|
{
|
2019-01-21 08:45:35 -06:00
|
|
|
return std::vector<double>();
|
2019-01-11 09:06:08 -06:00
|
|
|
}
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
const std::vector<double>& poroResults =
|
2020-04-23 16:25:22 -05:00
|
|
|
resultData->cellScalarResults( RigEclipseResultAddress( RiaDefines::ResultCatType::STATIC_NATIVE, "PORO" ), 0 );
|
2019-09-06 03:40:57 -05:00
|
|
|
const std::vector<double>& ntgResults =
|
2020-04-23 16:25:22 -05:00
|
|
|
resultData->cellScalarResults( RigEclipseResultAddress( RiaDefines::ResultCatType::STATIC_NATIVE, "NTG" ), 0 );
|
2019-11-04 08:08:09 -06:00
|
|
|
const std::vector<double>& dzResults =
|
2020-04-23 16:25:22 -05:00
|
|
|
resultData->cellScalarResults( RigEclipseResultAddress( RiaDefines::ResultCatType::STATIC_NATIVE, "DZ" ), 0 );
|
2019-09-06 03:40:57 -05:00
|
|
|
|
|
|
|
CVF_ASSERT( poroResults.size() == ntgResults.size() && ntgResults.size() == dzResults.size() );
|
2019-01-25 05:58:07 -06:00
|
|
|
|
2019-01-11 09:06:08 -06:00
|
|
|
int timeStep = view()->currentTimeStep();
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
std::vector<double> resultValues( poroResults.size(), 0.0 );
|
2019-01-21 08:45:35 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( resultAggregation == RESULTS_OIL_COLUMN || resultAggregation == RESULTS_HC_COLUMN )
|
2019-01-11 09:06:08 -06:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
const std::vector<double>& soilResults =
|
2020-04-23 16:25:22 -05:00
|
|
|
resultData->cellScalarResults( RigEclipseResultAddress( RiaDefines::ResultCatType::DYNAMIC_NATIVE, "SOIL" ),
|
|
|
|
timeStep );
|
2019-09-06 03:40:57 -05:00
|
|
|
for ( size_t cellResultIdx = 0; cellResultIdx < resultValues.size(); ++cellResultIdx )
|
2019-01-11 09:06:08 -06:00
|
|
|
{
|
2019-01-21 08:45:35 -06:00
|
|
|
resultValues[cellResultIdx] = soilResults[cellResultIdx];
|
2019-01-11 09:06:08 -06:00
|
|
|
}
|
|
|
|
}
|
2019-01-28 09:18:28 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( resultAggregation == RESULTS_GAS_COLUMN || resultAggregation == RESULTS_HC_COLUMN )
|
2019-01-11 09:06:08 -06:00
|
|
|
{
|
2020-04-23 16:25:22 -05:00
|
|
|
bool hasGasResult =
|
|
|
|
resultData->hasResultEntry( RigEclipseResultAddress( RiaDefines::ResultCatType::DYNAMIC_NATIVE, "SGAS" ) );
|
2020-04-10 01:05:06 -05:00
|
|
|
if ( hasGasResult )
|
2019-01-11 09:06:08 -06:00
|
|
|
{
|
2020-04-10 01:05:06 -05:00
|
|
|
const std::vector<double>& sgasResults =
|
2020-04-23 16:25:22 -05:00
|
|
|
resultData->cellScalarResults( RigEclipseResultAddress( RiaDefines::ResultCatType::DYNAMIC_NATIVE, "SGAS" ),
|
|
|
|
timeStep );
|
2020-04-10 01:05:06 -05:00
|
|
|
for ( size_t cellResultIdx = 0; cellResultIdx < resultValues.size(); ++cellResultIdx )
|
|
|
|
{
|
|
|
|
resultValues[cellResultIdx] += sgasResults[cellResultIdx];
|
|
|
|
}
|
2019-01-11 09:06:08 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
for ( size_t cellResultIdx = 0; cellResultIdx < resultValues.size(); ++cellResultIdx )
|
2019-01-21 08:45:35 -06:00
|
|
|
{
|
|
|
|
resultValues[cellResultIdx] *= poroResults[cellResultIdx] * ntgResults[cellResultIdx] * dzResults[cellResultIdx];
|
|
|
|
}
|
|
|
|
return resultValues;
|
2019-01-11 09:06:08 -06:00
|
|
|
}
|
|
|
|
|
2018-10-17 06:26:15 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-01-16 03:51:43 -06:00
|
|
|
void RimEclipseContourMapProjection::updateGridInformation()
|
2018-11-21 02:32:04 -06:00
|
|
|
{
|
2020-09-25 04:48:41 -05:00
|
|
|
m_mainGrid = eclipseCase()->eclipseCaseData()->mainGrid();
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
m_gridBoundingBox = eclipseCase()->activeCellsBoundingBox();
|
|
|
|
cvf::Vec3d minExpandedPoint = m_gridBoundingBox.min() - cvf::Vec3d( gridEdgeOffset(), gridEdgeOffset(), 0.0 );
|
|
|
|
cvf::Vec3d maxExpandedPoint = m_gridBoundingBox.max() + cvf::Vec3d( gridEdgeOffset(), gridEdgeOffset(), 0.0 );
|
|
|
|
m_expandedBoundingBox = cvf::BoundingBox( minExpandedPoint, maxExpandedPoint );
|
2019-01-10 14:16:22 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
m_mapSize = calculateMapSize();
|
2018-10-17 06:26:15 -05:00
|
|
|
|
2019-01-16 03:51:43 -06:00
|
|
|
// Re-jig max point to be an exact multiple of cell size
|
2019-09-06 03:40:57 -05:00
|
|
|
cvf::Vec3d minPoint = m_expandedBoundingBox.min();
|
|
|
|
cvf::Vec3d maxPoint = m_expandedBoundingBox.max();
|
2020-09-25 04:48:41 -05:00
|
|
|
maxPoint.x() = minPoint.x() + m_mapSize.x() * sampleSpacing();
|
|
|
|
maxPoint.y() = minPoint.y() + m_mapSize.y() * sampleSpacing();
|
2019-09-06 03:40:57 -05:00
|
|
|
m_expandedBoundingBox = cvf::BoundingBox( minPoint, maxPoint );
|
2019-01-16 03:51:43 -06:00
|
|
|
}
|
2018-10-17 08:46:47 -05:00
|
|
|
|
2019-01-16 03:51:43 -06:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
std::vector<double> RimEclipseContourMapProjection::retrieveParameterWeights()
|
|
|
|
{
|
|
|
|
std::vector<double> weights;
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( m_weightByParameter() )
|
2018-10-17 06:26:15 -05:00
|
|
|
{
|
2019-01-23 07:24:12 -06:00
|
|
|
RigEclipseResultAddress gridScalarResultIdx = m_weightingResult->eclipseResultAddress();
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( gridScalarResultIdx.isValid() )
|
2018-10-17 06:26:15 -05:00
|
|
|
{
|
2019-01-16 03:51:43 -06:00
|
|
|
m_weightingResult->loadResult();
|
|
|
|
int timeStep = 0;
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( m_weightingResult->hasDynamicResult() )
|
2018-11-09 08:25:35 -06:00
|
|
|
{
|
2019-01-16 03:51:43 -06:00
|
|
|
timeStep = view()->currentTimeStep();
|
2018-10-17 06:26:15 -05:00
|
|
|
}
|
2019-09-06 03:40:57 -05:00
|
|
|
weights = m_weightingResult->currentGridCellResults()->cellScalarResults( gridScalarResultIdx, timeStep );
|
2018-10-17 06:26:15 -05:00
|
|
|
}
|
|
|
|
}
|
2019-01-16 03:51:43 -06:00
|
|
|
return weights;
|
2018-11-13 07:22:34 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-04-25 00:42:38 -05:00
|
|
|
RimEclipseCase* RimEclipseContourMapProjection::eclipseCase() const
|
2018-11-13 07:22:34 -06:00
|
|
|
{
|
2019-04-25 00:42:38 -05:00
|
|
|
RimEclipseCase* eclipseCase = nullptr;
|
2019-09-06 03:40:57 -05:00
|
|
|
firstAncestorOrThisOfType( eclipseCase );
|
2019-01-16 03:51:43 -06:00
|
|
|
return eclipseCase;
|
|
|
|
}
|
2018-11-13 07:22:34 -06:00
|
|
|
|
2019-01-16 03:51:43 -06:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
RimGridView* RimEclipseContourMapProjection::baseView() const
|
|
|
|
{
|
|
|
|
return view();
|
|
|
|
}
|
2018-11-13 07:22:34 -06:00
|
|
|
|
2019-01-16 03:51:43 -06:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
std::vector<size_t> RimEclipseContourMapProjection::findIntersectingCells( const cvf::BoundingBox& bbox ) const
|
2019-01-16 03:51:43 -06:00
|
|
|
{
|
2018-11-13 07:22:34 -06:00
|
|
|
std::vector<size_t> allCellIndices;
|
2019-09-06 03:40:57 -05:00
|
|
|
m_mainGrid->findIntersectingCells( bbox, &allCellIndices );
|
2019-01-16 03:51:43 -06:00
|
|
|
return allCellIndices;
|
|
|
|
}
|
2018-11-13 07:22:34 -06:00
|
|
|
|
2019-01-16 03:51:43 -06:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
size_t RimEclipseContourMapProjection::kLayer( size_t globalCellIdx ) const
|
2019-01-16 03:51:43 -06:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
const RigCell& cell = m_mainGrid->globalCellArray()[globalCellIdx];
|
|
|
|
size_t mainGridCellIdx = cell.mainGridCellIndex();
|
|
|
|
size_t i, j, k;
|
|
|
|
m_mainGrid->ijkFromCellIndex( mainGridCellIdx, &i, &j, &k );
|
2019-01-21 08:45:35 -06:00
|
|
|
return k;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
double RimEclipseContourMapProjection::calculateOverlapVolume( size_t globalCellIdx, const cvf::BoundingBox& bbox ) const
|
2019-01-21 08:45:35 -06:00
|
|
|
{
|
|
|
|
std::array<cvf::Vec3d, 8> hexCorners;
|
|
|
|
|
|
|
|
const RigCell& cell = m_mainGrid->globalCellArray()[globalCellIdx];
|
2018-11-13 07:22:34 -06:00
|
|
|
|
2019-01-16 03:51:43 -06:00
|
|
|
size_t localCellIdx = cell.gridLocalCellIndex();
|
|
|
|
RigGridBase* localGrid = cell.hostGrid();
|
2018-11-13 07:22:34 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
localGrid->cellCornerVertices( localCellIdx, hexCorners.data() );
|
2018-11-13 07:22:34 -06:00
|
|
|
|
2019-01-16 03:51:43 -06:00
|
|
|
cvf::BoundingBox overlapBBox;
|
2019-03-22 02:49:39 -05:00
|
|
|
std::array<cvf::Vec3d, 8> overlapCorners;
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( RigCellGeometryTools::estimateHexOverlapWithBoundingBox( hexCorners, bbox, &overlapCorners, &overlapBBox ) )
|
2019-03-22 02:49:39 -05:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
double overlapVolume = RigCellGeometryTools::calculateCellVolume( overlapCorners );
|
2019-03-22 02:49:39 -05:00
|
|
|
return overlapVolume;
|
|
|
|
}
|
|
|
|
return 0.0;
|
2018-10-17 06:26:15 -05:00
|
|
|
}
|
|
|
|
|
2018-11-15 14:40:10 -06:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
double RimEclipseContourMapProjection::calculateRayLengthInCell( size_t globalCellIdx,
|
|
|
|
const cvf::Vec3d& highestPoint,
|
|
|
|
const cvf::Vec3d& lowestPoint ) const
|
2018-11-15 14:40:10 -06:00
|
|
|
{
|
2019-01-16 03:51:43 -06:00
|
|
|
std::array<cvf::Vec3d, 8> hexCorners;
|
2018-11-20 04:00:02 -06:00
|
|
|
|
2019-01-16 03:51:43 -06:00
|
|
|
RigCell cell = m_mainGrid->globalCellArray()[globalCellIdx];
|
|
|
|
|
|
|
|
size_t localCellIdx = cell.gridLocalCellIndex();
|
|
|
|
RigGridBase* localGrid = cell.hostGrid();
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
localGrid->cellCornerVertices( localCellIdx, hexCorners.data() );
|
2019-01-16 03:51:43 -06:00
|
|
|
std::vector<HexIntersectionInfo> intersections;
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( RigHexIntersectionTools::lineHexCellIntersection( highestPoint, lowestPoint, hexCorners.data(), 0, &intersections ) )
|
2019-01-16 03:51:43 -06:00
|
|
|
{
|
2019-11-04 08:08:09 -06:00
|
|
|
double lengthInCell =
|
|
|
|
( intersections.back().m_intersectionPoint - intersections.front().m_intersectionPoint ).length();
|
2019-01-16 03:51:43 -06:00
|
|
|
return lengthInCell;
|
|
|
|
}
|
|
|
|
return 0.0;
|
2018-11-15 14:40:10 -06:00
|
|
|
}
|
|
|
|
|
2018-11-21 02:32:04 -06:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
double RimEclipseContourMapProjection::getParameterWeightForCell( size_t cellResultIdx,
|
|
|
|
const std::vector<double>& cellWeights ) const
|
2018-11-21 02:32:04 -06:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( cellWeights.empty() ) return 1.0;
|
2019-01-16 03:51:43 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
double result = std::max( cellWeights[cellResultIdx], 0.0 );
|
|
|
|
if ( result < 1.0e-6 )
|
2019-01-16 03:51:43 -06:00
|
|
|
{
|
|
|
|
result = 0.0;
|
|
|
|
}
|
|
|
|
return result;
|
2018-11-21 02:32:04 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
size_t RimEclipseContourMapProjection::gridResultIndex( size_t globalCellIdx ) const
|
2018-11-21 02:32:04 -06:00
|
|
|
{
|
2020-04-23 23:53:06 -05:00
|
|
|
const RigActiveCellInfo* activeCellInfo =
|
|
|
|
eclipseCase()->eclipseCaseData()->activeCellInfo( RiaDefines::PorosityModelType::MATRIX_MODEL );
|
2019-09-06 03:40:57 -05:00
|
|
|
return activeCellInfo->cellResultIndex( globalCellIdx );
|
2018-11-21 02:32:04 -06:00
|
|
|
}
|
2019-01-02 08:53:13 -06:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-01-11 08:11:38 -06:00
|
|
|
RimEclipseContourMapView* RimEclipseContourMapProjection::view() const
|
2019-01-02 08:53:13 -06:00
|
|
|
{
|
2019-01-11 08:11:38 -06:00
|
|
|
RimEclipseContourMapView* view = nullptr;
|
2019-09-06 03:40:57 -05:00
|
|
|
firstAncestorOrThisOfTypeAsserted( view );
|
2019-01-11 08:11:38 -06:00
|
|
|
return view;
|
2019-01-02 08:53:13 -06:00
|
|
|
}
|
2019-01-11 09:14:54 -06:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
void RimEclipseContourMapProjection::fieldChangedByUi( const caf::PdmFieldHandle* changedField,
|
|
|
|
const QVariant& oldValue,
|
|
|
|
const QVariant& newValue )
|
2019-01-11 09:14:54 -06:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
RimContourMapProjection::fieldChangedByUi( changedField, oldValue, newValue );
|
|
|
|
if ( changedField == &m_weightByParameter || changedField == &m_weightingResult )
|
2019-01-11 09:14:54 -06:00
|
|
|
{
|
|
|
|
clearGridMapping();
|
|
|
|
}
|
|
|
|
}
|
2019-01-16 03:51:43 -06:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
void RimEclipseContourMapProjection::defineUiOrdering( QString uiConfigName, caf::PdmUiOrdering& uiOrdering )
|
2019-01-16 03:51:43 -06:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
RimContourMapProjection::defineUiOrdering( uiConfigName, uiOrdering );
|
2019-01-16 03:51:43 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
caf::PdmUiGroup* weightingGroup = uiOrdering.addNewGroup( "Mean Weighting Options" );
|
|
|
|
weightingGroup->add( &m_weightByParameter );
|
|
|
|
weightingGroup->setCollapsedByDefault( true );
|
2019-01-16 03:51:43 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
m_weightByParameter.uiCapability()->setUiReadOnly( !isMeanResult() );
|
|
|
|
if ( !isMeanResult() )
|
2019-01-16 03:51:43 -06:00
|
|
|
{
|
|
|
|
m_weightByParameter = false;
|
|
|
|
}
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( m_weightByParameter() )
|
2019-01-16 03:51:43 -06:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
m_weightingResult->uiOrdering( uiConfigName, *weightingGroup );
|
2019-01-16 03:51:43 -06:00
|
|
|
}
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
uiOrdering.skipRemainingFields( true );
|
2019-01-16 03:51:43 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RimEclipseContourMapProjection::initAfterRead()
|
|
|
|
{
|
|
|
|
RimContourMapProjection::initAfterRead();
|
2019-09-06 03:40:57 -05:00
|
|
|
if ( eclipseCase() )
|
2019-01-16 03:51:43 -06:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
m_weightingResult->setEclipseCase( eclipseCase() );
|
2019-01-16 03:51:43 -06:00
|
|
|
}
|
|
|
|
}
|