ResInsight/ApplicationLibCode/ProjectDataModel/Rim3dWellLogRftCurve.cpp

246 lines
9.5 KiB
C++
Raw Normal View History

/////////////////////////////////////////////////////////////////////////////////
//
2019-01-09 08:21:38 -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 "Rim3dWellLogRftCurve.h"
#include "RiaQDateTimeTools.h"
2018-04-27 08:30:34 -05:00
#include "RifReaderEclipseRft.h"
#include "RigWellLogCurveData.h"
2018-04-27 08:30:34 -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"
//==================================================================================================
///
///
//==================================================================================================
2019-09-06 06:17:36 -05:00
CAF_PDM_SOURCE_INIT( Rim3dWellLogRftCurve, "Rim3dWellLogRftCurve" );
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
Rim3dWellLogRftCurve::Rim3dWellLogRftCurve()
{
2019-09-06 06:17:36 -05:00
CAF_PDM_InitObject( "3d Well Log RFT Curve", ":/WellLogCurve16x16.png", "", "" );
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
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", "", "", "", "" );
m_nameConfig = new RimWellLogRftCurveNameConfig();
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
Rim3dWellLogRftCurve::~Rim3dWellLogRftCurve()
{
2018-04-27 08:30:34 -05:00
delete m_nameConfig;
}
//--------------------------------------------------------------------------------------------------
2019-09-06 06:17:36 -05:00
///
//--------------------------------------------------------------------------------------------------
2019-09-06 06:17:36 -05:00
void Rim3dWellLogRftCurve::curveValuesAndMds( std::vector<double>* values, std::vector<double>* measuredDepthValues ) const
{
2019-09-06 06:17:36 -05:00
if ( m_2dWellLogRftCurve->wellName() == QString() )
{
2019-09-06 06:17:36 -05:00
m_2dWellLogRftCurve->setDefaultAddress( wellName() );
}
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 );
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
QString Rim3dWellLogRftCurve::resultPropertyString() const
{
2019-09-06 06:17:36 -05:00
return caf::AppEnum<RifEclipseRftAddress::RftWellLogChannelType>::uiText( m_wellLogChannelName() );
}
2018-04-27 08:30:34 -05:00
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
QString Rim3dWellLogRftCurve::name() const
{
return m_nameConfig->name();
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
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();
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
2019-09-06 06:17:36 -05:00
void Rim3dWellLogRftCurve::fieldChangedByUi( const caf::PdmFieldHandle* changedField,
const QVariant& oldValue,
const QVariant& newValue )
{
2019-09-06 06:17:36 -05:00
if ( changedField == &m_wellLogChannelName || changedField == &m_timeStep )
{
this->resetMinMaxValues();
this->updateConnectedEditors();
}
2019-09-06 06:17:36 -05:00
Rim3dWellLogCurve::fieldChangedByUi( changedField, oldValue, newValue );
}
//--------------------------------------------------------------------------------------------------
2019-09-06 06:17:36 -05:00
///
//--------------------------------------------------------------------------------------------------
QList<caf::PdmOptionItemInfo>
Rim3dWellLogRftCurve::calculateValueOptions( const caf::PdmFieldHandle* fieldNeedingOptions, bool* useOptionsOnly )
{
QList<caf::PdmOptionItemInfo> options;
2019-09-06 06:17:36 -05:00
if ( fieldNeedingOptions == &m_eclipseResultCase )
{
2019-09-06 06:17:36 -05:00
RimTools::caseOptionItems( &options );
2019-09-06 06:17:36 -05:00
options.push_front( caf::PdmOptionItemInfo( "None", nullptr ) );
}
2019-09-06 06:17:36 -05:00
else if ( fieldNeedingOptions == &m_wellLogChannelName )
{
2019-09-06 06:17:36 -05:00
if ( m_eclipseResultCase )
{
RifReaderEclipseRft* reader = m_eclipseResultCase()->rftReader();
2019-09-06 06:17:36 -05:00
if ( reader )
{
2019-09-06 06:17:36 -05:00
for ( const RifEclipseRftAddress::RftWellLogChannelType& channelName :
reader->availableWellLogChannels( wellName() ) )
{
2019-09-06 06:17:36 -05:00
options.push_back(
caf::PdmOptionItemInfo( caf::AppEnum<RifEclipseRftAddress::RftWellLogChannelType>::uiText(
channelName ),
channelName ) );
}
}
2019-09-06 06:17:36 -05:00
if ( options.empty() )
{
options.push_back( caf::PdmOptionItemInfo( caf::AppEnum<RifEclipseRftAddress::RftWellLogChannelType>::uiText(
RifEclipseRftAddress::NONE ),
RifEclipseRftAddress::NONE ) );
}
}
}
2019-09-06 06:17:36 -05:00
else if ( fieldNeedingOptions == &m_timeStep )
{
2019-09-06 06:17:36 -05:00
if ( m_eclipseResultCase )
{
RifReaderEclipseRft* reader = m_eclipseResultCase()->rftReader();
2019-09-06 06:17:36 -05:00
if ( reader )
{
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 )
{
2019-09-06 06:17:36 -05:00
QString dateString = RiaQDateTimeTools::toStringUsingApplicationLocale( dt, dateFormat );
2019-09-06 06:17:36 -05:00
options.push_back( caf::PdmOptionItemInfo( dateString, dt ) );
}
}
2019-09-06 06:17:36 -05:00
options.push_back( caf::PdmOptionItemInfo( "None", QDateTime() ) );
}
}
return options;
}
//--------------------------------------------------------------------------------------------------
2019-09-06 06:17:36 -05:00
///
//--------------------------------------------------------------------------------------------------
2019-09-06 06:17:36 -05:00
void Rim3dWellLogRftCurve::defineUiOrdering( QString uiConfigName, caf::PdmUiOrdering& uiOrdering )
{
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 );
2019-09-06 06:17:36 -05:00
Rim3dWellLogCurve::configurationUiOrdering( uiOrdering );
2019-09-06 06:17:36 -05:00
caf::PdmUiGroup* nameGroup = uiOrdering.addNewGroup( "Curve Name" );
m_nameConfig->uiOrdering( uiConfigName, *nameGroup );
2019-09-06 06:17:36 -05:00
uiOrdering.skipRemainingFields( true );
}
//--------------------------------------------------------------------------------------------------
2019-09-06 06:17:36 -05:00
///
//--------------------------------------------------------------------------------------------------
QString Rim3dWellLogRftCurve::wellName() const
{
RimWellPath* wellPath = nullptr;
2019-09-06 06:17:36 -05:00
firstAncestorOrThisOfType( wellPath );
return wellPath->name();
}