version  0.0.1
Defines the C++ API for MsPASS
Loading...
Searching...
No Matches
Public Member Functions | List of all members
mspass::seismic::TimeSeriesWGaps Class Reference
Inheritance diagram for mspass::seismic::TimeSeriesWGaps:
mspass::seismic::TimeSeries mspass::seismic::DataGap mspass::seismic::CoreTimeSeries mspass::utility::ProcessingHistory mspass::seismic::BasicTimeSeries mspass::utility::Metadata mspass::utility::BasicProcessingHistory mspass::utility::BasicMetadata

Public Member Functions

 TimeSeriesWGaps ()
 Constructor.
 
 TimeSeriesWGaps (const TimeSeries &parent)
 
 TimeSeriesWGaps (const TimeSeriesWGaps &parent)
 
 TimeSeriesWGaps (const TimeSeries &tsp, const DataGap &dgp)
 
TimeSeriesWGapsoperator= (const TimeSeriesWGaps &parent)
 
void ator (const double tshift)
 
void rtoa (const double tshift)
 
void rtoa ()
 
void shift (const double dt)
 
void zero_gaps ()
 
size_t memory_use () const
 
- Public Member Functions inherited from mspass::seismic::TimeSeries
 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)
 
TimeSeriesoperator= (const TimeSeries &parent)
 
TimeSeriesoperator+= (const TimeSeries &d)
 
TimeSeriesoperator*= (const double scale)
 
TimeSeriesoperator-= (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.
 
CoreTimeSeriesoperator= (const CoreTimeSeries &parent)
 
CoreTimeSeriesoperator+= (const CoreTimeSeries &d)
 Summation operator.
 
const CoreTimeSeries operator+ (const CoreTimeSeries &other) const
 
CoreTimeSeriesoperator*= (const double)
 
CoreTimeSeriesoperator-= (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.
 
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.
 
BasicTimeSeriesoperator= (const BasicTimeSeries &parent)
 
- 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::NodeDataget_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::NodeDatainputs (const std::string id_to_find) const
 Return a list of data that define the inputs to a give uuids.
 
ProcessingHistoryoperator= (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)
 
BasicProcessingHistoryoperator= (const BasicProcessingHistory &parent)
 
- Public Member Functions inherited from mspass::seismic::DataGap
 DataGap ()
 
 DataGap (const std::list< mspass::algorithms::TimeWindow > &twlist)
 
 DataGap (const DataGap &parent)
 
bool is_gap (const double ttest)
 
bool has_gap (const mspass::algorithms::TimeWindow twin)
 
bool has_gap ()
 
void add_gap (const mspass::algorithms::TimeWindow tw)
 
std::list< mspass::algorithms::TimeWindowget_gaps () const
 
void clear_gaps ()
 Clear gaps.
 
int number_gaps () const
 
DataGap subset (const mspass::algorithms::TimeWindow tw) const
 
void translate_origin (double time_of_new_origin)
 
DataGapoperator= (const DataGap &parent)
 
DataGapoperator+= (const DataGap &other)
 

Additional Inherited Members

- Public Attributes inherited from mspass::seismic::CoreTimeSeries
std::vector< doubles
 
- 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::ProcessingHistory
std::multimap< std::string, mspass::utility::NodeDatanodes
 
- Protected Attributes inherited from mspass::utility::BasicProcessingHistory
std::string jid
 
std::string jnm
 
- Protected Attributes inherited from mspass::seismic::DataGap
std::set< mspass::algorithms::TimeWindow, mspass::algorithms::TimeWindowCmpgaps
 Holds data gap definitions. We use an STL set object to define data gaps for any time series object derived from this base class. The set is keyed by a TimeWindow which allows a simple, fast way to define a time range with invalid data.
 

Constructor & Destructor Documentation

◆ TimeSeriesWGaps() [1/4]

mspass::seismic::TimeSeriesWGaps::TimeSeriesWGaps ( )
inline

Constructor.

Will need a set of conastructors. Requires some thought as how to set gap is an issue.

12: TimeSeries(), DataGap() {};
DataGap()
Definition DataGap.h:27
TimeSeries()
Definition TimeSeries.h:17

◆ TimeSeriesWGaps() [2/4]

mspass::seismic::TimeSeriesWGaps::TimeSeriesWGaps ( const TimeSeries parent)
inline

Partial copy constructor from a plain TimeSeries.

Sometimes we need to build the skeleton of a gappy TimeSeries from a regular TimeSeries. This does that and builds makes a copy of the TimeSeries and creates an empty container that defines the gaps.

T get(const std::string key) const
Definition Metadata.h:445

◆ TimeSeriesWGaps() [3/4]

mspass::seismic::TimeSeriesWGaps::TimeSeriesWGaps ( const TimeSeriesWGaps parent)
inline

Copy constructor.

21 : TimeSeries(dynamic_cast<const TimeSeries &>(parent)),
22 DataGap(dynamic_cast<const DataGap &>(parent)) {};

◆ TimeSeriesWGaps() [4/4]

mspass::seismic::TimeSeriesWGaps::TimeSeriesWGaps ( const TimeSeries tsp,
const DataGap dgp 
)
inline
25 : TimeSeries(tsp), DataGap(dgp) {};

◆ ~TimeSeriesWGaps()

virtual mspass::seismic::TimeSeriesWGaps::~TimeSeriesWGaps ( )
inlinevirtual
27{};

Member Function Documentation

◆ ator()

void mspass::seismic::TimeSeriesWGaps::ator ( const double  tshift)
virtual

Absolute to relative time conversion. Sometimes we want to convert data from absolute time (epoch times) to a relative time standard. Examples are conversions to travel time using an event origin time or shifting to an arrival time reference frame. This operation simply switches the tref variable and alters t0 by tshift.

This method overrides the one in BasicTimeSeries to correctly reference gaps.

Parameters
tshift- time shift applied to data before switching data to relative time mode.

Reimplemented from mspass::seismic::BasicTimeSeries.

15 {
16 /* dead traces should to totally ignored */
17 if (this->dead())
18 return;
20 return;
21 this->t0shift = tshift;
22 this->mt0 -= tshift;
23 // We have to shift all the gap windows definitions
24 TimeWindow tw;
25 std::set<TimeWindow, TimeWindowCmp> shifted_gaps;
26 std::set<TimeWindow, TimeWindowCmp>::iterator this_gap;
27 for (this_gap = gaps.begin(); this_gap != gaps.end(); ++this_gap) {
28 tw.start = this_gap->start - tshift;
29 tw.end = this_gap->end - tshift;
30 shifted_gaps.insert(tw);
31 }
32 /* the section below is a replacement for the following simple
33 construct that worked in the old seispp library that used a
34 similar construct for gaps:
35 this->gaps = shifted_gaps;
36 Had to use the clear and loop below because g++ complained about operator=
37 not being defined for the set container. This loop is likely actually
38 faster than having to call operator= anyway but why this fails is unknown. */
39 this->gaps.clear();
40 for (this_gap = shifted_gaps.begin(); this_gap != shifted_gaps.end();
41 ++this_gap) {
42 this->gaps.insert(*this_gap);
43 }
45 this->t0shift_is_valid = true;
46}
bool dead() const
Definition BasicTimeSeries.h:145
TimeReferenceType tref
Definition BasicTimeSeries.h:265
double mt0
Definition BasicTimeSeries.h:251
std::set< mspass::algorithms::TimeWindow, mspass::algorithms::TimeWindowCmp > gaps
Holds data gap definitions. We use an STL set object to define data gaps for any time series object d...
Definition DataGap.h:110

References mspass::seismic::BasicTimeSeries::dead(), mspass::seismic::DataGap::gaps, mspass::utility::Metadata::get(), mspass::seismic::BasicTimeSeries::mt0, mspass::seismic::Relative, mspass::algorithms::TimeWindow::start, and mspass::seismic::BasicTimeSeries::tref.

◆ memory_use()

size_t mspass::seismic::TimeSeriesWGaps::memory_use ( ) const

Return an estimate of the memmory use by the data in this object.

Memory consumed by a TimeSeriesWGaps 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.

155 {
156 size_t memory_estimate;
158 memory_estimate += DATA_GAP_AVERAGE_SIZE * gaps.size();
159 return memory_estimate;
160}
size_t memory_use() const
Definition TimeSeries.cc:86

References mspass::seismic::DataGap::gaps, mspass::utility::Metadata::get(), and mspass::seismic::TimeSeries::memory_use().

◆ operator=()

148 {
149 if (this != (&parent)) {
151 this->gaps = parent.gaps;
152 }
153 return *this;
154}
TimeSeries & operator=(const TimeSeries &parent)
Definition TimeSeries.cc:76

◆ rtoa() [1/2]

void mspass::seismic::TimeSeriesWGaps::rtoa ( )
virtual

Relative to absolute time conversion. Sometimes we want to convert data from relative time to to an absolute time standard. An example would be converting segy shot data to something that could be processed like earthquake data in a css3.0 database.

This method returns data previously converted to relative back to absolute using the internally stored time shift attribute.

This method overrides the one in BasicTimeSeries to correctly reference gaps.

Reimplemented from mspass::seismic::BasicTimeSeries.

72 {
73 /* dead traces should to totally ignored */
74 if (this->dead())
75 return;
76 const std::string errormess(
77 "TimeSeriesWGaps::rtoa() t0shift for conversion is not defined.");
78 /* This perhaps should create a complaint message */
80 return;
81 /* A rather odd test for a nonzero. We use 100 s assuming no active
82 * source data would use a shift longer than that unless it really did
83 * have an absolute time standard. Also assumes we'll never use data from
84 * the first 2 minutes of 1960.*/
85 if (t0shift_is_valid || (t0shift > 100.0)) {
86 this->mt0 += this->t0shift;
87 TimeWindow tw;
88 std::set<TimeWindow, TimeWindowCmp> shifted_gaps;
89 std::set<TimeWindow, TimeWindowCmp>::iterator this_gap;
90 for (this_gap = gaps.begin(); this_gap != gaps.end(); ++this_gap) {
91 tw.start = this_gap->start + t0shift;
92 tw.end = this_gap->end + t0shift;
93 shifted_gaps.insert(tw);
94 }
95 /* See related comment on why the line below will not compile */
96 // this->gaps = shifted_gaps;
97 this->gaps.clear();
98 for (this_gap = shifted_gaps.begin(); this_gap != shifted_gaps.end();
99 ++this_gap) {
100 this->gaps.insert(*this_gap);
101 }
103 t0shift_is_valid = false;
104 } else {
105 this->kill();
106 throw MsPASSError(errormess, ErrorSeverity::Invalid);
107 }
108}
void kill()
Definition BasicTimeSeries.h:147

References mspass::seismic::BasicTimeSeries::dead(), mspass::seismic::DataGap::gaps, mspass::utility::Metadata::get(), mspass::seismic::BasicTimeSeries::kill(), mspass::seismic::BasicTimeSeries::mt0, mspass::algorithms::TimeWindow::start, mspass::seismic::BasicTimeSeries::tref, and mspass::seismic::UTC.

◆ rtoa() [2/2]

void mspass::seismic::TimeSeriesWGaps::rtoa ( const double  tshift)

Relative to absolute time conversion. Sometimes we want to convert data from relative time to to an absolute time standard. An example would be converting segy shot data to something that could be processed like earthquake data in a css3.0 database. This operation simply switches the tref variable and alters t0 by tshift.

This method overrides the one in BasicTimeSeries to correctly reference gaps.

Parameters
tshift- time shift applied to data before switching data to absolute time mode.

NOTE: This method is maintained only for backward compatibility. May be depricated in favor of method that uses internally stored private shift variable.

47 {
48 /* dead traces should to totally ignored */
49 if (this->dead())
50 return;
52 return;
53 this->mt0 += tshift;
54 TimeWindow tw;
55 std::set<TimeWindow, TimeWindowCmp> shifted_gaps;
56 std::set<TimeWindow, TimeWindowCmp>::iterator this_gap;
57 for (this_gap = gaps.begin(); this_gap != gaps.end(); ++this_gap) {
58 tw.start = this_gap->start + tshift;
59 tw.end = this_gap->end + tshift;
60 shifted_gaps.insert(tw);
61 }
62 /* See related comment on why the line below will not compile */
63 // this->gaps = shifted_gaps;
64 this->gaps.clear();
65 for (this_gap = shifted_gaps.begin(); this_gap != shifted_gaps.end();
66 ++this_gap) {
67 this->gaps.insert(*this_gap);
68 }
70 this->t0shift_is_valid = true;
71}

References mspass::seismic::BasicTimeSeries::dead(), mspass::seismic::DataGap::gaps, mspass::utility::Metadata::get(), mspass::seismic::BasicTimeSeries::mt0, mspass::algorithms::TimeWindow::start, mspass::seismic::BasicTimeSeries::tref, and mspass::seismic::UTC.

◆ shift()

void mspass::seismic::TimeSeriesWGaps::shift ( const double  dt)
virtual

Shift the reference time.

Sometimes we need to shift the reference time t0. An example is a moveout correction. This method shifts the reference time by dt. Note a positive dt means data aligned to zero will be shifted left because relative time is t-t0.

Reimplemented from mspass::seismic::BasicTimeSeries.

109 {
110 /* This is the same test for valid t0shift used in BasicTimeSeries*/
111 if (this->t0shift_is_valid || (this->t0shift > 100.0)) {
112 double oldt0shift = this->t0shift;
113 this->rtoa();
114 this->ator(oldt0shift + dt);
115 } else {
116 this->kill();
117 std::stringstream ss;
118 ss << "TimeSeriesWGaps::shift: internal shift attributes is marked invalid"
119 << std::endl
120 << "shift method should only be used on data originating with a UTC "
121 "time standard"
122 << std::endl;
123 throw MsPASSError(ss.str(), ErrorSeverity::Invalid);
124 }
125}
double dt() const
Definition BasicTimeSeries.h:153
void rtoa()
Definition TimeSeriesWGaps.cc:72
void ator(const double tshift)
Definition TimeSeriesWGaps.cc:15

References ator(), mspass::seismic::BasicTimeSeries::dt(), mspass::utility::Metadata::get(), mspass::seismic::BasicTimeSeries::kill(), and rtoa().

◆ zero_gaps()

void mspass::seismic::TimeSeriesWGaps::zero_gaps ( )

Force all data inside data gaps to zero.

126 {
127 int i, istart, iend;
128 std::set<TimeWindow, TimeWindowCmp>::iterator this_gap;
129
130 for (this_gap = gaps.begin(); this_gap != gaps.end(); ++this_gap) {
131 if (this_gap->end < this->mt0)
132 continue;
133 if (this_gap->start > this->endtime())
134 continue;
135 if (this_gap->start < this->mt0)
136 istart = 0;
137 else
138 istart = round((this_gap->start - this->mt0) / this->mdt);
139 if ((this_gap->end) > this->endtime())
140 iend = this->nsamp - 1;
141 else
142 iend = round((this_gap->end - mt0) / this->mdt);
143 for (i = istart; i <= iend; ++i)
144 this->s[i] = 0.0;
145 }
146}
size_t nsamp
Definition BasicTimeSeries.h:255
std::vector< double > s
Definition CoreTimeSeries.h:27

References mspass::seismic::DataGap::gaps, mspass::utility::Metadata::get(), mspass::seismic::BasicTimeSeries::mt0, mspass::seismic::BasicTimeSeries::nsamp, and mspass::seismic::CoreTimeSeries::s.


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