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

Scalar time series data object. More...

#include <CoreTimeSeries.h>

Inheritance diagram for mspass::seismic::CoreTimeSeries:
mspass::seismic::BasicTimeSeries mspass::utility::Metadata mspass::utility::BasicMetadata mspass::seismic::TimeSeries mspass::seismic::TimeSeriesWGaps

Public Member Functions

 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.
 
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.
 
BasicTimeSeriesoperator= (const BasicTimeSeries &parent)
 

Public Attributes

std::vector< doubles
 

Additional Inherited Members

- Protected Attributes inherited from mspass::seismic::BasicTimeSeries
bool mlive
 
double mdt
 
double mt0
 
size_t nsamp
 
TimeReferenceType tref
 
bool t0shift_is_valid
 
double t0shift
 

Detailed Description

Scalar time series data object.

This data object extends BasicTimeSeries mainly by adding a vector of scalar data. It uses a Metadata object to contain auxiliary parameters that aren't essential to define the data object, but which are necessary for some algorithms.

Author
Gary L. Pavlis

Constructor & Destructor Documentation

◆ CoreTimeSeries() [1/4]

mspass::seismic::CoreTimeSeries::CoreTimeSeries ( )

Default constructor. Initializes object data to zeros and sets the initial STL vector size to 0 length.

15 s.reserve(0);
16 this->set_dt(1.0);
17 this->set_t0(0.0);
18 this->set_npts(0);
19}
BasicTimeSeries()
Definition BasicTimeSeries.cc:45
void set_dt(const double sample_interval)
Set the sample interval.
Definition CoreTimeSeries.cc:165
std::vector< double > s
Definition CoreTimeSeries.h:27
void set_npts(const size_t npts)
Set the number of samples attribute for data.
Definition CoreTimeSeries.cc:196
void set_t0(const double t0in)
Set the data start time.
Definition CoreTimeSeries.cc:180
Metadata()
Definition Metadata.h:75

References s, set_dt(), set_npts(), and set_t0().

◆ CoreTimeSeries() [2/4]

mspass::seismic::CoreTimeSeries::CoreTimeSeries ( const size_t  nsin)

Similar to the default constructor but creates a vector of data with nsin samples and initializes all samples to 0.0. This vector can safely be accessed with the vector index operator (i.e. operator []). A corollary is that push_back or push_front applied to this vector will alter it's length so use this only if the size of the data to fill the object is already known.

22 /* IMPORTANT: this constructor assumes BasicTimeSeries initializes the
23 equivalent of:
24 set_dt(1.0)
25 set_t0(0.0)
26 set_tref(TimeReferenceType::Relative)
27 this->kill() - i.e. marked dead
28
29 It further assumes current api where set_npts allocates and initializes s
30 to nsin zeros */
32}
T get(const std::string key) const
Definition Metadata.h:445

References set_npts().

◆ ~CoreTimeSeries()

virtual mspass::seismic::CoreTimeSeries::~CoreTimeSeries ( )
inlinevirtual
43{};

◆ CoreTimeSeries() [3/4]

mspass::seismic::CoreTimeSeries::CoreTimeSeries ( const BasicTimeSeries bts,
const Metadata md 
)

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.

51 /* this assumes set_npts initializes the vector containers, s, to zeros
52 AND that BasicTimeSeries constructor initializes ns (npts) to the value
53 desired. */
55}
size_t nsamp
Definition BasicTimeSeries.h:255

References mspass::seismic::BasicTimeSeries::nsamp, and set_npts().

◆ CoreTimeSeries() [4/4]

mspass::seismic::CoreTimeSeries::CoreTimeSeries ( const CoreTimeSeries tsi)

Standard copy constructor.

36 if (mlive) {
37 s = tsi.s;
38 } else if (tsi.s.size() > 0) {
39 /* This is needed to preserve the contents of data vector when something
40 marks the data dead, but one wants to restore it later. Classic example
41 is an interactive trace editor. Found mysterious errors can occur
42 without this features. */
43 s = tsi.s;
44 }
45 /* Do nothing if the parent s is empty as std::vector will be properly
46 initialized*/
47}
bool mlive
Definition BasicTimeSeries.h:243

References mspass::utility::Metadata::get(), mspass::seismic::BasicTimeSeries::mlive, and s.

Member Function Documentation

◆ operator*=()

Multiply data by a scalar.

161 {
162 dscal(this->npts(), scale, &(this->s[0]), 1);
163 return *this;
164}
size_t npts() const
Definition BasicTimeSeries.h:171

References mspass::seismic::BasicTimeSeries::npts(), and s.

◆ operator+()

Addition operator.

This operator is implemented in a standard way utilizing operator+=. For data with irregular start and end times that has an important consequence; the operator is not communative. i.e given x an y z=x+y will not yield the same result as z=y+x.

150 {
151 CoreTimeSeries result(*this);
152 result += other;
153 return result;
154}
CoreTimeSeries()
Definition CoreTimeSeries.cc:14

References mspass::utility::Metadata::get().

◆ operator+=()

Summation operator.

Summing data from signals of irregular length requires handling potential mismatches in size and overlap. This behaves the way a += operator should logically behave in that situation. That is, because the lhs is where the sum is being accumulated, the size is always controlled by the left hand side of the operator. Any portions of the right hand side that are outside the t0 to endtime() of the left hand side are silently discarded. If the start time of the right hand side is greater than t0 or the endtime is less than endtime of the lhs there will be discontinuties in the sum there the ends of the rhs are inside the range of the lhs.

Parameters
dis other signal to add to this.
Exceptions
MsPASSErrorcan be thrown if lhs and rhs do not have matching time standards.
67 {
68 int i, iend, jend;
69 size_t i0;
70 size_t j, j0;
71 // Sun's compiler complains about const objects without this.
72 CoreTimeSeries &d = const_cast<CoreTimeSeries &>(data);
73 // Silently do nothing if d is marked dead
74 if (!d.mlive)
75 return (*this);
76 // Silently do nothing if d does not overlap with data to contain sum
77 if ((d.endtime() < mt0) || (d.mt0 > (this->endtime())))
78 return (*this);
79 if (d.tref != (this->tref))
80 throw MsPASSError("CoreTimeSeries += operator cannot handle data with "
81 "inconsistent time base\n",
82 ErrorSeverity::Invalid);
83 /* this defines the range of left and right hand sides to be summed */
84 i = d.sample_number(this->mt0);
85 if (i < 0) {
86 j0 = this->sample_number(d.t0());
87 i0 = 0;
88 } else {
89 j0 = 0;
90 i0 = i;
91 }
92 iend = d.sample_number(this->endtime());
93 jend = this->sample_number(d.endtime());
94 if (iend >= (d.npts())) {
95 iend = d.npts() - 1;
96 }
97 if (jend >= this->npts()) {
98 jend = this->npts() - 1;
99 }
100 // cout << "i0="<<i0<<" j0="<<j0<<" iend="<<iend<<" jend="<<jend<<endl;
101 /* Now do the actual sum using the computed ranges */
102 for (i = i0, j = j0; i <= iend && j <= jend; ++i, ++j)
103 this->s[j] += d.s[i];
104 return (*this);
105}
int sample_number(double t) const
Definition BasicTimeSeries.h:72
double mt0
Definition BasicTimeSeries.h:251
double endtime() const noexcept
Definition BasicTimeSeries.h:77

References mspass::seismic::BasicTimeSeries::endtime(), mspass::utility::Metadata::get(), mspass::seismic::BasicTimeSeries::mlive, mspass::seismic::BasicTimeSeries::mt0, mspass::seismic::BasicTimeSeries::npts(), s, mspass::seismic::BasicTimeSeries::sample_number(), mspass::seismic::BasicTimeSeries::t0(), and mspass::seismic::BasicTimeSeries::tref.

◆ operator-()

Subtraction operator.

This operator is implemented in a standard way utilizing operator-=. For data with irregular start and end times that has an important consequence; the operator is not communative. i.e given x an y z=x-y will not yield the same result as z=-(y-x).

156 {
157 CoreTimeSeries result(*this);
158 result -= other;
159 return result;
160}

References mspass::utility::Metadata::get().

◆ operator-=()

Subtraction operator.

Differencing data from signals of irregular length requires handling potential mismatches in size and overlap. This behaves the way a -= operator should logically behave in that situation. That is, because the lhs is where the sum is being accumulated, the size is always controlled by the left hand side of the operator. Any portions of the right hand side that are outside the t0 to endtime() of the left hand side are silently discarded. If the start time of the right hand side is greater than t0 or the endtime is less than endtime of the lhs there will be discontinuties in the sum there the ends of the rhs are inside the range of the lhs.

Parameters
dis other signal to subract from this.
Exceptions
MsPASSErrorcan be thrown if lhs and rhs do not have matching time standards.
110 {
111 int i, iend, jend;
112 size_t i0;
113 size_t j, j0;
114 // Sun's compiler complains about const objects without this.
115 CoreTimeSeries &d = const_cast<CoreTimeSeries &>(data);
116 // Silently do nothing if d is marked dead
117 if (!d.mlive)
118 return (*this);
119 // Silently do nothing if d does not overlap with data to contain sum
120 if ((d.endtime() < mt0) || (d.mt0 > (this->endtime())))
121 return (*this);
122 if (d.tref != (this->tref))
123 throw MsPASSError("CoreTimeSeries += operator cannot handle data with "
124 "inconsistent time base\n",
125 ErrorSeverity::Invalid);
126 /* this defines the range of left and right hand sides to be summed */
127 i = d.sample_number(this->mt0);
128 if (i < 0) {
129 j0 = this->sample_number(d.t0());
130 i0 = 0;
131 } else {
132 j0 = 0;
133 i0 = i;
134 }
135 iend = d.sample_number(this->endtime());
136 jend = this->sample_number(d.endtime());
137 if (iend >= (d.npts())) {
138 iend = d.npts() - 1;
139 }
140 if (jend >= this->npts()) {
141 jend = this->npts() - 1;
142 }
143 // cout << "i0="<<i0<<" j0="<<j0<<" iend="<<iend<<" jend="<<jend<<endl;
144 /* Now do the actual sum using the computed ranges */
145 for (i = i0, j = j0; i <= iend && j <= jend; ++i, ++j)
146 this->s[j] -= d.s[i];
147 return (*this);
148}

References mspass::seismic::BasicTimeSeries::endtime(), mspass::utility::Metadata::get(), mspass::seismic::BasicTimeSeries::mlive, mspass::seismic::BasicTimeSeries::mt0, mspass::seismic::BasicTimeSeries::npts(), s, mspass::seismic::BasicTimeSeries::sample_number(), mspass::seismic::BasicTimeSeries::t0(), and mspass::seismic::BasicTimeSeries::tref.

◆ operator=()

Standard assignment operator.

57 {
58 if (this != &tsi) {
61 s = tsi.s;
62 }
63 return (*this);
64}
BasicTimeSeries & operator=(const BasicTimeSeries &parent)
Definition BasicTimeSeries.cc:63
Metadata & operator=(const Metadata &mdold)
Definition Metadata.cc:90

References mspass::utility::Metadata::get(), mspass::seismic::BasicTimeSeries::operator=(), mspass::utility::Metadata::operator=(), and s.

◆ operator[]()

Extract a sample from data vector with range checking. Because the data vector is public in this interface this operator is simply an alterative interface to this->s[sample].

Exceptions
SeisppErrorexception if the requested sample is outside the range of the data. Note this includes an implicit "outside" defined when the contents are marked dead.
Parameters
sampleis the integer sample number of data desired.
240 {
241 if (!mlive)
242 throw MsPASSError(string("CoreTimeSeries operator[]: attempting to access "
243 "data marked as dead"),
244 ErrorSeverity::Invalid);
245 if ((i < 0) || (i >= s.size())) {
246 throw MsPASSError(string("CoreTimeSeries operator[]: request for sample "
247 "outside range of data"),
248 ErrorSeverity::Invalid);
249 }
250 return (s[i]);
251}

References mspass::utility::Metadata::get(), mspass::seismic::BasicTimeSeries::mlive, and s.

◆ set_dt()

void mspass::seismic::CoreTimeSeries::set_dt ( const double  sample_interval)
virtual

Set the sample interval.

This method is complicated by the need to sync the changed value with Metadata. That is further complicated by the need to support aliases for the keys used to defined dt in Metadata. That is handled by first setting the internal dt value and then going through a fixed list of valid alias keys for dt. Any that exist are changed. If none were previously defined the unique name (see documentation) is added to Metadata.

Parameters
sample_intervalis the new data sample interval to be used.

Reimplemented from mspass::seismic::BasicTimeSeries.

165 {
166 this->BasicTimeSeries::set_dt(sample_interval);
167 /* This is the unique name - we always set it.
168 Feb 2021 - changed to used const string value set in keywords.h*/
169 this->put(SEISMICMD_dt, sample_interval);
170 /* these are hard coded aliases for sample_interval */
171 std::set<string> aliases;
172 std::set<string>::iterator aptr;
173 aliases.insert("dt");
174 for (aptr = aliases.begin(); aptr != aliases.end(); ++aptr) {
175 if (this->is_defined(*aptr)) {
176 this->put(*aptr, sample_interval);
177 }
178 }
179}
virtual void set_dt(const double sample_interval)
Set the sample interval.
Definition BasicTimeSeries.h:197
bool is_defined(const std::string key) const noexcept
Definition Metadata.cc:63
const std::string SEISMICMD_dt("delta")

References mspass::utility::Metadata::get(), mspass::utility::Metadata::is_defined(), mspass::seismic::SEISMICMD_dt(), and mspass::seismic::BasicTimeSeries::set_dt().

◆ set_npts()

void mspass::seismic::CoreTimeSeries::set_npts ( const size_t  npts)
virtual

Set the number of samples attribute for data.

This method is complicated by the need to sync the changed value with Metadata. That is further complicated by the need to support aliases for the keys used to defined npts in Metadata. That is handled by first setting the internal npts value (actually ns) and then going through a fixed list of valid alias keys for npts. Any that exist are changed. If none were previously defined the unique name (see documentation) is added to Metadata.

This attribute has an additional complication compared to other setter that are overrides from BasicTimeSeries. That is, the number of points define the data buffer size to hold the sample data. To guarantee the buffer size and the internal remain consistent this method clears any existing content of the vector s and initializes npts points to 0.0. Note this means if one is using this to assemble a data object in pieces you MUST call this method before loading any data or it will be cleared and you will mysteriously find the data are all zeros.

Parameters
nptsis the new number of points to set.

Reimplemented from mspass::seismic::BasicTimeSeries.

196 {
198 /* This is the unique name - we always set it. Cast is necessary to
199 avoid type mismatch in python for unsigned.
200 Changed Feb 2021 to use key defined in in keywords.h*/
201 this->put(SEISMICMD_npts, (long int)npts);
202 /* these are hard coded aliases for sample_interval */
203 std::set<string> aliases;
204 std::set<string>::iterator aptr;
205 aliases.insert("nsamp");
206 aliases.insert("wfdisc.nsamp");
207 for (aptr = aliases.begin(); aptr != aliases.end(); ++aptr) {
208 if (this->is_defined(*aptr)) {
209 this->put(*aptr, (long int)npts);
210 }
211 }
212 /* this method has the further complication that npts sets the size of the
213 data buffer. We clear it an initialize it to 0 to be consistent with
214 how constructors handle this. */
215 std::vector<double>().swap(this->s); // Clear the memory allocation of s
216 this->s.reserve(npts);
217 for (size_t i = 0; i < npts; ++i)
218 this->s.push_back(0.0);
219}
virtual void set_npts(const size_t npts)
Set the number of samples attribute for data.
Definition BasicTimeSeries.h:209
const std::string SEISMICMD_npts("npts")

References mspass::utility::Metadata::get(), mspass::utility::Metadata::is_defined(), mspass::seismic::BasicTimeSeries::npts(), s, mspass::seismic::SEISMICMD_npts(), and mspass::seismic::BasicTimeSeries::set_npts().

◆ set_t0()

void mspass::seismic::CoreTimeSeries::set_t0 ( const double  t0in)
virtual

Set the data start time.

This method is complicated by the need to sync the changed value with Metadata. That is further complicated by the need to support aliases for the keys used to defined npts in Metadata. That is handled by first setting the internal t0 value and then going through a fixed list of valid alias keys for it. Any that exist are changed. If none were previously defined the unique name (see documentation) is added to Metadata.

This is a dangerous method to use on real data as it can mess up the time if not handled correctly. It should be used only when that sharp knife is needed such as in assembling data outside of constructors in a test program.

Parameters
t0inis the new data sample interval to be used.

Reimplemented from mspass::seismic::BasicTimeSeries.

180 {
182 /* This is the unique name - we always set it.
183 Changed Feb 2021 to use const string value defined in keywords.h*/
184 this->put(SEISMICMD_t0, t0in);
185 /* these are hard coded aliases for sample_interval */
186 std::set<string> aliases;
187 std::set<string>::iterator aptr;
188 aliases.insert("t0");
189 aliases.insert("time");
190 for (aptr = aliases.begin(); aptr != aliases.end(); ++aptr) {
191 if (this->is_defined(*aptr)) {
192 this->put(*aptr, t0in);
193 }
194 }
195}
virtual void set_t0(const double t0in)
Set the data start time.
Definition BasicTimeSeries.h:221
const std::string SEISMICMD_t0("starttime")

References mspass::utility::Metadata::get(), mspass::utility::Metadata::is_defined(), mspass::seismic::SEISMICMD_t0(), and mspass::seismic::BasicTimeSeries::set_t0().

◆ sync_npts()

void mspass::seismic::CoreTimeSeries::sync_npts ( )

Sync the number of samples attribute with actual data size.

This method syncs the npts attribute with the actual size of the vector s. It also syncs aliases in the same way as the set_npts method.

220 {
221 if (nsamp != this->s.size()) {
222 this->BasicTimeSeries::set_npts(this->s.size());
223 /* This is the unique name - we always set it. The weird
224 cast is necessary to avoid type mismatch with unsigned
225 Changed Feb 2021 to use key defined in keywords.h*/
226 this->put(SEISMICMD_npts, (long int)nsamp);
227 /* these are hard coded aliases for sample_interval */
228 std::set<string> aliases;
229 std::set<string>::iterator aptr;
230 aliases.insert("nsamp");
231 aliases.insert("wfdisc.nsamp");
232 for (aptr = aliases.begin(); aptr != aliases.end(); ++aptr) {
233 if (this->is_defined(*aptr)) {
234 this->put(*aptr, (long int)nsamp);
235 }
236 }
237 }
238}

References mspass::utility::Metadata::get(), mspass::utility::Metadata::is_defined(), mspass::seismic::BasicTimeSeries::nsamp, s, mspass::seismic::SEISMICMD_npts(), and mspass::seismic::BasicTimeSeries::set_npts().

Member Data Documentation

◆ s

std::vector<double> mspass::seismic::CoreTimeSeries::s

Actual data stored as an STL vector container. Note the STL guarantees the data elements of vector container are contiguous in memory like FORTRAN vectors. As a result things like the BLAS can be used with data object by using a syntax like this: if d is a CoreTimeSeries object, the address of the first sample of the data is &(d.s[0]).


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