version
0.0.1
Defines the C++ API for MsPASS
|
Implemntation of TimeSeries for MsPASS. More...
#include <TimeSeries.h>
Public Member Functions | |
TimeSeries () | |
TimeSeries (const size_t nsamples) | |
TimeSeries (const BasicTimeSeries &bts, const Metadata &md) | |
TimeSeries (const Metadata &md) | |
TimeSeries (const mspass::seismic::CoreTimeSeries &d) | |
Construct from lower level CoreTimeSeries. | |
TimeSeries (const mspass::seismic::CoreTimeSeries &d, const std::string alg) | |
TimeSeries (const mspass::seismic::BasicTimeSeries &b, const mspass::utility::Metadata &m, const mspass::utility::ProcessingHistory &mcts, const std::vector< double > &d) | |
TimeSeries (const TimeSeries &parent) | |
TimeSeries & | operator= (const TimeSeries &parent) |
TimeSeries & | operator+= (const TimeSeries &d) |
TimeSeries & | operator*= (const double scale) |
TimeSeries & | operator-= (const TimeSeries &d) |
void | load_history (const mspass::utility::ProcessingHistory &h) |
size_t | memory_use () const |
Public Member Functions inherited from mspass::seismic::CoreTimeSeries | |
CoreTimeSeries () | |
CoreTimeSeries (const size_t nsin) | |
CoreTimeSeries (const BasicTimeSeries &bts, const Metadata &md) | |
CoreTimeSeries (const CoreTimeSeries &) | |
void | set_dt (const double sample_interval) |
Set the sample interval. | |
void | set_npts (const size_t npts) |
Set the number of samples attribute for data. | |
void | sync_npts () |
Sync the number of samples attribute with actual data size. | |
void | set_t0 (const double t0in) |
Set the data start time. | |
CoreTimeSeries & | operator= (const CoreTimeSeries &parent) |
CoreTimeSeries & | operator+= (const CoreTimeSeries &d) |
Summation operator. | |
const CoreTimeSeries | operator+ (const CoreTimeSeries &other) const |
CoreTimeSeries & | operator*= (const double) |
CoreTimeSeries & | operator-= (const CoreTimeSeries &d) |
Subtraction operator. | |
const CoreTimeSeries | operator- (const CoreTimeSeries &other) const |
double | operator[] (size_t const sample) const |
Public Member Functions inherited from mspass::seismic::BasicTimeSeries | |
BasicTimeSeries () | |
BasicTimeSeries (const BasicTimeSeries &) | |
virtual | ~BasicTimeSeries () |
Virtual destructor. | |
double | time (const int i) const |
int | sample_number (double t) const |
double | endtime () const noexcept |
bool | shifted () const |
double | get_t0shift () const |
double | time_reference () const |
void | force_t0_shift (const double t) |
Force a t0 shift value on data. | |
virtual void | ator (const double tshift) |
virtual void | rtoa () |
virtual void | shift (const double dt) |
bool | live () const |
bool | dead () const |
void | kill () |
void | set_live () |
double | dt () const |
bool | time_is_UTC () const |
bool | time_is_relative () const |
TimeReferenceType | timetype () const |
double | samprate () const |
size_t | npts () const |
double | t0 () const |
std::vector< double > | time_axis () const |
void | set_tref (const TimeReferenceType newtref) |
Force the time standard. | |
BasicTimeSeries & | operator= (const BasicTimeSeries &parent) |
Public Member Functions inherited from mspass::utility::Metadata | |
Metadata () | |
Metadata (std::ifstream &ifs, const std::string form=std::string("pf")) | |
Metadata (const Metadata &mdold) | |
virtual | ~Metadata () |
Metadata & | operator= (const Metadata &mdold) |
Metadata & | operator+= (const Metadata &rhs) noexcept |
const Metadata | operator+ (const Metadata &other) const |
double | get_double (const std::string key) const override |
int | get_int (const std::string key) const override |
long | get_long (const std::string key) const |
std::string | get_string (const std::string key) const override |
bool | get_bool (const std::string key) const override |
template<typename T > | |
T | get (const std::string key) const |
template<typename T > | |
T | get (const char *key) const |
Generic get interface for C char array. | |
boost::any | get_any (const std::string key) const |
std::string | type (const std::string key) const |
template<typename T > | |
void | put (const std::string key, T val) noexcept |
template<typename T > | |
void | put (const char *key, T val) noexcept |
void | put (const std::string key, const double val) override |
void | put (const std::string key, const int val) override |
void | put (const std::string key, const bool val) override |
void | put (const std::string key, const std::string val) override |
void | put (const char *key, const char *val) |
void | put (std::string key, const char *val) |
void | put_object (const std::string key, const pybind11::object val) |
void | put_int (const std::string key, const int val) |
void | put_string (const std::string key, const std::string val) |
void | put_bool (const std::string key, const bool val) |
void | put_double (const std::string key, const double val) |
void | put_long (const std::string key, const long val) |
void | append_chain (const std::string key, const std::string val, const std::string separator=std::string(":")) |
std::set< std::string > | modified () const |
void | clear_modified () |
Mark all data as unmodified. | |
std::set< std::string > | keys () const noexcept |
bool | is_defined (const std::string key) const noexcept |
void | erase (const std::string key) |
std::size_t | size () const noexcept |
std::map< std::string, boost::any >::const_iterator | begin () const noexcept |
std::map< std::string, boost::any >::const_iterator | end () const noexcept |
void | change_key (const std::string oldkey, const std::string newkey) |
Change the keyword to access an attribute. | |
Public Member Functions inherited from mspass::utility::ProcessingHistory | |
ProcessingHistory () | |
ProcessingHistory (const std::string jobnm, const std::string jid) | |
ProcessingHistory (const ProcessingHistory &parent) | |
bool | is_empty () const |
bool | is_raw () const |
bool | is_origin () const |
bool | is_volatile () const |
bool | is_saved () const |
size_t | number_of_stages () override |
Return number of processing stages that have been applied to this object. | |
void | set_as_origin (const std::string alg, const std::string algid, const std::string uuid, const AtomicType typ, bool define_as_raw=false) |
std::string | new_ensemble_process (const std::string alg, const std::string algid, const AtomicType typ, const std::vector< ProcessingHistory * > parents, const bool create_newid=true) |
void | add_one_input (const ProcessingHistory &data_to_add) |
Add one datum as an input for current data. | |
void | add_many_inputs (const std::vector< ProcessingHistory * > &d) |
Define several data objects as inputs. | |
void | merge (const ProcessingHistory &data_to_add) |
Merge the history nodes from another. | |
void | accumulate (const std::string alg, const std::string algid, const AtomicType typ, const ProcessingHistory &newinput) |
Method to use with a spark reduce algorithm. | |
std::string | clean_accumulate_uuids () |
Clean up inconsistent uuids that can be produced by reduce. | |
std::string | new_map (const std::string alg, const std::string algid, const AtomicType typ, const ProcessingStatus newstatus=ProcessingStatus::VOLATILE) |
Define this algorithm as a one-to-one map of same type data. | |
std::string | new_map (const std::string alg, const std::string algid, const AtomicType typ, const ProcessingHistory &data_to_clone, const ProcessingStatus newstatus=ProcessingStatus::VOLATILE) |
Define this algorithm as a one-to-one map. | |
std::string | map_as_saved (const std::string alg, const std::string algid, const AtomicType typ) |
Prepare the current data for saving. | |
void | clear () |
std::multimap< std::string, mspass::utility::NodeData > | get_nodes () const |
int | stage () const |
ProcessingStatus | status () const |
std::string | id () const |
std::pair< std::string, std::string > | created_by () const |
NodeData | current_nodedata () const |
std::string | newid () |
int | number_inputs () const |
int | number_inputs (const std::string uuidstr) const |
void | set_id (const std::string newid) |
std::list< mspass::utility::NodeData > | inputs (const std::string id_to_find) const |
Return a list of data that define the inputs to a give uuids. | |
ProcessingHistory & | operator= (const ProcessingHistory &parent) |
Public Member Functions inherited from mspass::utility::BasicProcessingHistory | |
BasicProcessingHistory (const std::string jobname, const std::string jobid) | |
BasicProcessingHistory (const BasicProcessingHistory &parent) | |
std::string | jobid () const |
void | set_jobid (const std::string &newjid) |
std::string | jobname () const |
void | set_jobname (const std::string jobname) |
BasicProcessingHistory & | operator= (const BasicProcessingHistory &parent) |
Additional Inherited Members | |
Public Attributes inherited from mspass::seismic::CoreTimeSeries | |
std::vector< double > | s |
Public Attributes inherited from mspass::utility::ProcessingHistory | |
ErrorLogger | elog |
Protected Attributes inherited from mspass::seismic::BasicTimeSeries | |
bool | mlive |
double | mdt |
double | mt0 |
size_t | nsamp |
TimeReferenceType | tref |
bool | t0shift_is_valid |
double | t0shift |
Protected Attributes inherited from mspass::utility::Metadata | |
std::map< std::string, boost::any > | md |
std::set< std::string > | changed_or_set |
Protected Attributes inherited from mspass::utility::ProcessingHistory | |
std::multimap< std::string, mspass::utility::NodeData > | nodes |
Protected Attributes inherited from mspass::utility::BasicProcessingHistory | |
std::string | jid |
std::string | jnm |
Implemntation of TimeSeries for MsPASS.
This is the working version of a three-component TimeSeries object used in the MsPASS framework. It extends CoreTimeSeries by adding common MsPASS components (ProcessingHistory). It may evolve with additional special features.
|
inline |
Default constructor. Only runs subclass default constructors.
Bare bones constructor allocates space and little else.
Sometimes it is helpful to construct a skeleton that can be fleshed out manually. This constructor allocates an nsamples vector and initializes it to all zeros. The data are marked dead because the assumption is the caller will fill out commonly needed basic Metadata, load some kind of sample data into the data vector, and then call the set_live method when that process is completed. That kind of manipulation is most common in preparing simulation or test data where the common tags on real data do not exist and need to be defined manually for the simulatioon or test. The history section is initialized with the default constructor, which currently means it is empty. If a simulation or test requires a history origin the user must load it manaually.
nsamples | is the number of samples needed for storing the data vector. |
|
inline |
Partially construct from components.
There are times one wants to use the Metadata area as a template to flesh out a CoreTimeSeries as what might be called skin and bones: skin is Metadata and bones as BasicTimeSeries data. This constructor initializes those two base classes but does not fully a valid data vector. It only attempts to fetch the number of points expected for the data vector using the npts metadata (integer) key (i.e. it sets npts to md.get_int("npts")). It then creates the data vector of that length and initialzies it to all zeros.
This constructor is largely a wrapper for the CoreTimeSeries version with the same signature but it also initalizes the ProcessingHistory to null (calling the default constructor)
Partially construct from Metadata alone.
This constructor is useful for interaction with MongoDB where the Metadata container is constructed directly from MongoDB documents the database uses for storage. A key restrition of this constructor is that BasicTimeSeries attributes and the size of the internal array buffer, which is set by npts, are extracted from Metadata with keys fixed in the C++ code. The following keys are required or this contructor will throw a MwPASSWrror:
dt - sample sample_interval t0 - data startttime npts - number of samples (s array will be initialized to this many zeros) time_standard - UTC or Relative (anything but UTC is taken as relative)
It will also handle but not require the two attributes used in the mspass schema to handle shifting from absolute to relative time. These keys are t0_shift - sets amount t0 has been shiftee when originally utc but set to relative with the shift method. Ignored if time is UTC or it is not defined.
References mspass::seismic::BasicTimeSeries::force_t0_shift(), mspass::utility::Metadata::get(), mspass::utility::Metadata::get_double(), mspass::utility::Metadata::get_long(), mspass::utility::Metadata::get_string(), mspass::utility::Metadata::is_defined(), mspass::utility::ErrorLogger::log_error(), mspass::seismic::BasicTimeSeries::mdt, mspass::seismic::BasicTimeSeries::mlive, mspass::seismic::BasicTimeSeries::mt0, mspass::utility::Metadata::operator=(), mspass::seismic::Relative, mspass::seismic::SEISMICMD_dt(), mspass::seismic::SEISMICMD_npts(), mspass::seismic::SEISMICMD_t0(), mspass::seismic::SEISMICMD_t0_shift(), mspass::seismic::SEISMICMD_time_standard(), mspass::seismic::CoreTimeSeries::set_npts(), mspass::seismic::BasicTimeSeries::set_tref(), and mspass::seismic::UTC.
|
inline |
Construct from lower level CoreTimeSeries.
In MsPASS CoreTimeSeries has the primary functions that define the concept of a a single channel seismogram. TimeSeries implements mspass specific features needed to mesh with the mspass processing system. This constructor clones only the CoreTimeSeries components and initializes the ProcessingHistory with the default constructor leaving the history in an empty state. Users should call methods in ProcessingHistory to initiate a valid history chain. Processing can continue if left in that state, but the history chain will have an undefined origin. Job information will also be lost if not initialized (see BasicProcessingHistory)
d | is the data to be copied to create the new TimeSeries object. Note that means a deep copy wherein the data vector is copied. |
mspass::seismic::TimeSeries::TimeSeries | ( | const mspass::seismic::CoreTimeSeries & | d, |
const std::string | alg | ||
) |
Contruct from a core time series and initialize history as origin.
This constructor is a variant of a similar one built only from a CoreTimeSeries. This constuctor is intended to be used mainly on simulation data created by some mechanism (e.g. a python procedure). It is more rigid that the simple one arg constructor as it will create a top level history record. The record will mark the result as an origin with an id set as a uuid created by a random number generator (boost implementation). The jobname and jobid are frozen as "test". Use a different constructor and/or reset job info if more flexibility is desired. Use of this constructor is recommended only for test python programs that do not need to interact with MongoDB.
is | core data to be cloned |
alg | is the algorithm name to set for the origin history record. |
References mspass::utility::ProcessingHistory::newid(), and mspass::utility::ProcessingHistory::set_as_origin().
mspass::seismic::TimeSeries::TimeSeries | ( | const mspass::seismic::BasicTimeSeries & | b, |
const mspass::utility::Metadata & | m, | ||
const mspass::utility::ProcessingHistory & | mcts, | ||
const std::vector< double > & | d | ||
) |
Special constructor for pickle interface.
The pickle interface required by spark presented problems for MsPASS. The complicated data objects of TimeSeries and TimeSeries have to be serialized in pieces. This constructor is only used in the function called indirectly by pickle.load. It essentially contains a TimeSeries dismembered into the pieces that can be the serialized independently. The parameters are each associated with one of those required pieces and are simply copied to build a valid TimeSeries object in the pickle.load function
|
inline |
Standard copy constructor.
void mspass::seismic::TimeSeries::load_history | ( | const mspass::utility::ProcessingHistory & | h | ) |
size_t mspass::seismic::TimeSeries::memory_use | ( | ) | const |
Return an estimate of the memmory use by the data in this object.
Memory consumed by a TimeSeries object is needed to implement the sizeof method in python that dask/spark use to manage memory. Without that feature we had memory fault issues. Note the estimate this method returns should not be expected to be exact. The MsPASS implementation or any alternative implementation avoids an exact calculation because it requries an (expensive) traversal of multiple map containers.
References mspass::utility::Metadata::get(), mspass::seismic::BasicTimeSeries::npts(), and TimeSeries().
|
inline |
|
inline |
|
inline |
TimeSeries & mspass::seismic::TimeSeries::operator= | ( | const TimeSeries & | parent | ) |
Standard assignment operator.
References mspass::utility::Metadata::get(), mspass::seismic::CoreTimeSeries::operator=(), and mspass::utility::ProcessingHistory::operator=().