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::TriangulatedSetRepresentation Class Referenceabstract

A triangulated representation is a representation (most of time a surface) which is constituted by triangles. Usually all triangles are connected to each others by means of their nodes and edges. More...

#include <TriangulatedSetRepresentation.h>

Inheritance diagram for resqml2::TriangulatedSetRepresentation:
resqml2::AbstractSurfaceRepresentation resqml2::AbstractRepresentation

Public Member Functions

virtual ~TriangulatedSetRepresentation ()=default
 
virtual void pushBackTrianglePatch (unsigned int nodeCount, double const *nodes, unsigned int triangleCount, unsigned int const *triangleNodeIndices, eml2 ::AbstractHdfProxy *proxy=nullptr, resqml2 ::AbstractLocal3dCrs *localCrs=nullptr)=0
 
virtual uint64_t getTriangleCountOfPatch (unsigned int patchIndex) const =0
 
virtual uint64_t getTriangleCountOfAllPatches () const =0
 
virtual void getTriangleNodeIndicesOfPatch (unsigned int patchIndex, unsigned int *triangleNodeIndices) const =0
 
virtual void getTriangleNodeIndicesOfAllPatches (unsigned int *triangleNodeIndices) const =0
 
uint64_t getPatchCount () const override=0
 
virtual std::string getXmlTag () const final
 
- Public Member Functions inherited from resqml2::AbstractSurfaceRepresentation
virtual ~AbstractSurfaceRepresentation ()=default
 
unsigned int getBoundariesCount () const
 
common::DataObjectReference getOuterRingDor (unsigned int index) const
 
void pushBackOuterRing (PolylineRepresentation *outerRing)
 
void setSurfaceRole (gsoap_resqml2_0_1::resqml20__SurfaceRole surfaceRole)
 
gsoap_resqml2_0_1::resqml20__SurfaceRole getSurfaceRole () const
 
- Public Member Functions inherited from resqml2::AbstractRepresentation
virtual ~AbstractRepresentation ()=default
 
class AbstractLocal3dCrsgetLocalCrs (unsigned int patchIndex) const
 
virtual common::DataObjectReference getLocalCrsDor (unsigned int patchIndex) const
 
virtual common::DataObjectReference getHdfProxyDor () const =0
 Gets the data object reference of the HDF proxy which is used for storing the numerical values of this representation (i.e. its geometry).
 
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
 
virtual uint64_t getXyzPointCountOfPatch (unsigned int patchIndex) const =0
 
uint64_t getXyzPointCountOfAllPatches () const
 
virtual void getXyzPointsOfPatch (unsigned int patchIndex, double *xyzPoints) const =0
 Gets all the xyz points of a particular patch of this representation. xyz points are given in the local CRS.
 
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 = "TriangulatedSetRepresentation"
 
- Static Public Attributes inherited from resqml2::AbstractRepresentation
static constexpr char const * XML_TAG = "AbstractRepresentation"
 

Detailed Description

A triangulated representation is a representation (most of time a surface) which is constituted by triangles. Usually all triangles are connected to each others by means of their nodes and edges.

Constructor & Destructor Documentation

◆ ~TriangulatedSetRepresentation()

virtual resqml2::TriangulatedSetRepresentation::~TriangulatedSetRepresentation ( )
virtualdefault

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

Member Function Documentation

◆ getPatchCount()

uint64_t resqml2::TriangulatedSetRepresentation::getPatchCount ( ) const
overridepure virtual

Gets the patch count.

Returns
The patch count.

Implements resqml2::AbstractRepresentation.

◆ getTriangleCountOfAllPatches()

virtual uint64_t resqml2::TriangulatedSetRepresentation::getTriangleCountOfAllPatches ( ) const
pure virtual

Get the triangle count of all patches of this representation.

Returns
The triangle count of all patches.

◆ getTriangleCountOfPatch()

virtual uint64_t resqml2::TriangulatedSetRepresentation::getTriangleCountOfPatch ( unsigned int patchIndex) const
pure virtual

Gets the triangle count in a given patch of this representation.

Exceptions
std::out_of_rangeIf patchIndex >= getPatchCount().
Parameters
patchIndexA patch index.
Returns
The triangle count of the patch at position patchIndex.

◆ getTriangleNodeIndicesOfAllPatches()

virtual void resqml2::TriangulatedSetRepresentation::getTriangleNodeIndicesOfAllPatches ( unsigned int * triangleNodeIndices) const
pure virtual

Gets all the triangle node indices of all patches of this representation. See resqml2::AbstractRepresentation::getXyzPointsOfPatch method to read the xyz coordinates of the triangle nodes.

Parameters
[out]triangleNodeIndicesA preallocated array of size 3 * getTriangleCountOfAllPatches() to receive the triangle node indices. It is ordered first by nodes, then by triangles and then by patches.

◆ getTriangleNodeIndicesOfPatch()

virtual void resqml2::TriangulatedSetRepresentation::getTriangleNodeIndicesOfPatch ( unsigned int patchIndex,
unsigned int * triangleNodeIndices ) const
pure virtual

Gets all the triangle node indices of a particular patch of this representation. See resqml2::AbstractRepresentation::getXyzPointsOfPatch method to read the xyz coordinates of the triangle nodes.

Exceptions
std::out_of_rangeIf patchIndex >= getPatchCount().
Parameters
patchIndexThe index of the patch which contains the triangle node indices we want to get.
[out]triangleNodeIndicesA preallocated array of size 3 * getTriangleCountOfPatch(patchIndex) to receive the triangle node indices. The three first values give the 3 indices of the 3 vertices of the first triangle. The three following values define the 3 vertices of the second triangle and so on.

◆ pushBackTrianglePatch()

virtual void resqml2::TriangulatedSetRepresentation::pushBackTrianglePatch ( unsigned int nodeCount,
double const * nodes,
unsigned int triangleCount,
unsigned int const * triangleNodeIndices,
eml2 ::AbstractHdfProxy * proxy = nullptr,
resqml2 ::AbstractLocal3dCrs * localCrs = nullptr )
pure virtual

Pushes back a new patch of triangles.

Exceptions
std::invalid_argumentIf proxy == nullptr and no default HDF proxy is defined in the repository.
std::invalid_argumentIf localCrs == nullptr and no default local CRS id defined in the repository.
Parameters
nodeCountThe node count in this patch.
[in]nodesAn array of size 3 * nodeCount containing the xyz values of the nodes. It is ordered first by xyz and then by nodes.
triangleCountThe triangle count in this patch.
[in]triangleNodeIndicesAn array of size 3 * triangleCount containing the definition of the triangles of the triangulated topology by means of the indices of their vertices in the node list. The three first values give the 3 indices of the 3 vertices of the first triangle. The three following values define the 3 vertices of the second triangle and so on.
[in,out]proxy(Optional) The HDF proxy which defines where the nodes and triangle indices will be stored. If nullptr (default), then the repository default HDF proxy will be used.
[in]localCrs(Optional) The local CRS where the nodes are defined. If nullptr (default value), then the repository default local CRS will be used.

Member Data Documentation

◆ XML_TAG

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

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


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