GeoTessCPP  2.1
Software to facilitate storage and retrieval of 3D information about the Earth.
 All Classes Namespaces Files Functions Variables Typedefs Friends Macros
Public Member Functions | Static Public Member Functions | List of all members
geotess::GeoTessProfileEmpty Class Reference

#include <GeoTessProfileEmpty.h>

Inheritance diagram for geotess::GeoTessProfileEmpty:
geotess::GeoTessProfile

Public Member Functions

 GeoTessProfileEmpty (float radBot, float radTop)
 
 GeoTessProfileEmpty (IFStreamBinary &ifs)
 
 GeoTessProfileEmpty (IFStreamAscii &ifs)
 
 GeoTessProfileEmpty (float radii[], int &rIndex)
 
virtual ~GeoTessProfileEmpty ()
 
virtual int class_size () const
 
virtual GeoTessProfilecopy ()
 
virtual int findClosestRadiusIndex (double radius) const
 
virtual void getCoefficients (map< int, double > &coefficients, double radius, double horizontalCoefficient) const
 
virtual GeoTessData ** getData ()
 
virtual GeoTessDatagetData (int i)
 
virtual const GeoTessDatagetData (int i) const
 
virtual const GeoTessDatagetDataBottom () const
 
virtual GeoTessDatagetDataBottom ()
 
virtual const GeoTessDatagetDataTop () const
 
virtual GeoTessDatagetDataTop ()
 
virtual int getNData () const
 
virtual int getNRadii () const
 
virtual int getPointIndex (int nodeIndex) const
 
virtual float * getRadii ()
 
virtual float getRadius (int i) const
 
virtual float getRadiusBottom () const
 
virtual float getRadiusTop () const
 
virtual const GeoTessProfileTypegetType () const
 
virtual double getValue (const GeoTessInterpolatorType &rInterpType, int attributeIndex, double radius, bool allowRadiusOutOfRange) const
 
virtual double getValue (int attributeIndex, int nodeIndex) const
 
virtual double getValueBottom (int attributeIndex) const
 
virtual double getValueTop (int attributeIndex) const
 
virtual void getWeights (map< int, double > &weights, double dkm, double radius, double hcoefficient) const
 
virtual bool isNaN (int nodeIndex, int attributeIndex)
 
virtual bool operator== (const GeoTessProfile &p) const
 
virtual void resetPointIndices ()
 
virtual void setData (const vector< GeoTessData * > &inData)
 
virtual void setData (int index, GeoTessData *inData)
 
virtual void setInterpolationCoefficients (const GeoTessInterpolatorType &interpType, vector< int > &nodeIndexes, vector< double > &coefficients, double &radius, bool &allowOutOfRange)
 
virtual void setPointIndex (int nodeIndex, int pointIndex)
 
virtual void setRadii (const vector< float > &newRadii)
 
virtual void setRadius (int index, float radius)
 
virtual void write (IFStreamBinary &ofs)
 
virtual void write (IFStreamAscii &ofs)
 
- Public Member Functions inherited from geotess::GeoTessProfile
virtual double getInterpolationCoefficient (int i, double radius, bool allowOutOfRange) const
 
int getRadiusIndex (double radius) const
 
virtual int getRadiusIndex (double radius, int jlo) const
 
double getThickness ()
 
double getValue (const vector< int > &nodeIds, const vector< double > &coefficients, int attributeIndex) const
 

Static Public Member Functions

static string class_name ()
 
- Static Public Member Functions inherited from geotess::GeoTessProfile
static int class_count ()
 
static string class_name ()
 
static GeoTessProfilenewProfile (const vector< float > &radii, vector< GeoTessData * > &data)
 
static GeoTessProfilenewProfile (const vector< float > &radii, vector< vector< double > > &data)
 
static GeoTessProfilenewProfile (const vector< float > &radii, vector< vector< float > > &data)
 
static GeoTessProfilenewProfile (const vector< float > &radii, vector< vector< LONG_INT > > &data)
 
static GeoTessProfilenewProfile (const vector< float > &radii, vector< vector< int > > &data)
 
static GeoTessProfilenewProfile (const vector< float > &radii, vector< vector< short > > &data)
 
static GeoTessProfilenewProfile (const vector< float > &radii, vector< vector< byte > > &data)
 
static GeoTessProfilenewProfile (float *radii, const int &nRadii, GeoTessData **data, const int &nData)
 
static GeoTessProfilenewProfile (float *radii, const int &nRadii, double **values, const int &nNodes, const int &nAttributes)
 
static GeoTessProfilenewProfile (float *radii, const int &nRadii, float **values, const int &nNodes, const int &nAttributes)
 
static GeoTessProfilenewProfile (float *radii, const int &nRadii, LONG_INT **values, const int &nNodes, const int &nAttributes)
 
static GeoTessProfilenewProfile (float *radii, const int &nRadii, int **values, const int &nNodes, const int &nAttributes)
 
static GeoTessProfilenewProfile (float *radii, const int &nRadii, short **values, const int &nNodes, const int &nAttributes)
 
static GeoTessProfilenewProfile (float *radii, const int &nRadii, byte **values, const int &nNodes, const int &nAttributes)
 

Detailed Description

A Profile object that defines two radii, one at the bottom and other at the top of the associated layer, and no Data. Profiles of this type should never be connected together by the connectivity of a tessellation.

Constructor & Destructor Documentation

geotess::GeoTessProfileEmpty::GeoTessProfileEmpty ( float  radBot,
float  radTop 
)
inline

Default constructor.

geotess::GeoTessProfileEmpty::GeoTessProfileEmpty ( IFStreamBinary ifs)
inline

Standard constructor. Reads radii from the provided input file stream.

geotess::GeoTessProfileEmpty::GeoTessProfileEmpty ( IFStreamAscii ifs)
inline

Standard constructor. Reads radii from the provided input file stream.

geotess::GeoTessProfileEmpty::GeoTessProfileEmpty ( float  radii[],
int &  rIndex 
)
inline

Standard constructor creates references into the supplied array of radii.

virtual geotess::GeoTessProfileEmpty::~GeoTessProfileEmpty ( )
inlinevirtual

Default destructor.

Member Function Documentation

static string geotess::GeoTessProfileEmpty::class_name ( )
inlinestatic

Returns the class name.

virtual int geotess::GeoTessProfileEmpty::class_size ( ) const
inlinevirtual

Returns the class size.

Reimplemented from geotess::GeoTessProfile.

virtual GeoTessProfile* geotess::GeoTessProfileEmpty::copy ( )
inlinevirtual

Returns a deep copy of this profile.

virtual int geotess::GeoTessProfileEmpty::findClosestRadiusIndex ( double  radius) const
inlinevirtual

Find the index of the node in this Profile that has radius closest to the supplied radius.

Parameters
radiusin km
Returns
The index of the node in this Profile that has radius closest to the supplied radius.

Reimplemented from geotess::GeoTessProfile.

virtual void geotess::GeoTessProfileEmpty::getCoefficients ( map< int, double > &  coefficients,
double  radius,
double  horizontalCoefficient 
) const
inlinevirtual
virtual GeoTessData** geotess::GeoTessProfileEmpty::getData ( )
virtual

Retrieve a reference to all of the Data obects associated with this Profile.

Reimplemented from geotess::GeoTessProfile.

virtual GeoTessData* geotess::GeoTessProfileEmpty::getData ( int  i)
virtual

Retrieve a reference the i'th Data object

Reimplemented from geotess::GeoTessProfile.

virtual const GeoTessData& geotess::GeoTessProfileEmpty::getData ( int  i) const
virtual

Retrieve a reference the i'th Data object

Reimplemented from geotess::GeoTessProfile.

virtual const GeoTessData& geotess::GeoTessProfileEmpty::getDataBottom ( ) const
virtual

Get the Data object at the bottom of the profile.

Reimplemented from geotess::GeoTessProfile.

virtual GeoTessData* geotess::GeoTessProfileEmpty::getDataBottom ( )
inlinevirtual

Get the Data object at the bottom of the profile.

Reimplemented from geotess::GeoTessProfile.

virtual const GeoTessData& geotess::GeoTessProfileEmpty::getDataTop ( ) const
virtual

Get the Data object at the top of the profile.

Reimplemented from geotess::GeoTessProfile.

virtual GeoTessData* geotess::GeoTessProfileEmpty::getDataTop ( )
inlinevirtual

Get the Data object at the top of the profile.

Reimplemented from geotess::GeoTessProfile.

virtual int geotess::GeoTessProfileEmpty::getNData ( ) const
inlinevirtual

Get the number of Data objects that comprise this profile.

Reimplemented from geotess::GeoTessProfile.

virtual int geotess::GeoTessProfileEmpty::getNRadii ( ) const
inlinevirtual

Get the number of radii that comprise this profile.

Reimplemented from geotess::GeoTessProfile.

virtual int geotess::GeoTessProfileEmpty::getPointIndex ( int  nodeIndex) const
inlinevirtual

Get the pointIndex that corresponds to the supplied nodeIndex.

There is a node index for each Data object in a profile and they are indexed from 0 to the number of Data objects managed by a Profile. There is a pointIndex for every Data object in the entire model, indexed from 0 to the number of Data objects in the model.

Reimplemented from geotess::GeoTessProfile.

virtual float* geotess::GeoTessProfileEmpty::getRadii ( )
inlinevirtual

Retrieve a deeep copy of the radii values in km.

Reimplemented from geotess::GeoTessProfile.

virtual float geotess::GeoTessProfileEmpty::getRadius ( int  i) const
inlinevirtual

Get the i'th radius value in this profile in km. Radii are in order of increasing radius.

Reimplemented from geotess::GeoTessProfile.

virtual float geotess::GeoTessProfileEmpty::getRadiusBottom ( ) const
inlinevirtual

Get the radius at the bottom of the profile, in km.

Reimplemented from geotess::GeoTessProfile.

virtual float geotess::GeoTessProfileEmpty::getRadiusTop ( ) const
inlinevirtual

Get the radius at the top of the profile, in km.

Reimplemented from geotess::GeoTessProfile.

virtual const GeoTessProfileType& geotess::GeoTessProfileEmpty::getType ( ) const
inlinevirtual

Returns ProfileType (EMPTY).

Returns
ProfileType (EMPTY).

Reimplemented from geotess::GeoTessProfile.

virtual double geotess::GeoTessProfileEmpty::getValue ( const GeoTessInterpolatorType rInterpType,
int  attributeIndex,
double  radius,
bool  allowRadiusOutOfRange 
) const
virtual

Retrieve the value of the specified attribute interpolated at the specified radius. Unsuppported for ProfileEmpty.

Reimplemented from geotess::GeoTessProfile.

virtual double geotess::GeoTessProfileEmpty::getValue ( int  attributeIndex,
int  nodeIndex 
) const
inlinevirtual

Retrieve the value of the specified attribute interpolated from this profile at the specified radius index

Parameters
attributeIndex
nodeIndex
Returns
double

Reimplemented from geotess::GeoTessProfile.

virtual double geotess::GeoTessProfileEmpty::getValueBottom ( int  attributeIndex) const
inlinevirtual

Retrieve the value of the specified attribute at the bottom of the layer.

Parameters
attributeIndex
Returns
double

Reimplemented from geotess::GeoTessProfile.

virtual double geotess::GeoTessProfileEmpty::getValueTop ( int  attributeIndex) const
inlinevirtual

Retrieve the value of the specified attribute at the top of the layer.

Parameters
attributeIndex
Returns
double

Reimplemented from geotess::GeoTessProfile.

virtual void geotess::GeoTessProfileEmpty::getWeights ( map< int, double > &  weights,
double  dkm,
double  radius,
double  hcoefficient 
) const
inlinevirtual

Add dkm * hcoefficient to the weight of this point index into the input map. This works for Profile types Constant, Thin and Surface since they only have a single node in the profile. It does not work for ProfileNPoint and ProfileEmpty so they override this method.

virtual bool geotess::GeoTessProfileEmpty::isNaN ( int  nodeIndex,
int  attributeIndex 
)
inlinevirtual

Return true if the specified Data value is NaN. For doubles and floats, this means not NaN. For bytes, shorts, ints and longs, always returns false since there is no value that is NaN.

Parameters
nodeIndex
attributeIndex
Returns
true if the specified Data value is NaN.

Reimplemented from geotess::GeoTessProfile.

virtual bool geotess::GeoTessProfileEmpty::operator== ( const GeoTessProfile p) const
inlinevirtual

Return true if the input Profile object (p) equals this Profile object.

Reimplemented from geotess::GeoTessProfile.

virtual void geotess::GeoTessProfileEmpty::resetPointIndices ( )
inlinevirtual

Reset all the pointIndex values to -1.

There is a node index for each Data object in a profile and they are indexed from 0 to the number of Data objects managed by a Profile. There is a pointIndex for every Data object in the entire model, indexed from 0 to the number of Data objects in the model.

virtual void geotess::GeoTessProfileEmpty::setData ( const vector< GeoTessData * > &  inData)
inlinevirtual

Resets the data object to the new input data

Reimplemented from geotess::GeoTessProfile.

virtual void geotess::GeoTessProfileEmpty::setData ( int  index,
GeoTessData inData 
)
inlinevirtual

Resets the data object at index to the new input data.

Reimplemented from geotess::GeoTessProfile.

virtual void geotess::GeoTessProfileEmpty::setInterpolationCoefficients ( const GeoTessInterpolatorType interpType,
vector< int > &  nodeIndexes,
vector< double > &  coefficients,
double &  radius,
bool &  allowOutOfRange 
)
inlinevirtual
virtual void geotess::GeoTessProfileEmpty::setPointIndex ( int  nodeIndex,
int  pointIndex 
)
inlinevirtual

Set the pointIndex that corresponds to the supplied nodeIndex.

There is a node index for each Data object in a profile and they are indexed from 0 to the number of Data objects managed by a Profile. There is a pointIndex for every Data object in the entire model, indexed from 0 to the number of Data objects in the model.

virtual void geotess::GeoTessProfileEmpty::setRadii ( const vector< float > &  newRadii)
inlinevirtual

Replace the radii currently associated with this Profile with new values.

Reimplemented from geotess::GeoTessProfile.

virtual void geotess::GeoTessProfileEmpty::setRadius ( int  index,
float  radius 
)
inlinevirtual

Replace the radius at the specified nodeIndex.

Reimplemented from geotess::GeoTessProfile.

virtual void geotess::GeoTessProfileEmpty::write ( IFStreamBinary ofs)
inlinevirtual

Write the radii and data values to binary file.

virtual void geotess::GeoTessProfileEmpty::write ( IFStreamAscii ofs)
inlinevirtual

Write the radii and data values to binary file.


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