Fesapi 2.9.0.1
This project provides C++ classes which allow an easy access in import and export to the Energistics standards.
Loading...
Searching...
No Matches
Public Member Functions | Static Public Attributes | List of all members
resqml2::BlockedWellboreRepresentation Class Referenceabstract

A blocked wellbore representation. This is the information that allows you to locate, on one or several grids (existing or planned), the intersection of volume (cells) and surface (faces) elements with a wellbore trajectory (existing or planned). More...

#include <BlockedWellboreRepresentation.h>

Inheritance diagram for resqml2::BlockedWellboreRepresentation:
resqml2::WellboreFrameRepresentation resqml2::AbstractRepresentation

Public Member Functions

virtual ~BlockedWellboreRepresentation ()=default
 
virtual void setIntervalGridCells (int8_t const *gridIndices, int8_t gridIndicesNullValue, int64_t const *cellIndices, int8_t const *localFacePairPerCellIndices, int8_t localFacePairPerCellIndicesNullValue, eml2 ::AbstractHdfProxy *hdfProxy=nullptr)=0
 
virtual uint64_t getCellCount () const =0
 
virtual int8_t getGridIndices (int8_t *gridIndices) const =0
 
virtual int64_t getCellIndices (int64_t *cellIndices) const =0
 
virtual int8_t getLocalFacePairPerCellIndices (int8_t *localFacePairPerCellIndices) const =0
 
virtual void pushBackSupportingGridRepresentation (resqml2 ::AbstractGridRepresentation *supportingGridRep)=0
 
virtual uint64_t getSupportingGridRepresentationCount () const =0
 
resqml2::AbstractGridRepresentationgetSupportingGridRepresentation (uint64_t index) const
 
virtual common::DataObjectReference getSupportingGridRepresentationDor (uint64_t index) const =0
 
virtual std::string getXmlTag () const override
 
- Public Member Functions inherited from resqml2::WellboreFrameRepresentation
 ~WellboreFrameRepresentation ()=default
 
void setMdValues (double const *mdValues, uint64_t mdValueCount, eml2 ::AbstractHdfProxy *proxy=nullptr)
 
void setMdValues (double firstMdValue, double incrementMdValue, unsigned int mdValueCount)
 
bool areMdValuesRegularlySpaced () const
 
double getMdConstantIncrementValue () const
 
double getMdFirstValue () const
 
unsigned int getMdValuesCount () const
 
uint64_t getXyzPointCountOfPatch (unsigned int patchIndex) const override
 
void getXyzPointsOfPatch (unsigned int patchIndex, double *xyzPoints) const override
 
common::AbstractObject::numericalDatatypeEnum getMdHdfDatatype () const
 
void getMdAsDoubleValues (double *values) const
 
void getMdAsFloatValues (float *values) const
 
common::DataObjectReference getWellboreTrajectoryDor () const
 
class WellboreTrajectoryRepresentationgetWellboreTrajectory () const
 
common::DataObjectReference getLocalCrsDor (unsigned int patchIndex) const override
 
common::DataObjectReference getHdfProxyDor () const final
 Gets the data object reference of the HDF proxy which is used for storing the numerical values of this representation (i.e. its geometry).
 
uint64_t getPatchCount () const final
 
- Public Member Functions inherited from resqml2::AbstractRepresentation
virtual ~AbstractRepresentation ()=default
 
class AbstractLocal3dCrsgetLocalCrs (unsigned int patchIndex) const
 
void setTimeIndex (uint64_t timeIndex, eml2 ::TimeSeries *timeSeries)
 
uint64_t getTimeIndex () const
 Gets the time index of this representation in the associated TimeSeries. Be sure to first check that a TimeSeries is associated this representation by calling getTimeSeriesDor or getTimeSeries;.
 
eml2::TimeSeriesgetTimeSeries () const
 
common::DataObjectReference getTimeSeriesDor () const
 Gets the data object reference of the TimeSeries containing the time of this representation at a particular index. For now, this method only look for a TimeSeries at the first patch containing a point geometry.
 
std::vector< class AbstractProperty * > getPropertySet () const
 
void setInterpretation (class AbstractFeatureInterpretation *interp)
 
class AbstractFeatureInterpretationgetInterpretation () const
 
common::DataObjectReference getInterpretationDor () const
 
uint64_t getXyzPointCountOfAllPatches () const
 
void getXyzPointsOfPatchInGlobalCrs (unsigned int patchIndex, double *xyzPoints) const
 Gets all the xyz points of a particular patch of this representation. xyz points are given in the global CRS.
 
void getXyzPointsOfAllPatches (double *xyzPoints) const
 Gets all the xyz points of all patches of this representation. xyz points are given in the local CRS.
 
bool isInSingleLocalCrs () const
 
bool isInSingleGlobalCrs () const
 
void getXyzPointsOfAllPatchesInGlobalCrs (double *xyzPoints) const
 
AbstractRepresentationgetSeismicSupportOfPatch (const unsigned int &patchIndex) const
 
std::set< AbstractRepresentation * > getAllSeismicSupport () const
 
void pushBackIntoRepresentationSet (class RepresentationSetRepresentation *repSet)
 
void addSeismic3dCoordinatesToPatch (unsigned int patchIndex, double *inlines, double *crosslines, uint64_t pointCount, resqml2 ::AbstractRepresentation *seismicSupport, eml2 ::AbstractHdfProxy *proxy)
 
void addSeismic3dCoordinatesToPatch (unsigned int patchIndex, double startInline, double incrInline, unsigned int countInline, double startCrossline, double incrCrossline, unsigned int countCrossline, resqml2 ::AbstractRepresentation *seismicSupport)
 
void addSeismic2dCoordinatesToPatch (unsigned int patchIndex, double *lineAbscissa, resqml2 ::AbstractRepresentation *seismicSupport, eml2 ::AbstractHdfProxy *proxy)
 
void getSeismicLineAbscissaOfPointsOfPatch (unsigned int patchIndex, double *values) const
 
void getInlinesOfPointsOfPatch (unsigned int patchIndex, double *values) const
 
void getCrosslinesOfPointsOfPatch (unsigned int patchIndex, double *values) const
 

Static Public Attributes

static constexpr char const * XML_TAG = "BlockedWellboreRepresentation"
 
- Static Public Attributes inherited from resqml2::AbstractRepresentation
static constexpr char const * XML_TAG = "AbstractRepresentation"
 

Detailed Description

A blocked wellbore representation. This is the information that allows you to locate, on one or several grids (existing or planned), the intersection of volume (cells) and surface (faces) elements with a wellbore trajectory (existing or planned).

Constructor & Destructor Documentation

◆ ~BlockedWellboreRepresentation()

virtual resqml2::BlockedWellboreRepresentation::~BlockedWellboreRepresentation ( )
virtualdefault

Destructor does nothing since the memory is managed by the gSOAP context.

Member Function Documentation

◆ getCellCount()

virtual uint64_t resqml2::BlockedWellboreRepresentation::getCellCount ( ) const
pure virtual

Gets the cell count, that is to say the number of non-null entries in the grid indices array.

Returns
The cell count.

◆ getCellIndices()

virtual int64_t resqml2::BlockedWellboreRepresentation::getCellIndices ( int64_t * cellIndices) const
pure virtual

For each interval of the wellbore frame, gets the index of the cell it is associated to.

Exceptions
std::range_errorIf the cell indices are stored in an integer constant array and if the the constant value is strictly superior than int64_t maximum value.
std::logic_errorIf the cell indices are neither stored in a HDF5 integer array nor in an integer constant array.
Parameters
[out]gridIndicesAn array for receiving the cell indices. The size of this array is the interval count of the wellbore frame representation.
Returns
The null value used in cellIndices in order to indicate that an interval does not correspond to any intersected cell.

◆ getGridIndices()

virtual int8_t resqml2::BlockedWellboreRepresentation::getGridIndices ( int8_t * gridIndices) const
pure virtual

For each interval of the wellbore frame, gets the index of the grid it is associated to.

Exceptions
std::range_errorIf the grid indices are stored in an integer constant array and if the the constant value is strictly superior tha char maximum value.
std::logic_errorIf the grid indices are neither stored in a HDF5 integer array nor in an integer constant array.
Parameters
[out]gridIndicesAn array for receiving the grids indices. The size of this array is the interval count of the wellbore frame representation. The associated grids (and there indices) are defined using pushBackSupportingGridRepresentation() method.
Returns
The null value used in gridIndices in order to indicate that an interval does not correspond to any intersected grid.

◆ getLocalFacePairPerCellIndices()

virtual int8_t resqml2::BlockedWellboreRepresentation::getLocalFacePairPerCellIndices ( int8_t * localFacePairPerCellIndices) const
pure virtual

For each interval of the wellbore frame, gets the index of the entry and exit local face it is associated to.

Exceptions
std::range_errorIf the local face indices are stored in an integer constant array and if the the constant value is strictly superior than char maximum value.
std::logic_errorIf the local face indices are neither stored in a HDF5 integer array nor in an integer constant array.
Parameters
[out]gridIndicesAn array for receiving the local face indices. The size of this array is twice the interval count of the wellbore frame representation.
Returns
The null value used in localFacePairPerCellIndices in order to indicate that no face is intersected.

◆ getSupportingGridRepresentation()

resqml2::AbstractGridRepresentation * resqml2::BlockedWellboreRepresentation::getSupportingGridRepresentation ( uint64_t index) const

Gets the supporting grid representation located at a specific index of this blocked wellbore representation.

Exceptions
std::out_of_rangeIf index >= getSupportingGridRepresentationCount().
Parameters
indexZero-based index of the supporting grid representation we look for.
Returns
The supporting grid representation at position index.

◆ getSupportingGridRepresentationCount()

virtual uint64_t resqml2::BlockedWellboreRepresentation::getSupportingGridRepresentationCount ( ) const
pure virtual

Gets the count of supporting grid representations of this blocked wellbore representation.

Exceptions
std::range_errorIf the count of supporting grid representations is strictly greater than unsigned int max.
Returns
The count of supporting grid representation.

◆ getSupportingGridRepresentationDor()

virtual common::DataObjectReference resqml2::BlockedWellboreRepresentation::getSupportingGridRepresentationDor ( uint64_t index) const
pure virtual

Get the DOR of the supporting grid representation located at a specific index of this blocked wellbore representation.

Exceptions
std::out_of_rangeIf index >= getSupportingGridRepresentationCount().
Parameters
indexZero-based index of the supporting grid representation we look for.
Returns
The DOR of the supporting grid representation at position index.

◆ pushBackSupportingGridRepresentation()

virtual void resqml2::BlockedWellboreRepresentation::pushBackSupportingGridRepresentation ( resqml2 ::AbstractGridRepresentation * supportingGridRep)
pure virtual

Pushes back a grid representation which is one of the support of this representation.

Exceptions
std::invalid_argumentIf supportingGridRep == nullptr.
Parameters
[in]supportingGridRepThe supporting grid representation to push back.

◆ setIntervalGridCells()

virtual void resqml2::BlockedWellboreRepresentation::setIntervalGridCells ( int8_t const * gridIndices,
int8_t gridIndicesNullValue,
int64_t const * cellIndices,
int8_t const * localFacePairPerCellIndices,
int8_t localFacePairPerCellIndicesNullValue,
eml2 ::AbstractHdfProxy * hdfProxy = nullptr )
pure virtual

Sets all information about the intersected grid cells. You must first provide MD values of the frame before to use this method.

Exceptions
std::invalid_argumentIf gridIndices, cellIndices, localFacePairPerCellIndices or hdfProxy is nullptr.
std::logic_errorIf MD values of the frame have not been provided before using this method.
Parameters
gridIndicesAn array containing for each interval of the wellbore frame, the index of the grid it is associated to. The size of this array is the interval count of the wellbore frame representation. cellCount must equal the number of non- null entries in this array. The associated grids (and there indices) are defined using pushBackSupportingGridRepresentation() method.
gridIndicesNullValueThe null value used in gridIndices in order to indicate that an interval does not correspond to any intersected grid. Generally -1.
cellIndicesAn array containing the intersected cell index for each entry in gridIndices. The size of this array is the interval count of the wellbore frame representation. The null value will be set to gridIndicesNullValue which already informs about the presence or not of a cell.
localFacePairPerCellIndicesAn array containing, for each cell, the entry and exit intersection faces of the trajectory in the cell. The array dimension must equal 2 * intervalCount.
localFacePairPerCellIndicesNullValueThe null value used in localFacePerCellIndices in order to indicate that it corresponds to a missing intersection, e.g., when a trajectory originates or terminates within a cell.
[in,out]hdfProxyThe HDF proxy where the numerical values will be stored. If set to nullptr, the default HdfProxy will be used instead.

Member Data Documentation

◆ XML_TAG

constexpr char const* resqml2::BlockedWellboreRepresentation::XML_TAG = "BlockedWellboreRepresentation"
staticconstexpr

The standard XML tag without XML namespace for serializing this data object.


The documentation for this class was generated from the following file: