ResInsight/ApplicationLibCode/ReservoirDataModel/RigStimPlanFractureDefinition.h
Kristian Bendiksen 751ebf7eb6
6365 additional stimplan xml parameters (#7318)
* #6365 StimPlan XML: Parse formation dip and fracture orientation.
* #6365 Fracture: Use formation dip and fracture orientation from XML.
* #6365 Fracture: Compare case insensitive, use enum class

Co-authored-by: Magne Sjaastad <magne.sjaastad@ceetronsolutions.com>
2021-02-02 14:29:17 +01:00

168 lines
6.9 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.
//
/////////////////////////////////////////////////////////////////////////////////
#pragma once
#include "RiaDefines.h"
#include "cvfObject.h"
#include "cvfVector3.h"
#include <QString>
#include <vector>
class RigFractureGrid;
class MinMaxAccumulator;
class PosNegAccumulator;
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
class RigStimPlanResultFrames
{
public:
RigStimPlanResultFrames() {}
QString resultName;
QString unit;
// Vector for each time step, for each y and for each x-value
std::vector<std::vector<std::vector<double>>> parameterValues;
};
//--------------------------------------------------------------------------------------------------
///
//--------------------------------------------------------------------------------------------------
class RigStimPlanFractureDefinition : public cvf::Object
{
friend class RifStimPlanXmlReader;
public:
static const double THRESHOLD_VALUE;
enum class Orientation
{
UNDEFINED,
TRANSVERSE,
LONGITUDINAL
};
RigStimPlanFractureDefinition();
~RigStimPlanFractureDefinition() override;
RiaDefines::EclipseUnitSystem unitSet() const;
size_t xCount() const;
size_t yCount() const;
double minDepth() const;
double maxDepth() const;
double topPerfTvd() const;
double bottomPerfTvd() const;
void setTvdToTopPerf( double topPerfTvd );
void setTvdToBottomPerf( double bottomPerfTvd );
double topPerfMd() const;
double bottomPerfMd() const;
void setMdToTopPerf( double topPerfMd );
void setMdToBottomPerf( double bottomPerfMd );
double formationDip() const;
void setFormationDip( double formationDip );
Orientation orientation() const;
void setOrientation( Orientation orientation );
cvf::cref<RigFractureGrid> createFractureGrid( const QString& resultName,
int activeTimeStepIndex,
double xScaleFactor,
double yScaleFactor,
double wellPathIntersectionAtFractureDepth,
RiaDefines::EclipseUnitSystem requiredUnitSet ) const;
void createFractureTriangleGeometry( double xScaleFactor,
double yScaleFactor,
double wellPathIntersectionAtFractureDepth,
const QString& fractureUserName,
std::vector<cvf::Vec3f>* vertices,
std::vector<cvf::uint>* triangleIndices ) const;
const std::vector<double>& timeSteps() const;
void addTimeStep( double time );
size_t totalNumberTimeSteps() const;
std::vector<std::pair<QString, QString>> getStimPlanPropertyNamesUnits() const;
void setDataAtTimeValue( const QString& resultName,
const QString& unit,
const std::vector<std::vector<double>>& data,
double timeStepValue );
const std::vector<std::vector<double>>&
getDataAtTimeIndex( const QString& resultName, const QString& unit, size_t timeStepIndex ) const;
std::vector<double> fractureGridResults( const QString& resultName, const QString& unitName, size_t timeStepIndex ) const;
void appendDataToResultStatistics( const QString& resultName,
const QString& unit,
MinMaxAccumulator& minMaxAccumulator,
PosNegAccumulator& posNegAccumulator ) const;
QStringList conductivityResultNames() const;
private:
bool timeStepExists( double timeStepValue ) const;
size_t getTimeStepIndex( double timeStepValue ) const;
size_t resultIndex( const QString& resultName, const QString& unit ) const;
void generateXsFromFileXs( bool xMirrorMode );
std::vector<std::vector<double>> generateDataLayoutFromFileDataLayout( std::vector<std::vector<double>> rawXYData ) const;
bool numberOfParameterValuesOK( std::vector<std::vector<double>> propertyValuesAtTimestep ) const;
double minY() const;
double maxY() const;
static std::vector<double> adjustedYCoordsAroundWellPathPosition( const std::vector<double>& yCoords,
double wellPathIntersectionAtFractureDepth );
static std::vector<double> computeScaledXs( const std::vector<double>& xs, double scaleFactor );
static std::vector<double>
computeScaledYs( const std::vector<double>& ys, double scaleFactor, double wellPathIntersectionAtFractureDepth );
std::vector<std::vector<double>> conductivityValuesAtTimeStep( const QString& resultName,
int activeTimeStepIndex,
RiaDefines::EclipseUnitSystem requiredUnitSet ) const;
private:
RiaDefines::EclipseUnitSystem m_unitSet; // To be deleted
std::vector<double> m_fileXs;
std::vector<double> m_Ys;
std::vector<double> m_timeSteps;
std::vector<RigStimPlanResultFrames> m_stimPlanResults;
std::vector<double> m_Xs;
bool m_xMirrorMode;
double m_topPerfTvd;
double m_bottomPerfTvd;
double m_topPerfMd;
double m_bottomPerfMd;
double m_formationDip;
Orientation m_orientation;
};