2018-08-09 03:57:26 -05:00
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
2019-01-09 08:21:38 -06:00
|
|
|
// Copyright (C) 2018- Equinor ASA
|
2018-08-09 03:57:26 -05:00
|
|
|
//
|
|
|
|
// 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 "RicWellPathFractureReportItem.h"
|
|
|
|
|
2018-11-05 03:07:21 -06:00
|
|
|
#include "RigTransmissibilityEquations.h"
|
|
|
|
|
2018-11-09 07:20:36 -06:00
|
|
|
#include <cmath>
|
|
|
|
|
2018-08-09 03:57:26 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-23 04:32:50 -06:00
|
|
|
RicWellPathFractureReportItem::RicWellPathFractureReportItem(const QString& wellPathNameForExport,
|
2018-08-09 03:57:26 -05:00
|
|
|
const QString& fractureName,
|
2018-10-04 08:56:42 -05:00
|
|
|
const QString& fractureTemplateName,
|
|
|
|
double measuredDepth)
|
2018-11-23 04:32:50 -06:00
|
|
|
: m_wellPathNameForExport(wellPathNameForExport)
|
2018-08-09 03:57:26 -05:00
|
|
|
, m_wellPathFracture(fractureName)
|
|
|
|
, m_wellPathFractureTemplate(fractureTemplateName)
|
2018-10-04 08:56:42 -05:00
|
|
|
, m_mesuredDepth(measuredDepth)
|
2018-08-09 06:38:49 -05:00
|
|
|
, m_transmissibility(0.0)
|
|
|
|
, m_connectionCount(0)
|
|
|
|
, m_area(0.0)
|
|
|
|
, m_kfwf(0.0)
|
|
|
|
, m_kf(0.0)
|
|
|
|
, m_wf(0.0)
|
|
|
|
, m_xf(0.0)
|
|
|
|
, m_h(0.0)
|
|
|
|
, m_km(0.0)
|
2018-11-20 06:23:27 -06:00
|
|
|
, m_performPressureDepletionScaling(false)
|
|
|
|
, m_pressureDepletionUserWBHP(0.0)
|
|
|
|
, m_pressureDepletionActualWBHP(0.0)
|
2018-11-13 09:47:53 -06:00
|
|
|
, m_pressureDepletionMinPressureDrop(-1.0)
|
|
|
|
, m_pressureDepletionMaxPressureDrop(-1.0)
|
2018-08-09 03:57:26 -05:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-09 03:51:17 -06:00
|
|
|
void RicWellPathFractureReportItem::setData(double trans, size_t connCount, double area)
|
2018-08-09 03:57:26 -05:00
|
|
|
{
|
|
|
|
m_transmissibility = trans;
|
|
|
|
m_connectionCount = connCount;
|
|
|
|
m_area = area;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RicWellPathFractureReportItem::setWidthAndConductivity(double width, double conductivity)
|
|
|
|
{
|
|
|
|
m_wf = width;
|
2018-11-05 03:07:21 -06:00
|
|
|
|
|
|
|
double permeability = RigTransmissibilityEquations::permeability(conductivity, width);
|
|
|
|
m_kf = permeability;
|
2018-08-09 03:57:26 -05:00
|
|
|
|
2018-11-05 03:07:21 -06:00
|
|
|
m_kfwf = conductivity;
|
2018-08-09 03:57:26 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RicWellPathFractureReportItem::setHeightAndHalfLength(double height, double halfLength)
|
|
|
|
{
|
|
|
|
m_h = height;
|
|
|
|
m_xf = halfLength;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-08-09 06:38:49 -05:00
|
|
|
///
|
2018-08-09 03:57:26 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-21 06:44:31 -06:00
|
|
|
void RicWellPathFractureReportItem::setAreaWeightedPermeability(double permeability)
|
2018-08-09 03:57:26 -05:00
|
|
|
{
|
2018-11-21 06:44:31 -06:00
|
|
|
m_km = permeability;
|
2018-08-09 03:57:26 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-10-04 08:02:15 -05:00
|
|
|
QString RicWellPathFractureReportItem::wellPathNameForExport() const
|
2018-08-09 03:57:26 -05:00
|
|
|
{
|
2018-10-04 08:02:15 -05:00
|
|
|
return m_wellPathNameForExport;
|
2018-08-09 03:57:26 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-10-04 08:56:42 -05:00
|
|
|
///
|
2018-08-09 03:57:26 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-10-04 08:02:15 -05:00
|
|
|
QString RicWellPathFractureReportItem::fractureName() const
|
2018-08-09 03:57:26 -05:00
|
|
|
{
|
2018-10-04 08:02:15 -05:00
|
|
|
return m_wellPathFracture;
|
2018-08-09 03:57:26 -05:00
|
|
|
}
|
|
|
|
|
2018-08-31 05:50:17 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-10-04 08:56:42 -05:00
|
|
|
///
|
2018-08-31 05:50:17 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-10-04 08:02:15 -05:00
|
|
|
QString RicWellPathFractureReportItem::fractureTemplateName() const
|
|
|
|
{
|
|
|
|
return m_wellPathFractureTemplate;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-08-31 05:50:17 -05:00
|
|
|
void RicWellPathFractureReportItem::setUnitSystem(RiaEclipseUnitTools::UnitSystem unitSystem)
|
|
|
|
{
|
|
|
|
m_unitSystem = unitSystem;
|
|
|
|
}
|
|
|
|
|
2018-11-12 07:38:32 -06:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-21 04:10:41 -06:00
|
|
|
void RicWellPathFractureReportItem::setPressureDepletionParameters(bool performPDDScaling, QString timeStepString, QString wbhpString, double userWBHP, double actualWBHP, double minPressureDrop, double maxPressureDrop)
|
2018-11-12 07:38:32 -06:00
|
|
|
{
|
2018-11-20 06:23:27 -06:00
|
|
|
m_performPressureDepletionScaling = performPDDScaling;
|
2018-11-21 04:10:41 -06:00
|
|
|
m_pressureDepletionTimeStepString = timeStepString;
|
2018-11-20 06:23:27 -06:00
|
|
|
m_pressureDepletionWBHPString = wbhpString;
|
|
|
|
m_pressureDepletionUserWBHP = userWBHP;
|
|
|
|
m_pressureDepletionActualWBHP = actualWBHP;
|
|
|
|
m_pressureDepletionMinPressureDrop = minPressureDrop;
|
|
|
|
m_pressureDepletionMaxPressureDrop = maxPressureDrop;
|
2018-11-12 07:38:32 -06:00
|
|
|
}
|
|
|
|
|
2018-08-31 05:50:17 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-10-04 08:02:15 -05:00
|
|
|
///
|
2018-08-31 05:50:17 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
RiaEclipseUnitTools::UnitSystem RicWellPathFractureReportItem::unitSystem() const
|
|
|
|
{
|
|
|
|
return m_unitSystem;
|
|
|
|
}
|
|
|
|
|
2018-08-09 03:57:26 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
double RicWellPathFractureReportItem::transmissibility() const
|
|
|
|
{
|
|
|
|
return m_transmissibility;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
size_t RicWellPathFractureReportItem::connectionCount() const
|
|
|
|
{
|
|
|
|
return m_connectionCount;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
double RicWellPathFractureReportItem::fcd() const
|
|
|
|
{
|
2018-11-09 03:51:17 -06:00
|
|
|
double myFcd = 0.0;
|
|
|
|
|
|
|
|
double threshold = 1.0e-7;
|
2018-11-09 07:20:36 -06:00
|
|
|
if (fabs(kmxf()) > threshold)
|
2018-11-09 03:51:17 -06:00
|
|
|
{
|
|
|
|
myFcd = kfwf() / kmxf();
|
|
|
|
}
|
|
|
|
|
|
|
|
return myFcd;
|
2018-08-09 03:57:26 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
double RicWellPathFractureReportItem::area() const
|
|
|
|
{
|
|
|
|
return m_area;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
double RicWellPathFractureReportItem::kfwf() const
|
|
|
|
{
|
|
|
|
return m_kfwf;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
double RicWellPathFractureReportItem::kf() const
|
|
|
|
{
|
|
|
|
return m_kf;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
double RicWellPathFractureReportItem::wf() const
|
|
|
|
{
|
|
|
|
return m_wf;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
double RicWellPathFractureReportItem::xf() const
|
|
|
|
{
|
|
|
|
return m_xf;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
double RicWellPathFractureReportItem::h() const
|
|
|
|
{
|
|
|
|
return m_h;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
double RicWellPathFractureReportItem::km() const
|
|
|
|
{
|
|
|
|
return m_km;
|
|
|
|
}
|
2018-10-04 08:56:42 -05:00
|
|
|
|
2018-11-09 03:51:17 -06:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
double RicWellPathFractureReportItem::kmxf() const
|
|
|
|
{
|
|
|
|
return m_km * m_xf;
|
|
|
|
}
|
|
|
|
|
2018-11-20 06:23:27 -06:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
bool RicWellPathFractureReportItem::performPressureDepletionScaling() const
|
|
|
|
{
|
|
|
|
return m_performPressureDepletionScaling;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-21 04:10:41 -06:00
|
|
|
QString RicWellPathFractureReportItem::pressureDepletionTimeStepString() const
|
|
|
|
{
|
|
|
|
return m_pressureDepletionTimeStepString;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-20 06:23:27 -06:00
|
|
|
QString RicWellPathFractureReportItem::pressureDepletionWBHPString() const
|
|
|
|
{
|
|
|
|
return m_pressureDepletionWBHPString;
|
|
|
|
}
|
|
|
|
|
2018-11-12 07:38:32 -06:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-13 09:47:53 -06:00
|
|
|
double RicWellPathFractureReportItem::pressureDepletionUserWBHP() const
|
|
|
|
{
|
|
|
|
return m_pressureDepletionUserWBHP;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-20 06:23:27 -06:00
|
|
|
double RicWellPathFractureReportItem::pressureDepletionActualWBHP() const
|
|
|
|
{
|
|
|
|
return m_pressureDepletionActualWBHP;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-13 09:47:53 -06:00
|
|
|
double RicWellPathFractureReportItem::pressureDepletionMinPressureDrop() const
|
2018-11-12 07:38:32 -06:00
|
|
|
{
|
2018-11-13 09:47:53 -06:00
|
|
|
return m_pressureDepletionMinPressureDrop;
|
2018-11-12 07:38:32 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2018-11-13 09:47:53 -06:00
|
|
|
double RicWellPathFractureReportItem::pressureDepletionMaxPressureDrop() const
|
2018-11-12 07:38:32 -06:00
|
|
|
{
|
2018-11-13 09:47:53 -06:00
|
|
|
return m_pressureDepletionMaxPressureDrop;
|
2018-11-12 07:38:32 -06:00
|
|
|
}
|
|
|
|
|
2018-10-04 08:56:42 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
bool RicWellPathFractureReportItem::operator<(const RicWellPathFractureReportItem& other) const
|
|
|
|
{
|
|
|
|
if (this->wellPathNameForExport() != other.wellPathNameForExport())
|
|
|
|
{
|
|
|
|
return this->wellPathNameForExport() < other.wellPathNameForExport();
|
|
|
|
}
|
|
|
|
|
|
|
|
return this->m_mesuredDepth < other.m_mesuredDepth;
|
|
|
|
}
|