Go to the documentation of this file.
3 #ifndef EICD_VertexCollection_H
4 #define EICD_VertexCollection_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;
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(),
132 [
ID] (
VertexObj* 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);
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> position()
const;
169 template<
size_t arraysize>
170 const std::array<float, arraysize> time()
const;
171 template<
size_t arraysize>
172 const std::array<float, arraysize> chi2()
const;
173 template<
size_t arraysize>
174 const std::array<float, arraysize> probability()
const;
175 template<
size_t arraysize>
176 const std::array<bool, arraysize> primary()
const;
179 bool m_isValid{
false};
180 bool m_isReadFromFile{
false};
181 int m_collectionID{0};
188 podio::CollRefCollection m_refCollections{};
189 podio::VectorMembersInfo m_vecmem_info{};
193 std::ostream&
operator<<(std::ostream& o,
const VertexCollection& v);
195 template<
typename... Args>
196 Vertex VertexCollection::create(Args&&... args) {
197 const int size = m_entries.size();
198 auto obj =
new VertexObj({size, m_collectionID}, {args...});
199 m_entries.push_back(obj);
203 template<
size_t arraysize>
204 const std::array<eic::Index, arraysize> VertexCollection::ID()
const {
205 std::array<eic::Index, arraysize> tmp;
206 const auto valid_size = std::min(arraysize, m_entries.size());
207 for (
unsigned i = 0; i < valid_size; ++i) {
208 tmp[i] = m_entries[i]->data.ID;
213 template<
size_t arraysize>
214 const std::array<eic::VectorXYZ, arraysize> VertexCollection::position()
const {
215 std::array<eic::VectorXYZ, arraysize> tmp;
216 const auto valid_size = std::min(arraysize, m_entries.size());
217 for (
unsigned i = 0; i < valid_size; ++i) {
218 tmp[i] = m_entries[i]->data.position;
223 template<
size_t arraysize>
224 const std::array<float, arraysize> VertexCollection::time()
const {
225 std::array<float, arraysize> tmp;
226 const auto valid_size = std::min(arraysize, m_entries.size());
227 for (
unsigned i = 0; i < valid_size; ++i) {
228 tmp[i] = m_entries[i]->data.time;
233 template<
size_t arraysize>
234 const std::array<float, arraysize> VertexCollection::chi2()
const {
235 std::array<float, arraysize> tmp;
236 const auto valid_size = std::min(arraysize, m_entries.size());
237 for (
unsigned i = 0; i < valid_size; ++i) {
238 tmp[i] = m_entries[i]->data.chi2;
243 template<
size_t arraysize>
244 const std::array<float, arraysize> VertexCollection::probability()
const {
245 std::array<float, arraysize> tmp;
246 const auto valid_size = std::min(arraysize, m_entries.size());
247 for (
unsigned i = 0; i < valid_size; ++i) {
248 tmp[i] = m_entries[i]->data.probability;
253 template<
size_t arraysize>
254 const std::array<bool, arraysize> VertexCollection::primary()
const {
255 std::array<bool, arraysize> tmp;
256 const auto valid_size = std::min(arraysize, m_entries.size());
257 for (
unsigned i = 0; i < valid_size; ++i) {
258 tmp[i] = m_entries[i]->data.primary;
std::ostream & operator<<(std::ostream &o, const ConstBasicParticle &value)
Definition: BasicParticle.cc:102
std::vector< VertexData > VertexDataContainer
Definition: VertexCollection.h:26
podio::VectorMembersInfo * vectorMembers() override
Definition: VertexCollection.h:127
bool operator!=(const VertexCollectionIterator &x) const
Definition: VertexCollection.h:36
std::deque< VertexObj * > VertexObjPointerContainer
Definition: VertexCollection.h:27
std::string getValueTypeName() const override
fully qualified type name of elements - with namespace
Definition: VertexCollection.h:105
void push_back(ConstVertex object)
Append object to the collection.
Definition: VertexCollection.cc:89
iterator end()
Definition: VertexCollection.h:152
void clear() override final
Definition: VertexCollection.cc:50
ConstVertex operator*()
Definition: VertexCollection.cc:123
bool isValid() const override final
Definition: VertexCollection.h:141
Definition: VertexCollection.h:51
Definition: BasicParticle.cc:13
VertexCollection()
Definition: VertexCollection.cc:13
bool operator!=(const VertexConstCollectionIterator &x) const
Definition: VertexCollection.h:58
std::vector< VertexData > * _getBuffer()
Returns the pointer to the data buffer.
Definition: VertexCollection.h:163
Definition: VertexConst.h:21
void prepareForWrite() override final
Definition: VertexCollection.cc:56
VertexConstCollectionIterator(const VertexConstCollectionIterator &)=delete
ConstVertex * operator->()
Definition: VertexCollection.cc:128
VertexCollectionIterator(const VertexCollectionIterator &)=delete
Vertex operator*()
Definition: VertexCollection.cc:106
const_iterator end() const
Definition: VertexCollection.h:155
Vertex create()
Append a new object to the collection, and return this object.
Definition: VertexCollection.cc:43
void prepareAfterRead() override final
Definition: VertexCollection.cc:69
ConstVertex at(unsigned int index) const
Returns the const object of given index.
Definition: VertexCollection.cc:27
podio::CollRefCollection * referenceCollections() override final
Definition: VertexCollection.h:125
unsigned getID() const override final
Definition: VertexCollection.h:137
iterator begin()
Definition: VertexCollection.h:146
size_t size() const override final
number of elements in the collection
Definition: VertexCollection.cc:39
VertexConstCollectionIterator & operator++()
Definition: VertexCollection.cc:133
VertexConstCollectionIterator(size_t index, const VertexObjPointerContainer *collection)
Definition: VertexCollection.h:53
void setID(unsigned ID) override final
Definition: VertexCollection.h:129
bool setReferences(const podio::ICollectionProvider *collectionProvider) override final
Definition: VertexCollection.cc:84
ConstVertex operator[](unsigned int index) const
Returns the const object of given index.
Definition: VertexCollection.cc:23
VertexCollectionIterator & operator=(const VertexCollectionIterator &)=delete
Vertex * operator->()
Definition: VertexCollection.cc:111
Definition: VertexCollection.h:76
Definition: VertexCollection.h:29
VertexCollection(const VertexCollection &)=delete
void setBuffer(void *address) override final
Definition: VertexCollection.cc:101
~VertexCollection()
Definition: VertexCollection.cc:18
const std::array< eic::Index, arraysize > ID() const
Definition: VertexCollection.h:204
VertexCollectionIterator(size_t index, const VertexObjPointerContainer *collection)
Definition: VertexCollection.h:31
VertexCollectionIterator & operator++()
Definition: VertexCollection.cc:116
VertexConstCollectionIterator & operator=(const VertexConstCollectionIterator &)=delete
void * getBufferAddress() override final
returns the address of the pointer to the data buffer
Definition: VertexCollection.h:160
Definition: VertexObj.h:18
VertexCollection & operator=(const VertexCollection &)=delete
const_iterator begin() const
Definition: VertexCollection.h:149