Go to the documentation of this file.
3 #ifndef EICD_BasicParticleCollection_H
4 #define EICD_BasicParticleCollection_H
12 #include "podio/ICollectionProvider.h"
13 #include "podio/CollectionBase.h"
14 #include "podio/CollectionIDTable.h"
37 return m_index != x.m_index;
59 return m_index != x.m_index;
88 void clear() override final;
98 template<
typename... Args>
102 size_t size() const override final;
105 std::
string getValueTypeName()
const override {
return std::string(
"eic::BasicParticle"); }
122 void setBuffer(
void* address) override final;
123 bool setReferences(const podio::ICollectionProvider* collectionProvider) override final;
127 podio::VectorMembersInfo*
vectorMembers()
override {
return &m_vecmem_info; }
131 std::for_each(m_entries.begin(),m_entries.end(),
137 unsigned getID() const override final {
138 return m_collectionID;
153 return iterator(m_entries.size(), &m_entries);
163 std::vector<BasicParticleData>*
_getBuffer() {
return m_data; }
165 template<
size_t arraysize>
166 const std::array<eic::Index, arraysize> ID()
const;
167 template<
size_t arraysize>
168 const std::array<eic::VectorXYZ, arraysize> p()
const;
169 template<
size_t arraysize>
170 const std::array<eic::VectorXYZ, arraysize> v()
const;
171 template<
size_t arraysize>
172 const std::array<float, arraysize> time()
const;
173 template<
size_t arraysize>
174 const std::array<std::int32_t, arraysize> pid()
const;
175 template<
size_t arraysize>
176 const std::array<std::int16_t, arraysize> status()
const;
177 template<
size_t arraysize>
178 const std::array<std::int16_t, arraysize> charge()
const;
179 template<
size_t arraysize>
180 const std::array<eic::Weight, arraysize> weight()
const;
183 bool m_isValid{
false};
184 bool m_isReadFromFile{
false};
185 int m_collectionID{0};
192 podio::CollRefCollection m_refCollections{};
193 podio::VectorMembersInfo m_vecmem_info{};
197 std::ostream&
operator<<(std::ostream& o,
const BasicParticleCollection& v);
199 template<
typename... Args>
201 const int size = m_entries.size();
203 m_entries.push_back(obj);
207 template<
size_t arraysize>
208 const std::array<eic::Index, arraysize> BasicParticleCollection::ID()
const {
209 std::array<eic::Index, arraysize> tmp;
210 const auto valid_size = std::min(arraysize, m_entries.size());
211 for (
unsigned i = 0; i < valid_size; ++i) {
212 tmp[i] = m_entries[i]->data.ID;
217 template<
size_t arraysize>
218 const std::array<eic::VectorXYZ, arraysize> BasicParticleCollection::p()
const {
219 std::array<eic::VectorXYZ, arraysize> tmp;
220 const auto valid_size = std::min(arraysize, m_entries.size());
221 for (
unsigned i = 0; i < valid_size; ++i) {
222 tmp[i] = m_entries[i]->data.p;
227 template<
size_t arraysize>
228 const std::array<eic::VectorXYZ, arraysize> BasicParticleCollection::v()
const {
229 std::array<eic::VectorXYZ, arraysize> tmp;
230 const auto valid_size = std::min(arraysize, m_entries.size());
231 for (
unsigned i = 0; i < valid_size; ++i) {
232 tmp[i] = m_entries[i]->data.v;
237 template<
size_t arraysize>
238 const std::array<float, arraysize> BasicParticleCollection::time()
const {
239 std::array<float, arraysize> tmp;
240 const auto valid_size = std::min(arraysize, m_entries.size());
241 for (
unsigned i = 0; i < valid_size; ++i) {
242 tmp[i] = m_entries[i]->data.time;
247 template<
size_t arraysize>
248 const std::array<std::int32_t, arraysize> BasicParticleCollection::pid()
const {
249 std::array<std::int32_t, arraysize> tmp;
250 const auto valid_size = std::min(arraysize, m_entries.size());
251 for (
unsigned i = 0; i < valid_size; ++i) {
252 tmp[i] = m_entries[i]->data.pid;
257 template<
size_t arraysize>
258 const std::array<std::int16_t, arraysize> BasicParticleCollection::status()
const {
259 std::array<std::int16_t, arraysize> tmp;
260 const auto valid_size = std::min(arraysize, m_entries.size());
261 for (
unsigned i = 0; i < valid_size; ++i) {
262 tmp[i] = m_entries[i]->data.status;
267 template<
size_t arraysize>
268 const std::array<std::int16_t, arraysize> BasicParticleCollection::charge()
const {
269 std::array<std::int16_t, arraysize> tmp;
270 const auto valid_size = std::min(arraysize, m_entries.size());
271 for (
unsigned i = 0; i < valid_size; ++i) {
272 tmp[i] = m_entries[i]->data.charge;
277 template<
size_t arraysize>
278 const std::array<eic::Weight, arraysize> BasicParticleCollection::weight()
const {
279 std::array<eic::Weight, arraysize> tmp;
280 const auto valid_size = std::min(arraysize, m_entries.size());
281 for (
unsigned i = 0; i < valid_size; ++i) {
282 tmp[i] = m_entries[i]->data.weight;
BasicParticleCollectionIterator & operator=(const BasicParticleCollectionIterator &)=delete
std::ostream & operator<<(std::ostream &o, const ConstBasicParticle &value)
Definition: BasicParticle.cc:102
BasicParticleCollectionIterator(const BasicParticleCollectionIterator &)=delete
BasicParticle operator*()
Definition: BasicParticleCollection.cc:106
Definition: BasicParticle.h:24
std::deque< BasicParticleObj * > BasicParticleObjPointerContainer
Definition: BasicParticleCollection.h:27
BasicParticleConstCollectionIterator(size_t index, const BasicParticleObjPointerContainer *collection)
Definition: BasicParticleCollection.h:53
BasicParticleCollectionIterator(size_t index, const BasicParticleObjPointerContainer *collection)
Definition: BasicParticleCollection.h:31
size_t size() const override final
number of elements in the collection
Definition: BasicParticleCollection.cc:39
std::vector< BasicParticleData > BasicParticleDataContainer
Definition: BasicParticleCollection.h:26
iterator end()
Definition: BasicParticleCollection.h:152
BasicParticleCollection()
Definition: BasicParticleCollection.cc:13
const_iterator end() const
Definition: BasicParticleCollection.h:155
BasicParticleCollection(const BasicParticleCollection &)=delete
bool setReferences(const podio::ICollectionProvider *collectionProvider) override final
Definition: BasicParticleCollection.cc:84
Definition: BasicParticle.cc:13
Definition: BasicParticleCollection.h:51
bool operator!=(const BasicParticleConstCollectionIterator &x) const
Definition: BasicParticleCollection.h:58
podio::CollRefCollection * referenceCollections() override final
Definition: BasicParticleCollection.h:125
BasicParticleCollectionIterator & operator++()
Definition: BasicParticleCollection.cc:116
const std::array< eic::Index, arraysize > ID() const
Definition: BasicParticleCollection.h:208
void prepareAfterRead() override final
Definition: BasicParticleCollection.cc:69
const_iterator begin() const
Definition: BasicParticleCollection.h:149
std::vector< BasicParticleData > * _getBuffer()
Returns the pointer to the data buffer.
Definition: BasicParticleCollection.h:163
podio::VectorMembersInfo * vectorMembers() override
Definition: BasicParticleCollection.h:127
Definition: BasicParticleCollection.h:29
BasicParticleConstCollectionIterator & operator++()
Definition: BasicParticleCollection.cc:133
ConstBasicParticle at(unsigned int index) const
Returns the const object of given index.
Definition: BasicParticleCollection.cc:27
bool isValid() const override final
Definition: BasicParticleCollection.h:141
unsigned getID() const override final
Definition: BasicParticleCollection.h:137
~BasicParticleCollection()
Definition: BasicParticleCollection.cc:18
BasicParticle * operator->()
Definition: BasicParticleCollection.cc:111
bool operator!=(const BasicParticleCollectionIterator &x) const
Definition: BasicParticleCollection.h:36
std::string getValueTypeName() const override
fully qualified type name of elements - with namespace
Definition: BasicParticleCollection.h:105
BasicParticleCollection & operator=(const BasicParticleCollection &)=delete
void * getBufferAddress() override final
returns the address of the pointer to the data buffer
Definition: BasicParticleCollection.h:160
void setBuffer(void *address) override final
Definition: BasicParticleCollection.cc:101
ConstBasicParticle operator*()
Definition: BasicParticleCollection.cc:123
Definition: BasicParticleObj.h:18
BasicParticleConstCollectionIterator(const BasicParticleConstCollectionIterator &)=delete
Definition: BasicParticleConst.h:22
BasicParticleConstCollectionIterator & operator=(const BasicParticleConstCollectionIterator &)=delete
iterator begin()
Definition: BasicParticleCollection.h:146
BasicParticle create()
Append a new object to the collection, and return this object.
Definition: BasicParticleCollection.cc:43
void prepareForWrite() override final
Definition: BasicParticleCollection.cc:56
void clear() override final
Definition: BasicParticleCollection.cc:50
ConstBasicParticle operator[](unsigned int index) const
Returns the const object of given index.
Definition: BasicParticleCollection.cc:23
ConstBasicParticle * operator->()
Definition: BasicParticleCollection.cc:128
Definition: BasicParticleCollection.h:76
void push_back(ConstBasicParticle object)
Append object to the collection.
Definition: BasicParticleCollection.cc:89
void setID(unsigned ID) override final
Definition: BasicParticleCollection.h:129