///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2019- 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 // for more details. // ///////////////////////////////////////////////////////////////////////////////// #include "RigWbsParameter.h" #include "RiaWellLogUnitTools.h" #include "RigFemAddressDefines.h" #include "cafAssert.h" namespace caf { template <> void RigWbsParameter::SourceEnum::setUp() { addItem( RigWbsParameter::GRID, "GRID", "Grid" ); addItem( RigWbsParameter::LAS_FILE, "LAS_FILE", "LAS File" ); addItem( RigWbsParameter::ELEMENT_PROPERTY_TABLE, "ELEMENT_PROPERTY_TABLE", "Property Table" ); addItem( RigWbsParameter::USER_DEFINED, "USER_DEFINED", "User Defined" ); addItem( RigWbsParameter::HYDROSTATIC, "HYDROSTATIC", "Hydrostatic" ); addItem( RigWbsParameter::DERIVED_FROM_K0FG, "DERIVED_FROM_K0FG", "FG derived from K0_FG" ); addItem( RigWbsParameter::PROPORTIONAL_TO_SH, "PROPORTIONAL_TO_SH", "Proportional to SH" ); addItem( RigWbsParameter::UNDEFINED, "UNDEFINED", "Undefined" ); setDefault( RigWbsParameter::UNDEFINED ); } } // End namespace caf //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RigWbsParameter::RigWbsParameter( const QString& name, bool normalizeByHydroStaticPP, const SourceVector& sources, bool exclusiveOption ) : m_name( name ) , m_sources( sources ) , m_normalizeByHydroStaticPP( normalizeByHydroStaticPP ) , m_exclusiveOptions( false ) { } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RigWbsParameter::RigWbsParameter( const RigWbsParameter& rhs ) : m_name( rhs.m_name ) , m_sources( rhs.m_sources ) , m_normalizeByHydroStaticPP( rhs.m_normalizeByHydroStaticPP ) , m_exclusiveOptions( rhs.m_exclusiveOptions ) { } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RigWbsParameter& RigWbsParameter::operator=( const RigWbsParameter& rhs ) { m_name = rhs.m_name; m_sources = rhs.m_sources; m_normalizeByHydroStaticPP = rhs.m_normalizeByHydroStaticPP; m_exclusiveOptions = rhs.m_exclusiveOptions; return *this; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- const QString& RigWbsParameter::name() const { return m_name; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- std::vector RigWbsParameter::sources() const { std::vector allValidSources; for ( auto sourceEntryPair : m_sources ) { allValidSources.push_back( sourceEntryPair.first ); } return allValidSources; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RigWbsParameter::hasExternalSource() const { for ( auto sourcePair : m_sources ) { if ( sourcePair.first != GRID ) return true; } return false; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- QString RigWbsParameter::addressString( Source source ) const { SourceAddress sourceAddress; if ( address( source, &sourceAddress ) ) { return sourceAddress.primary; } return ""; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- QString RigWbsParameter::units( Source source ) const { SourceAddress sourceAddress; if ( address( source, &sourceAddress ) ) { return sourceAddress.units; } // Try the units of the first available source if ( !m_sources.empty() ) { return m_sources.front().second.units; } return RiaWellLogUnitTools::noUnitString(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RigFemResultAddress RigWbsParameter::femAddress( Source source ) const { RigFemResultPosEnum posType = RIG_WELLPATH_DERIVED; if ( source == GRID ) posType = RIG_ELEMENT_NODAL; else if ( source == ELEMENT_PROPERTY_TABLE ) posType = RIG_ELEMENT; SourceAddress addr; if ( address( source, &addr ) ) { return RigFemResultAddress( posType, addr.primary.toStdString(), addr.secondary.toStdString() ); } return RigFemResultAddress(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RigWbsParameter::normalizeByHydrostaticPP() const { return m_normalizeByHydroStaticPP; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RigWbsParameter::exclusiveOptions() const { return m_exclusiveOptions; } //-------------------------------------------------------------------------------------------------- /// Set options to be exclusive rather than an order of preference //-------------------------------------------------------------------------------------------------- void RigWbsParameter::setOptionsExclusive( bool exclusive ) { m_exclusiveOptions = exclusive; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- std::vector RigWbsParameter::allSourceUiLabels( const QString& delimiter /*= " "*/, double userDefinedValue /*= std::numeric_limits::infinity() */ ) { std::vector allLabels; for ( size_t i = 0; i < SourceEnum::size(); ++i ) { allLabels.push_back( sourceUiLabel( SourceEnum::fromIndex( i ), delimiter, userDefinedValue ) ); } return allLabels; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- QString RigWbsParameter::sourceUiLabel( Source currentSource, const QString& delimiter, double userDefinedValue /*= std::numeric_limits::infinity() */ ) { QString sourceLabel; if ( currentSource == USER_DEFINED ) { sourceLabel = QString( "%1 = %2" ).arg( m_name ).arg( userDefinedValue ); } else { sourceLabel = QString( "%1 = %2" ).arg( m_name ).arg( SourceEnum::uiText( currentSource ) ); } sourceLabel.replace( " ", delimiter ); return sourceLabel; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RigWbsParameter::operator==( const RigWbsParameter& rhs ) const { return m_name == rhs.m_name; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RigWbsParameter::operator<( const RigWbsParameter& rhs ) const { return m_name < rhs.m_name; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RigWbsParameter RigWbsParameter::PP_Reservoir() { SourceVector sources = { { GRID, SourceAddress( QString::fromStdString( RigFemAddressDefines::porBar() ), "", RiaWellLogUnitTools::barUnitString() ) }, { LAS_FILE, SourceAddress( "PP_INP", "", RiaWellLogUnitTools::sg_emwUnitString() ) }, { LAS_FILE, SourceAddress( "PP_RES_INP", "", RiaWellLogUnitTools::sg_emwUnitString() ) }, { LAS_FILE, SourceAddress( "POR_RES_INP", "", RiaWellLogUnitTools::gPerCm3UnitString() ) }, { ELEMENT_PROPERTY_TABLE, SourceAddress( "POR_INP", "", RiaWellLogUnitTools::pascalUnitString() ) }, { ELEMENT_PROPERTY_TABLE, SourceAddress( "PP_INP", "", RiaWellLogUnitTools::sg_emwUnitString() ) } }; return RigWbsParameter( "PP_Reservoir", true, sources ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RigWbsParameter RigWbsParameter::PP_NonReservoir() { SourceVector sources = { { LAS_FILE, SourceAddress( "PP_NONRES_INP", "", RiaWellLogUnitTools::sg_emwUnitString() ) }, { LAS_FILE, SourceAddress( "POR_NONRES_INP", "", RiaWellLogUnitTools::gPerCm3UnitString() ) }, { ELEMENT_PROPERTY_TABLE, SourceAddress( "POR_NONRES_INP", "", RiaWellLogUnitTools::pascalUnitString() ) }, { ELEMENT_PROPERTY_TABLE, SourceAddress( "PP_NONRES_INP", "", RiaWellLogUnitTools::sg_emwUnitString() ) }, { HYDROSTATIC, SourceAddress( "Hydrostatic", "", RiaWellLogUnitTools::barUnitString() ) } }; return RigWbsParameter( "PP_Non-Reservoir", true, sources ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RigWbsParameter RigWbsParameter::poissonRatio() { return RigWbsParameter( "Poisson_Ratio", false, { { LAS_FILE, SourceAddress( "POISSON_RATIO_INP" ) }, { ELEMENT_PROPERTY_TABLE, SourceAddress( "POISSON_RATIO_INP" ) }, { USER_DEFINED, SourceAddress() } } ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RigWbsParameter RigWbsParameter::UCS() { return RigWbsParameter( "UCS", false, { { LAS_FILE, SourceAddress( "UCS_INP", "", RiaWellLogUnitTools::MPaUnitString() ) }, { ELEMENT_PROPERTY_TABLE, SourceAddress( "UCS_INP", "", RiaWellLogUnitTools::pascalUnitString() ) }, { USER_DEFINED, SourceAddress( "", "", RiaWellLogUnitTools::barUnitString() ) } } ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RigWbsParameter RigWbsParameter::OBG() { std::vector> sources = { { GRID, SourceAddress( "ST", "S33", RiaWellLogUnitTools::barUnitString() ) }, { LAS_FILE, SourceAddress( "OBG_INP", "", RiaWellLogUnitTools::barUnitString() ) } }; return RigWbsParameter( "OBG_Input", true, sources ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RigWbsParameter RigWbsParameter::OBG0() { std::vector> sources = { { GRID, SourceAddress( "ST", "S33", RiaWellLogUnitTools::barUnitString() ) }, { LAS_FILE, SourceAddress( "OBG0_INP", "", RiaWellLogUnitTools::barUnitString() ) } }; return RigWbsParameter( "OBG0", true, sources ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RigWbsParameter RigWbsParameter::SH() { std::vector> sources = { { GRID, SourceAddress( "ST", "S3", RiaWellLogUnitTools::barUnitString() ) } }; return RigWbsParameter( "SH_Input", true, sources ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RigWbsParameter RigWbsParameter::DF() { return RigWbsParameter( "DF", false, { { LAS_FILE, SourceAddress( "DF_INP" ) }, { ELEMENT_PROPERTY_TABLE, SourceAddress( "DF_INP" ) }, { USER_DEFINED, SourceAddress() } } ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RigWbsParameter RigWbsParameter::K0_FG() { return RigWbsParameter( "K0_FG", false, { { LAS_FILE, SourceAddress( "K0_FG_INP", "", RiaWellLogUnitTools::sg_emwUnitString() ) }, { ELEMENT_PROPERTY_TABLE, SourceAddress( "K0_FG_INP" ) }, { USER_DEFINED, SourceAddress() } } ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RigWbsParameter RigWbsParameter::K0_SH() { return RigWbsParameter( "K0_SH", false, { { LAS_FILE, SourceAddress( "K0_SH_INP", "", RiaWellLogUnitTools::sg_emwUnitString() ) }, { ELEMENT_PROPERTY_TABLE, SourceAddress( "K0_SH_INP" ) }, { USER_DEFINED, SourceAddress() } } ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RigWbsParameter RigWbsParameter::FG_Shale() { RigWbsParameter param( "FG_Shale", false, { { DERIVED_FROM_K0FG, SourceAddress() }, { PROPORTIONAL_TO_SH, SourceAddress() }, { LAS_FILE, SourceAddress( "FG_SHALE_INP", "", RiaWellLogUnitTools::sg_emwUnitString() ) } } ); param.setOptionsExclusive( true ); return param; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RigWbsParameter RigWbsParameter::waterDensity() { RigWbsParameter param( "WaterDensity", false, { { USER_DEFINED, SourceAddress() }, { LAS_FILE, SourceAddress( "RHO_INP", "", RiaWellLogUnitTools::gPerCm3UnitString() ) } } ); return param; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- std::set RigWbsParameter::allParameters() { return { PP_Reservoir(), PP_NonReservoir(), poissonRatio(), UCS(), OBG(), OBG0(), SH(), DF(), K0_FG(), K0_SH(), FG_Shale(), waterDensity() }; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RigWbsParameter::findParameter( QString parameterName, RigWbsParameter* foundParam /* = nullptr*/ ) { auto params = allParameters(); auto it = params.find( parameterName ); if ( it != params.end() ) { if ( foundParam ) *foundParam = *it; return true; } return false; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RigWbsParameter::address( Source source, RigWbsParameter::SourceAddress* sourceAddress ) const { for ( auto sourceEntryPair : m_sources ) { if ( sourceEntryPair.first == source ) { *sourceAddress = sourceEntryPair.second; return true; } } return false; }