1 #ifndef _MSPASS_CORESEISMOGRAM_H_
2 #define _MSPASS_CORESEISMOGRAM_H_
5 #include "mspass/utility/Metadata.h"
6 #include "mspass/utility/dmatrix.h"
7 #include "mspass/seismic/BasicTimeSeries.h"
8 #include "mspass/seismic/CoreTimeSeries.h"
9 #include "mspass/utility/SphericalCoordinate.h"
10 #include "mspass/seismic/SlownessVector.h"
107 const unsigned int component_to_clone=0);
162 void set_dt(
const double sample_interval);
208 void set_t0(
const double t0in);
287 std::vector<double>
operator[](
const int sample)
const;
382 void rotate(
const double nu[3]);
399 void rotate(
const double phi);
435 for(
int j=0;j<3;++j) result(i,j)=
tmatrix[i][j];
523 bool tmatrix_is_cardinal();
Base class for time series objects.
Definition: BasicTimeSeries.h:35
size_t npts() const
Definition: BasicTimeSeries.h:188
double time(const int i) const
Definition: BasicTimeSeries.h:63
double mdt
Definition: BasicTimeSeries.h:276
double mt0
Definition: BasicTimeSeries.h:280
Vector (three-component) seismogram data object.
Definition: CoreSeismogram.h:40
const CoreSeismogram operator+(const CoreSeismogram &other) const
Definition: CoreSeismogram.cc:1016
std::vector< double > operator[](const int sample) const
Definition: CoreSeismogram.cc:1123
bool cardinal() const
Definition: CoreSeismogram.h:479
virtual ~CoreSeismogram()
Definition: CoreSeismogram.h:301
double tmatrix[3][3]
Definition: CoreSeismogram.h:519
bool orthogonal() const
Definition: CoreSeismogram.h:481
CoreSeismogram & operator+=(const CoreSeismogram &d)
Summation operator.
Definition: CoreSeismogram.cc:926
void set_dt(const double sample_interval)
Set the sample interval.
Definition: CoreSeismogram.cc:1028
void sync_npts()
Sync the number of samples attribute with actual data size.
Definition: CoreSeismogram.cc:1099
bool set_transformation_matrix(pybind11::object a)
Define the transformaton matrix with a python object.
void rotate_to_standard()
Definition: CoreSeismogram.cc:400
void set_t0(const double t0in)
Set the data start time.
Definition: CoreSeismogram.cc:1047
bool components_are_orthogonal
Definition: CoreSeismogram.h:489
CoreSeismogram(const std::vector< mspass::seismic::CoreTimeSeries > &ts, const unsigned int component_to_clone=0)
bool set_transformation_matrix(const mspass::utility::dmatrix &A)
Define the transformaton matrix.
Definition: CoreSeismogram.cc:787
mspass::utility::dmatrix u
Definition: CoreSeismogram.h:53
CoreSeismogram()
Definition: CoreSeismogram.cc:28
CoreSeismogram & operator=(const CoreSeismogram &)
Definition: CoreSeismogram.cc:896
mspass::utility::dmatrix get_transformation_matrix() const
Definition: CoreSeismogram.h:431
void rotate(mspass::utility::SphericalCoordinate &sc)
Definition: CoreSeismogram.cc:544
const CoreSeismogram operator-(const CoreSeismogram &other) const
Definition: CoreSeismogram.cc:1022
CoreSeismogram & operator*=(const double)
Definition: CoreSeismogram.cc:915
void free_surface_transformation(const mspass::seismic::SlownessVector u, const double vp0, const double vs0)
Definition: CoreSeismogram.cc:723
double endtime() const noexcept
Definition: CoreSeismogram.h:486
void set_npts(const size_t npts)
Set the number of samples attribute for data.
Definition: CoreSeismogram.cc:1067
void transform(const double a[3][3])
Definition: CoreSeismogram.cc:673
CoreSeismogram & operator-=(const CoreSeismogram &d)
Subtraction operator.
Definition: CoreSeismogram.cc:972
bool components_are_cardinal
Definition: CoreSeismogram.h:511
Slowness vector object.
Definition: SlownessVector.h:18
Lightweight, simple matrix object.
Definition: dmatrix.h:102
size_t columns() const
Definition: dmatrix.cc:232
Define metadata keys.
Definition: BasicSpectrum.h:6
Encapsulates spherical coordinates in a data structure.
Definition: SphericalCoordinate.h:14