Go to the documentation of this file.
3 #ifndef EICD_Cluster3DInfoCollection_H
4 #define EICD_Cluster3DInfoCollection_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::Cluster3DInfo"); }
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; }
129 void setID(
unsigned ID)
override final {
131 std::for_each(m_entries.begin(),m_entries.end(),
132 [ID] (
Cluster3DInfoObj* obj) { obj->id = {obj->id.index, static_cast<int>(ID)}; }
137 unsigned getID() const override final {
138 return m_collectionID;
153 return iterator(m_entries.size(), &m_entries);
163 std::vector<Cluster3DInfoData>*
_getBuffer() {
return m_data; }
165 template<
size_t arraysize>
166 const std::array<eic::Index, arraysize> clusterID()
const;
167 template<
size_t arraysize>
168 const std::array<eic::VectorPolar, arraysize> polar()
const;
169 template<
size_t arraysize>
170 const std::array<float, arraysize> eta()
const;
171 template<
size_t arraysize>
172 const std::array<eic::Direction, arraysize> direction()
const;
175 bool m_isValid{
false};
176 bool m_isReadFromFile{
false};
177 int m_collectionID{0};
184 podio::CollRefCollection m_refCollections{};
185 podio::VectorMembersInfo m_vecmem_info{};
189 std::ostream&
operator<<(std::ostream& o,
const Cluster3DInfoCollection& v);
191 template<
typename... Args>
193 const int size = m_entries.size();
195 m_entries.push_back(obj);
199 template<
size_t arraysize>
200 const std::array<eic::Index, arraysize> Cluster3DInfoCollection::clusterID()
const {
201 std::array<eic::Index, arraysize> tmp;
202 const auto valid_size = std::min(arraysize, m_entries.size());
203 for (
unsigned i = 0; i < valid_size; ++i) {
204 tmp[i] = m_entries[i]->data.clusterID;
209 template<
size_t arraysize>
210 const std::array<eic::VectorPolar, arraysize> Cluster3DInfoCollection::polar()
const {
211 std::array<eic::VectorPolar, arraysize> tmp;
212 const auto valid_size = std::min(arraysize, m_entries.size());
213 for (
unsigned i = 0; i < valid_size; ++i) {
214 tmp[i] = m_entries[i]->data.polar;
219 template<
size_t arraysize>
220 const std::array<float, arraysize> Cluster3DInfoCollection::eta()
const {
221 std::array<float, arraysize> tmp;
222 const auto valid_size = std::min(arraysize, m_entries.size());
223 for (
unsigned i = 0; i < valid_size; ++i) {
224 tmp[i] = m_entries[i]->data.eta;
229 template<
size_t arraysize>
230 const std::array<eic::Direction, arraysize> Cluster3DInfoCollection::direction()
const {
231 std::array<eic::Direction, arraysize> tmp;
232 const auto valid_size = std::min(arraysize, m_entries.size());
233 for (
unsigned i = 0; i < valid_size; ++i) {
234 tmp[i] = m_entries[i]->data.direction;
std::ostream & operator<<(std::ostream &o, const ConstBasicParticle &value)
Definition: BasicParticle.cc:102
void prepareAfterRead() override final
Definition: Cluster3DInfoCollection.cc:69
Cluster3DInfoConstCollectionIterator(const Cluster3DInfoConstCollectionIterator &)=delete
ConstCluster3DInfo * operator->()
Definition: Cluster3DInfoCollection.cc:128
unsigned getID() const override final
Definition: Cluster3DInfoCollection.h:137
Cluster3DInfoConstCollectionIterator(size_t index, const Cluster3DInfoObjPointerContainer *collection)
Definition: Cluster3DInfoCollection.h:53
void * getBufferAddress() override final
returns the address of the pointer to the data buffer
Definition: Cluster3DInfoCollection.h:160
podio::VectorMembersInfo * vectorMembers() override
Definition: Cluster3DInfoCollection.h:127
Cluster3DInfo operator*()
Definition: Cluster3DInfoCollection.cc:106
iterator end()
Definition: Cluster3DInfoCollection.h:152
bool operator!=(const Cluster3DInfoCollectionIterator &x) const
Definition: Cluster3DInfoCollection.h:36
Cluster3DInfo * operator->()
Definition: Cluster3DInfoCollection.cc:111
Definition: Cluster3DInfoCollection.h:51
bool operator!=(const Cluster3DInfoConstCollectionIterator &x) const
Definition: Cluster3DInfoCollection.h:58
const_iterator begin() const
Definition: Cluster3DInfoCollection.h:149
~Cluster3DInfoCollection()
Definition: Cluster3DInfoCollection.cc:18
void push_back(ConstCluster3DInfo object)
Append object to the collection.
Definition: Cluster3DInfoCollection.cc:89
ConstCluster3DInfo operator*()
Definition: Cluster3DInfoCollection.cc:123
Definition: BasicParticle.cc:13
Cluster3DInfoCollection & operator=(const Cluster3DInfoCollection &)=delete
Definition: Cluster3DInfoCollection.h:76
std::string getValueTypeName() const override
fully qualified type name of elements - with namespace
Definition: Cluster3DInfoCollection.h:105
Cluster3DInfoCollectionIterator & operator=(const Cluster3DInfoCollectionIterator &)=delete
Cluster3DInfoCollectionIterator & operator++()
Definition: Cluster3DInfoCollection.cc:116
std::vector< Cluster3DInfoData > * _getBuffer()
Returns the pointer to the data buffer.
Definition: Cluster3DInfoCollection.h:163
bool isValid() const override final
Definition: Cluster3DInfoCollection.h:141
Cluster3DInfoCollection(const Cluster3DInfoCollection &)=delete
Definition: Cluster3DInfo.h:24
iterator begin()
Definition: Cluster3DInfoCollection.h:146
const_iterator end() const
Definition: Cluster3DInfoCollection.h:155
ConstCluster3DInfo operator[](unsigned int index) const
Returns the const object of given index.
Definition: Cluster3DInfoCollection.cc:23
Definition: Cluster3DInfoCollection.h:29
size_t size() const override final
number of elements in the collection
Definition: Cluster3DInfoCollection.cc:39
Cluster3DInfoConstCollectionIterator & operator=(const Cluster3DInfoConstCollectionIterator &)=delete
void clear() override final
Definition: Cluster3DInfoCollection.cc:50
Cluster3DInfoConstCollectionIterator & operator++()
Definition: Cluster3DInfoCollection.cc:133
std::vector< Cluster3DInfoData > Cluster3DInfoDataContainer
Definition: Cluster3DInfoCollection.h:26
void prepareForWrite() override final
Definition: Cluster3DInfoCollection.cc:56
ConstCluster3DInfo at(unsigned int index) const
Returns the const object of given index.
Definition: Cluster3DInfoCollection.cc:27
void setID(unsigned ID) override final
Definition: Cluster3DInfoCollection.h:129
podio::CollRefCollection * referenceCollections() override final
Definition: Cluster3DInfoCollection.h:125
std::deque< Cluster3DInfoObj * > Cluster3DInfoObjPointerContainer
Definition: Cluster3DInfoCollection.h:27
Cluster3DInfoCollectionIterator(size_t index, const Cluster3DInfoObjPointerContainer *collection)
Definition: Cluster3DInfoCollection.h:31
void setBuffer(void *address) override final
Definition: Cluster3DInfoCollection.cc:101
Definition: Cluster3DInfoObj.h:18
Definition: Cluster3DInfoConst.h:22
bool setReferences(const podio::ICollectionProvider *collectionProvider) override final
Definition: Cluster3DInfoCollection.cc:84
Cluster3DInfo create()
Append a new object to the collection, and return this object.
Definition: Cluster3DInfoCollection.cc:43
Cluster3DInfoCollectionIterator(const Cluster3DInfoCollectionIterator &)=delete
Cluster3DInfoCollection()
Definition: Cluster3DInfoCollection.cc:13