mirror of
				https://github.com/OPM/ResInsight.git
				synced 2025-02-25 18:55:39 -06:00 
			
		
		
		
	
		
			
				
	
	
		
			1039 lines
		
	
	
		
			47 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			1039 lines
		
	
	
		
			47 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /////////////////////////////////////////////////////////////////////////////////
 | |
| //
 | |
| //  Copyright (C) Statoil ASA
 | |
| //  Copyright (C) Ceetron Solutions AS
 | |
| //
 | |
| //  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 "RiuResultTextBuilder.h"
 | |
| 
 | |
| #include "RigAllanDiagramData.h"
 | |
| #include "RigCaseCellResultsData.h"
 | |
| #include "RigEclipseCaseData.h"
 | |
| #include "RigFormationNames.h"
 | |
| #include "RigMainGrid.h"
 | |
| #include "RigNNCData.h"
 | |
| #include "RigResultAccessor.h"
 | |
| #include "RigResultAccessorFactory.h"
 | |
| #include "RigSimWellData.h"
 | |
| #include "RigWellResultPoint.h"
 | |
| 
 | |
| #include "Rim2dIntersectionView.h"
 | |
| #include "RimCellEdgeColors.h"
 | |
| #include "RimEclipseCase.h"
 | |
| #include "RimEclipseCellColors.h"
 | |
| #include "RimEclipseFaultColors.h"
 | |
| #include "RimEclipseView.h"
 | |
| #include "RimExtrudedCurveIntersection.h"
 | |
| #include "RimFormationNames.h"
 | |
| #include "RimIntersectionResultDefinition.h"
 | |
| #include "RimRegularLegendConfig.h"
 | |
| #include "RimReservoirCellResultsStorage.h"
 | |
| 
 | |
| #include "RivExtrudedCurveIntersectionPartMgr.h"
 | |
| 
 | |
| #include "cafDisplayCoordTransform.h"
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| RiuResultTextBuilder::RiuResultTextBuilder( RimGridView*                settingsView,
 | |
|                                             RimEclipseResultDefinition* eclResDef,
 | |
|                                             size_t                      gridIndex,
 | |
|                                             size_t                      cellIndex,
 | |
|                                             size_t                      timeStepIndex )
 | |
| {
 | |
|     CVF_ASSERT( eclResDef );
 | |
| 
 | |
|     m_displayCoordView       = settingsView;
 | |
|     m_viewWithFaultsSettings = dynamic_cast<RimEclipseView*>( settingsView );
 | |
|     m_eclResDef              = eclResDef;
 | |
|     m_gridIndex              = gridIndex;
 | |
|     m_cellIndex              = cellIndex;
 | |
|     m_timeStepIndex          = timeStepIndex;
 | |
| 
 | |
|     m_nncIndex                   = cvf::UNDEFINED_SIZE_T;
 | |
|     m_intersectionPointInDisplay = cvf::Vec3d::UNDEFINED;
 | |
|     m_face                       = cvf::StructGridInterface::NO_FACE;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| RiuResultTextBuilder::RiuResultTextBuilder( RimGridView*                settingsView,
 | |
|                                             RimEclipseResultDefinition* eclResDef,
 | |
|                                             size_t                      reservoirCellIndex,
 | |
|                                             size_t                      timeStepIndex )
 | |
| {
 | |
|     CVF_ASSERT( eclResDef );
 | |
| 
 | |
|     m_displayCoordView       = settingsView;
 | |
|     m_viewWithFaultsSettings = dynamic_cast<RimEclipseView*>( settingsView );
 | |
|     m_eclResDef              = eclResDef;
 | |
|     m_gridIndex              = 0;
 | |
|     m_cellIndex              = 0;
 | |
|     m_timeStepIndex          = timeStepIndex;
 | |
| 
 | |
|     RimEclipseCase* eclipseCase = eclResDef->eclipseCase();
 | |
|     if ( eclipseCase && eclipseCase->eclipseCaseData() )
 | |
|     {
 | |
|         RigEclipseCaseData* caseData = eclipseCase->eclipseCaseData();
 | |
|         RigMainGrid*        mainGrid = caseData->mainGrid();
 | |
| 
 | |
|         const RigCell& cell = caseData->mainGrid()->globalCellArray()[reservoirCellIndex];
 | |
| 
 | |
|         for ( size_t i = 0; i < mainGrid->gridCount(); i++ )
 | |
|         {
 | |
|             if ( mainGrid->gridByIndex( i ) == cell.hostGrid() )
 | |
|             {
 | |
|                 m_gridIndex = i;
 | |
|                 m_cellIndex = cell.gridLocalCellIndex();
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     m_nncIndex                   = cvf::UNDEFINED_SIZE_T;
 | |
|     m_intersectionPointInDisplay = cvf::Vec3d::UNDEFINED;
 | |
|     m_face                       = cvf::StructGridInterface::NO_FACE;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RiuResultTextBuilder::setNncIndex( size_t nncIndex )
 | |
| {
 | |
|     m_nncIndex = nncIndex;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RiuResultTextBuilder::setIntersectionPointInDisplay( cvf::Vec3d intersectionPointInDisplay )
 | |
| {
 | |
|     m_intersectionPointInDisplay = intersectionPointInDisplay;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RiuResultTextBuilder::set2dIntersectionView( Rim2dIntersectionView* intersectionView )
 | |
| {
 | |
|     m_2dIntersectionView = intersectionView;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RiuResultTextBuilder::setFace( cvf::StructGridInterface::FaceType face )
 | |
| {
 | |
|     m_face = face;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| QString RiuResultTextBuilder::mainResultText()
 | |
| {
 | |
|     QString text;
 | |
| 
 | |
|     // Produce result text for all variants
 | |
|     // Priority defined as follows :  NNC, Fault, Grid
 | |
|     {
 | |
|         QString nncText = nncResultText();
 | |
|         if ( !nncText.isEmpty() )
 | |
|         {
 | |
|             text = "NNC : " + nncText;
 | |
|         }
 | |
|         else if ( m_cellIndex != cvf::UNDEFINED_SIZE_T )
 | |
|         {
 | |
|             QString faultText = faultResultText();
 | |
| 
 | |
|             if ( !faultResultText().isEmpty() )
 | |
|             {
 | |
|                 text = "Fault : " + faultText;
 | |
|             }
 | |
|             else
 | |
|             {
 | |
|                 text = "Grid cell : " + gridResultText();
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         text += "\n";
 | |
|     }
 | |
| 
 | |
|     QString topoText = this->geometrySelectionText( "\n" );
 | |
|     text += topoText;
 | |
|     appendDetails( text, formationDetails() );
 | |
|     text += "\n";
 | |
| 
 | |
|     appendDetails( text, nncDetails() );
 | |
| 
 | |
|     if ( m_cellIndex != cvf::UNDEFINED_SIZE_T )
 | |
|     {
 | |
|         appendDetails( text, faultResultDetails() );
 | |
|         appendDetails( text, cellEdgeResultDetails() );
 | |
|         appendDetails( text, gridResultDetails() );
 | |
|         appendDetails( text, wellResultText() );
 | |
|     }
 | |
| 
 | |
|     return text;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| QString RiuResultTextBuilder::geometrySelectionText( QString itemSeparator )
 | |
| {
 | |
|     QString text;
 | |
| 
 | |
|     if ( m_eclResDef && m_eclResDef->eclipseCase() )
 | |
|     {
 | |
|         const RigEclipseCaseData* eclipseCase = m_eclResDef->eclipseCase()->eclipseCaseData();
 | |
|         if ( eclipseCase )
 | |
|         {
 | |
|             if ( m_cellIndex != cvf::UNDEFINED_SIZE_T )
 | |
|             {
 | |
|                 size_t i = 0;
 | |
|                 size_t j = 0;
 | |
|                 size_t k = 0;
 | |
| 
 | |
|                 const RigGridBase* grid = eclipseCase->grid( m_gridIndex );
 | |
|                 if ( grid->ijkFromCellIndex( m_cellIndex, &i, &j, &k ) )
 | |
|                 {
 | |
|                     // Adjust to 1-based Eclipse indexing
 | |
|                     i++;
 | |
|                     j++;
 | |
|                     k++;
 | |
| 
 | |
|                     if ( m_face != cvf::StructGridInterface::NO_FACE )
 | |
|                     {
 | |
|                         cvf::StructGridInterface::FaceEnum faceEnum( m_face );
 | |
| 
 | |
|                         QString faceText = faceEnum.text();
 | |
| 
 | |
|                         text += QString( "Face : %1" ).arg( faceText ) + itemSeparator;
 | |
|                     }
 | |
| 
 | |
|                     QString gridName = QString::fromStdString( grid->gridName() );
 | |
|                     text += QString( "Grid : %1 [%2]" ).arg( gridName ).arg( m_gridIndex ) + itemSeparator;
 | |
| 
 | |
|                     text += QString( "Cell : [%1, %2, %3]" ).arg( i ).arg( j ).arg( k ) + itemSeparator;
 | |
| 
 | |
|                     size_t globalCellIndex = grid->reservoirCellIndex( m_cellIndex );
 | |
|                     text += QString( "Global Cell Index : %4" ).arg( globalCellIndex ) + itemSeparator;
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             if ( m_intersectionPointInDisplay != cvf::Vec3d::UNDEFINED )
 | |
|             {
 | |
|                 QString formattedText;
 | |
|                 if ( m_2dIntersectionView )
 | |
|                 {
 | |
|                     formattedText =
 | |
|                         QString( "Horizontal length from well start: %1" ).arg( m_intersectionPointInDisplay.x(), 5, 'f', 2 );
 | |
|                     text += formattedText + itemSeparator;
 | |
| 
 | |
|                     cvf::Mat4d t = m_2dIntersectionView->flatIntersectionPartMgr()->unflattenTransformMatrix(
 | |
|                         m_intersectionPointInDisplay );
 | |
|                     if ( !t.isZero() )
 | |
|                     {
 | |
|                         cvf::Vec3d intPt = m_intersectionPointInDisplay.getTransformedPoint( t );
 | |
|                         formattedText    = QString( "Intersection point : [E: %1, N: %2, Depth: %3]" )
 | |
|                                             .arg( intPt.x(), 5, 'f', 2 )
 | |
|                                             .arg( intPt.y(), 5, 'f', 2 )
 | |
|                                             .arg( -intPt.z(), 5, 'f', 2 );
 | |
|                         text += formattedText;
 | |
|                     }
 | |
|                 }
 | |
|                 else
 | |
|                 {
 | |
|                     if ( m_displayCoordView )
 | |
|                     {
 | |
|                         cvf::ref<caf::DisplayCoordTransform> transForm = m_displayCoordView->displayCoordTransform();
 | |
|                         cvf::Vec3d domainCoord = transForm->translateToDomainCoord( m_intersectionPointInDisplay );
 | |
| 
 | |
|                         formattedText = QString( "Intersection point : [E: %1, N: %2, Depth: %3]" )
 | |
|                                             .arg( domainCoord.x(), 5, 'f', 2 )
 | |
|                                             .arg( domainCoord.y(), 5, 'f', 2 )
 | |
|                                             .arg( -domainCoord.z(), 5, 'f', 2 );
 | |
|                         text += formattedText;
 | |
|                     }
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     return text;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| QString RiuResultTextBuilder::gridResultDetails()
 | |
| {
 | |
|     QString text;
 | |
| 
 | |
|     if ( m_eclResDef->eclipseCase() && m_eclResDef->eclipseCase()->eclipseCaseData() )
 | |
|     {
 | |
|         RigEclipseCaseData* eclipseCaseData = m_eclResDef->eclipseCase()->eclipseCaseData();
 | |
| 
 | |
|         this->appendTextFromResultColors( eclipseCaseData, m_gridIndex, m_cellIndex, m_timeStepIndex, m_eclResDef, &text );
 | |
| 
 | |
|         if ( !text.isEmpty() )
 | |
|         {
 | |
|             text.prepend( "-- Grid cell result details --\n" );
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     return text;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| QString RiuResultTextBuilder::faultResultDetails()
 | |
| {
 | |
|     QString text;
 | |
| 
 | |
|     if ( m_eclResDef->eclipseCase() && m_eclResDef->eclipseCase()->eclipseCaseData() )
 | |
|     {
 | |
|         RigEclipseCaseData* eclipseCaseData = m_eclResDef->eclipseCase()->eclipseCaseData();
 | |
|         RigGridBase*        grid            = eclipseCaseData->grid( m_gridIndex );
 | |
|         RigMainGrid*        mainGrid        = grid->mainGrid();
 | |
| 
 | |
|         const RigFault* fault = mainGrid->findFaultFromCellIndexAndCellFace( m_cellIndex, m_face );
 | |
|         if ( fault )
 | |
|         {
 | |
|             text += "-- Fault result details --\n";
 | |
| 
 | |
|             text += QString( "Fault Name: %1\n" ).arg( fault->name() );
 | |
| 
 | |
|             cvf::StructGridInterface::FaceEnum faceHelper( m_face );
 | |
|             text += "Fault Face : " + faceHelper.text() + "\n";
 | |
| 
 | |
|             if ( m_viewWithFaultsSettings && m_viewWithFaultsSettings->faultResultSettings()->hasValidCustomResult() )
 | |
|             {
 | |
|                 if ( m_viewWithFaultsSettings->faultResultSettings()->customFaultResult()->resultType() !=
 | |
|                      RiaDefines::ResultCatType::ALLAN_DIAGRAMS )
 | |
|                 {
 | |
|                     text += "Fault result data:\n";
 | |
|                     this->appendTextFromResultColors( eclipseCaseData,
 | |
|                                                       m_gridIndex,
 | |
|                                                       m_cellIndex,
 | |
|                                                       m_timeStepIndex,
 | |
|                                                       m_viewWithFaultsSettings->currentFaultResultColors(),
 | |
|                                                       &text );
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     return text;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| QString RiuResultTextBuilder::formationDetails()
 | |
| {
 | |
|     QString  text;
 | |
|     RimCase* rimCase = m_eclResDef->eclipseCase();
 | |
|     if ( rimCase )
 | |
|     {
 | |
|         if ( rimCase->activeFormationNames() && rimCase->activeFormationNames()->formationNamesData() )
 | |
|         {
 | |
|             RigFormationNames* formNames = rimCase->activeFormationNames()->formationNamesData();
 | |
| 
 | |
|             size_t k = cvf::UNDEFINED_SIZE_T;
 | |
|             {
 | |
|                 const RigEclipseCaseData* eclipseData = m_eclResDef->eclipseCase()->eclipseCaseData();
 | |
|                 if ( eclipseData )
 | |
|                 {
 | |
|                     if ( m_cellIndex != cvf::UNDEFINED_SIZE_T )
 | |
|                     {
 | |
|                         size_t i = cvf::UNDEFINED_SIZE_T;
 | |
|                         size_t j = cvf::UNDEFINED_SIZE_T;
 | |
| 
 | |
|                         eclipseData->grid( m_gridIndex )->ijkFromCellIndex( m_cellIndex, &i, &j, &k );
 | |
|                     }
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             if ( k != cvf::UNDEFINED_SIZE_T )
 | |
|             {
 | |
|                 QString formName = formNames->formationNameFromKLayerIdx( k );
 | |
|                 if ( !formName.isEmpty() )
 | |
|                 {
 | |
|                     // text += "-- Formation details --\n";
 | |
| 
 | |
|                     text += QString( "Formation Name: %1\n" ).arg( formName );
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     return text;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| QString RiuResultTextBuilder::gridResultText()
 | |
| {
 | |
|     QString text = cellResultText( m_eclResDef );
 | |
| 
 | |
|     return text;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| QString RiuResultTextBuilder::faultResultText()
 | |
| {
 | |
|     QString text;
 | |
| 
 | |
|     if ( m_eclResDef->eclipseCase() && m_eclResDef->eclipseCase()->eclipseCaseData() )
 | |
|     {
 | |
|         RigEclipseCaseData* eclipseCaseData = m_eclResDef->eclipseCase()->eclipseCaseData();
 | |
| 
 | |
|         RigGridBase* grid     = eclipseCaseData->grid( m_gridIndex );
 | |
|         RigMainGrid* mainGrid = grid->mainGrid();
 | |
| 
 | |
|         const RigFault* fault = mainGrid->findFaultFromCellIndexAndCellFace( m_cellIndex, m_face );
 | |
| 
 | |
|         if ( fault )
 | |
|         {
 | |
|             cvf::StructGridInterface::FaceEnum faceHelper( m_face );
 | |
|             if ( m_viewWithFaultsSettings && m_viewWithFaultsSettings->faultResultSettings()->hasValidCustomResult() )
 | |
|             {
 | |
|                 text = cellResultText( m_viewWithFaultsSettings->currentFaultResultColors() );
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     return text;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| QString RiuResultTextBuilder::nncResultText()
 | |
| {
 | |
|     QString text;
 | |
| 
 | |
|     if ( m_nncIndex != cvf::UNDEFINED_SIZE_T )
 | |
|     {
 | |
|         if ( m_eclResDef.notNull() && m_eclResDef->eclipseCase() )
 | |
|         {
 | |
|             RigEclipseCaseData* eclipseCase = m_eclResDef->eclipseCase()->eclipseCaseData();
 | |
| 
 | |
|             RigMainGrid* grid = eclipseCase->mainGrid();
 | |
|             CVF_ASSERT( grid );
 | |
| 
 | |
|             RigNNCData* nncData = grid->nncData();
 | |
|             CVF_ASSERT( nncData );
 | |
| 
 | |
|             if ( nncData && m_nncIndex < nncData->allConnections().size() )
 | |
|             {
 | |
|                 const RigConnection& conn = nncData->allConnections()[m_nncIndex];
 | |
| 
 | |
|                 cvf::StructGridInterface::FaceEnum face( conn.face() );
 | |
| 
 | |
|                 if ( m_viewWithFaultsSettings && m_viewWithFaultsSettings->currentFaultResultColors() )
 | |
|                 {
 | |
|                     RigEclipseResultAddress eclipseResultAddress =
 | |
|                         m_viewWithFaultsSettings->currentFaultResultColors()->eclipseResultAddress();
 | |
|                     RiaDefines::ResultCatType resultType =
 | |
|                         m_viewWithFaultsSettings->currentFaultResultColors()->resultType();
 | |
| 
 | |
|                     const std::vector<double>* nncValues = nullptr;
 | |
| 
 | |
|                     if ( resultType == RiaDefines::ResultCatType::STATIC_NATIVE )
 | |
|                     {
 | |
|                         nncValues = nncData->staticConnectionScalarResult( eclipseResultAddress );
 | |
|                     }
 | |
|                     else if ( resultType == RiaDefines::ResultCatType::DYNAMIC_NATIVE )
 | |
|                     {
 | |
|                         if ( m_eclResDef.notNull() && m_eclResDef->eclipseCase() )
 | |
|                         {
 | |
|                             size_t nativeTimeStep = m_eclResDef->eclipseCase()->uiToNativeTimeStepIndex( m_timeStepIndex );
 | |
|                             nncValues = nncData->dynamicConnectionScalarResult( eclipseResultAddress, nativeTimeStep );
 | |
|                         }
 | |
|                     }
 | |
| 
 | |
|                     if ( nncValues && ( m_nncIndex < nncValues->size() ) )
 | |
|                     {
 | |
|                         QString resultVar = m_viewWithFaultsSettings->currentFaultResultColors()->resultVariableUiName();
 | |
|                         double  scalarValue = ( *nncValues )[m_nncIndex];
 | |
| 
 | |
|                         text = QString( "%1 : %2" ).arg( resultVar ).arg( scalarValue );
 | |
|                     }
 | |
| 
 | |
|                     if ( resultType == RiaDefines::ResultCatType::ALLAN_DIAGRAMS )
 | |
|                     {
 | |
|                         nncValues = nncData->staticConnectionScalarResult( eclipseResultAddress );
 | |
|                         QString resultValueText;
 | |
| 
 | |
|                         if ( m_viewWithFaultsSettings->currentFaultResultColors()->resultVariable() ==
 | |
|                              RiaResultNames::formationAllanResultName() )
 | |
|                         {
 | |
|                             std::pair<int, int> fmIndexPair =
 | |
|                                 eclipseCase->allanDiagramData()->formationIndexCombinationFromCategory(
 | |
|                                     ( *nncValues )[m_nncIndex] );
 | |
| 
 | |
|                             std::vector<QString> fmNames = eclipseCase->formationNames();
 | |
|                             // clang-format off
 | |
|                             if ( fmIndexPair.first >= 0 && 
 | |
|                                  fmIndexPair.second >= 0 &&
 | |
|                                  static_cast<int>(fmNames.size()) > fmIndexPair.first &&
 | |
|                                  static_cast<int>(fmNames.size()) > fmIndexPair.second )
 | |
|                             {
 | |
|                                 resultValueText = fmNames[fmIndexPair.first] + " - " +
 | |
|                                                   fmNames[fmIndexPair.second];
 | |
|                             }
 | |
|                             // clang-format on
 | |
|                         }
 | |
|                         else if ( m_viewWithFaultsSettings->currentFaultResultColors()->resultVariable() ==
 | |
|                                   RiaResultNames::formationBinaryAllanResultName() )
 | |
|                         {
 | |
|                             resultValueText = ( *nncValues )[m_nncIndex] == 0 ? "Same formation" : "Different formation";
 | |
|                         }
 | |
| 
 | |
|                         QString resultVar = m_viewWithFaultsSettings->currentFaultResultColors()->resultVariableUiName();
 | |
|                         text              = QString( "%1 : %2" ).arg( resultVar ).arg( resultValueText );
 | |
|                     }
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     return text;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RiuResultTextBuilder::appendTextFromResultColors( RigEclipseCaseData*         eclipseCase,
 | |
|                                                        size_t                      gridIndex,
 | |
|                                                        size_t                      cellIndex,
 | |
|                                                        size_t                      timeStepIndex,
 | |
|                                                        RimEclipseResultDefinition* resultColors,
 | |
|                                                        QString*                    resultInfoText )
 | |
| {
 | |
|     if ( !resultColors )
 | |
|     {
 | |
|         return;
 | |
|     }
 | |
| 
 | |
|     RiaDefines::PorosityModelType porosityModel = resultColors->porosityModel();
 | |
|     if ( resultColors->isTernarySaturationSelected() )
 | |
|     {
 | |
|         RigCaseCellResultsData* gridCellResults = resultColors->currentGridCellResults();
 | |
|         if ( gridCellResults )
 | |
|         {
 | |
|             gridCellResults->ensureKnownResultLoaded(
 | |
|                 RigEclipseResultAddress( RiaDefines::ResultCatType::DYNAMIC_NATIVE, RiaResultNames::soil() ) );
 | |
|             gridCellResults->ensureKnownResultLoaded(
 | |
|                 RigEclipseResultAddress( RiaDefines::ResultCatType::DYNAMIC_NATIVE, RiaResultNames::sgas() ) );
 | |
|             gridCellResults->ensureKnownResultLoaded(
 | |
|                 RigEclipseResultAddress( RiaDefines::ResultCatType::DYNAMIC_NATIVE, RiaResultNames::swat() ) );
 | |
| 
 | |
|             cvf::ref<RigResultAccessor> dataAccessObjectX =
 | |
|                 RigResultAccessorFactory::createFromResultAddress( eclipseCase,
 | |
|                                                                    gridIndex,
 | |
|                                                                    porosityModel,
 | |
|                                                                    timeStepIndex,
 | |
|                                                                    RigEclipseResultAddress( RiaDefines::ResultCatType::DYNAMIC_NATIVE,
 | |
|                                                                                             RiaResultNames::soil() ) );
 | |
|             cvf::ref<RigResultAccessor> dataAccessObjectY =
 | |
|                 RigResultAccessorFactory::createFromResultAddress( eclipseCase,
 | |
|                                                                    gridIndex,
 | |
|                                                                    porosityModel,
 | |
|                                                                    timeStepIndex,
 | |
|                                                                    RigEclipseResultAddress( RiaDefines::ResultCatType::DYNAMIC_NATIVE,
 | |
|                                                                                             RiaResultNames::sgas() ) );
 | |
|             cvf::ref<RigResultAccessor> dataAccessObjectZ =
 | |
|                 RigResultAccessorFactory::createFromResultAddress( eclipseCase,
 | |
|                                                                    gridIndex,
 | |
|                                                                    porosityModel,
 | |
|                                                                    timeStepIndex,
 | |
|                                                                    RigEclipseResultAddress( RiaDefines::ResultCatType::DYNAMIC_NATIVE,
 | |
|                                                                                             RiaResultNames::swat() ) );
 | |
| 
 | |
|             double scalarValue = 0.0;
 | |
| 
 | |
|             if ( dataAccessObjectX.notNull() )
 | |
|                 scalarValue = dataAccessObjectX->cellScalar( cellIndex );
 | |
|             else
 | |
|                 scalarValue = 0.0;
 | |
|             resultInfoText->append( QString( "SOIL : %1\n" ).arg( scalarValue ) );
 | |
| 
 | |
|             if ( dataAccessObjectY.notNull() )
 | |
|                 scalarValue = dataAccessObjectY->cellScalar( cellIndex );
 | |
|             else
 | |
|                 scalarValue = 0.0;
 | |
|             resultInfoText->append( QString( "SGAS : %1\n" ).arg( scalarValue ) );
 | |
| 
 | |
|             if ( dataAccessObjectZ.notNull() )
 | |
|                 scalarValue = dataAccessObjectZ->cellScalar( cellIndex );
 | |
|             else
 | |
|                 scalarValue = 0.0;
 | |
|             resultInfoText->append( QString( "SWAT : %1\n" ).arg( scalarValue ) );
 | |
|         }
 | |
| 
 | |
|         return;
 | |
|     }
 | |
|     else if ( resultColors->hasResult() )
 | |
|     {
 | |
|         if ( resultColors->hasStaticResult() )
 | |
|         {
 | |
|             if ( resultColors->resultVariable().compare( RiaResultNames::combinedTransmissibilityResultName(),
 | |
|                                                          Qt::CaseInsensitive ) == 0 )
 | |
|             {
 | |
|                 cvf::ref<RigResultAccessor> transResultAccessor =
 | |
|                     RigResultAccessorFactory::createFromResultAddress( eclipseCase,
 | |
|                                                                        gridIndex,
 | |
|                                                                        porosityModel,
 | |
|                                                                        0,
 | |
|                                                                        RigEclipseResultAddress(
 | |
|                                                                            RiaResultNames::combinedTransmissibilityResultName() ) );
 | |
|                 {
 | |
|                     double scalarValue = transResultAccessor->cellFaceScalar( cellIndex, cvf::StructGridInterface::POS_I );
 | |
|                     resultInfoText->append( QString( "Tran X : %1\n" ).arg( scalarValue ) );
 | |
| 
 | |
|                     scalarValue = transResultAccessor->cellFaceScalar( cellIndex, cvf::StructGridInterface::POS_J );
 | |
|                     resultInfoText->append( QString( "Tran Y : %1\n" ).arg( scalarValue ) );
 | |
| 
 | |
|                     scalarValue = transResultAccessor->cellFaceScalar( cellIndex, cvf::StructGridInterface::POS_K );
 | |
|                     resultInfoText->append( QString( "Tran Z : %1\n" ).arg( scalarValue ) );
 | |
|                 }
 | |
| 
 | |
|                 return;
 | |
|             }
 | |
|             else if ( resultColors->resultVariable().compare( RiaResultNames::combinedMultResultName(),
 | |
|                                                               Qt::CaseInsensitive ) == 0 )
 | |
|             {
 | |
|                 cvf::ref<RigResultAccessor> multResultAccessor =
 | |
|                     RigResultAccessorFactory::createFromResultAddress( eclipseCase,
 | |
|                                                                        gridIndex,
 | |
|                                                                        porosityModel,
 | |
|                                                                        0,
 | |
|                                                                        RigEclipseResultAddress(
 | |
|                                                                            RiaResultNames::combinedMultResultName() ) );
 | |
|                 {
 | |
|                     double scalarValue = multResultAccessor->cellFaceScalar( cellIndex, cvf::StructGridInterface::POS_I );
 | |
|                     resultInfoText->append( QString( "MULTX : %1\n" ).arg( scalarValue ) );
 | |
|                     scalarValue = multResultAccessor->cellFaceScalar( cellIndex, cvf::StructGridInterface::NEG_I );
 | |
|                     resultInfoText->append( QString( "MULTX- : %1\n" ).arg( scalarValue ) );
 | |
| 
 | |
|                     scalarValue = multResultAccessor->cellFaceScalar( cellIndex, cvf::StructGridInterface::POS_J );
 | |
|                     resultInfoText->append( QString( "MULTY : %1\n" ).arg( scalarValue ) );
 | |
|                     scalarValue = multResultAccessor->cellFaceScalar( cellIndex, cvf::StructGridInterface::NEG_J );
 | |
|                     resultInfoText->append( QString( "MULTY- : %1\n" ).arg( scalarValue ) );
 | |
| 
 | |
|                     scalarValue = multResultAccessor->cellFaceScalar( cellIndex, cvf::StructGridInterface::POS_K );
 | |
|                     resultInfoText->append( QString( "MULTZ : %1\n" ).arg( scalarValue ) );
 | |
|                     scalarValue = multResultAccessor->cellFaceScalar( cellIndex, cvf::StructGridInterface::NEG_K );
 | |
|                     resultInfoText->append( QString( "MULTZ- : %1\n" ).arg( scalarValue ) );
 | |
|                 }
 | |
| 
 | |
|                 return;
 | |
|             }
 | |
|             else if ( resultColors->resultVariable().compare( RiaResultNames::combinedRiTranResultName(),
 | |
|                                                               Qt::CaseInsensitive ) == 0 )
 | |
|             {
 | |
|                 cvf::ref<RigResultAccessor> transResultAccessor =
 | |
|                     RigResultAccessorFactory::createFromResultAddress( eclipseCase,
 | |
|                                                                        gridIndex,
 | |
|                                                                        porosityModel,
 | |
|                                                                        0,
 | |
|                                                                        RigEclipseResultAddress(
 | |
|                                                                            RiaResultNames::combinedRiTranResultName() ) );
 | |
|                 {
 | |
|                     double scalarValue = transResultAccessor->cellFaceScalar( cellIndex, cvf::StructGridInterface::POS_I );
 | |
|                     resultInfoText->append( QString( "riTran X : %1\n" ).arg( scalarValue ) );
 | |
| 
 | |
|                     scalarValue = transResultAccessor->cellFaceScalar( cellIndex, cvf::StructGridInterface::POS_J );
 | |
|                     resultInfoText->append( QString( "riTran Y : %1\n" ).arg( scalarValue ) );
 | |
| 
 | |
|                     scalarValue = transResultAccessor->cellFaceScalar( cellIndex, cvf::StructGridInterface::POS_K );
 | |
|                     resultInfoText->append( QString( "riTran Z : %1\n" ).arg( scalarValue ) );
 | |
|                 }
 | |
| 
 | |
|                 return;
 | |
|             }
 | |
|             else if ( resultColors->resultVariable().compare( RiaResultNames::combinedRiMultResultName(),
 | |
|                                                               Qt::CaseInsensitive ) == 0 )
 | |
|             {
 | |
|                 cvf::ref<RigResultAccessor> resultAccessor =
 | |
|                     RigResultAccessorFactory::createFromResultAddress( eclipseCase,
 | |
|                                                                        gridIndex,
 | |
|                                                                        porosityModel,
 | |
|                                                                        0,
 | |
|                                                                        RigEclipseResultAddress(
 | |
|                                                                            RiaResultNames::combinedRiMultResultName() ) );
 | |
|                 {
 | |
|                     double scalarValue = resultAccessor->cellFaceScalar( cellIndex, cvf::StructGridInterface::POS_I );
 | |
|                     resultInfoText->append( QString( "riMult X : %1\n" ).arg( scalarValue ) );
 | |
| 
 | |
|                     scalarValue = resultAccessor->cellFaceScalar( cellIndex, cvf::StructGridInterface::POS_J );
 | |
|                     resultInfoText->append( QString( "riMult Y : %1\n" ).arg( scalarValue ) );
 | |
| 
 | |
|                     scalarValue = resultAccessor->cellFaceScalar( cellIndex, cvf::StructGridInterface::POS_K );
 | |
|                     resultInfoText->append( QString( "riMult Z : %1\n" ).arg( scalarValue ) );
 | |
|                 }
 | |
|                 return;
 | |
|             }
 | |
|             else if ( resultColors->resultVariable().compare( RiaResultNames::combinedRiAreaNormTranResultName(),
 | |
|                                                               Qt::CaseInsensitive ) == 0 )
 | |
|             {
 | |
|                 cvf::ref<RigResultAccessor> resultAccessor =
 | |
|                     RigResultAccessorFactory::createFromResultAddress( eclipseCase,
 | |
|                                                                        gridIndex,
 | |
|                                                                        porosityModel,
 | |
|                                                                        0,
 | |
|                                                                        RigEclipseResultAddress(
 | |
|                                                                            RiaResultNames::combinedRiAreaNormTranResultName() ) );
 | |
|                 {
 | |
|                     double scalarValue = resultAccessor->cellFaceScalar( cellIndex, cvf::StructGridInterface::POS_I );
 | |
|                     resultInfoText->append( QString( "riTransByArea X : %1\n" ).arg( scalarValue ) );
 | |
| 
 | |
|                     scalarValue = resultAccessor->cellFaceScalar( cellIndex, cvf::StructGridInterface::POS_J );
 | |
|                     resultInfoText->append( QString( "riTransByArea Y : %1\n" ).arg( scalarValue ) );
 | |
| 
 | |
|                     scalarValue = resultAccessor->cellFaceScalar( cellIndex, cvf::StructGridInterface::POS_K );
 | |
|                     resultInfoText->append( QString( "riTransByArea Z : %1\n" ).arg( scalarValue ) );
 | |
|                 }
 | |
| 
 | |
|                 return;
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     resultInfoText->append( cellResultText( resultColors ) );
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| QString RiuResultTextBuilder::cellEdgeResultDetails()
 | |
| {
 | |
|     QString text;
 | |
| 
 | |
|     if ( m_viewWithFaultsSettings && m_viewWithFaultsSettings->cellEdgeResult()->hasResult() )
 | |
|     {
 | |
|         text += "-- Cell edge result data --\n";
 | |
| 
 | |
|         if ( m_viewWithFaultsSettings->cellEdgeResult()->isUsingSingleVariable() )
 | |
|         {
 | |
|             text += cellResultText( m_viewWithFaultsSettings->cellEdgeResult()->singleVarEdgeResultColors() );
 | |
|             text += "\n";
 | |
|         }
 | |
|         else
 | |
|         {
 | |
|             std::vector<RimCellEdgeMetaData> metaData;
 | |
|             m_viewWithFaultsSettings->cellEdgeResult()->cellEdgeMetaData( &metaData );
 | |
| 
 | |
|             std::set<RigEclipseResultAddress> uniqueResultIndices;
 | |
| 
 | |
|             for ( int idx = 0; idx < 6; idx++ )
 | |
|             {
 | |
|                 RigEclipseResultAddress resultAddr = metaData[idx].m_eclipseResultAddress;
 | |
|                 if ( !resultAddr.isValid() ) continue;
 | |
| 
 | |
|                 if ( uniqueResultIndices.find( resultAddr ) != uniqueResultIndices.end() ) continue;
 | |
| 
 | |
|                 size_t adjustedTimeStep = m_timeStepIndex;
 | |
|                 if ( metaData[idx].m_isStatic )
 | |
|                 {
 | |
|                     adjustedTimeStep = 0;
 | |
|                 }
 | |
| 
 | |
|                 RiaDefines::PorosityModelType porosityModel = m_eclResDef->porosityModel();
 | |
|                 cvf::ref<RigResultAccessor>   resultAccessor =
 | |
|                     RigResultAccessorFactory::createFromResultAddress( m_eclResDef->eclipseCase()->eclipseCaseData(),
 | |
|                                                                        m_gridIndex,
 | |
|                                                                        porosityModel,
 | |
|                                                                        adjustedTimeStep,
 | |
|                                                                        resultAddr );
 | |
|                 if ( resultAccessor.notNull() )
 | |
|                 {
 | |
|                     double scalarValue = resultAccessor->cellScalar( m_cellIndex );
 | |
|                     text.append( QString( "%1 : %2\n" ).arg( metaData[idx].m_resultVariable ).arg( scalarValue ) );
 | |
| 
 | |
|                     uniqueResultIndices.insert( resultAddr );
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     return text;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| QString RiuResultTextBuilder::nncDetails()
 | |
| {
 | |
|     QString text;
 | |
| 
 | |
|     if ( m_nncIndex != cvf::UNDEFINED_SIZE_T )
 | |
|     {
 | |
|         if ( m_eclResDef.notNull() && m_eclResDef->eclipseCase() )
 | |
|         {
 | |
|             RigEclipseCaseData* eclipseCase = m_eclResDef->eclipseCase()->eclipseCaseData();
 | |
| 
 | |
|             RigMainGrid* grid = eclipseCase->mainGrid();
 | |
|             CVF_ASSERT( grid );
 | |
| 
 | |
|             RigNNCData* nncData = grid->nncData();
 | |
|             CVF_ASSERT( nncData );
 | |
| 
 | |
|             if ( nncData && m_nncIndex < nncData->allConnections().size() )
 | |
|             {
 | |
|                 text += "-- NNC details --\n";
 | |
|                 {
 | |
|                     const RigConnection&               conn = nncData->allConnections()[m_nncIndex];
 | |
|                     cvf::StructGridInterface::FaceEnum face( conn.face() );
 | |
| 
 | |
|                     // First cell of NNC
 | |
|                     {
 | |
|                         CVF_ASSERT( conn.c1GlobIdx() < grid->globalCellArray().size() );
 | |
|                         const RigCell& cell = grid->globalCellArray()[conn.c1GlobIdx()];
 | |
| 
 | |
|                         RigGridBase* hostGrid           = cell.hostGrid();
 | |
|                         size_t       gridLocalCellIndex = cell.gridLocalCellIndex();
 | |
| 
 | |
|                         size_t i, j, k;
 | |
|                         if ( hostGrid->ijkFromCellIndex( gridLocalCellIndex, &i, &j, &k ) )
 | |
|                         {
 | |
|                             // Adjust to 1-based Eclipse indexing
 | |
|                             i++;
 | |
|                             j++;
 | |
|                             k++;
 | |
| 
 | |
|                             QString gridName = QString::fromStdString( hostGrid->gridName() );
 | |
|                             text.append( QString( "NNC 1 : cell [%1, %2, %3] face %4 (%5)\n" )
 | |
|                                              .arg( i )
 | |
|                                              .arg( j )
 | |
|                                              .arg( k )
 | |
|                                              .arg( face.text() )
 | |
|                                              .arg( gridName ) );
 | |
|                         }
 | |
|                     }
 | |
| 
 | |
|                     // Second cell of NNC
 | |
|                     {
 | |
|                         CVF_ASSERT( conn.c2GlobIdx() < grid->globalCellArray().size() );
 | |
|                         const RigCell& cell = grid->globalCellArray()[conn.c2GlobIdx()];
 | |
| 
 | |
|                         RigGridBase* hostGrid           = cell.hostGrid();
 | |
|                         size_t       gridLocalCellIndex = cell.gridLocalCellIndex();
 | |
| 
 | |
|                         size_t i, j, k;
 | |
|                         if ( hostGrid->ijkFromCellIndex( gridLocalCellIndex, &i, &j, &k ) )
 | |
|                         {
 | |
|                             // Adjust to 1-based Eclipse indexing
 | |
|                             i++;
 | |
|                             j++;
 | |
|                             k++;
 | |
| 
 | |
|                             QString gridName = QString::fromStdString( hostGrid->gridName() );
 | |
|                             cvf::StructGridInterface::FaceEnum oppositeFaceEnum(
 | |
|                                 cvf::StructGridInterface::oppositeFace( face ) );
 | |
|                             QString faceText = oppositeFaceEnum.text();
 | |
| 
 | |
|                             text.append( QString( "NNC 2 : cell [%1, %2, %3] face %4 (%5)\n" )
 | |
|                                              .arg( i )
 | |
|                                              .arg( j )
 | |
|                                              .arg( k )
 | |
|                                              .arg( faceText )
 | |
|                                              .arg( gridName ) );
 | |
|                         }
 | |
|                     }
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     return text;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RiuResultTextBuilder::appendDetails( QString& text, const QString& details )
 | |
| {
 | |
|     if ( !details.isEmpty() )
 | |
|     {
 | |
|         text += "\n";
 | |
|         text += details;
 | |
|     }
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| QString RiuResultTextBuilder::cellResultText( RimEclipseResultDefinition* eclResDef )
 | |
| {
 | |
|     QString text;
 | |
| 
 | |
|     if ( m_eclResDef->eclipseCase() && m_eclResDef->eclipseCase()->eclipseCaseData() )
 | |
|     {
 | |
|         RigEclipseCaseData* eclipseCaseData = m_eclResDef->eclipseCase()->eclipseCaseData();
 | |
| 
 | |
|         if ( eclResDef->isTernarySaturationSelected() )
 | |
|         {
 | |
|             RigCaseCellResultsData* gridCellResults = m_eclResDef->currentGridCellResults();
 | |
|             if ( gridCellResults )
 | |
|             {
 | |
|                 gridCellResults->ensureKnownResultLoaded(
 | |
|                     RigEclipseResultAddress( RiaDefines::ResultCatType::DYNAMIC_NATIVE, RiaResultNames::soil() ) );
 | |
|                 gridCellResults->ensureKnownResultLoaded(
 | |
|                     RigEclipseResultAddress( RiaDefines::ResultCatType::DYNAMIC_NATIVE, RiaResultNames::sgas() ) );
 | |
|                 gridCellResults->ensureKnownResultLoaded(
 | |
|                     RigEclipseResultAddress( RiaDefines::ResultCatType::DYNAMIC_NATIVE, RiaResultNames::swat() ) );
 | |
| 
 | |
|                 RiaDefines::PorosityModelType porosityModel = eclResDef->porosityModel();
 | |
| 
 | |
|                 cvf::ref<RigResultAccessor> dataAccessObjectX =
 | |
|                     RigResultAccessorFactory::createFromResultAddress( eclipseCaseData,
 | |
|                                                                        m_gridIndex,
 | |
|                                                                        porosityModel,
 | |
|                                                                        m_timeStepIndex,
 | |
|                                                                        RigEclipseResultAddress( RiaDefines::ResultCatType::DYNAMIC_NATIVE,
 | |
|                                                                                                 RiaResultNames::soil() ) );
 | |
|                 cvf::ref<RigResultAccessor> dataAccessObjectY =
 | |
|                     RigResultAccessorFactory::createFromResultAddress( eclipseCaseData,
 | |
|                                                                        m_gridIndex,
 | |
|                                                                        porosityModel,
 | |
|                                                                        m_timeStepIndex,
 | |
|                                                                        RigEclipseResultAddress( RiaDefines::ResultCatType::DYNAMIC_NATIVE,
 | |
|                                                                                                 RiaResultNames::sgas() ) );
 | |
|                 cvf::ref<RigResultAccessor> dataAccessObjectZ =
 | |
|                     RigResultAccessorFactory::createFromResultAddress( eclipseCaseData,
 | |
|                                                                        m_gridIndex,
 | |
|                                                                        porosityModel,
 | |
|                                                                        m_timeStepIndex,
 | |
|                                                                        RigEclipseResultAddress( RiaDefines::ResultCatType::DYNAMIC_NATIVE,
 | |
|                                                                                                 RiaResultNames::swat() ) );
 | |
| 
 | |
|                 double scalarValue = 0.0;
 | |
| 
 | |
|                 if ( dataAccessObjectX.notNull() )
 | |
|                     scalarValue = dataAccessObjectX->cellScalar( m_cellIndex );
 | |
|                 else
 | |
|                     scalarValue = 0.0;
 | |
|                 text += QString( "SOIL : %1 " ).arg( scalarValue );
 | |
| 
 | |
|                 if ( dataAccessObjectY.notNull() )
 | |
|                     scalarValue = dataAccessObjectY->cellScalar( m_cellIndex );
 | |
|                 else
 | |
|                     scalarValue = 0.0;
 | |
|                 text += QString( "SGAS : %1 " ).arg( scalarValue );
 | |
| 
 | |
|                 if ( dataAccessObjectZ.notNull() )
 | |
|                     scalarValue = dataAccessObjectZ->cellScalar( m_cellIndex );
 | |
|                 else
 | |
|                     scalarValue = 0.0;
 | |
|                 text += QString( "SWAT : %1 " ).arg( scalarValue );
 | |
|             }
 | |
|         }
 | |
|         else
 | |
|         {
 | |
|             size_t adjustedTimeStep = m_timeStepIndex;
 | |
|             if ( eclResDef->hasStaticResult() )
 | |
|             {
 | |
|                 adjustedTimeStep = 0;
 | |
|             }
 | |
| 
 | |
|             cvf::ref<RigResultAccessor> resultAccessor =
 | |
|                 RigResultAccessorFactory::createFromResultDefinition( eclipseCaseData, m_gridIndex, adjustedTimeStep, eclResDef );
 | |
|             if ( resultAccessor.notNull() )
 | |
|             {
 | |
|                 double  scalarValue           = resultAccessor->cellFaceScalar( m_cellIndex, m_face );
 | |
|                 QString resultDescriptionText = eclResDef->resultVariableUiName();
 | |
| 
 | |
|                 QString resultValueText;
 | |
|                 if ( eclResDef->hasCategoryResult() )
 | |
|                 {
 | |
|                     auto resColorDef = dynamic_cast<RimEclipseCellColors*>( eclResDef );
 | |
| 
 | |
|                     RimRegularLegendConfig* legendConfig = nullptr;
 | |
| 
 | |
|                     if ( resColorDef )
 | |
|                     {
 | |
|                         legendConfig = resColorDef->legendConfig();
 | |
|                     }
 | |
|                     else
 | |
|                     {
 | |
|                         RimIntersectionResultDefinition* interResDef = nullptr;
 | |
|                         eclResDef->firstAncestorOrThisOfType( interResDef );
 | |
|                         if ( interResDef )
 | |
|                         {
 | |
|                             legendConfig = interResDef->regularLegendConfig();
 | |
|                         }
 | |
|                     }
 | |
| 
 | |
|                     resultValueText += legendConfig->categoryNameFromCategoryValue( scalarValue );
 | |
|                 }
 | |
|                 else
 | |
|                 {
 | |
|                     resultValueText = QString( "%1" ).arg( scalarValue );
 | |
|                 }
 | |
| 
 | |
|                 text = QString( "%1 : %2" ).arg( resultDescriptionText ).arg( resultValueText );
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     return text;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| QString RiuResultTextBuilder::wellResultText()
 | |
| {
 | |
|     QString text;
 | |
| 
 | |
|     if ( m_eclResDef->eclipseCase() && m_eclResDef->eclipseCase()->eclipseCaseData() )
 | |
|     {
 | |
|         cvf::Collection<RigSimWellData> simWellData = m_eclResDef->eclipseCase()->eclipseCaseData()->wellResults();
 | |
|         for ( size_t i = 0; i < simWellData.size(); i++ )
 | |
|         {
 | |
|             RigSimWellData* singleWellResultData = simWellData.at( i );
 | |
| 
 | |
|             if ( !singleWellResultData->hasWellResult( m_timeStepIndex ) )
 | |
|             {
 | |
|                 continue;
 | |
|             }
 | |
| 
 | |
|             const RigWellResultFrame* wellResultFrame = singleWellResultData->wellResultFrame( m_timeStepIndex );
 | |
|             const RigWellResultPoint* wellResultCell =
 | |
|                 wellResultFrame->findResultCellWellHeadIncluded( m_gridIndex, m_cellIndex );
 | |
|             if ( wellResultCell )
 | |
|             {
 | |
|                 text += QString( "-- Well-cell connection info --\n Well Name: %1\n Branch Id: %2\n Segment Id: %3\n" )
 | |
|                             .arg( singleWellResultData->m_wellName )
 | |
|                             .arg( wellResultCell->m_ertBranchId )
 | |
|                             .arg( wellResultCell->m_ertSegmentId );
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     return text;
 | |
| }
 |