2012-05-18 09:45:23 +02:00
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
//
|
2014-09-23 15:04:57 +02:00
|
|
|
// Copyright (C) 2011- Statoil ASA
|
|
|
|
|
// Copyright (C) 2013- Ceetron Solutions AS
|
|
|
|
|
// Copyright (C) 2011-2012 Ceetron AS
|
2018-11-06 08:35:04 +01:00
|
|
|
//
|
2012-05-18 09:45:23 +02:00
|
|
|
// 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.
|
2018-11-06 08:35:04 +01:00
|
|
|
//
|
2012-05-18 09:45:23 +02:00
|
|
|
// 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.
|
2018-11-06 08:35:04 +01:00
|
|
|
//
|
|
|
|
|
// See the GNU General Public License at <http://www.gnu.org/licenses/gpl.html>
|
2012-05-18 09:45:23 +02:00
|
|
|
// for more details.
|
|
|
|
|
//
|
|
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
2015-05-15 09:16:33 +02:00
|
|
|
#include "RimEclipseCase.h"
|
2013-05-06 10:55:00 +02:00
|
|
|
|
2014-07-30 09:13:47 +02:00
|
|
|
#include "RiaApplication.h"
|
2017-04-06 14:12:24 +02:00
|
|
|
#include "RiaColorTables.h"
|
2018-11-05 14:28:07 +01:00
|
|
|
#include "RiaFieldHandleTools.h"
|
2014-07-30 09:13:47 +02:00
|
|
|
#include "RiaPreferences.h"
|
2019-02-14 21:42:31 +01:00
|
|
|
#include "RiaQDateTimeTools.h"
|
2014-08-14 11:45:13 +02:00
|
|
|
|
2018-11-06 08:35:04 +01:00
|
|
|
#include "CompletionExportCommands/RicWellPathExportCompletionDataFeatureImpl.h"
|
2018-03-14 09:35:48 +01:00
|
|
|
|
2020-02-24 15:42:23 +01:00
|
|
|
#include "RicfCommandObject.h"
|
2020-03-26 13:04:57 +01:00
|
|
|
#include "RifEclipseInputPropertyLoader.h"
|
2019-04-04 15:19:30 +02:00
|
|
|
#include "RifReaderSettings.h"
|
|
|
|
|
|
2017-01-09 19:14:07 +01:00
|
|
|
#include "RigActiveCellInfo.h"
|
2014-07-24 10:11:43 +02:00
|
|
|
#include "RigCaseCellResultsData.h"
|
2017-01-10 09:51:39 +01:00
|
|
|
#include "RigEclipseCaseData.h"
|
2017-01-09 19:04:45 +01:00
|
|
|
#include "RigMainGrid.h"
|
2017-10-13 13:44:53 +02:00
|
|
|
#include "RigSimWellData.h"
|
2018-03-14 09:35:48 +01:00
|
|
|
#include "RigVirtualPerforationTransmissibilities.h"
|
2014-08-14 11:45:13 +02:00
|
|
|
|
2018-02-15 14:37:38 +01:00
|
|
|
#include "Rim2dIntersectionViewCollection.h"
|
2014-07-24 10:11:43 +02:00
|
|
|
#include "RimCaseCollection.h"
|
2015-06-25 13:45:32 +02:00
|
|
|
#include "RimCellEdgeColors.h"
|
2015-07-31 18:58:23 +02:00
|
|
|
#include "RimEclipseCellColors.h"
|
2019-02-14 21:26:23 +01:00
|
|
|
#include "RimEclipseContourMapView.h"
|
|
|
|
|
#include "RimEclipseContourMapViewCollection.h"
|
2020-03-26 13:04:57 +01:00
|
|
|
#include "RimEclipseInputProperty.h"
|
2019-10-30 15:27:31 +01:00
|
|
|
#include "RimEclipseInputPropertyCollection.h"
|
2015-06-25 13:05:28 +02:00
|
|
|
#include "RimEclipsePropertyFilter.h"
|
|
|
|
|
#include "RimEclipsePropertyFilterCollection.h"
|
2017-11-09 13:55:50 +01:00
|
|
|
#include "RimEclipseStatisticsCase.h"
|
2015-05-21 10:34:38 +02:00
|
|
|
#include "RimEclipseView.h"
|
2020-01-25 12:04:16 +01:00
|
|
|
#include "RimFaultInViewCollection.h"
|
2016-09-06 10:27:30 +02:00
|
|
|
#include "RimFormationNames.h"
|
2018-10-24 13:01:17 +02:00
|
|
|
#include "RimGridCollection.h"
|
2018-02-01 17:45:22 +01:00
|
|
|
#include "RimIntersectionCollection.h"
|
2015-10-22 14:26:54 +02:00
|
|
|
#include "RimMainPlotCollection.h"
|
2017-11-09 13:55:50 +01:00
|
|
|
#include "RimOilField.h"
|
2018-03-14 09:35:48 +01:00
|
|
|
#include "RimPerforationCollection.h"
|
2017-08-25 06:51:56 +02:00
|
|
|
#include "RimProject.h"
|
2019-02-14 21:26:23 +01:00
|
|
|
#include "RimReloadCaseTools.h"
|
2017-08-25 06:51:56 +02:00
|
|
|
#include "RimReservoirCellResultsStorage.h"
|
2018-01-12 10:55:00 +01:00
|
|
|
#include "RimStimPlanColors.h"
|
2017-08-25 06:51:56 +02:00
|
|
|
#include "RimWellLogPlotCollection.h"
|
2017-10-11 15:23:14 +02:00
|
|
|
#include "RimWellPath.h"
|
2017-11-09 13:55:50 +01:00
|
|
|
#include "RimWellPathCollection.h"
|
2014-07-24 10:11:43 +02:00
|
|
|
|
2014-08-14 11:45:13 +02:00
|
|
|
#include "cafPdmDocument.h"
|
2020-03-10 14:11:22 +01:00
|
|
|
#include "cafPdmFieldIOScriptability.h"
|
|
|
|
|
#include "cafPdmObjectScriptability.h"
|
2018-01-23 14:23:28 +01:00
|
|
|
#include "cafPdmUiTreeOrdering.h"
|
2018-11-06 08:35:04 +01:00
|
|
|
#include "cafProgressInfo.h"
|
2012-05-18 09:45:23 +02:00
|
|
|
|
2019-04-04 15:19:30 +02:00
|
|
|
#include "cafUtils.h"
|
|
|
|
|
#include <QFileInfo>
|
|
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
CAF_PDM_XML_ABSTRACT_SOURCE_INIT( RimEclipseCase, "RimReservoir" );
|
2013-03-18 11:40:39 +01:00
|
|
|
|
|
|
|
|
//------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2012-05-18 09:45:23 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
RimEclipseCase::RimEclipseCase()
|
2012-05-18 09:45:23 +02:00
|
|
|
{
|
2020-03-03 10:43:07 +01:00
|
|
|
CAF_PDM_InitScriptableObjectWithNameAndComment( "EclipseCase",
|
|
|
|
|
":/Case48x48.png",
|
|
|
|
|
"",
|
|
|
|
|
"",
|
|
|
|
|
"Reservoir",
|
|
|
|
|
"Abtract base class for Eclipse Cases" );
|
2019-10-09 09:21:28 +02:00
|
|
|
|
2020-03-04 14:52:16 +01:00
|
|
|
CAF_PDM_InitScriptableFieldWithKeywordNoDefault( &reservoirViews,
|
|
|
|
|
"ReservoirViews",
|
|
|
|
|
"Views",
|
|
|
|
|
"",
|
|
|
|
|
"",
|
|
|
|
|
"",
|
|
|
|
|
"All Eclipse Views in the case" );
|
2019-09-06 10:40:57 +02:00
|
|
|
reservoirViews.uiCapability()->setUiHidden( true );
|
2013-03-18 14:34:29 +01:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
CAF_PDM_InitFieldNoDefault( &m_matrixModelResults, "MatrixModelResults", "", "", "", "" );
|
|
|
|
|
m_matrixModelResults.uiCapability()->setUiHidden( true );
|
|
|
|
|
CAF_PDM_InitFieldNoDefault( &m_fractureModelResults, "FractureModelResults", "", "", "", "" );
|
|
|
|
|
m_fractureModelResults.uiCapability()->setUiHidden( true );
|
2013-03-18 14:34:29 +01:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
CAF_PDM_InitField( &m_flipXAxis, "FlipXAxis", false, "Flip X Axis", "", "", "" );
|
|
|
|
|
CAF_PDM_InitField( &m_flipYAxis, "FlipYAxis", false, "Flip Y Axis", "", "", "" );
|
2013-04-26 13:19:34 +02:00
|
|
|
|
2019-12-10 16:36:07 +01:00
|
|
|
CAF_PDM_InitFieldNoDefault( &m_filesContainingFaults, "CachedFileNamesContainingFaults", "", "", "", "" );
|
|
|
|
|
m_filesContainingFaults.uiCapability()->setUiHidden( true );
|
2017-06-19 10:54:05 +02:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
CAF_PDM_InitFieldNoDefault( &m_contourMapCollection, "ContourMaps", "2d Contour Maps", "", "", "" );
|
2019-01-16 10:51:43 +01:00
|
|
|
m_contourMapCollection = new RimEclipseContourMapViewCollection;
|
2019-09-06 10:40:57 +02:00
|
|
|
m_contourMapCollection.uiCapability()->setUiTreeHidden( true );
|
2018-10-23 16:32:40 +02:00
|
|
|
|
2019-10-30 15:27:31 +01:00
|
|
|
CAF_PDM_InitFieldNoDefault( &m_inputPropertyCollection, "InputPropertyCollection", "", "", "", "" );
|
|
|
|
|
m_inputPropertyCollection = new RimEclipseInputPropertyCollection;
|
|
|
|
|
m_inputPropertyCollection->parentField()->uiCapability()->setUiHidden( true );
|
|
|
|
|
|
2017-06-19 10:54:05 +02:00
|
|
|
// Obsolete fields
|
2019-09-06 10:40:57 +02:00
|
|
|
CAF_PDM_InitFieldNoDefault( &m_filesContainingFaults_OBSOLETE, "FilesContainingFaults", "", "", "", "" );
|
|
|
|
|
RiaFieldhandleTools::disableWriteAndSetFieldHidden( &m_filesContainingFaults_OBSOLETE );
|
2013-04-26 13:19:34 +02:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
CAF_PDM_InitField( &m_caseName_OBSOLETE, "CaseName", QString(), "Obsolete", "", "", "" );
|
|
|
|
|
RiaFieldhandleTools::disableWriteAndSetFieldHidden( &m_caseName_OBSOLETE );
|
2013-04-11 12:06:38 +02:00
|
|
|
|
2017-06-19 10:54:05 +02:00
|
|
|
// Init
|
|
|
|
|
|
2013-03-19 10:29:34 +01:00
|
|
|
m_matrixModelResults = new RimReservoirCellResultsStorage;
|
2019-09-06 10:40:57 +02:00
|
|
|
m_matrixModelResults.uiCapability()->setUiHidden( true );
|
|
|
|
|
m_matrixModelResults.uiCapability()->setUiTreeChildrenHidden( true );
|
2015-08-09 11:16:52 +02:00
|
|
|
|
2013-03-19 10:29:34 +01:00
|
|
|
m_fractureModelResults = new RimReservoirCellResultsStorage;
|
2019-09-06 10:40:57 +02:00
|
|
|
m_fractureModelResults.uiCapability()->setUiHidden( true );
|
|
|
|
|
m_fractureModelResults.uiCapability()->setUiTreeChildrenHidden( true );
|
2013-03-18 14:34:29 +01:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
this->setReservoirData( nullptr );
|
2013-03-18 14:34:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2013-03-18 14:34:29 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2015-05-15 08:40:27 +02:00
|
|
|
RimEclipseCase::~RimEclipseCase()
|
2013-03-18 14:34:29 +01:00
|
|
|
{
|
|
|
|
|
reservoirViews.deleteAllChildObjects();
|
|
|
|
|
|
|
|
|
|
delete m_matrixModelResults();
|
|
|
|
|
delete m_fractureModelResults();
|
2019-10-30 15:27:31 +01:00
|
|
|
delete m_inputPropertyCollection;
|
2013-03-18 14:34:29 +01:00
|
|
|
|
2020-05-12 09:50:38 +02:00
|
|
|
RimProject* project = RimProject::current();
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( project )
|
2015-10-22 14:26:54 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( project->mainPlotCollection() )
|
2015-10-22 14:26:54 +02:00
|
|
|
{
|
|
|
|
|
RimWellLogPlotCollection* plotCollection = project->mainPlotCollection()->wellLogPlotCollection();
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( plotCollection )
|
2015-10-22 14:26:54 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
plotCollection->removeExtractors( this->eclipseCaseData() );
|
2015-10-22 14:26:54 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( this->eclipseCaseData() )
|
2013-03-18 14:34:29 +01:00
|
|
|
{
|
|
|
|
|
// At this point, we assume that memory should be released
|
2019-09-06 10:40:57 +02:00
|
|
|
CVF_ASSERT( this->eclipseCaseData()->refCount() == 1 );
|
2013-03-18 14:34:29 +01:00
|
|
|
}
|
2012-05-18 09:45:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2012-05-18 09:45:23 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2017-03-15 09:10:16 +01:00
|
|
|
RigEclipseCaseData* RimEclipseCase::eclipseCaseData()
|
2012-05-18 09:45:23 +02:00
|
|
|
{
|
2013-02-14 10:19:27 +01:00
|
|
|
return m_rigEclipseCase.p();
|
2012-05-18 09:45:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
///
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2017-03-15 09:10:16 +01:00
|
|
|
const RigEclipseCaseData* RimEclipseCase::eclipseCaseData() const
|
2012-05-18 09:45:23 +02:00
|
|
|
{
|
2013-02-14 10:19:27 +01:00
|
|
|
return m_rigEclipseCase.p();
|
2012-05-18 09:45:23 +02:00
|
|
|
}
|
|
|
|
|
|
2019-04-04 15:19:30 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
///
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
void RimEclipseCase::ensureDeckIsParsedForEquilData()
|
|
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( m_rigEclipseCase.notNull() )
|
2019-04-04 15:19:30 +02:00
|
|
|
{
|
|
|
|
|
QString includeFileAbsolutePathPrefix;
|
|
|
|
|
{
|
|
|
|
|
RiaPreferences* prefs = RiaApplication::instance()->preferences();
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( prefs->readerSettings() )
|
2019-04-04 15:19:30 +02:00
|
|
|
{
|
2019-04-04 20:28:36 +02:00
|
|
|
includeFileAbsolutePathPrefix = prefs->readerSettings()->includeFileAbsolutePathPrefix();
|
2019-04-04 15:19:30 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
QString dataDeckFile;
|
|
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
QFileInfo fi( gridFileName() );
|
2019-04-04 15:19:30 +02:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
dataDeckFile = caf::Utils::constructFullFileName( fi.absolutePath(), fi.baseName(), ".DATA" );
|
2019-04-04 15:19:30 +02:00
|
|
|
}
|
|
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
m_rigEclipseCase->ensureDeckIsParsedForEquilData( dataDeckFile, includeFileAbsolutePathPrefix );
|
2019-04-04 15:19:30 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2017-04-06 14:12:24 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2017-04-06 14:12:24 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 10:40:57 +02:00
|
|
|
cvf::Color3f RimEclipseCase::defaultWellColor( const QString& wellName )
|
2017-04-06 14:12:24 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( m_wellToColorMap.empty() )
|
2017-04-06 14:12:24 +02:00
|
|
|
{
|
2018-11-06 08:35:04 +01:00
|
|
|
const caf::ColorTable& colorTable = RiaColorTables::wellsPaletteColors();
|
|
|
|
|
cvf::Color3ubArray wellColors = colorTable.color3ubArray();
|
|
|
|
|
cvf::Color3ubArray interpolatedWellColors = wellColors;
|
2017-04-06 14:12:24 +02:00
|
|
|
|
2017-10-13 13:44:53 +02:00
|
|
|
const cvf::Collection<RigSimWellData>& simWellData = this->eclipseCaseData()->wellResults();
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( simWellData.size() > 1 )
|
2017-04-06 14:12:24 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
interpolatedWellColors = caf::ColorTable::interpolateColorArray( wellColors, simWellData.size() );
|
2017-04-06 14:12:24 +02:00
|
|
|
}
|
|
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
for ( size_t wIdx = 0; wIdx < simWellData.size(); ++wIdx )
|
2017-04-06 14:12:24 +02:00
|
|
|
{
|
2017-10-13 13:44:53 +02:00
|
|
|
m_wellToColorMap[simWellData[wIdx]->m_wellName] = cvf::Color3f::BLACK;
|
2017-04-06 14:12:24 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
size_t wIdx = 0;
|
2019-09-06 10:40:57 +02:00
|
|
|
for ( auto& wNameColorPair : m_wellToColorMap )
|
2017-04-06 14:12:24 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
wNameColorPair.second = cvf::Color3f( interpolatedWellColors[wIdx] );
|
2017-04-06 14:12:24 +02:00
|
|
|
|
|
|
|
|
++wIdx;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
auto nmColor = m_wellToColorMap.find( wellName );
|
|
|
|
|
if ( nmColor != m_wellToColorMap.end() )
|
2017-04-06 14:12:24 +02:00
|
|
|
{
|
|
|
|
|
return nmColor->second;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
return cvf::Color3f::LIGHT_GRAY;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2018-01-30 13:29:14 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2018-01-30 13:29:14 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
const RigMainGrid* RimEclipseCase::mainGrid() const
|
|
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( eclipseCaseData() )
|
2018-01-30 13:29:14 +01:00
|
|
|
{
|
|
|
|
|
return eclipseCaseData()->mainGrid();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return nullptr;
|
|
|
|
|
}
|
|
|
|
|
|
2013-04-08 12:16:38 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2013-04-08 12:16:38 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2015-05-15 08:40:27 +02:00
|
|
|
void RimEclipseCase::initAfterRead()
|
2012-05-18 09:45:23 +02:00
|
|
|
{
|
2019-10-09 09:21:28 +02:00
|
|
|
RimCase::initAfterRead();
|
|
|
|
|
|
2012-05-18 09:45:23 +02:00
|
|
|
size_t j;
|
2019-09-06 10:40:57 +02:00
|
|
|
for ( j = 0; j < reservoirViews().size(); j++ )
|
2012-05-18 09:45:23 +02:00
|
|
|
{
|
2015-05-21 10:05:33 +02:00
|
|
|
RimEclipseView* riv = reservoirViews()[j];
|
2019-09-06 10:40:57 +02:00
|
|
|
CVF_ASSERT( riv );
|
2012-05-18 09:45:23 +02:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
riv->setEclipseCase( this );
|
2012-05-18 09:45:23 +02:00
|
|
|
}
|
2019-09-06 10:40:57 +02:00
|
|
|
for ( RimEclipseContourMapView* contourMap : m_contourMapCollection->views() )
|
2018-10-23 16:32:40 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
contourMap->setEclipseCase( this );
|
2018-10-23 16:32:40 +02:00
|
|
|
}
|
|
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( caseUserDescription().isEmpty() && !m_caseName_OBSOLETE().isEmpty() )
|
2013-04-11 12:06:38 +02:00
|
|
|
{
|
2018-01-09 09:57:54 +01:00
|
|
|
caseUserDescription = m_caseName_OBSOLETE;
|
2013-04-11 12:06:38 +02:00
|
|
|
}
|
2012-05-18 09:45:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2012-05-18 09:45:23 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2015-05-21 10:05:33 +02:00
|
|
|
RimEclipseView* RimEclipseCase::createAndAddReservoirView()
|
2012-05-18 09:45:23 +02:00
|
|
|
{
|
2016-12-22 08:45:30 +01:00
|
|
|
RimEclipseView* rimEclipseView = new RimEclipseView();
|
2019-08-23 11:25:00 +02:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
rimEclipseView->setEclipseCase( this );
|
2018-01-12 10:55:00 +01:00
|
|
|
|
|
|
|
|
// Set default values
|
|
|
|
|
{
|
2020-04-23 23:25:22 +02:00
|
|
|
rimEclipseView->cellResult()->setResultType( RiaDefines::ResultCatType::DYNAMIC_NATIVE );
|
2018-01-12 10:55:00 +01:00
|
|
|
|
2020-01-25 12:04:16 +01:00
|
|
|
auto prefs = RiaApplication::instance()->preferences();
|
|
|
|
|
if ( prefs->loadAndShowSoil )
|
2018-01-12 10:55:00 +01:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
rimEclipseView->cellResult()->setResultVariable( "SOIL" );
|
2018-01-12 10:55:00 +01:00
|
|
|
}
|
|
|
|
|
|
2020-01-25 12:04:16 +01:00
|
|
|
rimEclipseView->faultCollection()->showFaultCollection = prefs->enableFaultsByDefault();
|
|
|
|
|
|
2018-01-12 10:55:00 +01:00
|
|
|
rimEclipseView->hasUserRequestedAnimation = true;
|
|
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
rimEclipseView->cellEdgeResult()->setResultVariable( "MULT" );
|
|
|
|
|
rimEclipseView->cellEdgeResult()->setActive( false );
|
2018-02-06 12:57:50 +01:00
|
|
|
rimEclipseView->fractureColors()->setDefaultResultName();
|
2018-01-12 10:55:00 +01:00
|
|
|
}
|
2012-05-18 09:45:23 +02:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
caf::PdmDocument::updateUiIconStateRecursively( rimEclipseView );
|
2014-08-14 11:45:13 +02:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
reservoirViews().push_back( rimEclipseView );
|
2012-05-18 09:45:23 +02:00
|
|
|
|
2016-12-22 08:45:30 +01:00
|
|
|
return rimEclipseView;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2016-12-22 08:45:30 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 10:40:57 +02:00
|
|
|
RimEclipseView* RimEclipseCase::createCopyAndAddView( const RimEclipseView* sourceView )
|
2016-12-22 08:45:30 +01:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
CVF_ASSERT( sourceView );
|
2016-12-22 08:45:30 +01:00
|
|
|
|
2018-11-06 08:35:04 +01:00
|
|
|
RimEclipseView* rimEclipseView = dynamic_cast<RimEclipseView*>(
|
2019-09-06 10:40:57 +02:00
|
|
|
sourceView->xmlCapability()->copyByXmlSerialization( caf::PdmDefaultObjectFactory::instance() ) );
|
|
|
|
|
CVF_ASSERT( rimEclipseView );
|
|
|
|
|
rimEclipseView->setEclipseCase( this );
|
2018-11-06 08:35:04 +01:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
caf::PdmDocument::updateUiIconStateRecursively( rimEclipseView );
|
2016-12-22 08:45:30 +01:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
reservoirViews().push_back( rimEclipseView );
|
2016-12-22 08:45:30 +01:00
|
|
|
|
|
|
|
|
// Resolve references after reservoir view has been inserted into Rim structures
|
|
|
|
|
rimEclipseView->resolveReferencesRecursively();
|
2017-04-03 12:33:27 +02:00
|
|
|
rimEclipseView->initAfterReadRecursively();
|
2016-12-22 08:45:30 +01:00
|
|
|
|
|
|
|
|
return rimEclipseView;
|
2012-05-18 09:45:23 +02:00
|
|
|
}
|
|
|
|
|
|
2018-03-14 09:35:48 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2018-03-14 09:35:48 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
const RigVirtualPerforationTransmissibilities* RimEclipseCase::computeAndGetVirtualPerforationTransmissibilities()
|
|
|
|
|
{
|
|
|
|
|
RigEclipseCaseData* rigEclipseCase = eclipseCaseData();
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( !rigEclipseCase ) return nullptr;
|
2018-03-14 09:35:48 +01:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( rigEclipseCase->virtualPerforationTransmissibilities() == nullptr )
|
2018-03-14 09:35:48 +01:00
|
|
|
{
|
|
|
|
|
cvf::ref<RigVirtualPerforationTransmissibilities> perfTrans = new RigVirtualPerforationTransmissibilities;
|
|
|
|
|
|
|
|
|
|
std::vector<RimWellPath*> visibleWellPaths;
|
2018-11-06 08:35:04 +01:00
|
|
|
bool anyPerforationsPresent = false;
|
2018-03-14 09:35:48 +01:00
|
|
|
{
|
2020-05-12 09:50:38 +02:00
|
|
|
RimProject* proj = RimProject::current();
|
2018-03-14 09:35:48 +01:00
|
|
|
std::vector<RimWellPath*> wellPaths = proj->allWellPaths();
|
2019-09-06 10:40:57 +02:00
|
|
|
for ( auto w : wellPaths )
|
2018-03-14 09:35:48 +01:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( w->showWellPath() )
|
2018-03-14 09:35:48 +01:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
visibleWellPaths.push_back( w );
|
2018-03-14 09:35:48 +01:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( !w->perforationIntervalCollection()->perforations().empty() )
|
2018-03-14 09:35:48 +01:00
|
|
|
{
|
|
|
|
|
anyPerforationsPresent = true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
for ( auto w : visibleWellPaths )
|
2018-03-14 09:35:48 +01:00
|
|
|
{
|
2018-11-06 08:35:04 +01:00
|
|
|
std::vector<RigCompletionData> staticCompletionData =
|
2019-09-06 10:40:57 +02:00
|
|
|
RicWellPathExportCompletionDataFeatureImpl::computeStaticCompletionsForWellPath( w, this );
|
2018-11-06 08:35:04 +01:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( anyPerforationsPresent )
|
2018-03-14 09:35:48 +01:00
|
|
|
{
|
|
|
|
|
std::vector<std::vector<RigCompletionData>> allCompletionData;
|
2018-11-06 08:35:04 +01:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
for ( size_t i = 0; i < timeStepDates().size(); i++ )
|
2018-03-14 09:35:48 +01:00
|
|
|
{
|
2018-11-06 08:35:04 +01:00
|
|
|
std::vector<RigCompletionData> dynamicCompletionDataOneTimeStep =
|
2019-09-06 10:40:57 +02:00
|
|
|
RicWellPathExportCompletionDataFeatureImpl::computeDynamicCompletionsForWellPath( w, this, i );
|
2018-03-14 09:35:48 +01:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
std::copy( staticCompletionData.begin(),
|
|
|
|
|
staticCompletionData.end(),
|
|
|
|
|
std::back_inserter( dynamicCompletionDataOneTimeStep ) );
|
2018-03-14 09:35:48 +01:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
allCompletionData.push_back( dynamicCompletionDataOneTimeStep );
|
2018-03-14 09:35:48 +01:00
|
|
|
}
|
2018-11-06 08:35:04 +01:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
perfTrans->setCompletionDataForWellPath( w, allCompletionData );
|
2018-03-14 09:35:48 +01:00
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
std::vector<std::vector<RigCompletionData>> allCompletionData;
|
2019-09-06 10:40:57 +02:00
|
|
|
allCompletionData.push_back( staticCompletionData );
|
2018-03-14 09:35:48 +01:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
perfTrans->setCompletionDataForWellPath( w, allCompletionData );
|
2018-03-14 09:35:48 +01:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
for ( const auto& wellRes : rigEclipseCase->wellResults() )
|
2018-03-14 09:35:48 +01:00
|
|
|
{
|
2018-04-05 13:50:14 +02:00
|
|
|
std::vector<std::vector<RigCompletionData>> completionsPerTimeStep;
|
2019-09-06 10:40:57 +02:00
|
|
|
for ( size_t i = 0; i < timeStepDates().size(); i++ )
|
2018-03-14 09:35:48 +01:00
|
|
|
{
|
2018-04-05 13:50:14 +02:00
|
|
|
std::vector<RigCompletionData> completionData;
|
|
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( wellRes->hasWellResult( i ) )
|
2018-03-14 09:35:48 +01:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
for ( const auto& wellResultBranch : wellRes->wellResultFrame( i ).m_wellResultBranches )
|
2018-03-14 09:35:48 +01:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
for ( const auto& r : wellResultBranch.m_branchResultPoints )
|
2018-04-05 13:50:14 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( r.isCell() )
|
2018-04-05 13:50:14 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
RigCompletionData compData( wellRes->m_wellName,
|
|
|
|
|
RigCompletionDataGridCell( r.m_gridCellIndex,
|
|
|
|
|
rigEclipseCase->mainGrid() ),
|
|
|
|
|
0 );
|
|
|
|
|
compData.setTransmissibility( r.connectionFactor() );
|
2018-04-05 13:50:14 +02:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
completionData.push_back( compData );
|
2018-04-05 13:50:14 +02:00
|
|
|
}
|
|
|
|
|
}
|
2018-03-14 09:35:48 +01:00
|
|
|
}
|
|
|
|
|
}
|
2018-04-05 13:50:14 +02:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
completionsPerTimeStep.push_back( completionData );
|
2018-04-05 13:50:14 +02:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
perfTrans->setCompletionDataForSimWell( wellRes.p(), completionsPerTimeStep );
|
2018-03-14 09:35:48 +01:00
|
|
|
}
|
|
|
|
|
}
|
2018-04-05 13:50:14 +02:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
rigEclipseCase->setVirtualPerforationTransmissibilities( perfTrans.p() );
|
2018-03-14 09:35:48 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return rigEclipseCase->virtualPerforationTransmissibilities();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2018-03-14 09:35:48 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 10:40:57 +02:00
|
|
|
void RimEclipseCase::fieldChangedByUi( const caf::PdmFieldHandle* changedField,
|
|
|
|
|
const QVariant& oldValue,
|
|
|
|
|
const QVariant& newValue )
|
2012-08-31 19:12:47 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( changedField == &m_releaseResultMemory )
|
2012-08-31 19:12:47 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
RimReloadCaseTools::reloadAllEclipseGridData( this );
|
2012-08-31 19:12:47 +02:00
|
|
|
|
2018-08-24 09:34:24 +02:00
|
|
|
m_releaseResultMemory = oldValue.toBool();
|
2012-08-31 19:12:47 +02:00
|
|
|
}
|
2019-09-06 10:40:57 +02:00
|
|
|
else if ( changedField == &m_flipXAxis || changedField == &m_flipYAxis )
|
2013-04-26 13:19:34 +02:00
|
|
|
{
|
2017-03-15 09:10:16 +01:00
|
|
|
RigEclipseCaseData* rigEclipseCase = eclipseCaseData();
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( rigEclipseCase )
|
2013-04-26 13:19:34 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
rigEclipseCase->mainGrid()->setFlipAxis( m_flipXAxis, m_flipYAxis );
|
2013-04-26 13:19:34 +02:00
|
|
|
|
|
|
|
|
computeCachedData();
|
|
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
for ( size_t i = 0; i < reservoirViews().size(); i++ )
|
2013-04-26 13:19:34 +02:00
|
|
|
{
|
2015-05-21 10:05:33 +02:00
|
|
|
RimEclipseView* reservoirView = reservoirViews()[i];
|
2013-04-26 13:19:34 +02:00
|
|
|
|
|
|
|
|
reservoirView->scheduleReservoirGridGeometryRegen();
|
2017-03-13 11:05:46 +01:00
|
|
|
reservoirView->scheduleSimWellGeometryRegen();
|
2013-04-26 13:19:34 +02:00
|
|
|
reservoirView->createDisplayModelAndRedraw();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2020-01-06 14:33:54 +01:00
|
|
|
else if ( changedField == &m_activeFormationNames )
|
2016-09-06 10:27:30 +02:00
|
|
|
{
|
|
|
|
|
updateFormationNamesData();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2016-09-06 10:27:30 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
void RimEclipseCase::updateFormationNamesData()
|
|
|
|
|
{
|
2017-03-15 09:10:16 +01:00
|
|
|
RigEclipseCaseData* rigEclipseCase = eclipseCaseData();
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( rigEclipseCase )
|
2016-09-06 10:27:30 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( activeFormationNames() )
|
2016-09-06 10:27:30 +02:00
|
|
|
{
|
2020-01-06 15:27:16 +01:00
|
|
|
rigEclipseCase->setActiveFormationNames( activeFormationNames()->formationNamesData() );
|
2016-09-06 10:27:30 +02:00
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2020-01-06 15:27:16 +01:00
|
|
|
rigEclipseCase->setActiveFormationNames( nullptr );
|
2016-09-06 10:27:30 +02:00
|
|
|
}
|
2020-01-06 15:27:16 +01:00
|
|
|
|
|
|
|
|
// Update plots based on formations
|
|
|
|
|
{
|
2020-05-12 09:50:38 +02:00
|
|
|
RimProject* project = RimProject::current();
|
2020-01-06 15:27:16 +01:00
|
|
|
if ( project )
|
|
|
|
|
{
|
|
|
|
|
if ( project->mainPlotCollection() )
|
|
|
|
|
{
|
|
|
|
|
project->mainPlotCollection->updatePlotsWithFormations();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2018-01-09 10:11:28 +01:00
|
|
|
std::vector<Rim3dView*> views = this->views();
|
2019-09-06 10:40:57 +02:00
|
|
|
for ( Rim3dView* view : views )
|
2016-09-12 11:36:59 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
RimEclipseView* eclView = dynamic_cast<RimEclipseView*>( view );
|
2016-11-04 08:08:55 +01:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( eclView && eclView->isUsingFormationNames() )
|
2016-09-12 11:36:59 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( !activeFormationNames() )
|
2016-11-04 08:08:55 +01:00
|
|
|
{
|
2020-04-23 23:25:22 +02:00
|
|
|
if ( eclView->cellResult()->resultType() == RiaDefines::ResultCatType::FORMATION_NAMES )
|
2016-11-04 08:08:55 +01:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
eclView->cellResult()->setResultVariable( RiaDefines::undefinedResultName() );
|
2016-11-04 08:48:38 +01:00
|
|
|
eclView->cellResult()->updateConnectedEditors();
|
2016-11-04 08:08:55 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
RimEclipsePropertyFilterCollection* eclFilColl = eclView->eclipsePropertyFilterCollection();
|
2019-09-06 10:40:57 +02:00
|
|
|
for ( RimEclipsePropertyFilter* propFilter : eclFilColl->propertyFilters )
|
2016-11-04 08:08:55 +01:00
|
|
|
{
|
2020-04-23 23:25:22 +02:00
|
|
|
if ( propFilter->resultDefinition()->resultType() == RiaDefines::ResultCatType::FORMATION_NAMES )
|
2016-11-04 08:08:55 +01:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
propFilter->resultDefinition()->setResultVariable( RiaDefines::undefinedResultName() );
|
2016-11-04 08:08:55 +01:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
RimEclipsePropertyFilterCollection* eclFilColl = eclView->eclipsePropertyFilterCollection();
|
2019-09-06 10:40:57 +02:00
|
|
|
for ( RimEclipsePropertyFilter* propFilter : eclFilColl->propertyFilters )
|
2016-11-04 08:08:55 +01:00
|
|
|
{
|
2020-04-23 23:25:22 +02:00
|
|
|
if ( propFilter->resultDefinition()->resultType() == RiaDefines::ResultCatType::FORMATION_NAMES )
|
2016-11-04 08:48:38 +01:00
|
|
|
{
|
|
|
|
|
propFilter->setToDefaultValues();
|
|
|
|
|
propFilter->updateConnectedEditors();
|
|
|
|
|
}
|
2016-11-04 08:08:55 +01:00
|
|
|
}
|
|
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
view->scheduleGeometryRegen( PROPERTY_FILTERED );
|
2016-09-12 11:36:59 +02:00
|
|
|
view->scheduleCreateDisplayModelAndRedraw();
|
2019-11-26 12:30:44 +01:00
|
|
|
eclView->intersectionCollection()->scheduleCreateDisplayModelAndRedraw2dIntersectionViews();
|
2016-09-12 11:36:59 +02:00
|
|
|
}
|
|
|
|
|
}
|
2016-09-06 10:27:30 +02:00
|
|
|
}
|
2012-08-31 19:12:47 +02:00
|
|
|
}
|
|
|
|
|
|
2018-01-23 14:23:28 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2018-01-23 14:23:28 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 10:40:57 +02:00
|
|
|
void RimEclipseCase::defineUiTreeOrdering( caf::PdmUiTreeOrdering& uiTreeOrdering, QString uiConfigName /*= ""*/ )
|
2018-01-23 14:23:28 +01:00
|
|
|
{
|
|
|
|
|
std::vector<PdmObjectHandle*> children;
|
2019-09-06 10:40:57 +02:00
|
|
|
reservoirViews.childObjects( &children );
|
2018-01-23 14:23:28 +01:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
for ( auto child : children )
|
|
|
|
|
uiTreeOrdering.add( child );
|
2018-11-06 08:35:04 +01:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( !m_2dIntersectionViewCollection->views().empty() )
|
2018-02-15 14:37:38 +01:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
uiTreeOrdering.add( &m_2dIntersectionViewCollection );
|
2018-02-15 14:37:38 +01:00
|
|
|
}
|
2019-01-16 10:51:43 +01:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( !m_contourMapCollection->views().empty() )
|
2018-10-23 16:32:40 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
uiTreeOrdering.add( &m_contourMapCollection );
|
2018-10-23 16:32:40 +02:00
|
|
|
}
|
2019-01-16 10:51:43 +01:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
uiTreeOrdering.skipRemainingChildren( true );
|
2018-01-23 14:23:28 +01:00
|
|
|
}
|
|
|
|
|
|
2013-02-14 13:16:56 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2013-02-14 13:16:56 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2015-05-15 08:40:27 +02:00
|
|
|
void RimEclipseCase::computeCachedData()
|
2013-02-14 13:16:56 +01:00
|
|
|
{
|
2017-03-15 09:10:16 +01:00
|
|
|
RigEclipseCaseData* rigEclipseCase = eclipseCaseData();
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( rigEclipseCase )
|
2013-02-14 13:16:56 +01:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
caf::ProgressInfo pInf( 30, "" );
|
2019-04-04 15:19:30 +02:00
|
|
|
|
2019-03-12 11:02:06 +01:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
auto task = pInf.task( "", 1 );
|
2019-03-12 11:02:06 +01:00
|
|
|
rigEclipseCase->computeActiveCellBoundingBoxes();
|
|
|
|
|
}
|
2018-11-06 08:35:04 +01:00
|
|
|
|
2016-11-04 08:08:55 +01:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
auto task = pInf.task( "Calculating Cell Search Tree", 10 );
|
2019-03-12 11:02:06 +01:00
|
|
|
rigEclipseCase->mainGrid()->computeCachedData();
|
2016-11-04 08:08:55 +01:00
|
|
|
}
|
2019-03-12 11:02:06 +01:00
|
|
|
|
2016-11-04 08:08:55 +01:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
auto task = pInf.task( "Calculating faults", 17 );
|
2020-05-13 12:35:03 +02:00
|
|
|
|
2020-05-13 17:57:21 +02:00
|
|
|
ensureFaultDataIsComputed();
|
2016-11-04 08:08:55 +01:00
|
|
|
}
|
|
|
|
|
|
2019-03-12 11:02:06 +01:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
auto task = pInf.task( "Calculating Formation Names Result", 2 );
|
|
|
|
|
if ( activeFormationNames() )
|
2019-03-12 11:02:06 +01:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
rigEclipseCase->setActiveFormationNames( activeFormationNames()->formationNamesData() );
|
2019-03-12 11:02:06 +01:00
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
rigEclipseCase->setActiveFormationNames( nullptr );
|
2019-03-12 11:02:06 +01:00
|
|
|
}
|
|
|
|
|
}
|
2013-02-14 13:16:56 +01:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2013-03-13 11:42:26 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2013-03-13 11:42:26 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2015-05-15 08:40:27 +02:00
|
|
|
RimCaseCollection* RimEclipseCase::parentCaseCollection()
|
2013-03-13 11:42:26 +01:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
return dynamic_cast<RimCaseCollection*>( this->parentField()->ownerObject() );
|
2013-03-13 11:42:26 +01:00
|
|
|
}
|
|
|
|
|
|
2018-11-08 16:18:03 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
///
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-01-16 10:51:43 +01:00
|
|
|
RimEclipseContourMapViewCollection* RimEclipseCase::contourMapCollection()
|
2018-11-08 16:18:03 +01:00
|
|
|
{
|
2018-11-09 09:04:40 +01:00
|
|
|
return m_contourMapCollection;
|
2018-11-08 16:18:03 +01:00
|
|
|
}
|
|
|
|
|
|
2019-10-30 15:27:31 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
///
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
RimEclipseInputPropertyCollection* RimEclipseCase::inputPropertyCollection()
|
|
|
|
|
{
|
|
|
|
|
return m_inputPropertyCollection();
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-26 13:04:57 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
///
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
std::vector<QString> RimEclipseCase::additionalFiles() const
|
|
|
|
|
{
|
|
|
|
|
std::vector<QString> additionalFiles;
|
|
|
|
|
for ( const RimEclipseInputProperty* inputProperty : m_inputPropertyCollection()->inputProperties() )
|
|
|
|
|
{
|
|
|
|
|
if ( inputProperty->fileName == gridFileName() ) continue;
|
|
|
|
|
|
|
|
|
|
additionalFiles.push_back( inputProperty->fileName().path() );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return additionalFiles;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
/// Loads input property data from the gridFile and additional files
|
|
|
|
|
/// Creates new InputProperties if necessary, and flags the unused ones as obsolete
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
void RimEclipseCase::loadAndSyncronizeInputProperties( bool includeGridFileName )
|
|
|
|
|
{
|
|
|
|
|
// Make sure we actually have reservoir data
|
|
|
|
|
|
|
|
|
|
CVF_ASSERT( this->eclipseCaseData() );
|
|
|
|
|
CVF_ASSERT( this->eclipseCaseData()->mainGrid()->gridPointDimensions() != cvf::Vec3st( 0, 0, 0 ) );
|
|
|
|
|
|
|
|
|
|
// Then read the properties from all the files referenced by the InputReservoir
|
|
|
|
|
|
|
|
|
|
std::vector<QString> filenames;
|
|
|
|
|
for ( const QString& fileName : additionalFiles() )
|
|
|
|
|
{
|
|
|
|
|
filenames.push_back( fileName );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ( includeGridFileName ) filenames.push_back( gridFileName() );
|
|
|
|
|
|
|
|
|
|
RifEclipseInputPropertyLoader::loadAndSyncronizeInputProperties( inputPropertyCollection(), eclipseCaseData(), filenames );
|
|
|
|
|
}
|
|
|
|
|
|
2020-05-13 17:57:21 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
///
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
void RimEclipseCase::ensureFaultDataIsComputed()
|
|
|
|
|
{
|
|
|
|
|
RigEclipseCaseData* rigEclipseCase = eclipseCaseData();
|
|
|
|
|
if ( rigEclipseCase )
|
|
|
|
|
{
|
|
|
|
|
bool computeFaults = RiaApplication::instance()->preferences()->readerSettings()->importFaults();
|
|
|
|
|
if ( computeFaults )
|
|
|
|
|
{
|
2020-05-15 11:19:16 +02:00
|
|
|
RigActiveCellInfo* actCellInfo = rigEclipseCase->activeCellInfo( RiaDefines::PorosityModelType::MATRIX_MODEL );
|
|
|
|
|
rigEclipseCase->mainGrid()->calculateFaults( actCellInfo );
|
2020-05-13 17:57:21 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-05-16 15:51:59 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
///
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
bool RimEclipseCase::ensureNncDataIsComputed()
|
|
|
|
|
{
|
|
|
|
|
bool computedData = false;
|
|
|
|
|
RigEclipseCaseData* rigEclipseCase = eclipseCaseData();
|
|
|
|
|
if ( rigEclipseCase && rigEclipseCase->mainGrid() )
|
|
|
|
|
{
|
|
|
|
|
computedData = rigEclipseCase->mainGrid()->nncData()->ensureConnectionDataIsProcecced();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return computedData;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
///
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
void RimEclipseCase::createDisplayModelAndUpdateAllViews()
|
|
|
|
|
{
|
|
|
|
|
for ( const auto& v : views() )
|
|
|
|
|
{
|
|
|
|
|
RimEclipseView* eclipseView = dynamic_cast<RimEclipseView*>( v );
|
|
|
|
|
if ( eclipseView )
|
|
|
|
|
{
|
|
|
|
|
eclipseView->scheduleReservoirGridGeometryRegen();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
v->loadDataAndUpdate();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2013-03-18 14:34:29 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2013-03-18 14:34:29 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 10:40:57 +02:00
|
|
|
void RimEclipseCase::setReservoirData( RigEclipseCaseData* eclipseCase )
|
2013-03-18 14:34:29 +01:00
|
|
|
{
|
2018-11-06 08:35:04 +01:00
|
|
|
m_rigEclipseCase = eclipseCase;
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( this->eclipseCaseData() )
|
2013-03-18 14:34:29 +01:00
|
|
|
{
|
2020-04-24 06:53:06 +02:00
|
|
|
m_fractureModelResults()->setCellResults(
|
|
|
|
|
eclipseCaseData()->results( RiaDefines::PorosityModelType::FRACTURE_MODEL ) );
|
|
|
|
|
m_matrixModelResults()->setCellResults( eclipseCaseData()->results( RiaDefines::PorosityModelType::MATRIX_MODEL ) );
|
2013-03-18 14:34:29 +01:00
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
m_fractureModelResults()->setCellResults( nullptr );
|
|
|
|
|
m_matrixModelResults()->setCellResults( nullptr );
|
2013-03-18 14:34:29 +01:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2017-06-16 16:40:35 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2017-06-16 16:40:35 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
void RimEclipseCase::createTimeStepFormatString()
|
|
|
|
|
{
|
|
|
|
|
std::vector<QDateTime> timeStepDates = this->timeStepDates();
|
|
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
m_timeStepFormatString = RiaQDateTimeTools::createTimeFormatStringFromDates( timeStepDates );
|
2017-06-16 16:40:35 +02:00
|
|
|
}
|
|
|
|
|
|
2020-01-23 14:43:51 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
///
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
cvf::BoundingBox RimEclipseCase::reservoirBoundingBox()
|
|
|
|
|
{
|
|
|
|
|
return activeCellsBoundingBox();
|
|
|
|
|
}
|
|
|
|
|
|
2015-11-16 07:16:30 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2015-11-16 07:16:30 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
cvf::BoundingBox RimEclipseCase::activeCellsBoundingBox() const
|
|
|
|
|
{
|
2020-04-24 06:53:06 +02:00
|
|
|
if ( m_rigEclipseCase.notNull() && m_rigEclipseCase->activeCellInfo( RiaDefines::PorosityModelType::MATRIX_MODEL ) )
|
2015-11-16 07:16:30 +01:00
|
|
|
{
|
2020-04-24 06:53:06 +02:00
|
|
|
return m_rigEclipseCase->activeCellInfo( RiaDefines::PorosityModelType::MATRIX_MODEL )->geometryBoundingBox();
|
2015-11-16 07:16:30 +01:00
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
return cvf::BoundingBox();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2015-11-16 07:16:30 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
cvf::BoundingBox RimEclipseCase::allCellsBoundingBox() const
|
|
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( m_rigEclipseCase.notNull() && m_rigEclipseCase->mainGrid() )
|
2015-11-16 07:16:30 +01:00
|
|
|
{
|
|
|
|
|
return m_rigEclipseCase->mainGrid()->boundingBox();
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
return cvf::BoundingBox();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2015-11-16 07:16:30 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
cvf::Vec3d RimEclipseCase::displayModelOffset() const
|
|
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( m_rigEclipseCase.notNull() && m_rigEclipseCase->mainGrid() )
|
2015-11-16 07:16:30 +01:00
|
|
|
{
|
|
|
|
|
return m_rigEclipseCase->mainGrid()->displayModelOffset();
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
return cvf::Vec3d::ZERO;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2013-03-18 14:34:29 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2013-03-18 14:34:29 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 10:40:57 +02:00
|
|
|
RigCaseCellResultsData* RimEclipseCase::results( RiaDefines::PorosityModelType porosityModel )
|
2017-09-12 11:39:32 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( m_rigEclipseCase.notNull() )
|
2017-09-12 11:39:32 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
return m_rigEclipseCase->results( porosityModel );
|
2017-09-12 11:39:32 +02:00
|
|
|
}
|
2018-11-06 08:35:04 +01:00
|
|
|
|
2017-09-12 11:39:32 +02:00
|
|
|
return nullptr;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2017-09-12 11:39:32 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 10:40:57 +02:00
|
|
|
const RigCaseCellResultsData* RimEclipseCase::results( RiaDefines::PorosityModelType porosityModel ) const
|
2017-09-12 11:39:32 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( m_rigEclipseCase.notNull() )
|
2017-09-12 11:39:32 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
return m_rigEclipseCase->results( porosityModel );
|
2017-09-12 11:39:32 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return nullptr;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2017-09-12 11:39:32 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 10:40:57 +02:00
|
|
|
RimReservoirCellResultsStorage* RimEclipseCase::resultsStorage( RiaDefines::PorosityModelType porosityModel )
|
2013-03-18 14:34:29 +01:00
|
|
|
{
|
2020-04-24 06:53:06 +02:00
|
|
|
if ( porosityModel == RiaDefines::PorosityModelType::MATRIX_MODEL )
|
2013-03-18 14:34:29 +01:00
|
|
|
{
|
|
|
|
|
return m_matrixModelResults();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return m_fractureModelResults();
|
|
|
|
|
}
|
2013-04-12 08:31:59 +02:00
|
|
|
|
2017-06-16 16:45:14 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2017-06-16 16:45:14 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 10:40:57 +02:00
|
|
|
const RimReservoirCellResultsStorage* RimEclipseCase::resultsStorage( RiaDefines::PorosityModelType porosityModel ) const
|
2013-03-18 14:34:29 +01:00
|
|
|
{
|
2020-04-24 06:53:06 +02:00
|
|
|
if ( porosityModel == RiaDefines::PorosityModelType::MATRIX_MODEL )
|
2013-03-18 14:34:29 +01:00
|
|
|
{
|
|
|
|
|
return m_matrixModelResults();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return m_fractureModelResults();
|
|
|
|
|
}
|
2013-04-12 08:31:59 +02:00
|
|
|
|
2017-06-19 10:54:05 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2017-06-19 10:54:05 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
std::vector<QString> RimEclipseCase::filesContainingFaults() const
|
|
|
|
|
{
|
|
|
|
|
std::vector<QString> stdPathList;
|
|
|
|
|
|
2019-12-10 16:36:07 +01:00
|
|
|
for ( auto& filePath : m_filesContainingFaults() )
|
|
|
|
|
{
|
|
|
|
|
stdPathList.push_back( filePath.path() );
|
|
|
|
|
}
|
2013-04-12 08:31:59 +02:00
|
|
|
|
2017-06-19 10:54:05 +02:00
|
|
|
return stdPathList;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2017-06-19 10:54:05 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-12-10 16:36:07 +01:00
|
|
|
void RimEclipseCase::setFilesContainingFaults( const std::vector<QString>& pathStrings )
|
2017-06-19 10:54:05 +02:00
|
|
|
{
|
2019-12-10 16:36:07 +01:00
|
|
|
std::vector<caf::FilePath> filePaths;
|
|
|
|
|
for ( const auto& pathString : pathStrings )
|
2017-06-19 10:54:05 +02:00
|
|
|
{
|
2019-12-10 16:36:07 +01:00
|
|
|
filePaths.push_back( pathString );
|
2017-06-19 10:54:05 +02:00
|
|
|
}
|
2019-12-10 16:36:07 +01:00
|
|
|
|
|
|
|
|
m_filesContainingFaults = filePaths;
|
2017-06-19 10:54:05 +02:00
|
|
|
}
|
2014-08-21 08:39:19 +02:00
|
|
|
|
2019-01-29 10:01:24 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-02-14 21:26:23 +01:00
|
|
|
///
|
2019-01-29 10:01:24 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
bool RimEclipseCase::ensureReservoirCaseIsOpen()
|
|
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( m_rigEclipseCase.notNull() )
|
2019-01-29 10:01:24 +01:00
|
|
|
{
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return openReserviorCase();
|
|
|
|
|
}
|
|
|
|
|
|
2014-08-21 08:39:19 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2014-08-21 08:39:19 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2015-05-15 08:40:27 +02:00
|
|
|
bool RimEclipseCase::openReserviorCase()
|
2014-08-21 08:39:19 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( !openEclipseGridFile() )
|
2014-08-21 08:39:19 +02:00
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
2017-10-20 15:48:08 +02:00
|
|
|
bool createPlaceholderEntries = true;
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( dynamic_cast<RimEclipseStatisticsCase*>( this ) )
|
2017-10-20 15:48:08 +02:00
|
|
|
{
|
2018-11-06 08:35:04 +01:00
|
|
|
// Never create placeholder entries for statistical cases. This does not make sense, and breaks the
|
2017-10-20 15:48:08 +02:00
|
|
|
// logic for testing if data is present in RimEclipseStatisticsCase::hasComputedStatistics()
|
|
|
|
|
createPlaceholderEntries = false;
|
|
|
|
|
}
|
|
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( createPlaceholderEntries )
|
2014-08-21 08:39:19 +02:00
|
|
|
{
|
2014-08-26 12:07:08 +02:00
|
|
|
{
|
2020-04-24 06:53:06 +02:00
|
|
|
RigCaseCellResultsData* results = this->results( RiaDefines::PorosityModelType::MATRIX_MODEL );
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( results )
|
2017-06-26 10:25:08 +02:00
|
|
|
{
|
2017-10-20 15:48:08 +02:00
|
|
|
results->createPlaceholderResultEntries();
|
2018-11-06 08:35:04 +01:00
|
|
|
// After the placeholder result for combined transmissibility is created,
|
2017-10-20 15:48:08 +02:00
|
|
|
// make sure the nnc transmissibilities can be addressed by this scalarResultIndex as well
|
2019-01-28 16:18:28 +01:00
|
|
|
|
2020-04-23 23:25:22 +02:00
|
|
|
RigEclipseResultAddress combinedTransmissibilityResAddr( RiaDefines::ResultCatType::STATIC_NATIVE,
|
2019-09-06 10:40:57 +02:00
|
|
|
RiaDefines::combinedTransmissibilityResultName() );
|
|
|
|
|
if ( results->hasResultEntry( combinedTransmissibilityResAddr ) )
|
2017-10-20 15:48:08 +02:00
|
|
|
{
|
2020-01-13 14:45:39 +01:00
|
|
|
eclipseCaseData()->mainGrid()->nncData()->setEclResultAddress( RiaDefines::propertyNameCombTrans(),
|
2019-09-06 10:40:57 +02:00
|
|
|
combinedTransmissibilityResAddr );
|
2017-10-20 15:48:08 +02:00
|
|
|
}
|
2019-02-14 21:26:23 +01:00
|
|
|
|
2020-04-23 23:25:22 +02:00
|
|
|
RigEclipseResultAddress combinedWaterFluxResAddr( RiaDefines::ResultCatType::DYNAMIC_NATIVE,
|
2019-09-06 10:40:57 +02:00
|
|
|
RiaDefines::combinedWaterFluxResultName() );
|
|
|
|
|
if ( results->hasResultEntry( combinedWaterFluxResAddr ) )
|
2017-10-20 15:48:08 +02:00
|
|
|
{
|
2020-01-13 14:45:39 +01:00
|
|
|
eclipseCaseData()->mainGrid()->nncData()->setEclResultAddress( RiaDefines::propertyNameFluxWat(),
|
2019-09-06 10:40:57 +02:00
|
|
|
combinedWaterFluxResAddr );
|
2017-10-20 15:48:08 +02:00
|
|
|
}
|
2019-01-28 16:18:28 +01:00
|
|
|
|
2020-04-23 23:25:22 +02:00
|
|
|
RigEclipseResultAddress combinedOilFluxResAddr( RiaDefines::ResultCatType::DYNAMIC_NATIVE,
|
2019-09-06 10:40:57 +02:00
|
|
|
RiaDefines::combinedOilFluxResultName() );
|
|
|
|
|
if ( results->hasResultEntry( combinedOilFluxResAddr ) )
|
2017-10-20 15:48:08 +02:00
|
|
|
{
|
2020-01-13 14:45:39 +01:00
|
|
|
eclipseCaseData()->mainGrid()->nncData()->setEclResultAddress( RiaDefines::propertyNameFluxOil(),
|
2019-09-06 10:40:57 +02:00
|
|
|
combinedOilFluxResAddr );
|
2017-10-20 15:48:08 +02:00
|
|
|
}
|
2020-04-23 23:25:22 +02:00
|
|
|
RigEclipseResultAddress combinedGasFluxResAddr( RiaDefines::ResultCatType::DYNAMIC_NATIVE,
|
2019-09-06 10:40:57 +02:00
|
|
|
RiaDefines::combinedGasFluxResultName() );
|
2019-02-14 21:26:23 +01:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( results->hasResultEntry( combinedGasFluxResAddr ) )
|
2017-10-20 15:48:08 +02:00
|
|
|
{
|
2020-01-13 14:45:39 +01:00
|
|
|
eclipseCaseData()->mainGrid()->nncData()->setEclResultAddress( RiaDefines::propertyNameFluxGas(),
|
2019-09-06 10:40:57 +02:00
|
|
|
combinedGasFluxResAddr );
|
2017-10-20 15:48:08 +02:00
|
|
|
}
|
2014-09-23 11:41:27 +02:00
|
|
|
}
|
2017-10-20 15:48:08 +02:00
|
|
|
}
|
2017-08-25 06:51:56 +02:00
|
|
|
|
|
|
|
|
{
|
2020-04-24 06:53:06 +02:00
|
|
|
RigCaseCellResultsData* results = this->results( RiaDefines::PorosityModelType::FRACTURE_MODEL );
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( results )
|
2017-10-20 15:48:08 +02:00
|
|
|
{
|
|
|
|
|
results->createPlaceholderResultEntries();
|
|
|
|
|
}
|
2017-08-25 06:51:56 +02:00
|
|
|
}
|
2014-08-21 08:39:19 +02:00
|
|
|
}
|
|
|
|
|
|
2017-06-16 16:40:35 +02:00
|
|
|
createTimeStepFormatString();
|
|
|
|
|
|
2017-10-11 15:23:14 +02:00
|
|
|
// Associate existing well paths with simulation wells
|
2020-05-12 09:50:38 +02:00
|
|
|
RimProject* proj = RimProject::current();
|
2019-09-06 10:40:57 +02:00
|
|
|
for ( const auto& oilField : proj->oilFields() )
|
2017-10-11 15:23:14 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
for ( const auto& wellPath : oilField->wellPathCollection()->wellPaths() )
|
2017-10-11 15:23:14 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( !wellPath->isAssociatedWithSimulationWell() )
|
2017-10-11 15:23:14 +02:00
|
|
|
{
|
|
|
|
|
wellPath->tryAssociateWithSimulationWell();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2018-10-24 13:01:17 +02:00
|
|
|
|
|
|
|
|
// Update grids node
|
|
|
|
|
{
|
|
|
|
|
std::vector<RimGridCollection*> gridColls;
|
2019-09-06 10:40:57 +02:00
|
|
|
descendantsIncludingThisOfType( gridColls );
|
|
|
|
|
for ( RimGridCollection* gridCollection : gridColls )
|
2018-10-24 13:01:17 +02:00
|
|
|
{
|
2018-11-27 13:39:11 +01:00
|
|
|
gridCollection->syncFromMainEclipseGrid();
|
2018-10-24 13:01:17 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2014-08-21 08:39:19 +02:00
|
|
|
return true;
|
|
|
|
|
}
|
2015-05-15 18:51:49 +02:00
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2015-05-15 18:51:49 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-01-17 08:00:36 +01:00
|
|
|
std::vector<Rim3dView*> RimEclipseCase::allSpecialViews() const
|
2015-05-15 18:51:49 +02:00
|
|
|
{
|
2018-01-09 10:11:28 +01:00
|
|
|
std::vector<Rim3dView*> views;
|
2019-09-06 10:40:57 +02:00
|
|
|
for ( RimEclipseView* view : reservoirViews )
|
2018-10-23 16:32:40 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
views.push_back( view );
|
2018-10-23 16:32:40 +02:00
|
|
|
}
|
|
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
for ( RimEclipseContourMapView* view : m_contourMapCollection->views() )
|
2015-05-15 18:51:49 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
views.push_back( view );
|
2015-05-15 18:51:49 +02:00
|
|
|
}
|
2018-11-06 08:35:04 +01:00
|
|
|
|
2015-05-15 18:51:49 +02:00
|
|
|
return views;
|
|
|
|
|
}
|
2015-09-21 11:20:07 +02:00
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2015-09-21 11:20:07 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2017-06-16 16:45:14 +02:00
|
|
|
QStringList RimEclipseCase::timeStepStrings() const
|
2015-09-21 11:20:07 +02:00
|
|
|
{
|
|
|
|
|
QStringList stringList;
|
|
|
|
|
|
2020-04-24 06:53:06 +02:00
|
|
|
const RigCaseCellResultsData* cellResultData = results( RiaDefines::PorosityModelType::MATRIX_MODEL );
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( cellResultData )
|
2015-11-11 16:21:07 +01:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
int timeStepCount = static_cast<int>( cellResultData->maxTimeStepCount() );
|
|
|
|
|
for ( int i = 0; i < timeStepCount; i++ )
|
2018-11-13 13:28:16 +01:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
stringList += this->timeStepName( i );
|
2018-11-13 13:28:16 +01:00
|
|
|
}
|
2015-11-11 16:21:07 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return stringList;
|
|
|
|
|
}
|
2015-09-21 11:20:07 +02:00
|
|
|
|
2015-11-11 16:21:07 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2015-11-11 16:21:07 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 10:40:57 +02:00
|
|
|
QString RimEclipseCase::timeStepName( int frameIdx ) const
|
2015-11-11 16:21:07 +01:00
|
|
|
{
|
2017-03-29 20:53:00 +02:00
|
|
|
std::vector<QDateTime> timeStepDates = this->timeStepDates();
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( frameIdx < static_cast<int>( timeStepDates.size() ) )
|
2018-06-11 13:47:21 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
QDateTime date = timeStepDates.at( frameIdx );
|
2018-10-01 20:50:43 +02:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
return RiaQDateTimeTools::toStringUsingApplicationLocale( date, m_timeStepFormatString );
|
2018-06-11 13:47:21 +02:00
|
|
|
}
|
2018-10-01 20:50:43 +02:00
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
return QString( "" );
|
2017-03-24 15:09:10 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2017-03-24 15:09:10 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2017-06-19 20:55:58 +02:00
|
|
|
double RimEclipseCase::characteristicCellSize() const
|
|
|
|
|
{
|
|
|
|
|
const RigEclipseCaseData* rigEclipseCase = eclipseCaseData();
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( rigEclipseCase )
|
2017-06-19 20:55:58 +02:00
|
|
|
{
|
|
|
|
|
return rigEclipseCase->mainGrid()->characteristicIJCellSize();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return 10.0;
|
|
|
|
|
}
|
|
|
|
|
|
2018-07-10 12:44:58 +02:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
///
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
std::set<QString> RimEclipseCase::sortedSimWellNames() const
|
|
|
|
|
{
|
|
|
|
|
std::set<QString> sortedWellNames;
|
2019-09-06 10:40:57 +02:00
|
|
|
if ( eclipseCaseData() )
|
2018-07-10 12:44:58 +02:00
|
|
|
{
|
|
|
|
|
const cvf::Collection<RigSimWellData>& simWellData = eclipseCaseData()->wellResults();
|
|
|
|
|
|
2019-09-06 10:40:57 +02:00
|
|
|
for ( size_t wIdx = 0; wIdx < simWellData.size(); ++wIdx )
|
2018-07-10 12:44:58 +02:00
|
|
|
{
|
2019-09-06 10:40:57 +02:00
|
|
|
sortedWellNames.insert( simWellData[wIdx]->m_wellName );
|
2018-07-10 12:44:58 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return sortedWellNames;
|
|
|
|
|
}
|
|
|
|
|
|
2017-03-24 15:09:10 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-06 08:35:04 +01:00
|
|
|
///
|
2017-03-24 15:09:10 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2017-06-16 16:45:14 +02:00
|
|
|
std::vector<QDateTime> RimEclipseCase::timeStepDates() const
|
2017-03-24 15:09:10 +01:00
|
|
|
{
|
2020-04-24 06:53:06 +02:00
|
|
|
if ( results( RiaDefines::PorosityModelType::MATRIX_MODEL ) )
|
2018-06-11 13:47:21 +02:00
|
|
|
{
|
2020-04-24 06:53:06 +02:00
|
|
|
return results( RiaDefines::PorosityModelType::MATRIX_MODEL )->timeStepDates();
|
2018-06-11 13:47:21 +02:00
|
|
|
}
|
|
|
|
|
return std::vector<QDateTime>();
|
2017-03-24 15:09:10 +01:00
|
|
|
}
|
2019-10-30 16:52:25 +01:00
|
|
|
|
2019-11-06 10:54:42 +01:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
///
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-10-30 16:52:25 +01:00
|
|
|
bool RimEclipseCase::importAsciiInputProperties( const QStringList& fileNames )
|
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|