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::Ensemble< Tdata > Class Template Reference
Inheritance diagram for mspass::seismic::Ensemble< Tdata >:
mspass::utility::Metadata mspass::utility::BasicMetadata

Public Member Functions

 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)
 
Tdataoperator[] (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

std::vector< Tdatamember
 Container holding data objects.
 

Additional Inherited Members

Constructor & Destructor Documentation

◆ Ensemble() [1/4]

template<typename Tdata >
mspass::seismic::Ensemble< Tdata >::Ensemble ( )
inline

Default constructor.

22{};

◆ Ensemble() [2/4]

template<typename Tdata >
mspass::seismic::Ensemble< Tdata >::Ensemble ( const size_t  n)
inline

Reserve space but build empty ensemble.

Often we know what the size of an ensemble is before we start building it. This constructor reserve space but marks all members dead.

Parameters
-expected number of members.
31{ member.reserve(n); };
std::vector< Tdata > member
Container holding data objects.
Definition Ensemble.h:20

References mspass::seismic::Ensemble< Tdata >::member.

◆ Ensemble() [3/4]

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

Partial constructor to clone metadata and set aside n slots but no data

35 member.reserve(n);
36 };
Definition Metadata.h:71

References mspass::seismic::Ensemble< Tdata >::member.

◆ Ensemble() [4/4]

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

Standard copy constructor.

40 dynamic_cast<const mspass::utility::Metadata &>(parent)),
41 member(parent.member) {};
T get(const std::string key) const
Definition Metadata.h:445

Member Function Documentation

◆ operator=()

Standard assignment operator.

43 {
44 if (this != (&parent)) {
46 member = parent.member;
47 }
48 return *this;
49 };
Metadata & operator=(const Metadata &mdold)
Definition Metadata.cc:90

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

◆ operator[]()

template<typename Tdata >
Tdata & mspass::seismic::Ensemble< Tdata >::operator[] ( const size_t  n) const
inline
61 {
62 return (this->member[n]);
63 } catch (...) {
64 throw;
65 };

◆ sync_metadata() [1/2]

template<typename Tdata >
void mspass::seismic::Ensemble< Tdata >::sync_metadata ( )
inline

copy ensemble metadata to all members.

An ensemble has global metadata, but each member is required to have a metadata component. This method takes the ensemble metadata and copies it to each of the member objects. The operation will overwrite previous key:value pairs in a member that are also present in the ensemble metadata.

92 {
93 size_t i;
94 for (i = 0; i < this->member.size(); ++i) {
96 (*mdmember) += dynamic_cast<mspass::utility::Metadata &>(*this);
97 }
98 };

◆ sync_metadata() [2/2]

template<typename Tdata >
void mspass::seismic::Ensemble< Tdata >::sync_metadata ( std::vector< std::string >  exclude)
inline

copy ensemble metadata to all members except for the ones excluded.

101 {
103 for (size_t i = 0; i < exclude.size(); i++) {
104 if (sync_md.is_defined(exclude[i])) {
105 sync_md.erase(exclude[i]);
106 }
107 }
108 for (size_t i = 0; i < this->member.size(); ++i) {
110 (*mdmember) += sync_md;
111 }
112 };

References mspass::utility::Metadata::erase(), and mspass::utility::Metadata::is_defined().

◆ update_metadata()

template<typename Tdata >
void mspass::seismic::Ensemble< Tdata >::update_metadata ( const mspass::utility::Metadata newmd)
inline

updates ensemble header (Metadata).

Sometime it is helpful to change a group of header attributes stored in the Metadata component. Rather than do a bunch of puts this uses operator += to update the header. Note this operator uses the property that any existing attributes with the same key as one in the updates set will be replaced with the update.

Parameters
newmdcontains new Metadata to use for updates.
77 {
79 md = dynamic_cast<mspass::utility::Metadata *>(this);
80 (*md) += newmd;
81 } catch (...) {
82 throw;
83 };

Member Data Documentation

◆ member

template<typename Tdata >
std::vector<Tdata> mspass::seismic::Ensemble< Tdata >::member

Container holding data objects.

An ensemble is defined as a collection of data objects linked by some property that is normally defined by data sharing a comomon data-value pair. The data are stored here in a vector container. We make this vector public because the assumption is the member objects can be large and copying with a getter would be a serious inefficiently.


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