RSTT
3.2.0
Regional Seismic Travel Time
|
#include <GridGeoTess.h>
Public Member Functions | |
GridGeoTess () | |
virtual | ~GridGeoTess () |
Destructor. More... | |
GeoTessModelSLBM * | loadModel (const string &filename, const string &relGridPath="") |
void | clear () |
Clears and releases all memory held by this GridSLBM object. More... | |
void | loadFromFile (const string &filename) |
Load the depth, velocity and gradient information from an ascii flat file. More... | |
void | loadFromDirectory (const string &dirName) |
Load the depth, velocity and gradient information from binary files in specified directory. More... | |
void | loadFromDataBuffer (util::DataBuffer &buffer) |
Load the depth, velocity and gradient information from DataBuffer. More... | |
void | saveVelocityModel (const string &filename, const int &format) |
Save the Earth model currently in memory, to an ascii flat file. More... | |
void | saveVelocityModel (util::DataBuffer &buffer) |
Save the Earth model currently in memory, to a DataBuffer. More... | |
int | getBufferSize () const |
Returns the size of a DataBuffer object required to store this Grid objects model data. More... | |
double | getAverageMantleVelocity (const int &waveType) |
Retreive the average P or S wave velocity of the mantle, in km/sec. More... | |
void | setAverageMantleVelocity (const int &waveType, const double &velocity) |
Retreive the average P or S wave velocity of the mantle, in km/sec. More... | |
virtual bool | findProfile (Location &location, vector< GridProfile * > &neighbors, vector< int > &nodeIds, vector< double > &coefficients) |
Find the neighboring GridProfile objects and associated interpolation coefficients at a specified Location. More... | |
void | getNodeNeighbors (const int &nodeId, int neighbors[], int &nNeighbors) |
Retrieve the grid node id of the nodes that are direct neighbors of the specified grid node. More... | |
void | getNodeNeighbors (const int &nodeId, vector< int > &neighbors) |
Retrieve the grid node ids of the nodes that are direct neighbors of the specified grid node. More... | |
void | getActiveNodeNeighbors (const int &nodeid, int neighbors[], int &nNeighbors) |
void | getActiveNodeNeighbors (const int &nodeid, vector< int > &neighbors) |
void | getNodeNeighborInfo (const int &nodeid, int neighbors[], double distance[], double azimuth[], int &nNeighbors) |
Retrieve the grid node id of the nodes that are direct neighbors of the specified grid node. More... | |
void | getNodeNeighborInfo (const int &nodeid, vector< int > &neighbors, vector< double > &distance, vector< double > &azimuth) |
Retrieve the grid node id of the nodes that are direct neighbors of the specified grid node. More... | |
void | getNodeSeparation (const int &node1, const int &node2, double &distance) |
Retrieve the angular separation in radians between any pair of. More... | |
void | getNodeAzimuth (const int &node1, const int &node2, double &azimuth) |
Retrieve the azimuth in radians from one grid node to another. More... | |
size_t | memSize () |
string | getTessId () |
int | addGeoStack (GeoStack *geoStack) |
GeoTessModelSLBM * | getModel () |
string | toString () |
void | setInterpolatorType (const string &interpolatorType) |
string | getInterpolatorType () |
![]() | |
Grid () | |
Default constructor. More... | |
virtual | ~Grid () |
Destructor. More... | |
virtual bool | operator== (const Grid &other) |
Equality operator. More... | |
virtual bool | operator!= (const Grid &other) |
Inequality operator. More... | |
virtual bool | is_directory (const string &dir) |
virtual int | getNNodes () |
Retrieve the number of nodes in the model. More... | |
virtual int | getNIntervals () |
Retrieve the number of intervals in each Profile. More... | |
virtual GridProfile * | getProfile (const int &nodeId) |
Retrieve a pointer to the GridProfile that is node (i, j) in this Grid. More... | |
virtual GreatCircle * | getGreatCircle (const int &phase, const double &latSource, const double &lonSource, const double &depthSource, const double &latReceiver, const double &lonReceiver, const double &depthReceiver, const double &delta, const double &ch_max) |
Retrieve a GreatCircle object between a source and a receiver. More... | |
virtual CrustalProfile * | getReceiverProfile (const int &phase, const double &lat, const double &lon, const double &depth) |
Retrieve a CrustalProfile containing data appropriate for the specified phase at the specified location. More... | |
virtual CrustalProfile * | getSourceProfile (const int &phase, const double &lat, const double &lon, const double &depth) |
virtual void | clearCrustalProfiles () |
Delete all the CrustalProfile objects managed by this Grid. More... | |
virtual LayerProfile * | getLayerProfile (GreatCircle *greatCircle, Location &location) |
Retrieve a LayerProfile containing data appropriate for the specified GreatCircle, at the specified geographic latitude and longitude. More... | |
virtual QueryProfile * | getQueryProfile (Location &location) |
Retrieve a QueryProfile containing all available model information, at the latitude and longitude of the specified Location. More... | |
vector< vector< UncertaintyPIU * > > & | getUncertainty () |
vector< vector< UncertaintyPIU * > > & | getUncertaintyPIU () |
UncertaintyPIU & | getUncertaintyPIU (int phase, int attribute) |
vector< UncertaintyPDU * > & | getUncertaintyPDU () |
UncertaintyPDU & | getUncertaintyPDU (int phase) |
virtual int | getNCrustalProfiles () |
void | initializeActiveNodes (double activeNodeLatMin, double activeNodeLonMin, double activeNodeLatMax, double activeNodeLonMax) |
Specify the latitude, longitude range in radians that will define which grid nodes are also active nodes. More... | |
void | initializeActiveNodes (GeoTessPolygon *polygon) |
Specify the Polygon that will define which grid nodes are also active nodes. More... | |
virtual int | getNActiveNodes () |
Retrieve the number of active nodes. More... | |
void | clearActiveNodes () |
virtual int | getGridNodeId (int activeNodeId) |
Retrieve the grid node id that corresponds to a specified active node id. More... | |
virtual int | getActiveNodeId (int nodeId) |
Retrieve the grid node id that corresponds to a specified active node id. More... | |
virtual void | getActiveNodeNeighborInfo (const int &nid, int neighbors[], double distance[], double azimuth[], int &nNeighbors) |
virtual void | getActiveNodeNeighborInfo (const int &nid, vector< int > &neighbors, vector< double > &distance, vector< double > &azimuth) |
virtual void | getNodeHitCount (const int &nodeId, int &hitCount) |
virtual void | clearNodeHitCount () |
virtual size_t | memSizeCrustalProfiles () |
string & | getModelPath () |
const string | getOutputDirectory () |
void | specifyOutputDirectory (const string &outputDir) |
Static Public Member Functions | |
static string | class_name () |
![]() | |
static Grid * | getGrid (const string &modelDirectory) |
static Grid * | getGrid (util::DataBuffer &buffer) |
static bool | fileExists (const string &fileName) |
static string | class_name () |
Additional Inherited Members | |
![]() | |
void | writeBufferToFile (util::DataBuffer &buffer, string fileName) |
void | reaDataBuffererFromFile (util::DataBuffer &buffer, string dirname, string fileName) |
![]() | |
string | modelPath |
The name of the file or directory from which the velocity model was loaded. More... | |
vector< GridProfile * > | profiles |
The GridProfile objects which constitute the nodes in a Grid object. More... | |
vector< int > | activeNodes |
GeoTessModelSLBM * | model |
GeoTessPolygon * | polygon |
CrustalProfileStore * | sources |
CrustalProfileStore * | receivers |
vector< vector< UncertaintyPIU * > > | piu |
vector< UncertaintyPDU * > | pdu |
Definition at line 60 of file GridGeoTess.h.
slbm::GridGeoTess::GridGeoTess | ( | ) |
|
virtual |
Destructor.
Destructor.
|
inlinevirtual |
Reimplemented from slbm::Grid.
Definition at line 270 of file GridGeoTess.h.
|
inlinestatic |
Returns the class name.
Definition at line 74 of file GridGeoTess.h.
|
virtual |
Clears and releases all memory held by this GridSLBM object.
Clears and releases all memory held by this GridSLBM object.
Reimplemented from slbm::Grid.
|
virtual |
Find the neighboring GridProfile objects and associated interpolation coefficients at a specified Location.
Given a Location, find the GridProfile objects that surround the Location and compute the interpolation coefficient for each of those surrounding GridProfile objects. Interpolated values will equal the sum of the values at the GridProfile objects times the corresponding interpolation coefficient.
This method is called by getCrustalProfile() and getMantleProfile() to compute InterpolatedProfile objects.
location | the Location of the desired profile. |
neighbors | the GridProfile objects which surround the specified Location. |
nodeIds | the node indices of the neighbors |
coefficients | the interpolation coefficient corresponding to each neighbor. |
Reimplemented from slbm::Grid.
|
inlinevirtual |
Reimplemented from slbm::Grid.
Definition at line 340 of file GridGeoTess.h.
|
inlinevirtual |
Reimplemented from slbm::Grid.
Definition at line 361 of file GridGeoTess.h.
|
inlinevirtual |
Retreive the average P or S wave velocity of the mantle, in km/sec.
Retreive the average P or S wave velocity of the mantle. These values are retrieved from the header information in the velocity model file.
waveType | either SLBMGlobals::PWAVE or SLBMGlobals::SWAVE. |
Reimplemented from slbm::Grid.
Definition at line 126 of file GridGeoTess.h.
|
inlinevirtual |
Returns the size of a DataBuffer object required to store this Grid objects model data.
Returns the size of a DataBuffer object required to store this Grid objects model data.
Reimplemented from slbm::Grid.
Definition at line 118 of file GridGeoTess.h.
|
inlinevirtual |
Reimplemented from slbm::Grid.
Definition at line 279 of file GridGeoTess.h.
|
inlinevirtual |
Reimplemented from slbm::Grid.
Definition at line 273 of file GridGeoTess.h.
|
inlinevirtual |
Retrieve the azimuth in radians from one grid node to another.
Retrieve the azimuth in radians from one grid node to another.
Reimplemented from slbm::Grid.
Definition at line 387 of file GridGeoTess.h.
|
inlinevirtual |
Retrieve the grid node id of the nodes that are direct neighbors of the specified grid node.
Retrieve the grid node id of the nodes that are direct neighbors of the specified grid node. Also returns the angular distance and azimuth from the specified grid node to each of its neighbors. Distances and azimuths are in radians.
Reimplemented from slbm::Grid.
Definition at line 200 of file GridGeoTess.h.
|
inlinevirtual |
Retrieve the grid node id of the nodes that are direct neighbors of the specified grid node.
Retrieve the grid node id of the nodes that are direct neighbors of the specified grid node. Also returns the angular distance and azimuth from the specified grid node to each of its neighbors. Distances and azimuths are in radians.
Reimplemented from slbm::Grid.
Definition at line 225 of file GridGeoTess.h.
|
inlinevirtual |
Retrieve the grid node id of the nodes that are direct neighbors of the specified grid node.
Retrieve the grid node id of the nodes that are direct neighbors of the specified grid node.
Reimplemented from slbm::Grid.
Definition at line 316 of file GridGeoTess.h.
|
inlinevirtual |
Retrieve the grid node ids of the nodes that are direct neighbors of the specified grid node.
Retrieve the grid node ids of the nodes that are direct neighbors of the specified grid node.
Reimplemented from slbm::Grid.
Definition at line 328 of file GridGeoTess.h.
|
inlinevirtual |
Retrieve the angular separation in radians between any pair of.
Retrieve the angular separation in radians between any pair of
Reimplemented from slbm::Grid.
Definition at line 381 of file GridGeoTess.h.
|
inlinevirtual |
Reimplemented from slbm::Grid.
Definition at line 268 of file GridGeoTess.h.
|
virtual |
Load the depth, velocity and gradient information from DataBuffer.
Load the Earth model information from DataBuffer
buffer | the DataBuffer from which to load the model |
Reimplemented from slbm::Grid.
|
virtual |
Load the depth, velocity and gradient information from binary files in specified directory.
Load the Earth model information from binary files in specified directory
dirName | the name of directory from which to load the model |
Reimplemented from slbm::Grid.
|
virtual |
Load the depth, velocity and gradient information from an ascii flat file.
Load the Earth model information from an ascii flat file.
filename | the name of the ascii flat file containing the data. |
Reimplemented from slbm::Grid.
GeoTessModelSLBM* slbm::GridGeoTess::loadModel | ( | const string & | filename, |
const string & | relGridPath = "" |
||
) |
|
virtual |
Reimplemented from slbm::Grid.
|
virtual |
Save the Earth model currently in memory, to an ascii flat file.
Save the Earth model currently in memory, to an ascii flat file. An exception will be thrown if the speficied filename is the same as the name of the file from which the Earth model was originally loaded with loadVelocityModel()
Reimplemented from slbm::Grid.
|
virtual |
Save the Earth model currently in memory, to a DataBuffer.
Save the Earth model currently in memory, to to a DataBuffer.
buffer | the DataBuffer to which to save the model |
Reimplemented from slbm::Grid.
|
inlinevirtual |
Retreive the average P or S wave velocity of the mantle, in km/sec.
Retreive the average P or S wave velocity of the mantle. These values are retrieved from the header information in the velocity model file.
waveType | either SLBMGlobals::PWAVE or SLBMGlobals::SWAVE. |
velocity | (output) the average P or S wave mantle velocity, in km/sec. |
Reimplemented from slbm::Grid.
Definition at line 135 of file GridGeoTess.h.
|
inlinevirtual |
Reimplemented from slbm::Grid.
Definition at line 289 of file GridGeoTess.h.
|
virtual |
Reimplemented from slbm::Grid.