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