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"
# include "RigTesselatorTools.h"
# include "RimFracture.h"
# include "RimProject.h"
# include "cafPdmObject.h"
2017-04-19 04:00:52 -05:00
# include "cafPdmUiDoubleSliderEditor.h"
2017-02-07 02:09:00 -06:00
# include "cvfVector3.h"
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
2017-02-07 02:09:00 -06:00
}
CAF_PDM_XML_ABSTRACT_SOURCE_INIT ( RimFractureTemplate , " RimFractureTemplate " ) ;
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
RimFractureTemplate : : RimFractureTemplate ( void )
{
CAF_PDM_InitObject ( " Fracture Template " , " :/FractureTemplate16x16.png " , " " , " " ) ;
CAF_PDM_InitField ( & name , " UserDescription " , QString ( " Fracture Template " ) , " Name " , " " , " " , " " ) ;
2017-02-22 04:52:06 -06:00
CAF_PDM_InitField ( & fractureTemplateUnit , " fractureTemplateUnit " , caf : : AppEnum < RimDefines : : UnitSystem > ( RimDefines : : UNITS_METRIC ) , " Units System " , " " , " " , " " ) ;
2017-02-14 02:49:14 -06:00
fractureTemplateUnit . uiCapability ( ) - > setUiReadOnly ( true ) ;
2017-02-22 04:52:06 -06:00
CAF_PDM_InitField ( & orientation , " Orientation " , caf : : AppEnum < FracOrientationEnum > ( TRANSVERSE_WELL_PATH ) , " Fracture Orientation " , " " , " " , " " ) ;
2017-02-07 02:09:00 -06:00
CAF_PDM_InitField ( & azimuthAngle , " AzimuthAngle " , 0.0f , " Azimuth Angle " , " " , " " , " " ) ; //Is this correct description?
CAF_PDM_InitField ( & skinFactor , " SkinFactor " , 1.0f , " Skin Factor " , " " , " " , " " ) ;
2017-02-10 06:29:31 -06:00
2017-04-19 04:00:52 -05:00
CAF_PDM_InitField ( & perforationLength , " PerforationLength " , 0.0 , " Perforation Length " , " " , " " , " " ) ;
CAF_PDM_InitField ( & perforationEfficiency , " perforationEfficiency " , 1.0 , " perforation Efficiency " , " " , " " , " " ) ;
perforationEfficiency . uiCapability ( ) - > setUiEditorTypeName ( caf : : PdmUiDoubleSliderEditor : : uiEditorTypeName ( ) ) ;
CAF_PDM_InitField ( & wellRadius , " wellRadius " , 0.0 , " Well Radius at Fracture " , " " , " " , " " ) ;
2017-02-22 04:52:06 -06:00
CAF_PDM_InitField ( & fractureConductivity , " FractureCondictivity " , caf : : AppEnum < FracConductivityEnum > ( INFINITE_CONDUCTIVITY ) , " Conductivity in Fracture " , " " , " " , " " ) ;
2017-02-10 06:29:31 -06:00
2017-02-07 02:09:00 -06:00
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
RimFractureTemplate : : ~ RimFractureTemplate ( )
{
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
caf : : PdmFieldHandle * RimFractureTemplate : : userDescriptionField ( )
{
return & name ;
}
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
void RimFractureTemplate : : fieldChangedByUi ( const caf : : PdmFieldHandle * changedField , const QVariant & oldValue , const QVariant & newValue )
{
2017-02-23 02:47:30 -06:00
if ( changedField = = & azimuthAngle | | changedField = = & orientation )
{
//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 )
{
if ( fracture - > attachedFractureDefinition ( ) = = this )
{
if ( changedField = = & azimuthAngle & & ( abs ( oldValue . toDouble ( ) - fracture - > azimuth ( ) ) < 1e-5 ) )
{
fracture - > updateAzimuthFromFractureDefinition ( ) ;
fracture - > setRecomputeGeometryFlag ( ) ;
}
if ( changedField = = & orientation )
{
fracture - > updateAzimuthFromFractureDefinition ( ) ;
fracture - > setRecomputeGeometryFlag ( ) ;
}
}
}
proj - > createDisplayModelAndRedrawAllViews ( ) ;
}
}
2017-02-07 02:09:00 -06:00
2017-04-19 04:00:52 -05:00
if ( changedField = = & perforationLength | | changedField = = & perforationEfficiency | | changedField = = & wellRadius )
{
RimProject * proj ;
this - > firstAncestorOrThisOfType ( proj ) ;
if ( ! proj ) return ;
std : : vector < RimFracture * > fractures ;
proj - > descendantsIncludingThisOfType ( fractures ) ;
for ( RimFracture * fracture : fractures )
{
if ( fracture - > attachedFractureDefinition ( ) = = this )
{
if ( changedField = = & perforationLength & & ( abs ( oldValue . toDouble ( ) - fracture - > perforationLength ( ) ) < 1e-5 ) )
{
fracture - > perforationLength = perforationLength ;
}
if ( changedField = = & perforationEfficiency & & ( abs ( oldValue . toDouble ( ) - fracture - > perforationEfficiency ( ) ) < 1e-5 ) )
{
fracture - > perforationEfficiency = perforationEfficiency ;
}
if ( changedField = = & wellRadius & & ( abs ( oldValue . toDouble ( ) - fracture - > wellRadius ( ) ) < 1e-5 ) )
{
fracture - > wellRadius = wellRadius ;
}
}
}
}
}
2017-02-07 02:09:00 -06:00
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
void RimFractureTemplate : : defineUiOrdering ( QString uiConfigName , caf : : PdmUiOrdering & uiOrdering )
{
2017-02-14 02:49:14 -06:00
2017-02-10 03:33:07 -06:00
if ( orientation = = RimFractureTemplate : : ALONG_WELL_PATH
| | orientation = = RimFractureTemplate : : TRANSVERSE_WELL_PATH )
{
azimuthAngle . uiCapability ( ) - > setUiHidden ( true ) ;
}
else if ( orientation = = RimFractureTemplate : : AZIMUTH )
{
azimuthAngle . uiCapability ( ) - > setUiHidden ( false ) ;
}
2017-02-07 02:09:00 -06:00
}
2017-04-19 04:00:52 -05:00
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
void RimFractureTemplate : : defineEditorAttribute ( const caf : : PdmFieldHandle * field , QString uiConfigName , caf : : PdmUiEditorAttribute * attribute )
{
if ( field = = & perforationEfficiency )
{
caf : : PdmUiDoubleSliderEditorAttribute * myAttr = dynamic_cast < caf : : PdmUiDoubleSliderEditorAttribute * > ( attribute ) ;
if ( myAttr )
{
myAttr - > m_minimum = 0 ;
myAttr - > m_maximum = 1.0 ;
}
}
}