mirror of
				https://github.com/OPM/ResInsight.git
				synced 2025-02-25 18:55:39 -06:00 
			
		
		
		
	
		
			
				
	
	
		
			198 lines
		
	
	
		
			7.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			198 lines
		
	
	
		
			7.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /////////////////////////////////////////////////////////////////////////////////
 | |
| //
 | |
| //  Copyright (C) 2017     Statoil 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 "RiaSummaryCurveDefinition.h"
 | |
| 
 | |
| #include "RifSummaryReaderInterface.h"
 | |
| #include "RimSummaryCase.h"
 | |
| #include "RimSummaryCaseCollection.h"
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| RiaSummaryCurveDefinition::RiaSummaryCurveDefinition()
 | |
|     : m_summaryCase( nullptr )
 | |
|     , m_ensemble( nullptr )
 | |
| 
 | |
| {
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| RiaSummaryCurveDefinition::RiaSummaryCurveDefinition( RimSummaryCase*                 summaryCase,
 | |
|                                                       const RifEclipseSummaryAddress& summaryAddress,
 | |
|                                                       RimSummaryCaseCollection*       ensemble )
 | |
|     : m_summaryCase( summaryCase )
 | |
|     , m_ensemble( ensemble )
 | |
|     , m_summaryAddress( summaryAddress )
 | |
| {
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| RimSummaryCase* RiaSummaryCurveDefinition::summaryCase() const
 | |
| {
 | |
|     return m_summaryCase;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| RimSummaryCaseCollection* RiaSummaryCurveDefinition::ensemble() const
 | |
| {
 | |
|     return m_ensemble;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| const RifEclipseSummaryAddress& RiaSummaryCurveDefinition::summaryAddress() const
 | |
| {
 | |
|     return m_summaryAddress;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| bool RiaSummaryCurveDefinition::isEnsembleCurve() const
 | |
| {
 | |
|     return m_ensemble != nullptr;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RiaSummaryCurveDefinition::resultValues( const RiaSummaryCurveDefinition& curveDefinition,
 | |
|                                               std::vector<double>*             values )
 | |
| {
 | |
|     CVF_ASSERT( values );
 | |
| 
 | |
|     if ( !curveDefinition.summaryAddress().isValid() ) return;
 | |
|     if ( !curveDefinition.summaryCase() ) return;
 | |
| 
 | |
|     RifSummaryReaderInterface* reader = curveDefinition.summaryCase()->summaryReader();
 | |
|     if ( !reader ) return;
 | |
| 
 | |
|     reader->values( curveDefinition.summaryAddress(), values );
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| const std::vector<time_t>& RiaSummaryCurveDefinition::timeSteps( const RiaSummaryCurveDefinition& curveDefinition )
 | |
| {
 | |
|     static std::vector<time_t> dummy;
 | |
| 
 | |
|     if ( !curveDefinition.summaryAddress().isValid() ) return dummy;
 | |
|     if ( !curveDefinition.summaryCase() ) return dummy;
 | |
| 
 | |
|     RifSummaryReaderInterface* reader = curveDefinition.summaryCase()->summaryReader();
 | |
|     if ( !reader ) return dummy;
 | |
| 
 | |
|     return reader->timeSteps( curveDefinition.summaryAddress() );
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| QString RiaSummaryCurveDefinition::curveDefinitionText() const
 | |
| {
 | |
|     QString caseName;
 | |
|     if ( summaryCase() )
 | |
|         caseName = summaryCase()->caseName();
 | |
|     else if ( ensemble() )
 | |
|         caseName = ensemble()->name();
 | |
| 
 | |
|     return RiaSummaryCurveDefinition::curveDefinitionText( caseName, summaryAddress() );
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| QString RiaSummaryCurveDefinition::curveDefinitionText( const QString&                  caseName,
 | |
|                                                         const RifEclipseSummaryAddress& summaryAddress )
 | |
| {
 | |
|     QString txt;
 | |
| 
 | |
|     txt += caseName;
 | |
|     txt += ", ";
 | |
| 
 | |
|     txt += QString::fromStdString( summaryAddress.uiText() );
 | |
| 
 | |
|     return txt;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| bool RiaSummaryCurveDefinition::operator<( const RiaSummaryCurveDefinition& other ) const
 | |
| {
 | |
|     if ( m_ensemble != other.ensemble() )
 | |
|     {
 | |
|         QString ensembleName;
 | |
|         QString otherEnsembleName;
 | |
| 
 | |
|         if ( m_ensemble )
 | |
|         {
 | |
|             ensembleName = m_ensemble->name();
 | |
|         }
 | |
| 
 | |
|         if ( other.ensemble() )
 | |
|         {
 | |
|             otherEnsembleName = other.ensemble()->name();
 | |
|         }
 | |
| 
 | |
|         // First check if names are different to ensure stable alphabetic sort
 | |
|         if ( ensembleName != otherEnsembleName )
 | |
|         {
 | |
|             return ensembleName < otherEnsembleName;
 | |
|         }
 | |
| 
 | |
|         // Use pointer address, sorting will be be unstable
 | |
|         return m_ensemble < other.ensemble();
 | |
|     }
 | |
| 
 | |
|     if ( m_summaryCase != other.summaryCase() )
 | |
|     {
 | |
|         QString summaryCaseName;
 | |
|         QString otherSummaryCaseName;
 | |
| 
 | |
|         if ( m_summaryCase )
 | |
|         {
 | |
|             summaryCaseName = m_summaryCase->caseName();
 | |
|         }
 | |
|         if ( other.summaryCase() )
 | |
|         {
 | |
|             otherSummaryCaseName = other.summaryCase()->caseName();
 | |
|         }
 | |
| 
 | |
|         // First check if names are different to ensure stable alphabetic sort
 | |
|         if ( summaryCaseName != otherSummaryCaseName )
 | |
|         {
 | |
|             return summaryCaseName < otherSummaryCaseName;
 | |
|         }
 | |
| 
 | |
|         // Use pointer address, sorting will be be unstable
 | |
|         return m_summaryCase < other.summaryCase();
 | |
|     }
 | |
| 
 | |
|     return ( m_summaryAddress < other.summaryAddress() );
 | |
| }
 |