2018-03-16 05:20:17 -05:00
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
2019-01-09 08:21:38 -06:00
|
|
|
// Copyright (C) 2018- Equinor ASA
|
2018-03-16 05:20:17 -05: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.
|
|
|
|
//
|
|
|
|
// 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 "Rim3dWellLogRftCurve.h"
|
|
|
|
|
2018-10-01 13:50:43 -05:00
|
|
|
#include "RiaQDateTimeTools.h"
|
|
|
|
|
2018-04-27 08:30:34 -05:00
|
|
|
#include "RifReaderEclipseRft.h"
|
2018-10-01 13:50:43 -05:00
|
|
|
|
2018-03-16 05:20:17 -05:00
|
|
|
#include "RigWellLogCurveData.h"
|
2018-04-27 08:30:34 -05:00
|
|
|
|
2018-03-16 05:20:17 -05:00
|
|
|
#include "RimEclipseResultCase.h"
|
|
|
|
#include "RimTools.h"
|
2018-04-27 08:30:34 -05:00
|
|
|
#include "RimWellLogCurve.h"
|
2019-09-06 06:17:36 -05:00
|
|
|
#include "RimWellLogRftCurveNameConfig.h"
|
|
|
|
#include "RimWellPath.h"
|
2018-03-16 05:20:17 -05:00
|
|
|
|
|
|
|
//==================================================================================================
|
|
|
|
///
|
|
|
|
///
|
|
|
|
//==================================================================================================
|
|
|
|
|
2019-09-06 06:17:36 -05:00
|
|
|
CAF_PDM_SOURCE_INIT( Rim3dWellLogRftCurve, "Rim3dWellLogRftCurve" );
|
2018-03-16 05:20:17 -05:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
Rim3dWellLogRftCurve::Rim3dWellLogRftCurve()
|
|
|
|
{
|
2019-09-06 06:17:36 -05:00
|
|
|
CAF_PDM_InitObject( "3d Well Log RFT Curve", ":/WellLogCurve16x16.png", "", "" );
|
2018-03-16 05:20:17 -05:00
|
|
|
|
2019-09-06 06:17:36 -05:00
|
|
|
CAF_PDM_InitFieldNoDefault( &m_eclipseResultCase, "eclipseResultCase", "", "", "", "" );
|
|
|
|
CAF_PDM_InitFieldNoDefault( &m_timeStep, "timeStep", "", "", "", "" );
|
2018-03-16 07:40:49 -05:00
|
|
|
|
2019-09-06 06:17:36 -05:00
|
|
|
CAF_PDM_InitFieldNoDefault( &m_wellLogChannelName, "wellLogChannelName", "", "", "", "" );
|
2018-03-16 07:40:49 -05:00
|
|
|
|
2019-09-06 06:17:36 -05:00
|
|
|
CAF_PDM_InitFieldNoDefault( &m_2dWellLogRftCurve, "my2dWellLogRftCurve", "", "", "", "" );
|
2018-03-16 07:40:49 -05:00
|
|
|
|
2018-03-16 05:20:17 -05:00
|
|
|
m_2dWellLogRftCurve = new RimWellLogRftCurve();
|
2018-03-16 07:40:49 -05:00
|
|
|
m_2dWellLogRftCurve.xmlCapability()->disableIO();
|
|
|
|
|
2019-09-06 06:17:36 -05:00
|
|
|
CAF_PDM_InitFieldNoDefault( &m_nameConfig, "NameConfig", "", "", "", "" );
|
2019-09-06 03:59:04 -05:00
|
|
|
m_nameConfig = new RimWellLogRftCurveNameConfig();
|
2018-03-16 05:20:17 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
Rim3dWellLogRftCurve::~Rim3dWellLogRftCurve()
|
|
|
|
{
|
2018-04-27 08:30:34 -05:00
|
|
|
delete m_nameConfig;
|
2018-03-16 05:20:17 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 06:17:36 -05:00
|
|
|
///
|
2018-03-16 05:20:17 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 06:17:36 -05:00
|
|
|
void Rim3dWellLogRftCurve::curveValuesAndMds( std::vector<double>* values, std::vector<double>* measuredDepthValues ) const
|
2018-03-16 05:20:17 -05:00
|
|
|
{
|
2019-09-06 06:17:36 -05:00
|
|
|
if ( m_2dWellLogRftCurve->wellName() == QString() )
|
2018-03-16 05:20:17 -05:00
|
|
|
{
|
2019-09-06 06:17:36 -05:00
|
|
|
m_2dWellLogRftCurve->setDefaultAddress( wellName() );
|
2018-03-16 05:20:17 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
const RigWellLogCurveData* curveData = m_2dWellLogRftCurve->curveData();
|
|
|
|
|
2019-09-06 06:17:36 -05:00
|
|
|
// These values are for a simulation well
|
|
|
|
*values = curveData->xValues();
|
2020-04-24 00:13:33 -05:00
|
|
|
*measuredDepthValues = curveData->depths( RiaDefines::DepthTypeEnum::MEASURED_DEPTH );
|
2018-03-16 05:20:17 -05:00
|
|
|
}
|
|
|
|
|
2018-04-25 04:00:27 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
QString Rim3dWellLogRftCurve::resultPropertyString() const
|
|
|
|
{
|
2019-09-06 06:17:36 -05:00
|
|
|
return caf::AppEnum<RifEclipseRftAddress::RftWellLogChannelType>::uiText( m_wellLogChannelName() );
|
2018-04-25 04:00:27 -05:00
|
|
|
}
|
|
|
|
|
2018-04-27 08:30:34 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
QString Rim3dWellLogRftCurve::name() const
|
|
|
|
{
|
|
|
|
return m_nameConfig->name();
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-07-16 01:56:28 -05:00
|
|
|
QString Rim3dWellLogRftCurve::createAutoName() const
|
2018-04-27 08:30:34 -05:00
|
|
|
{
|
|
|
|
QStringList name;
|
|
|
|
|
2019-09-06 06:17:36 -05:00
|
|
|
if ( !wellName().isEmpty() )
|
2018-04-27 08:30:34 -05:00
|
|
|
{
|
2019-09-06 06:17:36 -05:00
|
|
|
name.push_back( wellName() );
|
2018-04-27 08:30:34 -05:00
|
|
|
}
|
|
|
|
|
2019-09-06 06:17:36 -05:00
|
|
|
name.push_back( "RFT" );
|
2018-04-27 08:30:34 -05:00
|
|
|
|
2019-09-06 06:17:36 -05:00
|
|
|
if ( m_eclipseResultCase )
|
2018-04-27 08:30:34 -05:00
|
|
|
{
|
2019-09-06 06:17:36 -05:00
|
|
|
name.push_back( m_eclipseResultCase->caseUserDescription() );
|
2018-04-27 08:30:34 -05:00
|
|
|
}
|
2019-09-06 06:17:36 -05:00
|
|
|
if ( m_wellLogChannelName().text() !=
|
|
|
|
caf::AppEnum<RifEclipseRftAddress::RftWellLogChannelType>::text( RifEclipseRftAddress::NONE ) )
|
2018-04-27 08:30:34 -05:00
|
|
|
{
|
|
|
|
RifEclipseRftAddress::RftWellLogChannelType channelNameEnum = m_wellLogChannelName();
|
2019-09-06 06:17:36 -05:00
|
|
|
name.push_back( caf::AppEnum<RifEclipseRftAddress::RftWellLogChannelType>::uiText( channelNameEnum ) );
|
2018-04-27 08:30:34 -05:00
|
|
|
}
|
2019-09-06 06:17:36 -05:00
|
|
|
if ( !m_timeStep().isNull() )
|
2018-04-27 08:30:34 -05:00
|
|
|
{
|
2019-09-06 06:17:36 -05:00
|
|
|
name.push_back( m_timeStep().toString( RiaQDateTimeTools::dateFormatString() ) );
|
2018-04-27 08:30:34 -05:00
|
|
|
}
|
|
|
|
|
2019-09-06 06:17:36 -05:00
|
|
|
return name.join( ", " );
|
2018-04-27 08:30:34 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
caf::PdmFieldHandle* Rim3dWellLogRftCurve::userDescriptionField()
|
|
|
|
{
|
|
|
|
return m_nameConfig()->nameField();
|
|
|
|
}
|
|
|
|
|
2018-03-16 05:20:17 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-04-19 06:42:53 -05:00
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 06:17:36 -05:00
|
|
|
void Rim3dWellLogRftCurve::fieldChangedByUi( const caf::PdmFieldHandle* changedField,
|
|
|
|
const QVariant& oldValue,
|
|
|
|
const QVariant& newValue )
|
2018-04-19 06:42:53 -05:00
|
|
|
{
|
2019-09-06 06:17:36 -05:00
|
|
|
if ( changedField == &m_wellLogChannelName || changedField == &m_timeStep )
|
2018-04-19 06:42:53 -05:00
|
|
|
{
|
2019-09-11 08:50:22 -05:00
|
|
|
this->resetMinMaxValues();
|
|
|
|
this->updateConnectedEditors();
|
2018-04-19 06:42:53 -05:00
|
|
|
}
|
2019-09-06 06:17:36 -05:00
|
|
|
Rim3dWellLogCurve::fieldChangedByUi( changedField, oldValue, newValue );
|
2018-04-19 06:42:53 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 06:17:36 -05:00
|
|
|
///
|
2018-03-16 05:20:17 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2020-02-12 04:43:15 -06:00
|
|
|
QList<caf::PdmOptionItemInfo>
|
|
|
|
Rim3dWellLogRftCurve::calculateValueOptions( const caf::PdmFieldHandle* fieldNeedingOptions, bool* useOptionsOnly )
|
2018-03-16 05:20:17 -05:00
|
|
|
{
|
|
|
|
QList<caf::PdmOptionItemInfo> options;
|
|
|
|
|
2019-09-06 06:17:36 -05:00
|
|
|
if ( fieldNeedingOptions == &m_eclipseResultCase )
|
2018-03-16 05:20:17 -05:00
|
|
|
{
|
2019-09-06 06:17:36 -05:00
|
|
|
RimTools::caseOptionItems( &options );
|
2018-03-16 05:20:17 -05:00
|
|
|
|
2019-09-06 06:17:36 -05:00
|
|
|
options.push_front( caf::PdmOptionItemInfo( "None", nullptr ) );
|
2018-03-16 05:20:17 -05:00
|
|
|
}
|
2019-09-06 06:17:36 -05:00
|
|
|
else if ( fieldNeedingOptions == &m_wellLogChannelName )
|
2018-03-16 05:20:17 -05:00
|
|
|
{
|
2019-09-06 06:17:36 -05:00
|
|
|
if ( m_eclipseResultCase )
|
2018-03-16 05:20:17 -05:00
|
|
|
{
|
|
|
|
RifReaderEclipseRft* reader = m_eclipseResultCase()->rftReader();
|
2019-09-06 06:17:36 -05:00
|
|
|
if ( reader )
|
2018-03-16 05:20:17 -05:00
|
|
|
{
|
2019-09-06 06:17:36 -05:00
|
|
|
for ( const RifEclipseRftAddress::RftWellLogChannelType& channelName :
|
|
|
|
reader->availableWellLogChannels( wellName() ) )
|
2018-03-16 05:20:17 -05:00
|
|
|
{
|
2019-09-06 06:17:36 -05:00
|
|
|
options.push_back(
|
|
|
|
caf::PdmOptionItemInfo( caf::AppEnum<RifEclipseRftAddress::RftWellLogChannelType>::uiText(
|
|
|
|
channelName ),
|
|
|
|
channelName ) );
|
2018-03-16 05:20:17 -05:00
|
|
|
}
|
|
|
|
}
|
2019-09-06 06:17:36 -05:00
|
|
|
if ( options.empty() )
|
2018-03-16 05:20:17 -05:00
|
|
|
{
|
2020-02-12 04:43:15 -06:00
|
|
|
options.push_back( caf::PdmOptionItemInfo( caf::AppEnum<RifEclipseRftAddress::RftWellLogChannelType>::uiText(
|
|
|
|
RifEclipseRftAddress::NONE ),
|
|
|
|
RifEclipseRftAddress::NONE ) );
|
2018-03-16 05:20:17 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2019-09-06 06:17:36 -05:00
|
|
|
else if ( fieldNeedingOptions == &m_timeStep )
|
2018-03-16 05:20:17 -05:00
|
|
|
{
|
2019-09-06 06:17:36 -05:00
|
|
|
if ( m_eclipseResultCase )
|
2018-03-16 05:20:17 -05:00
|
|
|
{
|
|
|
|
RifReaderEclipseRft* reader = m_eclipseResultCase()->rftReader();
|
2019-09-06 06:17:36 -05:00
|
|
|
if ( reader )
|
2018-03-16 05:20:17 -05:00
|
|
|
{
|
2019-09-06 06:17:36 -05:00
|
|
|
QString dateFormat = "dd MMM yyyy";
|
|
|
|
std::set<QDateTime> timeStamps = reader->availableTimeSteps( wellName(), m_wellLogChannelName() );
|
|
|
|
for ( const QDateTime& dt : timeStamps )
|
2018-03-16 05:20:17 -05:00
|
|
|
{
|
2019-09-06 06:17:36 -05:00
|
|
|
QString dateString = RiaQDateTimeTools::toStringUsingApplicationLocale( dt, dateFormat );
|
2018-10-01 13:50:43 -05:00
|
|
|
|
2019-09-06 06:17:36 -05:00
|
|
|
options.push_back( caf::PdmOptionItemInfo( dateString, dt ) );
|
2018-03-16 05:20:17 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-09-06 06:17:36 -05:00
|
|
|
options.push_back( caf::PdmOptionItemInfo( "None", QDateTime() ) );
|
2018-03-16 05:20:17 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return options;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 06:17:36 -05:00
|
|
|
///
|
2018-03-16 05:20:17 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 06:17:36 -05:00
|
|
|
void Rim3dWellLogRftCurve::defineUiOrdering( QString uiConfigName, caf::PdmUiOrdering& uiOrdering )
|
2018-03-16 05:20:17 -05:00
|
|
|
{
|
2019-09-06 06:17:36 -05:00
|
|
|
caf::PdmUiGroup* curveDataGroup = uiOrdering.addNewGroup( "Curve Data" );
|
|
|
|
curveDataGroup->add( &m_eclipseResultCase );
|
|
|
|
curveDataGroup->add( &m_wellLogChannelName );
|
|
|
|
curveDataGroup->add( &m_timeStep );
|
2018-03-16 05:20:17 -05:00
|
|
|
|
2019-09-06 06:17:36 -05:00
|
|
|
Rim3dWellLogCurve::configurationUiOrdering( uiOrdering );
|
2018-03-16 05:20:17 -05:00
|
|
|
|
2019-09-06 06:17:36 -05:00
|
|
|
caf::PdmUiGroup* nameGroup = uiOrdering.addNewGroup( "Curve Name" );
|
|
|
|
m_nameConfig->uiOrdering( uiConfigName, *nameGroup );
|
2018-04-30 02:22:59 -05:00
|
|
|
|
2019-09-06 06:17:36 -05:00
|
|
|
uiOrdering.skipRemainingFields( true );
|
2018-03-16 05:20:17 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 06:17:36 -05:00
|
|
|
///
|
2018-03-16 05:20:17 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
QString Rim3dWellLogRftCurve::wellName() const
|
|
|
|
{
|
|
|
|
RimWellPath* wellPath = nullptr;
|
2019-09-06 06:17:36 -05:00
|
|
|
firstAncestorOrThisOfType( wellPath );
|
2018-03-16 05:20:17 -05:00
|
|
|
|
|
|
|
return wellPath->name();
|
|
|
|
}
|