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::PowerSpectrum Class Reference

#include <PowerSpectrum.h>

Inheritance diagram for mspass::seismic::PowerSpectrum:
mspass::seismic::BasicSpectrum mspass::utility::Metadata mspass::utility::BasicMetadata

Public Member Functions

 PowerSpectrum ()
 
template<class T >
 PowerSpectrum (const mspass::utility::Metadata &md, const std::vector< T > &d, const double dfin, const std::string nm, const double f0in, const double dtin, const int npts_in)
 
 PowerSpectrum (const PowerSpectrum &parent)
 
PowerSpectrumoperator= (const PowerSpectrum &parent)
 
PowerSpectrumoperator+= (const PowerSpectrum &other)
 Standard accumulation operator.
 
std::vector< doubleamplitude () const
 Compute amplitude spectrum from power spectrum.
 
double power (const double f) const
 power at a given frequency.
 
double frequency (const int sample_number) const
 
std::vector< doublefrequencies () const
 
size_t nf () const
 
double Nyquist () const
 
- Public Member Functions inherited from mspass::seismic::BasicSpectrum
 BasicSpectrum ()
 
 BasicSpectrum (const double dfin, const double f0in, const double dtin, const int npts_in)
 
 BasicSpectrum (const BasicSpectrum &parent)
 
BasicSpectrumoperator= (const BasicSpectrum &parent)
 
bool live () const
 
bool dead () const
 
void kill ()
 
void set_live ()
 
double df () const
 
double f0 () const
 
double dt () const
 Return the original sample interval of data used to generate spectrum.
 
double rayleigh () const
 Return the Rayleigh bin size for this spectrum.
 
int timeseries_npts () const
 
int sample_number (const double f) const
 
void set_df (const double dfin)
 
void set_f0 (const double f0in)
 
void set_dt (const double dtin)
 
void set_npts (const int npts_in)
 

Public Attributes

std::string spectrum_type
 
std::vector< doublespectrum
 
mspass::utility::ErrorLogger elog
 

Additional Inherited Members

- Protected Attributes inherited from mspass::seismic::BasicSpectrum
double dfval
 
double f0val
 
double parent_dt
 
double parent_npts
 
bool is_live
 

Detailed Description

Class defining the concept of a power psectrum.

Constructor & Destructor Documentation

◆ PowerSpectrum() [1/3]

mspass::seismic::PowerSpectrum::PowerSpectrum ( )

Default constructor. Makes am empty, dead datum.

10 : BasicSpectrum(), Metadata(), elog() {
11 spectrum_type = string("UNDEFINED");
12}
BasicSpectrum()
Definition BasicSpectrum.h:22
mspass::utility::ErrorLogger elog
Definition PowerSpectrum.h:26
std::string spectrum_type
Definition PowerSpectrum.h:18
Metadata()
Definition Metadata.h:75
T get(const std::string key) const
Definition Metadata.h:445

References mspass::utility::Metadata::get(), and spectrum_type.

◆ PowerSpectrum() [2/3]

template<class T >
mspass::seismic::PowerSpectrum::PowerSpectrum ( const mspass::utility::Metadata md,
const std::vector< T > &  d,
const double  dfin,
const std::string  nm,
const double  f0in,
const double  dtin,
const int  npts_in 
)

Standard constructor template.

This constructor is a template largely to allow vectors of data other than double as inputs. If the input is not double it is converted on input to an std::vector<double> container stored in the spectrum attribute.

Parameters
mdcontents of this Metadata container are copied to the result.
dvector of sample data to load into spectrum array.
dfinfrequency bin size (sample interval)
nmname defining algorithm used to constuct this spectral estimate.
f0infrequency of component 0 of input (default is 0.0).
dtinparent sampell interval of data used to make this estimate
npts_innumber of points in parent time series used to compute this estimate.

Fully parameterized constructor template.

See class definition of PowerSpectrum for usage. Template to allow data vector of multiple types.

110 elog() {
111 spectrum_type = nm;
112 spectrum.reserve(d.size());
113 for (size_t k = 0; k < d.size(); ++k)
114 spectrum.push_back(static_cast<double>(d[k]));
115 this->set_live();
116};
void set_live()
Definition BasicSpectrum.h:91
std::vector< double > spectrum
Definition PowerSpectrum.h:20
Definition Metadata.h:71

References mspass::seismic::BasicSpectrum::set_live(), spectrum, and spectrum_type.

◆ PowerSpectrum() [3/3]

mspass::seismic::PowerSpectrum::PowerSpectrum ( const PowerSpectrum parent)
15 spectrum_type = parent.spectrum_type;
16 spectrum_type = parent.spectrum_type;
17 spectrum = parent.spectrum;
18 elog = parent.elog;
19}

Member Function Documentation

◆ amplitude()

vector< double > mspass::seismic::PowerSpectrum::amplitude ( ) const

Compute amplitude spectrum from power spectrum.

The amplitude spectrum is sqrt of the power values. This is a convenience class to return the values in that form.

67 {
68 vector<double> result;
69 result.reserve(spectrum.size());
70 for (int k = 0; k < spectrum.size(); ++k)
71 result.push_back(sqrt(spectrum[k]));
72 return result;
73}

References mspass::utility::Metadata::get(), and spectrum.

◆ frequencies()

std::vector< double > mspass::seismic::PowerSpectrum::frequencies ( ) const
virtual

Return an std::vector container containing the frequency of each sample in the spectrum vector. Commonly necessary for plotting. Made virtual because nf method needs to be virtual.

Implements mspass::seismic::BasicSpectrum.

90 {
92 f.reserve(this->nf());
93 for (auto i = 0; i < this->nf(); ++i)
94 f.push_back(this->f0val + this->dfval * static_cast<double>(i));
95 return f;
96}
size_t nf() const
Definition PowerSpectrum.h:94

References mspass::utility::Metadata::get(), and nf().

◆ frequency()

double mspass::seismic::PowerSpectrum::frequency ( const int  sample_number) const
inlinevirtual

Return frequency at a specified sample number. Virtual to allow subclasses to throw an error for illegal value.

Implements mspass::seismic::BasicSpectrum.

78 {
79 const std::string base_error("PowerSpectrum::frequency: ");
80 if (sample_number < 0)
82 base_error + "Sample number parameter passed cannot be negative");
83 if (sample_number >= (this->nf()))
86 "Sample number parameter passed xceeds range of spectrum array");
87 return this->f0() + sample_number * this->df();
88 };
int sample_number(const double f) const
Definition BasicSpectrum.h:124
double df() const
Definition BasicSpectrum.h:93
double f0() const
Definition BasicSpectrum.h:98
Base class for error object thrown by MsPASS library routines.
Definition MsPASSError.h:38

References mspass::seismic::BasicSpectrum::df(), mspass::seismic::BasicSpectrum::f0(), nf(), and mspass::seismic::BasicSpectrum::sample_number().

◆ nf()

size_t mspass::seismic::PowerSpectrum::nf ( ) const
inlinevirtual

Return the number of frequency bin.

Implements mspass::seismic::BasicSpectrum.

94{ return spectrum.size(); };

References spectrum.

◆ Nyquist()

double mspass::seismic::PowerSpectrum::Nyquist ( ) const
inlinevirtual

Return the nyquist frequency for this estimate.

Implements mspass::seismic::BasicSpectrum.

96{ return 1.0 / (2.0 * this->parent_dt); };

◆ operator+=()

Standard accumulation operator.

Sometimes we need to sum power spectra. Type examplel would be total noise amplitude on a 3C seismogram or average noise amplitude in an array of instruments. This can be used to build such sum in the usual way. Add spectral elements sample by sample.

Exceptions
willthrow a MsPaSSError if the left and right side are not equal length of have different f0 of df values.
30 {
31 /* Allow self accumulation - double values */
32 if (this == (&other)) {
33 for (int k = 0; k < this->nf(); ++k)
34 spectrum[k] *= 2.0;
35 } else {
36 if (this->nf() != other.nf()) {
37 stringstream ss;
38 ss << "operator+=(accumulation) size mismatch of spectrum arrays" << endl
39 << "right hade side spectrum size=" << other.nf() << endl
40 << "left had side spectrum size=" << this->nf() << endl;
41 this->elog.log_error("PowerSpectrum::operator+-", ss.str(),
42 ErrorSeverity::Invalid);
43 this->kill();
44 } else if (this->f0() != other.f0()) {
45 stringstream ss;
46 ss << "operator+=(accumulation) f0 mismatch of spectrum estimates" << endl
47 << "right hade side spectrum f0=" << other.f0() << endl
48 << "left had side spectrum f0=" << this->f0() << endl;
49 this->elog.log_error("PowerSpectrum::operator+-", ss.str(),
50 ErrorSeverity::Invalid);
51 this->kill();
52 } else if (this->df() != other.df()) {
53 stringstream ss;
54 ss << "operator+=(accumulation) df mismatch of spectrum estimates" << endl
55 << "right hade side spectrum df=" << other.df() << endl
56 << "left had side spectrum df=" << this->df() << endl;
57 this->elog.log_error("PowerSpectrum::operator+-", ss.str(),
58 ErrorSeverity::Invalid);
59 this->kill();
60 } else {
61 for (int k = 0; k < this->nf(); ++k)
62 spectrum[k] += other.spectrum[k];
63 }
64 }
65 return *this;
66}
void kill()
Definition BasicSpectrum.h:84
int log_error(const mspass::utility::MsPASSError &merr)
Definition ErrorLogger.cc:72

References mspass::seismic::BasicSpectrum::df(), elog, mspass::seismic::BasicSpectrum::f0(), mspass::utility::Metadata::get(), mspass::seismic::BasicSpectrum::kill(), mspass::utility::ErrorLogger::log_error(), nf(), and spectrum.

◆ operator=()

20 {
21 if (this != (&parent)) {
23 this->BasicSpectrum::operator=(parent);
24 spectrum_type = parent.spectrum_type;
25 spectrum = parent.spectrum;
26 elog = parent.elog;
27 }
28 return *this;
29}
Metadata & operator=(const Metadata &mdold)
Definition Metadata.cc:90

◆ power()

double mspass::seismic::PowerSpectrum::power ( const double  f) const

power at a given frequency.

Returns the power estimate at a specified frequency. Uses a linear interpolation between nearest neighbors. Returns the frequency exceeds the Nyquist silently returns 0.

Parameters
fis the frequency for which amplitude is desired.
Exceptions
MsPASSErorrobject will be throw f f is less than 0.
74 {
75 if (f < 0.0)
76 throw MsPASSError("PowerSpectrum::amplitude: requested amplitude for a "
77 "negative frequency which is assumed to be an erorr",
78 ErrorSeverity::Invalid);
79 int filow;
80 filow = static_cast<int>((f - this->f0val) / this->dfval);
81 /* Force 0 at Nyquist and above - this allows simple interpolation in else */
82 if (filow >= (spectrum.size() - 1))
83 return 0.0;
84 else {
85 double slope = (spectrum[filow + 1] - spectrum[filow]) / this->dfval;
86 double flow = this->f0val + ((double)filow) * this->dfval;
87 return spectrum[filow] + slope * (f - flow);
88 }
89}

References mspass::utility::Metadata::get(), and spectrum.

Member Data Documentation

◆ elog

mspass::utility::ErrorLogger mspass::seismic::PowerSpectrum::elog

MsPASS Error logging class.

MsPASS uses an error logger to allow posting of error messages that go with the data. That approach is needed in map reduce to allow the error messages to be cleanly preserved.

◆ spectrum

std::vector<double> mspass::seismic::PowerSpectrum::spectrum

Vector of spectral estimates. spectrum[0] == estimate at f0.

◆ spectrum_type

std::string mspass::seismic::PowerSpectrum::spectrum_type

Descriptive name assigned by creator of algorithm used to generate it.

There are a number of different algorithms to generate power spectra. this name field should be used to set a unique name for a given algorithm.


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