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::LoggingEnsemble< T > Class Template Reference

Template class that extends Ensemble to include an error log and live tests. More...

#include <Ensemble.h>

Inheritance diagram for mspass::seismic::LoggingEnsemble< T >:
mspass::seismic::Ensemble< T > mspass::utility::Metadata mspass::utility::BasicMetadata

Public Member Functions

 LoggingEnsemble ()
 
 LoggingEnsemble (const size_t n)
 
 LoggingEnsemble (const mspass::utility::Metadata &md, const size_t n)
 
 LoggingEnsemble (const mspass::utility::Metadata &md, const mspass::utility::ErrorLogger &elogin, const size_t ndata)
 
 LoggingEnsemble (const LoggingEnsemble< T > &parent)
 
 LoggingEnsemble (const Ensemble< T > &parent)
 
void kill ()
 
bool live () const
 
bool dead () const
 
bool validate ()
 
bool set_live ()
 
LoggingEnsemble< T > & operator= (const LoggingEnsemble< T > &parent)
 
size_t memory_use () const
 
- Public Member Functions inherited from mspass::seismic::Ensemble< T >
 Ensemble ()
 
 Ensemble (const size_t n)
 Reserve space but build empty ensemble.
 
 Ensemble (const mspass::utility::Metadata &md, const size_t n)
 
 Ensemble (const Ensemble &parent)
 
Ensembleoperator= (const Ensemble &parent)
 
T & operator[] (const size_t n) const
 
void update_metadata (const mspass::utility::Metadata &newmd)
 updates ensemble header (Metadata).
 
void sync_metadata ()
 copy ensemble metadata to all members.
 
void sync_metadata (std::vector< std::string > exclude)
 copy ensemble metadata to all members except for the ones excluded.
 

Public Attributes

mspass::utility::ErrorLogger elog
 
- Public Attributes inherited from mspass::seismic::Ensemble< T >
std::vector< T > member
 Container holding data objects.
 

Additional Inherited Members

Detailed Description

template<typename T>
class mspass::seismic::LoggingEnsemble< T >

Template class that extends Ensemble to include an error log and live tests.

This class extends the Ensemble class defined in MsPASS for bundling collections of data that can be pushed to an std::vector container. The class is actually very generic, but mspass defines it for TimeSeries and Seismogram objects. This class is a necessary extension for an algorithm that take ensembles in and emits a different ensemble. In that situation we need a way to indicate the entire ensemble is invalid and not be to used and post error messages that give an explanation of why the output is invalid. This class provides that mechanism by adding a mspass::utility::ErrorLogger and a (private) boolean defining if the ensemble has valid data. That makes the API to a LoggingEnsemble a hybrid with the atomic Seismogram and TimeSeries objects (adds the dna of ErrorLogger and live/dead concept).

A secondary fundamental reason this class can be needed is to parallelize algorithms that emit an ensemble (regardless of inputs). The live/dead tests and error logger make the handlers consistent with the atomic objects of mspass.

Constructor & Destructor Documentation

◆ LoggingEnsemble() [1/6]

template<typename T >
mspass::seismic::LoggingEnsemble< T >::LoggingEnsemble ( )
inline

Default constructor. Initializes all pieces with default constructor and marks the ensemble dead.

141: Ensemble<T>(), elog() { ensemble_is_live = false; };
mspass::utility::ErrorLogger elog
Definition Ensemble.h:138

◆ LoggingEnsemble() [2/6]

template<typename T >
mspass::seismic::LoggingEnsemble< T >::LoggingEnsemble ( const size_t  n)
inline

Reserve slots but otherwise create and empty ensemble marked dead.

This constructor is a minor variant from the default constructor that calls reserve to set aside n slotes for the data. Use this one when you know the size of the ensemble you want to create. Note after the ensemble, like the default constructor, is marked initially as dead. The user must call the set_live method of this ensemble after loading data or downstream processors may drop the data.

154 : Ensemble<T>(n), elog() {
155 ensemble_is_live = false;
156 }

◆ LoggingEnsemble() [3/6]

template<typename T >
mspass::seismic::LoggingEnsemble< T >::LoggingEnsemble ( const mspass::utility::Metadata md,
const size_t  n 
)
inline

Construct a framework for the ensemble with metadata.

This constructor loads the metadata received into the ensmeble area and reserves n slots to be added. Be warned it marks the ensemble dead. Once valid data are loaded the user should call the set_live method for the ensemble to prevent the data from being ignored downstream.

164 : Ensemble<T>(md, n), elog() {
165 /* Might be advised to set this true, but since an object created by
166 this method has only slots but no data validate would return false.*/
167 ensemble_is_live = false;
168 }

◆ LoggingEnsemble() [4/6]

template<typename T >
mspass::seismic::LoggingEnsemble< T >::LoggingEnsemble ( const mspass::utility::Metadata md,
const mspass::utility::ErrorLogger elogin,
const size_t  ndata 
)
inline

Construct from all pieces.

This constructor was added for the python interface. It is a helpful construct for the pickle interface. It is unlikely to be of interest in a C++ application. Calls reserve only for member vector but but does not insert data - detail of the pickle implementation

178 : Ensemble<T>(md, ndata), elog(elogin) {};
T get(const std::string key) const
Definition Metadata.h:445

◆ LoggingEnsemble() [5/6]

template<typename T >
mspass::seismic::LoggingEnsemble< T >::LoggingEnsemble ( const LoggingEnsemble< T > &  parent)
inline

Standard copy constructor.

181 : Ensemble<T>(parent), elog(parent.elog) {
182 ensemble_is_live = parent.ensemble_is_live;
183 };

◆ LoggingEnsemble() [6/6]

template<typename T >
mspass::seismic::LoggingEnsemble< T >::LoggingEnsemble ( const Ensemble< T > &  parent)
inline

Clone from a base class Ensemble. Initializes error null and sets live.

186 : Ensemble<T>(parent), elog() {
187 ensemble_is_live = true;
188 };

Member Function Documentation

◆ dead()

template<typename T >
bool mspass::seismic::LoggingEnsemble< T >::dead ( ) const
inline

Complement to live method - returns true if there are no valid data members.

195{ return !ensemble_is_live; };

◆ kill()

template<typename T >
void mspass::seismic::LoggingEnsemble< T >::kill ( )
inline

Markt the entire ensemble bad.

190{ ensemble_is_live = false; };

◆ live()

template<typename T >
bool mspass::seismic::LoggingEnsemble< T >::live ( ) const
inline

Getter to test if the ensemble has any valid data.

192{ return ensemble_is_live; };

◆ memory_use()

template<typename T >
size_t mspass::seismic::LoggingEnsemble< T >::memory_use ( ) const
inline
230 {
231 size_t memuse;
232 memuse = sizeof(*this);
233 for (auto p = this->member.begin(); p != this->member.end(); ++p) {
234 memuse += p->memory_use();
235 }
236 /* Account for ensemble metadata */
237 /* We can only estimate the size of the Metadata container.
238 These constants are defined in memory_constants.h */
239 memuse +=
240 mspass::utility::memory_constants::MD_AVERAGE_SIZE * this->md.size();
241 memuse += mspass::utility::memory_constants::KEY_AVERAGE_SIZE *
242 this->changed_or_set.size();
243 /* Account for error log size */
244 memuse += mspass::utility::memory_constants::ELOG_AVERAGE_SIZE *
245 this->elog.size();
246 return memuse;
247 };
std::vector< T > member
Container holding data objects.
Definition Ensemble.h:20

◆ operator=()

Standard assignment operator.

220 {
221 if (&parent != this) {
223 this->member.reserve(parent.member.size());
224 this->member = parent.member;
225 elog = parent.elog;
226 ensemble_is_live = parent.ensemble_is_live;
227 }
228 return *this;
229 };
Metadata & operator=(const Metadata &mdold)
Definition Metadata.cc:90

References mspass::seismic::LoggingEnsemble< T >::elog, mspass::seismic::Ensemble< Tdata >::member, and mspass::utility::Metadata::operator=().

◆ set_live()

template<typename T >
bool mspass::seismic::LoggingEnsemble< T >::set_live ( )
inline

Force, with care, the ensemble to be marked live.

This extension of CoreEnsemble adds a boolean that is used to test if an entire ensemble should be treated as dead or alive. It first runs the validate method. If validate is false it refuses to set the state live and returns false. If validate returns true it will return true.

211 {
212 if (this->validate()) {
213 ensemble_is_live = true;
214 return true;
215 } else
216 return false;
217 };
bool validate()
Definition Ensemble.h:253

References mspass::seismic::LoggingEnsemble< T >::validate().

◆ validate()

template<typename T >
bool mspass::seismic::LoggingEnsemble< T >::validate ( )

Check to see if ensemble has any live data.

In processing one can occasionally (not rare but not common either) end up with enemble full of data marked dead. This is a convenience method to check all members. If it finds any live member it will immediately return true (ok). If after a search of the entire ensemble no live members are found it will return false AND then mark the entire ensemble bad.

253 {
254 for (auto dptr = this->member.begin(); dptr != this->member.end(); ++dptr) {
255 if (dptr->live())
256 return true;
257 }
258 return false;
259}

Member Data Documentation

◆ elog

Standard mspass container for holding error logs.


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