version  0.0.1
Defines the C++ API for MsPASS
Loading...
Searching...
No Matches
Public Member Functions | Public Attributes | List of all members
mspass::utility::NodeData Class Reference

Holds properties of data used as input to algorithm that created this object. More...

#include <ProcessingHistory.h>

Public Member Functions

 NodeData (const NodeData &parent)
 
NodeDataoperator= (const NodeData &parent)
 
bool operator== (const NodeData &other)
 
bool operator!= (const NodeData &other)
 

Public Attributes

mspass::utility::ProcessingStatus status
 
std::string uuid
 
mspass::utility::AtomicType type
 
int stage
 
std::string algorithm
 Name of algorithm algorithm applied at this stage.
 
std::string algid
 

Detailed Description

Holds properties of data used as input to algorithm that created this object.

The implementation here uses a multimap to define parents of each uuid in a history chain. This class is used mainly internally for ProcessingHistory to maintain that data. It will be visible to C++ programs but will not be visible in python. One of these entries is created for each parent data used to create the current data.

Constructor & Destructor Documentation

◆ NodeData() [1/2]

mspass::utility::NodeData::NodeData ( )
36 {
37 status = ProcessingStatus::UNDEFINED;
38 uuid = "UNDEFINED";
39 type = AtomicType::UNDEFINED;
40 stage = -1; // Invalid value could be used as a hint of uninitialized data
41}
std::string uuid
Definition ProcessingHistory.h:118
mspass::utility::ProcessingStatus status
Definition ProcessingHistory.h:116
int stage
Definition ProcessingHistory.h:123
mspass::utility::AtomicType type
Definition ProcessingHistory.h:120

◆ NodeData() [2/2]

mspass::utility::NodeData::NodeData ( const NodeData parent)
43 : uuid(parent.uuid), algorithm(parent.algorithm), algid(parent.algid) {
44 status = parent.status;
45 type = parent.type;
46 stage = parent.stage;
47}
std::string algorithm
Name of algorithm algorithm applied at this stage.
Definition ProcessingHistory.h:132
std::string algid
Definition ProcessingHistory.h:142

Member Function Documentation

◆ operator!=()

bool mspass::utility::NodeData::operator!= ( const NodeData other)
77{ return !((*this) == other); }

◆ operator=()

NodeData & mspass::utility::NodeData::operator= ( const NodeData parent)
48 {
49 if (&parent != this) {
50 status = parent.status;
51 type = parent.type;
52 stage = parent.stage;
53 uuid = parent.uuid;
54 algorithm = parent.algorithm;
55 algid = parent.algid;
56 }
57 return *this;
58}

◆ operator==()

bool mspass::utility::NodeData::operator== ( const NodeData other)
59 {
60 /* Not sure if this will generate the most compact code. Alternative
61 is a string of && conditionsals. The advantage here is these were
62 organized by a guess of which would most likely yield a false */
63 if ((this->algorithm) != (other.algorithm))
64 return false;
65 if ((this->uuid) != (other.uuid))
66 return false;
67 if ((this->status) != (other.status))
68 return false;
69 if ((this->type) != (other.type))
70 return false;
71 if ((this->stage) != (other.stage))
72 return false;
73 if ((this->algid) != (other.algid))
74 return false;
75 return true;
76}

Member Data Documentation

◆ algid

std::string mspass::utility::NodeData::algid

id string to identify this instance of algorithm.

Only assumption is that the combination of algorithm and id provide a unique specification of a particular instance of an algorithm. That means some algorithm and a particular set of control parameters that control the outcome of the algorithm. In MsPASS this is usually the ObjectID string of saved parameters in MongoDB, but users can use any method they wish to describe a unique combination of parameters and an algorithm implementation.

◆ algorithm

std::string mspass::utility::NodeData::algorithm

Name of algorithm algorithm applied at this stage.

We use the concept that every processing algorithm has a name keyword that togther with an id and/or instance defines a unique definition of the algorithm and a set of input parameters that define the algorithm's behavior. Note this is the algorithm that creates the uuid also stored in this struct (class)

◆ stage

int mspass::utility::NodeData::stage

Integer count of the number of processing steps applied to create this parent.

◆ status

mspass::utility::ProcessingStatus mspass::utility::NodeData::status

status definition of the parent.

◆ type

mspass::utility::AtomicType mspass::utility::NodeData::type

This enum can be used to track changes in data type.

◆ uuid

std::string mspass::utility::NodeData::uuid

uuid of the parent.


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