mirror of
https://github.com/OPM/ResInsight.git
synced 2025-02-25 18:55:39 -06:00
#9620 Pressure/depth data: add user interface.
This commit is contained in:
@@ -32,6 +32,7 @@
|
||||
#include "RimObservedDataCollection.h"
|
||||
#include "RimObservedFmuRftData.h"
|
||||
#include "RimOilField.h"
|
||||
#include "RimPressureDepthData.h"
|
||||
#include "RimProject.h"
|
||||
#include "RimSummaryCase.h"
|
||||
#include "RimSummaryCaseCollection.h"
|
||||
@@ -486,6 +487,39 @@ std::vector<RimObservedFmuRftData*> RimWellPlotTools::observedFmuRftData()
|
||||
return {};
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
std::vector<RimPressureDepthData*> RimWellPlotTools::pressureDepthDataForWell( const QString& simWellName )
|
||||
{
|
||||
std::vector<RimPressureDepthData*> observedDataForWell;
|
||||
std::vector<RimPressureDepthData*> allObservedData = pressureDepthData();
|
||||
for ( RimPressureDepthData* observedData : allObservedData )
|
||||
{
|
||||
if ( observedData->hasWell( simWellName ) )
|
||||
{
|
||||
observedDataForWell.push_back( observedData );
|
||||
}
|
||||
}
|
||||
return observedDataForWell;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
std::vector<RimPressureDepthData*> RimWellPlotTools::pressureDepthData()
|
||||
{
|
||||
const RimProject* project = RimProject::current();
|
||||
RimObservedDataCollection* observedDataCollection =
|
||||
project->activeOilField() ? project->activeOilField()->observedDataCollection() : nullptr;
|
||||
|
||||
if ( observedDataCollection )
|
||||
{
|
||||
return observedDataCollection->allPressureDepthData();
|
||||
}
|
||||
return {};
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
@@ -588,6 +622,7 @@ RiaRftPltCurveDefinition RimWellPlotTools::curveDefFromCurve( const RimWellLogCu
|
||||
RimSummaryCase* rftSummaryCase = rftCurve->summaryCase();
|
||||
RimSummaryCaseCollection* rftEnsemble = rftCurve->ensemble();
|
||||
RimObservedFmuRftData* rftFmuData = rftCurve->observedFmuRftData();
|
||||
RimPressureDepthData* pressureDepthData = rftCurve->pressureDepthData();
|
||||
|
||||
const RifEclipseRftAddress rftAddress = rftCurve->rftAddress();
|
||||
const QString& wellName = rftAddress.wellName();
|
||||
@@ -620,6 +655,13 @@ RiaRftPltCurveDefinition RimWellPlotTools::curveDefFromCurve( const RimWellLogCu
|
||||
wellName,
|
||||
timeStep );
|
||||
}
|
||||
else if ( pressureDepthData != nullptr )
|
||||
{
|
||||
return RiaRftPltCurveDefinition( RifDataSourceForRftPlt( RifDataSourceForRftPlt::OBSERVED_FMU_RFT,
|
||||
pressureDepthData ),
|
||||
wellName,
|
||||
timeStep );
|
||||
}
|
||||
}
|
||||
else if ( gridCurve != nullptr )
|
||||
{
|
||||
@@ -765,6 +807,20 @@ std::set<RiaRftPltCurveDefinition>
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
RimPressureDepthData* pressureDepthData = addr.pressureDepthData();
|
||||
if ( pressureDepthData && pressureDepthData->rftReader() )
|
||||
{
|
||||
std::set<QDateTime> timeSteps =
|
||||
pressureDepthData->rftReader()->availableTimeSteps( wellPathNameOrSimWellName );
|
||||
for ( const QDateTime& time : timeSteps )
|
||||
{
|
||||
if ( selectedTimeStepSet.count( time ) )
|
||||
{
|
||||
curveDefs.insert( RiaRftPltCurveDefinition( addr, wellPathNameOrSimWellName, time ) );
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
else if ( addr.ensemble() )
|
||||
{
|
||||
@@ -1082,13 +1138,27 @@ std::map<QDateTime, std::set<RifDataSourceForRftPlt>> RimWellPlotTools::calculat
|
||||
{
|
||||
observedTimeStepsWithSources[source.wellLogFile()->date()].insert( source );
|
||||
}
|
||||
else if ( source.sourceType() == RifDataSourceForRftPlt::OBSERVED_FMU_RFT && source.observedFmuRftData() )
|
||||
else if ( source.sourceType() == RifDataSourceForRftPlt::OBSERVED_FMU_RFT )
|
||||
{
|
||||
std::set<QDateTime> rftFmuTimes =
|
||||
source.observedFmuRftData()->rftReader()->availableTimeSteps( wellPathNameOrSimWellName );
|
||||
for ( const QDateTime& date : rftFmuTimes )
|
||||
{
|
||||
observedTimeStepsWithSources[date].insert( source );
|
||||
if ( source.observedFmuRftData() )
|
||||
{
|
||||
std::set<QDateTime> rftFmuTimes =
|
||||
source.observedFmuRftData()->rftReader()->availableTimeSteps( wellPathNameOrSimWellName );
|
||||
for ( const QDateTime& date : rftFmuTimes )
|
||||
{
|
||||
observedTimeStepsWithSources[date].insert( source );
|
||||
}
|
||||
}
|
||||
else if ( source.pressureDepthData() )
|
||||
{
|
||||
std::set<QDateTime> rftFmuTimes =
|
||||
source.pressureDepthData()->rftReader()->availableTimeSteps( wellPathNameOrSimWellName );
|
||||
for ( const QDateTime& date : rftFmuTimes )
|
||||
{
|
||||
observedTimeStepsWithSources[date].insert( source );
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -39,6 +39,7 @@ class RimWellLogCurve;
|
||||
class RimWellLogFileChannel;
|
||||
class RimWellLogPlot;
|
||||
class RimWellPath;
|
||||
class RimPressureDepthData;
|
||||
class RiuWellRftPlot;
|
||||
class RigEclipseCaseData;
|
||||
class RigEclipseResultAddress;
|
||||
@@ -134,6 +135,9 @@ public:
|
||||
|
||||
static bool hasFlowData( const RimWellPath* wellPath );
|
||||
|
||||
static std::vector<RimPressureDepthData*> pressureDepthData();
|
||||
static std::vector<RimPressureDepthData*> pressureDepthDataForWell( const QString& simWellName );
|
||||
|
||||
private:
|
||||
friend class StaticFieldsInitializer;
|
||||
static const std::set<QString> PRESSURE_DATA_NAMES;
|
||||
|
||||
@@ -38,6 +38,7 @@
|
||||
#include "RimEnsembleCurveSetColorManager.h"
|
||||
#include "RimObservedFmuRftData.h"
|
||||
#include "RimOilField.h"
|
||||
#include "RimPressureDepthData.h"
|
||||
#include "RimProject.h"
|
||||
#include "RimRegularLegendConfig.h"
|
||||
#include "RimSummaryCaseCollection.h"
|
||||
@@ -516,11 +517,18 @@ void RimWellRftPlot::updateCurvesInPlot( const std::set<RiaRftPltCurveDefinition
|
||||
else if ( curveDefToAdd.address().sourceType() == RifDataSourceForRftPlt::OBSERVED_FMU_RFT )
|
||||
{
|
||||
auto curve = new RimWellLogRftCurve();
|
||||
curve->setErrorBarsVisible( m_showErrorInObservedData );
|
||||
plotTrack->addCurve( curve );
|
||||
|
||||
auto observedFmuRftData = curveDefToAdd.address().observedFmuRftData();
|
||||
curve->setObservedFmuRftData( observedFmuRftData );
|
||||
if ( auto observedFmuRftData = curveDefToAdd.address().observedFmuRftData() )
|
||||
{
|
||||
curve->setErrorBarsVisible( m_showErrorInObservedData );
|
||||
curve->setObservedFmuRftData( observedFmuRftData );
|
||||
}
|
||||
else if ( auto pressureDepthData = curveDefToAdd.address().pressureDepthData() )
|
||||
{
|
||||
curve->setPressureDepthData( pressureDepthData );
|
||||
}
|
||||
|
||||
RifEclipseRftAddress address =
|
||||
RifEclipseRftAddress::createAddress( m_wellPathNameOrSimWellName,
|
||||
curveDefToAdd.timeStep(),
|
||||
@@ -851,6 +859,22 @@ QList<caf::PdmOptionItemInfo> RimWellRftPlot::calculateValueOptions( const caf::
|
||||
options.push_back( item );
|
||||
}
|
||||
}
|
||||
const std::vector<RimPressureDepthData*> pressureDepthData =
|
||||
RimWellPlotTools::pressureDepthDataForWell( m_wellPathNameOrSimWellName );
|
||||
if ( !pressureDepthData.empty() )
|
||||
{
|
||||
options.push_back( caf::PdmOptionItemInfo::createHeader( RifDataSourceForRftPlt::sourceTypeUiText(
|
||||
RifDataSourceForRftPlt::OBSERVED_FMU_RFT ),
|
||||
true ) );
|
||||
|
||||
for ( const auto& pd : pressureDepthData )
|
||||
{
|
||||
auto addr = RifDataSourceForRftPlt( RifDataSourceForRftPlt::OBSERVED_FMU_RFT, pd );
|
||||
auto item = caf::PdmOptionItemInfo( pd->name(), QVariant::fromValue( addr ) );
|
||||
item.setLevel( 1 );
|
||||
options.push_back( item );
|
||||
}
|
||||
}
|
||||
}
|
||||
else if ( fieldNeedingOptions == &m_selectedTimeSteps )
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user