EDM4eic
EIC data model
Loading...
Searching...
No Matches
SimPulseCollectionData.h
Go to the documentation of this file.
1// AUTOMATICALLY GENERATED FILE - DO NOT EDIT
2
3#ifndef EDM4EIC_SimPulse_CollectionData_H
4#define EDM4EIC_SimPulse_CollectionData_H
5
6// datamodel specific includes
9#include "edm4hep/MCParticle.h"
10#include "edm4hep/SimCalorimeterHit.h"
11#include "edm4hep/SimTrackerHit.h"
12
13// schema evolution specific includes
14
15// podio specific includes
16#include "podio/CollectionBuffers.h"
17#include "podio/ICollectionProvider.h"
18
19#include <deque>
20#include <memory>
21
22namespace edm4eic {
23
24
25using SimPulseObjPointerContainer = std::deque<SimPulseObj*>;
26using SimPulseDataContainer = std::vector<SimPulseData>;
27
28
29/**
30 * Class encapsulating everything related to storage of data that is needed by a
31 * collection.
32 */
34public:
35 /**
36 * The Objs of this collection
37 */
39
40 /**
41 * Default constructor setting up the necessary buffers
42 */
44
45 /**
46 * Constructor from existing I/O buffers
47 */
48 SimPulseCollectionData(podio::CollectionReadBuffers buffers, bool isSubsetColl);
49
50 /**
51 * Non copy-able, move-only class
52 */
57
58 /**
59 * Destructor
60 */
62
63 void clear(bool isSubsetColl);
64
65 podio::CollectionWriteBuffers getCollectionBuffers(bool isSubsetColl);
66
67 void prepareForWrite(bool isSubsetColl);
68
69 void prepareAfterRead(uint32_t collectionID);
70
72
74
75 bool setReferences(const podio::ICollectionProvider* collectionProvider, bool isSubsetColl);
76
77private:
78 // members to handle 1-to-N-relations
79 podio::UVecPtr<edm4hep::SimCalorimeterHit> m_rel_calorimeterHits; ///< Relation buffer for read / write
80 std::vector<podio::UVecPtr<edm4hep::SimCalorimeterHit>> m_rel_calorimeterHits_tmp{}; ///< Relation buffer for internal book-keeping
81 podio::UVecPtr<edm4hep::SimTrackerHit> m_rel_trackerHits; ///< Relation buffer for read / write
82 std::vector<podio::UVecPtr<edm4hep::SimTrackerHit>> m_rel_trackerHits_tmp{}; ///< Relation buffer for internal book-keeping
83 podio::UVecPtr<edm4eic::SimPulse> m_rel_pulses; ///< Relation buffer for read / write
84 std::vector<podio::UVecPtr<edm4eic::SimPulse>> m_rel_pulses_tmp{}; ///< Relation buffer for internal book-keeping
85 podio::UVecPtr<edm4hep::MCParticle> m_rel_particles; ///< Relation buffer for read / write
86 std::vector<podio::UVecPtr<edm4hep::MCParticle>> m_rel_particles_tmp{}; ///< Relation buffer for internal book-keeping
87
88 // members to handle vector members
89 podio::UVecPtr<float> m_vec_amplitude{nullptr}; /// combined vector of all objects in collection
90 std::vector<podio::UVecPtr<float>> m_vecs_amplitude{}; /// pointers to individual member vectors
91
92 // I/O related buffers
93 podio::CollRefCollection m_refCollections{};
94 podio::VectorMembersInfo m_vecmem_info{};
95 std::unique_ptr<SimPulseDataContainer> m_data{nullptr};
96};
97
98
99} // namespace edm4eic
100
101
102#endif
Definition SimPulseCollectionData.h:33
bool setReferences(const podio::ICollectionProvider *collectionProvider, bool isSubsetColl)
Definition SimPulseCollectionData.cc:234
SimPulseCollectionData & operator=(const SimPulseCollectionData &)=delete
void makeSubsetCollection()
Definition SimPulseCollectionData.cc:317
void prepareAfterRead(uint32_t collectionID)
Definition SimPulseCollectionData.cc:202
void createRelations(SimPulseObj *obj)
Definition SimPulseCollectionData.cc:221
void prepareForWrite(bool isSubsetColl)
Definition SimPulseCollectionData.cc:129
SimPulseObjPointerContainer entries
Definition SimPulseCollectionData.h:38
SimPulseCollectionData()
Definition SimPulseCollectionData.cc:14
SimPulseCollectionData(const SimPulseCollectionData &)=delete
podio::CollectionWriteBuffers getCollectionBuffers(bool isSubsetColl)
Definition SimPulseCollectionData.cc:115
void clear(bool isSubsetColl)
Definition SimPulseCollectionData.cc:48
SimPulseCollectionData(SimPulseCollectionData &&other)=default
SimPulseCollectionData & operator=(SimPulseCollectionData &&other)=default
Definition SimPulseObj.h:21
Definition CalorimeterHit.cc:17
std::deque< SimPulseObj * > SimPulseObjPointerContainer
Definition SimPulseCollectionData.h:25
std::vector< SimPulseData > SimPulseDataContainer
Definition SimPulseCollectionData.h:26