version  0.0.1
Defines the C++ API for MsPASS
Loading...
Searching...
No Matches
Public Member Functions | Protected Attributes | List of all members
mspass::algorithms::deconvolution::ScalarDecon Class Referenceabstract

Base class decon operator for single station 3C decon (receiver functions). More...

#include <ScalarDecon.h>

Inheritance diagram for mspass::algorithms::deconvolution::ScalarDecon:
mspass::algorithms::deconvolution::BasicDeconOperator mspass::algorithms::deconvolution::GeneralIterDecon mspass::algorithms::deconvolution::LeastSquareDecon mspass::algorithms::deconvolution::MultiTaperSpecDivDecon mspass::algorithms::deconvolution::MultiTaperXcorDecon mspass::algorithms::deconvolution::WaterLevelDecon

Public Member Functions

 ScalarDecon (const mspass::utility::Metadata &md)
 
 ScalarDecon (const std::vector< double > &d, const std::vector< double > &w)
 
 ScalarDecon (const ScalarDecon &parent)
 
int load (const std::vector< double > &wavelet, const std::vector< double > &data)
 Load all data required for decon.
 
int loaddata (const std::vector< double > &data)
 
int loadwavelet (const std::vector< double > &wavelet)
 
virtual void process ()=0
 
ScalarDeconoperator= (const ScalarDecon &parent)
 
std::vector< double > getresult ()
 
void changeparameter (const mspass::utility::Metadata &md)
 
void change_shaping_wavelet (const ShapingWavelet &nsw)
 
ShapingWavelet get_shaping_wavelet () const
 
mspass::seismic::CoreTimeSeries ideal_output ()
 
virtual mspass::seismic::CoreTimeSeries actual_output ()=0
 Return the actual output of the deconvolution operator.
 
virtual mspass::seismic::CoreTimeSeries inverse_wavelet ()=0
 Return a FIR represention of the inverse filter.
 
virtual mspass::seismic::CoreTimeSeries inverse_wavelet (double)=0
 
virtual mspass::utility::Metadata QCMetrics ()=0
 Return appropriate quality measures.
 

Protected Attributes

std::vector< double > data
 
std::vector< double > wavelet
 
std::vector< double > result
 
ShapingWavelet shapingwavelet
 

Detailed Description

Base class decon operator for single station 3C decon (receiver functions).

A class of algorithms exist for computing so called receiver functions. Simple for this application means a method that is applied to a single station's data and computed in a scalar time series sense. Thus the interface assumes we want to always at least load an estimate of the source wavelet for deconvolution and the data to which it is to be applied.

The design of this interface was made more complicated by a design goal to allow application of different conventional methods as the first step in the generalized iterative method. The generalized method can select one of the children of this base class.

Constructor & Destructor Documentation

◆ ScalarDecon() [1/3]

mspass::algorithms::deconvolution::ScalarDecon::ScalarDecon ( )
inline
31: shapingwavelet() {};

◆ ScalarDecon() [2/3]

mspass::algorithms::deconvolution::ScalarDecon::ScalarDecon ( const mspass::utility::Metadata md)
6 : shapingwavelet(md) {
7 try {
8 /* This has to be defined or the shapingwavlet constructor will
9 * fail in the current implementation */
10 int nfft = md.get_int("operator_nfft");
11 wavelet.reserve(nfft);
12 data.reserve(nfft);
13 result.reserve(nfft);
14 } catch (...) {
15 throw;
16 };
17}
int get_int(const std::string key) const override
Definition Metadata.h:154

◆ ScalarDecon() [3/3]

mspass::algorithms::deconvolution::ScalarDecon::ScalarDecon ( const ScalarDecon parent)
23 : data(parent.data), wavelet(parent.wavelet), result(parent.result),
24 shapingwavelet(parent.shapingwavelet) {}

◆ ~ScalarDecon()

mspass::algorithms::deconvolution::ScalarDecon::~ScalarDecon ( )
inline
51{};

Member Function Documentation

◆ actual_output()

virtual mspass::seismic::CoreTimeSeries mspass::algorithms::deconvolution::ScalarDecon::actual_output ( )
pure virtual

Return the actual output of the deconvolution operator.

The actual output is defined as w^-1*w and is compable to resolution kernels in linear inverse theory. Although not required we would normally expect this function to be peaked at 0. Offsets from 0 would imply a bias.

Implemented in mspass::algorithms::deconvolution::GeneralIterDecon, mspass::algorithms::deconvolution::LeastSquareDecon, mspass::algorithms::deconvolution::MultiTaperSpecDivDecon, mspass::algorithms::deconvolution::MultiTaperXcorDecon, and mspass::algorithms::deconvolution::WaterLevelDecon.

◆ change_shaping_wavelet()

void mspass::algorithms::deconvolution::ScalarDecon::change_shaping_wavelet ( const ShapingWavelet nsw)

Change the shaping wavelet that will be applied to output.

The suite of algorithms here use the concept of a shaping wavelet thoughout. The shaping wavelet for most applications should have a zero phase impulse response. This method changes the wavelet set with the operator.

56 {
57 shapingwavelet = nsw;
58}

◆ changeparameter()

void mspass::algorithms::deconvolution::ScalarDecon::changeparameter ( const mspass::utility::Metadata md)
virtual

Implements mspass::algorithms::deconvolution::BasicDeconOperator.

53 {
54 shapingwavelet = ShapingWavelet(md);
55}

◆ get_shaping_wavelet()

ShapingWavelet mspass::algorithms::deconvolution::ScalarDecon::get_shaping_wavelet ( ) const
inline

getter for ShapingWavelet stored with the operator.

65{ return this->shapingwavelet; };

◆ getresult()

std::vector< double > mspass::algorithms::deconvolution::ScalarDecon::getresult ( )
inline
53{ return result; };

◆ ideal_output()

mspass::seismic::CoreTimeSeries mspass::algorithms::deconvolution::ScalarDecon::ideal_output ( )
inline
72 {
73 return this->shapingwavelet.impulse_response();
74 };
mspass::seismic::CoreTimeSeries impulse_response()
Definition ShapingWavelet.cc:265

◆ inverse_wavelet() [1/2]

virtual mspass::seismic::CoreTimeSeries mspass::algorithms::deconvolution::ScalarDecon::inverse_wavelet ( )
pure virtual

Return a FIR represention of the inverse filter.

After any deconvolution is computed one can sometimes produce a finite impulse response (FIR) respresentation of the inverse filter.

Implemented in mspass::algorithms::deconvolution::GeneralIterDecon, mspass::algorithms::deconvolution::LeastSquareDecon, mspass::algorithms::deconvolution::MultiTaperSpecDivDecon, mspass::algorithms::deconvolution::MultiTaperXcorDecon, and mspass::algorithms::deconvolution::WaterLevelDecon.

◆ inverse_wavelet() [2/2]

virtual mspass::seismic::CoreTimeSeries mspass::algorithms::deconvolution::ScalarDecon::inverse_wavelet ( double  )
pure virtual

◆ load()

int mspass::algorithms::deconvolution::ScalarDecon::load ( const std::vector< double > &  wavelet,
const std::vector< double > &  data 
)

Load all data required for decon.

This method loads both the data vector and wavelet estimates as simple std::vectors. Timing must be maintained externally. This or the pair of methods loaddata and loadwavelet must be called before process. This method has a slight advantage in efficiency over successive calls to loaddata and loadwavelet for several reasons, but the difference is small.

Returns
always returns 0
33 {
34 wavelet = w;
35 data = d;
36 result.clear();
37 return 0;
38}

◆ loaddata()

int mspass::algorithms::deconvolution::ScalarDecon::loaddata ( const std::vector< double > &  data)

Load only the data vector.

43 {
44 data = d;
45 result.clear();
46 return 0;
47}

◆ loadwavelet()

int mspass::algorithms::deconvolution::ScalarDecon::loadwavelet ( const std::vector< double > &  wavelet)

Load only the wavelet estimate.

48 {
49 wavelet = w;
50 result.clear();
51 return 0;
52}

◆ operator=()

ScalarDecon & mspass::algorithms::deconvolution::ScalarDecon::operator= ( const ScalarDecon parent)
25 {
26 if (this != &parent) {
27 wavelet = parent.wavelet;
28 data = parent.data;
29 result = parent.result;
30 }
31 return *this;
32}

◆ QCMetrics()

virtual mspass::utility::Metadata mspass::algorithms::deconvolution::ScalarDecon::QCMetrics ( )
pure virtual

Return appropriate quality measures.

Each operator commonly has different was to measure the quality of the result. This method should return these in a generic Metadata object.

Implemented in mspass::algorithms::deconvolution::GeneralIterDecon, mspass::algorithms::deconvolution::LeastSquareDecon, mspass::algorithms::deconvolution::MultiTaperSpecDivDecon, mspass::algorithms::deconvolution::MultiTaperXcorDecon, and mspass::algorithms::deconvolution::WaterLevelDecon.


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