EICd
EIC data model
TrackerHitCollection.h
Go to the documentation of this file.
1 // AUTOMATICALLY GENERATED FILE - DO NOT EDIT
2 
3 #ifndef EICD_TrackerHitCollection_H
4 #define EICD_TrackerHitCollection_H
5 
6 // datamodel specific includes
7 #include "eicd/TrackerHitData.h"
8 #include "eicd/TrackerHit.h"
9 #include "eicd/TrackerHitObj.h"
10 
11 // podio specific includes
12 #include "podio/ICollectionProvider.h"
13 #include "podio/CollectionBase.h"
14 #include "podio/CollectionIDTable.h"
15 
16 #include <string>
17 #include <vector>
18 #include <deque>
19 #include <array>
20 #include <algorithm>
21 #include <ostream>
22 
23 namespace eic {
24 
25 
26 using TrackerHitDataContainer = std::vector<TrackerHitData>;
27 using TrackerHitObjPointerContainer = std::deque<TrackerHitObj*>;
28 
30 public:
31  TrackerHitCollectionIterator(size_t index, const TrackerHitObjPointerContainer* collection) : m_index(index), m_object(nullptr), m_collection(collection) {}
32 
35 
37  return m_index != x.m_index; // TODO: may not be complete
38  }
39 
43 
44 private:
45  size_t m_index;
46  TrackerHit m_object;
47  const TrackerHitObjPointerContainer* m_collection;
48 };
49 
50 
52 public:
53  TrackerHitConstCollectionIterator(size_t index, const TrackerHitObjPointerContainer* collection) : m_index(index), m_object(nullptr), m_collection(collection) {}
54 
57 
59  return m_index != x.m_index; // TODO: may not be complete
60  }
61 
65 
66 private:
67  size_t m_index;
68  ConstTrackerHit m_object;
69  const TrackerHitObjPointerContainer* m_collection;
70 };
71 
72 
73 /**
74 A Collection is identified by an ID.
75 */
76 class TrackerHitCollection : public podio::CollectionBase {
77 
78 public:
81 
85 // TrackerHitCollection(TrackerHitVector* data, int collectionID);
87 
88  void clear() override final;
89 
90  /// operator to allow pointer like calling of members a la LCIO
91  TrackerHitCollection* operator->() { return (TrackerHitCollection*) this; }
92 
93  /// Append a new object to the collection, and return this object.
95 
96  /// Append a new object to the collection, and return this object.
97  /// Initialized with the parameters given
98  template<typename... Args>
99  TrackerHit create(Args&&... args);
100 
101  /// number of elements in the collection
102  size_t size() const override final;
103 
104  /// fully qualified type name of elements - with namespace
105  std::string getValueTypeName() const override { return std::string("eic::TrackerHit"); }
106 
107  /// Returns the const object of given index
108  ConstTrackerHit operator[](unsigned int index) const;
109  /// Returns the object of a given index
110  TrackerHit operator[](unsigned int index);
111  /// Returns the const object of given index
112  ConstTrackerHit at(unsigned int index) const;
113  /// Returns the object of given index
114  TrackerHit at(unsigned int index);
115 
116 
117  /// Append object to the collection
118  void push_back(ConstTrackerHit object);
119 
120  void prepareForWrite() override final;
121  void prepareAfterRead() override final;
122  void setBuffer(void* address) override final;
123  bool setReferences(const podio::ICollectionProvider* collectionProvider) override final;
124 
125  podio::CollRefCollection* referenceCollections() override final { return &m_refCollections; }
126 
127  podio::VectorMembersInfo* vectorMembers() override { return &m_vecmem_info; }
128 
129  void setID(unsigned ID) override final {
130  m_collectionID = ID;
131  std::for_each(m_entries.begin(),m_entries.end(),
132  [ID] (TrackerHitObj* obj) { obj->id = {obj->id.index, static_cast<int>(ID)}; }
133  );
134  m_isValid = true;
135  };
136 
137  unsigned getID() const override final {
138  return m_collectionID;
139  }
140 
141  bool isValid() const override final {
142  return m_isValid;
143  }
144 
145  // support for the iterator protocol
147  return iterator(0, &m_entries);
148  }
150  return const_iterator(0, &m_entries);
151  }
153  return iterator(m_entries.size(), &m_entries);
154  }
155  const_iterator end() const {
156  return const_iterator(m_entries.size(), &m_entries);
157  }
158 
159  /// returns the address of the pointer to the data buffer
160  void* getBufferAddress() override final { return (void*)&m_data; }
161 
162  /// Returns the pointer to the data buffer
163  std::vector<TrackerHitData>* _getBuffer() { return m_data; }
164 
165  template<size_t arraysize>
166  const std::array<eic::Index, arraysize> ID() const;
167  template<size_t arraysize>
168  const std::array<std::int64_t, arraysize> cellID() const;
169  template<size_t arraysize>
170  const std::array<eic::VectorXYZT, arraysize> position() const;
171  template<size_t arraysize>
172  const std::array<eic::CovDiagXYZT, arraysize> covMatrix() const;
173  template<size_t arraysize>
174  const std::array<float, arraysize> edep() const;
175  template<size_t arraysize>
176  const std::array<float, arraysize> edepError() const;
177 
178 private:
179  bool m_isValid{false};
180  bool m_isReadFromFile{false};
181  int m_collectionID{0};
183 
184  // members to handle 1-to-N-relations
185 
186  // members to handle vector members
187  // members to handle streaming
188  podio::CollRefCollection m_refCollections{};
189  podio::VectorMembersInfo m_vecmem_info{};
190  TrackerHitDataContainer* m_data;
191 };
192 
193 std::ostream& operator<<(std::ostream& o, const TrackerHitCollection& v);
194 
195 template<typename... Args>
196 TrackerHit TrackerHitCollection::create(Args&&... args) {
197  const int size = m_entries.size();
198  auto obj = new TrackerHitObj({size, m_collectionID}, {args...});
199  m_entries.push_back(obj);
200  return TrackerHit(obj);
201 }
202 
203 template<size_t arraysize>
204 const std::array<eic::Index, arraysize> TrackerHitCollection::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;
209  }
210  return tmp;
211 }
212 
213 template<size_t arraysize>
214 const std::array<std::int64_t, arraysize> TrackerHitCollection::cellID() const {
215  std::array<std::int64_t, 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.cellID;
219  }
220  return tmp;
221 }
222 
223 template<size_t arraysize>
224 const std::array<eic::VectorXYZT, arraysize> TrackerHitCollection::position() const {
225  std::array<eic::VectorXYZT, 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.position;
229  }
230  return tmp;
231 }
232 
233 template<size_t arraysize>
234 const std::array<eic::CovDiagXYZT, arraysize> TrackerHitCollection::covMatrix() const {
235  std::array<eic::CovDiagXYZT, 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.covMatrix;
239  }
240  return tmp;
241 }
242 
243 template<size_t arraysize>
244 const std::array<float, arraysize> TrackerHitCollection::edep() 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.edep;
249  }
250  return tmp;
251 }
252 
253 template<size_t arraysize>
254 const std::array<float, arraysize> TrackerHitCollection::edepError() const {
255  std::array<float, 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.edepError;
259  }
260  return tmp;
261 }
262 
263 
264 } // namespace eic
265 
266 
267 #endif
eic::operator<<
std::ostream & operator<<(std::ostream &o, const ConstBasicParticle &value)
Definition: BasicParticle.cc:102
eic::TrackerHitConstCollectionIterator::operator->
ConstTrackerHit * operator->()
Definition: TrackerHitCollection.cc:128
TrackerHitData.h
eic::TrackerHitCollectionIterator::TrackerHitCollectionIterator
TrackerHitCollectionIterator(size_t index, const TrackerHitObjPointerContainer *collection)
Definition: TrackerHitCollection.h:31
eic::TrackerHitCollectionIterator
Definition: TrackerHitCollection.h:29
eic::TrackerHitCollection::clear
void clear() override final
Definition: TrackerHitCollection.cc:50
eic::TrackerHitCollectionIterator::operator=
TrackerHitCollectionIterator & operator=(const TrackerHitCollectionIterator &)=delete
eic::TrackerHitCollectionIterator::operator->
TrackerHit * operator->()
Definition: TrackerHitCollection.cc:111
eic::TrackerHitCollection::setReferences
bool setReferences(const podio::ICollectionProvider *collectionProvider) override final
Definition: TrackerHitCollection.cc:84
eic::TrackerHitCollection::at
ConstTrackerHit at(unsigned int index) const
Returns the const object of given index.
Definition: TrackerHitCollection.cc:27
eic::TrackerHitCollectionIterator::operator++
TrackerHitCollectionIterator & operator++()
Definition: TrackerHitCollection.cc:116
eic::TrackerHitCollection::getID
unsigned getID() const override final
Definition: TrackerHitCollection.h:137
eic::TrackerHitCollection::TrackerHitCollection
TrackerHitCollection()
Definition: TrackerHitCollection.cc:13
eic
Definition: BasicParticle.cc:13
eic::TrackerHitConstCollectionIterator::operator*
ConstTrackerHit operator*()
Definition: TrackerHitCollection.cc:123
eic::TrackerHitCollection::prepareAfterRead
void prepareAfterRead() override final
Definition: TrackerHitCollection.cc:69
eic::TrackerHitCollectionIterator::operator*
TrackerHit operator*()
Definition: TrackerHitCollection.cc:106
eic::TrackerHitCollection::end
const_iterator end() const
Definition: TrackerHitCollection.h:155
eic::TrackerHitCollection::~TrackerHitCollection
~TrackerHitCollection()
Definition: TrackerHitCollection.cc:18
eic::TrackerHitCollection
Definition: TrackerHitCollection.h:76
eic::TrackerHitCollection::operator[]
ConstTrackerHit operator[](unsigned int index) const
Returns the const object of given index.
Definition: TrackerHitCollection.cc:23
eic::TrackerHitCollection::setBuffer
void setBuffer(void *address) override final
Definition: TrackerHitCollection.cc:101
eic::TrackerHitCollection::end
iterator end()
Definition: TrackerHitCollection.h:152
eic::TrackerHitObj
Definition: TrackerHitObj.h:18
eic::TrackerHitCollection::getBufferAddress
void * getBufferAddress() override final
returns the address of the pointer to the data buffer
Definition: TrackerHitCollection.h:160
eic::TrackerHitCollection::begin
iterator begin()
Definition: TrackerHitCollection.h:146
eic::TrackerHitConstCollectionIterator
Definition: TrackerHitCollection.h:51
eic::TrackerHitCollection::create
TrackerHit create()
Append a new object to the collection, and return this object.
Definition: TrackerHitCollection.cc:43
eic::TrackerHitConstCollectionIterator::operator++
TrackerHitConstCollectionIterator & operator++()
Definition: TrackerHitCollection.cc:133
eic::TrackerHitCollection::ID
const std::array< eic::Index, arraysize > ID() const
Definition: TrackerHitCollection.h:204
eic::ConstTrackerHit
Definition: TrackerHitConst.h:22
eic::TrackerHitConstCollectionIterator::TrackerHitConstCollectionIterator
TrackerHitConstCollectionIterator(size_t index, const TrackerHitObjPointerContainer *collection)
Definition: TrackerHitCollection.h:53
TrackerHitObj.h
eic::TrackerHitCollection::size
size_t size() const override final
number of elements in the collection
Definition: TrackerHitCollection.cc:39
TrackerHit.h
eic::TrackerHitCollection::isValid
bool isValid() const override final
Definition: TrackerHitCollection.h:141
eic::TrackerHit
Definition: TrackerHit.h:24
eic::TrackerHitCollectionIterator::operator!=
bool operator!=(const TrackerHitCollectionIterator &x) const
Definition: TrackerHitCollection.h:36
eic::TrackerHitConstCollectionIterator::TrackerHitConstCollectionIterator
TrackerHitConstCollectionIterator(const TrackerHitConstCollectionIterator &)=delete
eic::TrackerHitCollection::referenceCollections
podio::CollRefCollection * referenceCollections() override final
Definition: TrackerHitCollection.h:125
eic::TrackerHitConstCollectionIterator::operator=
TrackerHitConstCollectionIterator & operator=(const TrackerHitConstCollectionIterator &)=delete
eic::TrackerHitCollection::setID
void setID(unsigned ID) override final
Definition: TrackerHitCollection.h:129
eic::TrackerHitObjPointerContainer
std::deque< TrackerHitObj * > TrackerHitObjPointerContainer
Definition: TrackerHitCollection.h:27
eic::TrackerHitConstCollectionIterator::operator!=
bool operator!=(const TrackerHitConstCollectionIterator &x) const
Definition: TrackerHitCollection.h:58
eic::TrackerHitCollection::getValueTypeName
std::string getValueTypeName() const override
fully qualified type name of elements - with namespace
Definition: TrackerHitCollection.h:105
eic::TrackerHitCollectionIterator::TrackerHitCollectionIterator
TrackerHitCollectionIterator(const TrackerHitCollectionIterator &)=delete
eic::TrackerHitCollection::TrackerHitCollection
TrackerHitCollection(const TrackerHitCollection &)=delete
eic::TrackerHitCollection::begin
const_iterator begin() const
Definition: TrackerHitCollection.h:149
eic::TrackerHitCollection::operator=
TrackerHitCollection & operator=(const TrackerHitCollection &)=delete
eic::TrackerHitCollection::_getBuffer
std::vector< TrackerHitData > * _getBuffer()
Returns the pointer to the data buffer.
Definition: TrackerHitCollection.h:163
eic::TrackerHitCollection::push_back
void push_back(ConstTrackerHit object)
Append object to the collection.
Definition: TrackerHitCollection.cc:89
eic::TrackerHitDataContainer
std::vector< TrackerHitData > TrackerHitDataContainer
Definition: TrackerHitCollection.h:26
eic::TrackerHitCollection::prepareForWrite
void prepareForWrite() override final
Definition: TrackerHitCollection.cc:56
eic::TrackerHitCollection::vectorMembers
podio::VectorMembersInfo * vectorMembers() override
Definition: TrackerHitCollection.h:127