2017-02-07 02:09:00 -06:00
/////////////////////////////////////////////////////////////////////////////////
//
// 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 "RimFractureTemplate.h"
2018-02-14 06:35:35 -06:00
# include "RiaFractureDefines.h"
2017-02-07 02:09:00 -06:00
# include "RigTesselatorTools.h"
# include "RimFracture.h"
2018-01-05 04:38:58 -06:00
# include "RimFractureContainment.h"
2017-02-07 02:09:00 -06:00
# include "RimProject.h"
# include "cafPdmObject.h"
2017-04-19 04:00:52 -05:00
# include "cafPdmUiDoubleSliderEditor.h"
2018-02-14 06:35:35 -06:00
# include "cafPdmUiTextEditor.h"
2017-02-07 02:09:00 -06:00
# include "cvfVector3.h"
2018-01-05 04:38:58 -06:00
# include <cmath>
2017-02-07 02:09:00 -06:00
namespace caf
{
template < >
void caf : : AppEnum < RimFractureTemplate : : FracOrientationEnum > : : setUp ( )
{
addItem ( RimFractureTemplate : : AZIMUTH , " Az " , " Azimuth " ) ;
addItem ( RimFractureTemplate : : ALONG_WELL_PATH , " AlongWellPath " , " Along Well Path " ) ;
addItem ( RimFractureTemplate : : TRANSVERSE_WELL_PATH , " TransverseWellPath " , " Transverse (normal) to Well Path " ) ;
setDefault ( RimFractureTemplate : : TRANSVERSE_WELL_PATH ) ;
}
2017-02-10 06:29:31 -06:00
2017-02-10 06:43:22 -06:00
template < >
2017-02-10 06:29:31 -06:00
void caf : : AppEnum < RimFractureTemplate : : FracConductivityEnum > : : setUp ( )
{
2017-02-22 04:52:06 -06:00
addItem ( RimFractureTemplate : : INFINITE_CONDUCTIVITY , " InfiniteConductivity " , " Infinite Conductivity " ) ;
addItem ( RimFractureTemplate : : FINITE_CONDUCTIVITY , " FiniteConductivity " , " Finite Conductivity " ) ;
2017-02-10 06:29:31 -06:00
setDefault ( RimFractureTemplate : : INFINITE_CONDUCTIVITY ) ;
}
2017-02-14 02:49:14 -06:00
2018-02-14 06:35:35 -06:00
template < >
void caf : : AppEnum < RimFractureTemplate : : EffectivePermeabilityEnum > : : setUp ( )
{
addItem ( RimFractureTemplate : : USER_DEFINED_PERMEABILITY , " UserDefinedPermeability " , " User Defined " ) ;
addItem ( RimFractureTemplate : : CONDUCTIVITY_FROM_FRACTURE , " FractureConductivity " , " Use Fracture Conductivity " ) ;
setDefault ( RimFractureTemplate : : CONDUCTIVITY_FROM_FRACTURE ) ;
}
2017-02-14 02:49:14 -06:00
2017-02-07 02:09:00 -06:00
}
2018-02-09 00:26:48 -06:00
// TODO Move to cafPdmObject.h
# define CAF_PDM_InitField_Basic(field, keyword, default, uiName) CAF_PDM_InitField(field, keyword, default, uiName, "", "", "")
2017-02-07 02:09:00 -06:00
CAF_PDM_XML_ABSTRACT_SOURCE_INIT ( RimFractureTemplate , " RimFractureTemplate " ) ;
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
2018-01-10 00:44:26 -06:00
RimFractureTemplate : : RimFractureTemplate ( )
2017-02-07 02:09:00 -06:00
{
CAF_PDM_InitObject ( " Fracture Template " , " :/FractureTemplate16x16.png " , " " , " " ) ;
2018-02-08 06:57:43 -06:00
CAF_PDM_InitField ( & m_name , " UserDescription " , QString ( " Fracture Template " ) , " Name " , " " , " " , " " ) ;
CAF_PDM_InitField ( & m_fractureTemplateUnit , " UnitSystem " , caf : : AppEnum < RiaEclipseUnitTools : : UnitSystem > ( RiaEclipseUnitTools : : UNITS_METRIC ) , " Units System " , " " , " " , " " ) ;
m_fractureTemplateUnit . uiCapability ( ) - > setUiReadOnly ( true ) ;
2017-02-14 02:49:14 -06:00
2018-02-08 06:57:43 -06:00
CAF_PDM_InitField ( & m_orientationType , " Orientation " , caf : : AppEnum < FracOrientationEnum > ( TRANSVERSE_WELL_PATH ) , " Fracture Orientation " , " " , " " , " " ) ;
2018-02-08 04:34:18 -06:00
CAF_PDM_InitField ( & m_azimuthAngle , " AzimuthAngle " , 0.0f , " Azimuth Angle " , " " , " " , " " ) ; //Is this correct description?
CAF_PDM_InitField ( & m_skinFactor , " SkinFactor " , 0.0f , " Skin Factor " , " " , " " , " " ) ;
2017-02-10 06:29:31 -06:00
2018-02-08 04:34:18 -06:00
CAF_PDM_InitField ( & m_perforationLength , " PerforationLength " , 1.0 , " Perforation Length " , " " , " " , " " ) ;
CAF_PDM_InitField ( & m_perforationEfficiency , " PerforationEfficiency " , 1.0 , " Perforation Efficiency " , " " , " " , " " ) ;
m_perforationEfficiency . uiCapability ( ) - > setUiEditorTypeName ( caf : : PdmUiDoubleSliderEditor : : uiEditorTypeName ( ) ) ;
CAF_PDM_InitField ( & m_wellDiameter , " WellDiameter " , 0.216 , " Well Diameter at Fracture " , " " , " " , " " ) ;
2017-04-19 04:00:52 -05:00
2018-02-08 04:34:18 -06:00
CAF_PDM_InitField ( & m_conductivityType , " ConductivityType " , caf : : AppEnum < FracConductivityEnum > ( FINITE_CONDUCTIVITY ) , " Conductivity in Fracture " , " " , " " , " " ) ;
2017-02-10 06:29:31 -06:00
2017-12-15 07:26:59 -06:00
CAF_PDM_InitFieldNoDefault ( & m_fractureContainment , " FractureContainmentField " , " Fracture Containment " , " " , " " , " " ) ;
2017-06-09 10:21:59 -05:00
m_fractureContainment = new RimFractureContainment ( ) ;
m_fractureContainment . uiCapability ( ) - > setUiTreeHidden ( true ) ;
m_fractureContainment . uiCapability ( ) - > setUiTreeChildrenHidden ( true ) ;
2018-02-09 00:26:48 -06:00
// Non-Darcy Flow options
CAF_PDM_InitField_Basic ( & m_useNonDarcyFlow , " UseNonDarcyFlow " , false , " Use Non-Darcy Flow " ) ;
2018-02-14 06:35:35 -06:00
CAF_PDM_InitField_Basic ( & m_inertialCoefficient , " InertialCoefficient " , 0.006083236 , " Inertial Coefficient " ) ;
2018-02-15 08:38:27 -06:00
CAF_PDM_InitFieldNoDefault ( & m_permeabilityType , " PermeabilityType " , " Type " , " " , " " , " " ) ;
CAF_PDM_InitField_Basic ( & m_relativePermeability , " RelativePermeability " , 1.0 , " Relative Permeability " ) ;
CAF_PDM_InitField ( & m_userDefinedEffectivePermeability , " EffectivePermeability " , 0.0 , " Effective Permeability [mD] " , " " , " " , " " ) ;
2018-02-14 06:35:35 -06:00
CAF_PDM_InitField ( & m_relativeGasDensity , " RelativeGasDensity " , 0.8 , " Relative Gas Density " , " " , " Relative density of gas at surface conditions with respect to air at STP " , " " ) ;
CAF_PDM_InitField ( & m_gasViscosity , " GasViscosity " , 0.02 , " Gas Viscosity " , " " , " Gas viscosity at bottom hole pressure " , " " ) ;
CAF_PDM_InitFieldNoDefault ( & m_dFactorDisplayField , " dFactorDisplayField " , " D Factor " , " " , " " , " " ) ;
m_dFactorDisplayField . registerGetMethod ( this , & RimFractureTemplate : : computeDFactor ) ;
m_dFactorDisplayField . uiCapability ( ) - > setUiReadOnly ( true ) ;
CAF_PDM_InitFieldNoDefault ( & m_dFactorSummaryText , " dFactorSummaryText " , " D Factor Summary " , " " , " " , " " ) ;
m_dFactorSummaryText . registerGetMethod ( this , & RimFractureTemplate : : dFactorSummary ) ;
m_dFactorSummaryText . uiCapability ( ) - > setUiReadOnly ( true ) ;
m_dFactorSummaryText . uiCapability ( ) - > setUiEditorTypeName ( caf : : PdmUiTextEditor : : uiEditorTypeName ( ) ) ;
m_dFactorSummaryText . uiCapability ( ) - > setUiLabelPosition ( caf : : PdmUiItemInfo : : LabelPosType : : TOP ) ;
2017-02-07 02:09:00 -06:00
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
RimFractureTemplate : : ~ RimFractureTemplate ( )
{
}
2018-02-08 06:57:43 -06:00
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
void RimFractureTemplate : : setName ( const QString & name )
{
m_name = name ;
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
void RimFractureTemplate : : setFractureTemplateUnit ( RiaEclipseUnitTools : : UnitSystemType unitSystem )
{
m_fractureTemplateUnit = unitSystem ;
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
QString RimFractureTemplate : : name ( ) const
{
return m_name ;
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
RimFractureTemplate : : FracOrientationEnum RimFractureTemplate : : orientationType ( ) const
{
return m_orientationType ( ) ;
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
RiaEclipseUnitTools : : UnitSystemType RimFractureTemplate : : fractureTemplateUnit ( ) const
{
return m_fractureTemplateUnit ( ) ;
}
2017-02-07 02:09:00 -06:00
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
caf : : PdmFieldHandle * RimFractureTemplate : : userDescriptionField ( )
{
2018-02-08 06:57:43 -06:00
return & m_name ;
2017-02-07 02:09:00 -06:00
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
void RimFractureTemplate : : fieldChangedByUi ( const caf : : PdmFieldHandle * changedField , const QVariant & oldValue , const QVariant & newValue )
{
2018-02-08 06:57:43 -06:00
if ( changedField = = & m_azimuthAngle | | changedField = = & m_orientationType )
2017-02-23 02:47:30 -06:00
{
//Changes to one of these parameters should change all fractures with this fracture template attached.
RimProject * proj ;
this - > firstAncestorOrThisOfType ( proj ) ;
if ( proj )
{
//Regenerate geometry
std : : vector < RimFracture * > fractures ;
proj - > descendantsIncludingThisOfType ( fractures ) ;
for ( RimFracture * fracture : fractures )
{
2017-06-09 10:21:59 -05:00
if ( fracture - > fractureTemplate ( ) = = this )
2017-02-23 02:47:30 -06:00
{
2018-02-08 04:34:18 -06:00
if ( changedField = = & m_azimuthAngle & & ( fabs ( oldValue . toDouble ( ) - fracture - > m_azimuth ( ) ) < 1e-5 ) )
2017-02-23 02:47:30 -06:00
{
2018-02-08 04:34:18 -06:00
fracture - > m_azimuth = m_azimuthAngle ;
2017-02-23 02:47:30 -06:00
}
2018-02-08 06:57:43 -06:00
if ( changedField = = & m_orientationType )
2017-02-23 02:47:30 -06:00
{
2017-06-29 08:06:44 -05:00
if ( newValue = = AZIMUTH )
{
2018-02-08 04:34:18 -06:00
fracture - > m_azimuth = m_azimuthAngle ;
2017-06-29 08:06:44 -05:00
}
else fracture - > updateAzimuthBasedOnWellAzimuthAngle ( ) ;
2017-02-23 02:47:30 -06:00
}
}
}
proj - > createDisplayModelAndRedrawAllViews ( ) ;
}
}
2017-02-07 02:09:00 -06:00
2018-02-08 04:34:18 -06:00
if ( changedField = = & m_perforationLength | | changedField = = & m_perforationEfficiency | | changedField = = & m_wellDiameter )
2017-04-19 04:00:52 -05:00
{
RimProject * proj ;
this - > firstAncestorOrThisOfType ( proj ) ;
if ( ! proj ) return ;
std : : vector < RimFracture * > fractures ;
proj - > descendantsIncludingThisOfType ( fractures ) ;
for ( RimFracture * fracture : fractures )
{
2017-06-09 10:21:59 -05:00
if ( fracture - > fractureTemplate ( ) = = this )
2017-04-19 04:00:52 -05:00
{
2018-02-08 04:34:18 -06:00
if ( changedField = = & m_perforationLength & & ( fabs ( oldValue . toDouble ( ) - fracture - > m_perforationLength ( ) ) < 1e-5 ) )
2017-04-19 04:00:52 -05:00
{
2018-02-08 04:34:18 -06:00
fracture - > m_perforationLength = m_perforationLength ;
2017-04-19 04:00:52 -05:00
}
2018-02-08 04:34:18 -06:00
if ( changedField = = & m_perforationEfficiency & & ( fabs ( oldValue . toDouble ( ) - fracture - > m_perforationEfficiency ( ) ) < 1e-5 ) )
2017-04-19 04:00:52 -05:00
{
2018-02-08 04:34:18 -06:00
fracture - > m_perforationEfficiency = m_perforationEfficiency ;
2017-04-19 04:00:52 -05:00
}
2018-02-08 04:34:18 -06:00
if ( changedField = = & m_wellDiameter & & ( fabs ( oldValue . toDouble ( ) - fracture - > m_wellDiameter ( ) ) < 1e-5 ) )
2017-04-19 04:00:52 -05:00
{
2018-02-08 04:34:18 -06:00
fracture - > m_wellDiameter = m_wellDiameter ;
2017-04-19 04:00:52 -05:00
}
}
}
}
2018-01-19 08:08:28 -06:00
2018-02-08 04:34:18 -06:00
if ( changedField = = & m_perforationLength )
2018-01-19 08:08:28 -06:00
{
RimProject * proj ;
this - > firstAncestorOrThisOfType ( proj ) ;
if ( proj )
{
proj - > createDisplayModelAndRedrawAllViews ( ) ;
}
}
2017-04-19 04:00:52 -05:00
}
2017-02-07 02:09:00 -06:00
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
void RimFractureTemplate : : defineUiOrdering ( QString uiConfigName , caf : : PdmUiOrdering & uiOrdering )
{
2018-02-09 00:26:48 -06:00
prepareFieldsForUiDisplay ( ) ;
auto group = uiOrdering . addNewGroup ( " Non-Darcy Flow " ) ;
group - > setCollapsedByDefault ( true ) ;
group - > add ( & m_useNonDarcyFlow ) ;
group - > add ( & m_inertialCoefficient ) ;
2018-02-14 06:35:35 -06:00
{
auto permGroup = group - > addNewGroup ( " Effective Permeability " ) ;
permGroup - > add ( & m_permeabilityType ) ;
2018-02-15 08:38:27 -06:00
permGroup - > add ( & m_relativePermeability ) ;
permGroup - > add ( & m_userDefinedEffectivePermeability ) ;
2018-02-14 06:35:35 -06:00
}
group - > add ( & m_relativeGasDensity ) ;
2018-02-09 00:26:48 -06:00
group - > add ( & m_gasViscosity ) ;
2018-02-14 06:35:35 -06:00
group - > add ( & m_dFactorDisplayField ) ;
{
auto dFactorGroup = group - > addNewGroup ( " D Factor Details " ) ;
dFactorGroup - > setCollapsedByDefault ( true ) ;
dFactorGroup - > add ( & m_dFactorSummaryText ) ;
}
2018-02-09 00:26:48 -06:00
uiOrdering . add ( & m_fractureTemplateUnit ) ;
}
2017-02-14 02:49:14 -06:00
2018-02-09 00:26:48 -06:00
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
void RimFractureTemplate : : defineEditorAttribute ( const caf : : PdmFieldHandle * field , QString uiConfigName , caf : : PdmUiEditorAttribute * attribute )
{
if ( field = = & m_perforationEfficiency )
{
auto myAttr = dynamic_cast < caf : : PdmUiDoubleSliderEditorAttribute * > ( attribute ) ;
if ( myAttr )
{
myAttr - > m_minimum = 0 ;
myAttr - > m_maximum = 1.0 ;
}
}
2018-02-14 06:35:35 -06:00
if ( field = = & m_dFactorSummaryText )
{
auto myAttr = dynamic_cast < caf : : PdmUiTextEditorAttribute * > ( attribute ) ;
if ( myAttr )
{
myAttr - > wrapMode = caf : : PdmUiTextEditorAttribute : : NoWrap ;
QFont font ( " Monospace " , 10 ) ;
myAttr - > font = font ;
myAttr - > textMode = caf : : PdmUiTextEditorAttribute : : HTML ;
}
}
}
2018-02-09 00:26:48 -06:00
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
void RimFractureTemplate : : prepareFieldsForUiDisplay ( )
{
2018-02-08 06:57:43 -06:00
if ( m_fractureTemplateUnit = = RiaEclipseUnitTools : : UNITS_METRIC )
2017-06-08 04:00:35 -05:00
{
2018-02-08 04:34:18 -06:00
m_wellDiameter . uiCapability ( ) - > setUiName ( " Well Diameter [m] " ) ;
m_perforationLength . uiCapability ( ) - > setUiName ( " Perforation Length [m] " ) ;
2017-06-08 04:00:35 -05:00
}
2018-02-08 06:57:43 -06:00
else if ( m_fractureTemplateUnit = = RiaEclipseUnitTools : : UNITS_FIELD )
2017-06-08 04:00:35 -05:00
{
2018-02-08 04:34:18 -06:00
m_wellDiameter . uiCapability ( ) - > setUiName ( " Well Diameter [inches] " ) ;
m_perforationLength . uiCapability ( ) - > setUiName ( " Perforation Length [Ft] " ) ;
2017-06-08 04:00:35 -05:00
}
2018-02-08 06:57:43 -06:00
if ( m_orientationType = = RimFractureTemplate : : ALONG_WELL_PATH
| | m_orientationType = = RimFractureTemplate : : TRANSVERSE_WELL_PATH )
2017-02-10 03:33:07 -06:00
{
2018-02-08 04:34:18 -06:00
m_azimuthAngle . uiCapability ( ) - > setUiHidden ( true ) ;
2017-02-10 03:33:07 -06:00
}
2018-02-08 06:57:43 -06:00
else if ( m_orientationType = = RimFractureTemplate : : AZIMUTH )
2017-02-10 03:33:07 -06:00
{
2018-02-08 04:34:18 -06:00
m_azimuthAngle . uiCapability ( ) - > setUiHidden ( false ) ;
2017-02-10 03:33:07 -06:00
}
2017-06-02 08:34:37 -05:00
2018-02-08 06:57:43 -06:00
if ( m_orientationType = = RimFractureTemplate : : ALONG_WELL_PATH )
2017-06-02 08:34:37 -05:00
{
2018-02-08 04:34:18 -06:00
m_perforationEfficiency . uiCapability ( ) - > setUiHidden ( false ) ;
m_perforationLength . uiCapability ( ) - > setUiHidden ( false ) ;
2017-06-02 08:34:37 -05:00
}
else
{
2018-02-08 04:34:18 -06:00
m_perforationEfficiency . uiCapability ( ) - > setUiHidden ( true ) ;
m_perforationLength . uiCapability ( ) - > setUiHidden ( true ) ;
2017-06-02 08:34:37 -05:00
}
2017-06-26 03:43:14 -05:00
2018-02-08 04:34:18 -06:00
if ( m_conductivityType = = FINITE_CONDUCTIVITY )
2017-06-26 03:43:14 -05:00
{
2018-02-08 04:34:18 -06:00
m_wellDiameter . uiCapability ( ) - > setUiHidden ( false ) ;
2017-06-26 03:43:14 -05:00
}
2018-02-08 04:34:18 -06:00
else if ( m_conductivityType = = INFINITE_CONDUCTIVITY )
2017-06-26 03:43:14 -05:00
{
2018-02-08 04:34:18 -06:00
m_wellDiameter . uiCapability ( ) - > setUiHidden ( true ) ;
2017-06-26 03:43:14 -05:00
}
2017-04-19 04:00:52 -05:00
2018-02-09 00:26:48 -06:00
// Non Darcy Flow
m_inertialCoefficient . uiCapability ( ) - > setUiReadOnly ( ! m_useNonDarcyFlow ) ;
2018-02-14 06:35:35 -06:00
m_permeabilityType . uiCapability ( ) - > setUiReadOnly ( ! m_useNonDarcyFlow ) ;
2018-02-15 08:38:27 -06:00
m_relativePermeability . uiCapability ( ) - > setUiReadOnly ( ! m_useNonDarcyFlow ) ;
m_userDefinedEffectivePermeability . uiCapability ( ) - > setUiReadOnly ( ! m_useNonDarcyFlow ) ;
2018-02-14 06:35:35 -06:00
m_relativeGasDensity . uiCapability ( ) - > setUiReadOnly ( ! m_useNonDarcyFlow ) ;
2018-02-09 00:26:48 -06:00
m_gasViscosity . uiCapability ( ) - > setUiReadOnly ( ! m_useNonDarcyFlow ) ;
2018-02-14 06:35:35 -06:00
if ( m_useNonDarcyFlow )
{
if ( m_permeabilityType = = RimFractureTemplate : : USER_DEFINED_PERMEABILITY )
{
2018-02-15 08:38:27 -06:00
m_relativePermeability . uiCapability ( ) - > setUiHidden ( true ) ;
m_userDefinedEffectivePermeability . uiCapability ( ) - > setUiHidden ( false ) ;
2018-02-14 06:35:35 -06:00
}
else
{
2018-02-15 08:38:27 -06:00
m_relativePermeability . uiCapability ( ) - > setUiHidden ( false ) ;
m_userDefinedEffectivePermeability . uiCapability ( ) - > setUiHidden ( true ) ;
2018-02-14 06:35:35 -06:00
}
}
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
QString RimFractureTemplate : : dFactorSummary ( ) const
{
QString text ;
auto dFactor = computeDFactor ( ) ;
text + = QString ( " D-factor : %1 " ) . arg ( dFactor ) ;
text + = " <br> " ;
text + = " <br> " ;
auto alpha = RiaDefines : : nonDarcyFlowAlpha ( m_fractureTemplateUnit ( ) ) ;
text + = QString ( " α : %1 " ) . arg ( alpha ) ;
text + = " <br> " ;
auto beta = m_inertialCoefficient ;
text + = QString ( " β : %1 " ) . arg ( beta ) ;
text + = " <br> " ;
double effPerm = effectivePermeability ( ) ;
text + = QString ( " Ke : %1 " ) . arg ( effPerm ) ;
text + = " <br> " ;
double gamma = m_relativeGasDensity ;
text + = QString ( " γ : %1 " ) . arg ( gamma ) ;
text + = " <br> " ;
auto h = nonDarcyH ( ) ;
text + = QString ( " h : %1 " ) . arg ( h ) ;
text + = " <br> " ;
auto wellRadius = m_wellDiameter / 2.0 ;
text + = QString ( " rw : %1 " ) . arg ( wellRadius ) ;
text + = " <br> " ;
auto mu = m_gasViscosity ;
text + = QString ( " μ : %1 " ) . arg ( mu ) ;
return text ;
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
double RimFractureTemplate : : effectivePermeability ( ) const
{
if ( m_permeabilityType ( ) = = RimFractureTemplate : : USER_DEFINED_PERMEABILITY )
{
2018-02-15 08:38:27 -06:00
return m_userDefinedEffectivePermeability ;
2018-02-14 06:35:35 -06:00
}
else
{
auto values = widthAndConductivityAtWellPathIntersection ( ) ;
auto fracPermeability = values . m_permeability ;
2018-02-15 08:38:27 -06:00
return fracPermeability * m_relativePermeability ;
2018-02-14 06:35:35 -06:00
}
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
double RimFractureTemplate : : computeDFactor ( ) const
{
auto alpha = RiaDefines : : nonDarcyFlowAlpha ( m_fractureTemplateUnit ( ) ) ;
auto beta = m_inertialCoefficient ;
auto effPerm = effectivePermeability ( ) ;
auto gamma = m_relativeGasDensity ;
auto radius = m_wellDiameter / 2.0 ;
auto mu = m_gasViscosity ;
auto h = nonDarcyH ( ) ;
double numerator = alpha * beta * effPerm * gamma ;
double denumerator = h * radius * mu ;
if ( denumerator < 1e-10 ) return HUGE_VAL ;
return numerator / denumerator ;
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
double RimFractureTemplate : : nonDarcyH ( ) const
{
if ( m_orientationType ( ) = = RimFractureTemplate : : ALONG_WELL_PATH )
2017-04-19 04:00:52 -05:00
{
2018-02-14 06:35:35 -06:00
return m_perforationLength ( ) ;
2018-02-09 00:26:48 -06:00
}
else
{
2018-02-14 06:35:35 -06:00
auto values = widthAndConductivityAtWellPathIntersection ( ) ;
return values . m_width ;
2017-04-19 04:00:52 -05:00
}
}
2017-06-08 02:15:50 -05:00
2017-06-15 03:49:27 -05:00
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
double RimFractureTemplate : : wellDiameterInFractureUnit ( RiaEclipseUnitTools : : UnitSystemType fractureUnit )
{
2018-02-08 06:57:43 -06:00
if ( fractureUnit = = m_fractureTemplateUnit ( ) )
2017-06-15 03:49:27 -05:00
{
2018-02-08 04:34:18 -06:00
return m_wellDiameter ;
2017-06-15 03:49:27 -05:00
}
2018-02-08 06:57:43 -06:00
else if ( m_fractureTemplateUnit = = RiaEclipseUnitTools : : UNITS_METRIC
2017-06-15 03:49:27 -05:00
& & fractureUnit = = RiaEclipseUnitTools : : UNITS_FIELD )
{
2018-02-08 04:34:18 -06:00
return RiaEclipseUnitTools : : meterToInch ( m_wellDiameter ) ;
2017-06-15 03:49:27 -05:00
}
2018-02-08 06:57:43 -06:00
else if ( m_fractureTemplateUnit = = RiaEclipseUnitTools : : UNITS_FIELD
2017-06-15 03:49:27 -05:00
& & fractureUnit = = RiaEclipseUnitTools : : UNITS_METRIC )
{
2018-02-08 04:34:18 -06:00
return RiaEclipseUnitTools : : inchToMeter ( m_wellDiameter ) ;
2017-06-15 03:49:27 -05:00
}
return cvf : : UNDEFINED_DOUBLE ;
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
double RimFractureTemplate : : perforationLengthInFractureUnit ( RiaEclipseUnitTools : : UnitSystemType fractureUnit )
{
2018-02-08 06:57:43 -06:00
if ( fractureUnit = = m_fractureTemplateUnit ( ) )
2017-06-15 03:49:27 -05:00
{
2018-02-08 04:34:18 -06:00
return m_perforationLength ;
2017-06-15 03:49:27 -05:00
}
2018-02-08 06:57:43 -06:00
else if ( m_fractureTemplateUnit = = RiaEclipseUnitTools : : UNITS_METRIC
2017-06-15 03:49:27 -05:00
& & fractureUnit = = RiaEclipseUnitTools : : UNITS_FIELD )
{
2018-02-08 04:34:18 -06:00
return RiaEclipseUnitTools : : meterToFeet ( m_perforationLength ) ;
2017-06-15 03:49:27 -05:00
}
2018-02-08 06:57:43 -06:00
else if ( m_fractureTemplateUnit = = RiaEclipseUnitTools : : UNITS_FIELD
2017-06-15 03:49:27 -05:00
& & fractureUnit = = RiaEclipseUnitTools : : UNITS_METRIC )
{
2018-02-08 04:34:18 -06:00
return RiaEclipseUnitTools : : feetToMeter ( m_perforationLength ) ;
2017-06-15 03:49:27 -05:00
}
return cvf : : UNDEFINED_DOUBLE ;
}
2017-06-20 04:18:19 -05:00
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
const RimFractureContainment * RimFractureTemplate : : fractureContainment ( )
{
return m_fractureContainment ( ) ;
}
2018-02-08 04:34:18 -06:00
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
RimFractureTemplate : : FracConductivityEnum RimFractureTemplate : : conductivityType ( ) const
{
return m_conductivityType ( ) ;
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
float RimFractureTemplate : : azimuthAngle ( ) const
{
return m_azimuthAngle ;
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
float RimFractureTemplate : : skinFactor ( ) const
{
return m_skinFactor ;
}
2017-06-08 02:15:50 -05:00
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
void RimFractureTemplate : : setDefaultWellDiameterFromUnit ( )
{
2018-02-08 06:57:43 -06:00
if ( m_fractureTemplateUnit = = RiaEclipseUnitTools : : UNITS_FIELD )
2017-06-08 02:15:50 -05:00
{
2018-02-08 04:34:18 -06:00
m_wellDiameter = 8.5 ;
2017-06-08 02:15:50 -05:00
}
2018-02-08 06:57:43 -06:00
else if ( m_fractureTemplateUnit = = RiaEclipseUnitTools : : UNITS_METRIC )
2017-06-08 02:15:50 -05:00
{
2018-02-08 04:34:18 -06:00
m_wellDiameter = 0.216 ;
2017-06-08 02:15:50 -05:00
}
2018-01-10 00:44:26 -06:00
}