EDM4eic
EIC data model
Loading...
Searching...
No Matches
MCRecoTrackParticleAssociation.h
Go to the documentation of this file.
1// AUTOMATICALLY GENERATED FILE - DO NOT EDIT
2
3#ifndef EDM4EIC_MCRecoTrackParticleAssociation_H
4#define EDM4EIC_MCRecoTrackParticleAssociation_H
5
7
8#include <edm4eic/Track.h>
9#include <edm4hep/MCParticle.h>
10
11#include "podio/utilities/MaybeSharedPtr.h"
12#include "podio/detail/OrderKey.h"
13
14#include <ostream>
15#include <cstdint>
16
17#if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
18#include "nlohmann/json_fwd.hpp"
19#endif
20
21// forward declarations
22namespace edm4eic {
24class Track;
25class MutableTrack;
26}
27namespace edm4hep {
28class MCParticle;
29class MutableMCParticle;
30}
31
32
33namespace podio::detail {
34// Internal function used in less comparison operators of the datatypes and interface types
35OrderKey getOrderKey(const edm4eic::MCRecoTrackParticleAssociation& obj);
36};
37
38namespace edm4eic {
39
43
44/** @class MCRecoTrackParticleAssociation
45 * Association between a Track and a MCParticle
46 * @author: S. Joosten
47 */
49
54 friend podio::detail::OrderKey podio::detail::getOrderKey(const MCRecoTrackParticleAssociation & obj);
55
56public:
59
60 /// default constructor
62
63 /// Constructor initializing all members
64 MCRecoTrackParticleAssociation(const float weight);
65
66 /// copy constructor
68
69 /// copy-assignment operator
70 MCRecoTrackParticleAssociation& operator=(MCRecoTrackParticleAssociation other) &; // Rebind this to other's internal object
71 MCRecoTrackParticleAssociation& operator=(MCRecoTrackParticleAssociation other) && = delete; // Prevent rebinding temporary as the changes wouldn't persist
72
73 /// create a mutable deep-copy of the object with identical relations
74 /// if cloneRelations=false, the relations are not cloned and will be empty
75 MutableMCRecoTrackParticleAssociation clone(bool cloneRelations=true) const;
76
77 /// destructor
79
80 /// converting constructor from mutable object
82
84
85public:
86
87 static constexpr std::string_view typeName = "edm4eic::MCRecoTrackParticleAssociation";
88
89 /// Access the weight of this association
90 float getWeight() const;
91
92
93 /// Access the reference to the track
94 const edm4eic::Track getRec() const;
95 /// Access the reference to the Monte-Carlo particle
96 const edm4hep::MCParticle getSim() const;
97
98
99 [[deprecated("use getSim().getObjectID().index instead")]] int getSimID() const { return getSim().getObjectID().index; }
100 [[deprecated("use getRec().getObjectID().index instead")]] int getRecID() const { return getRec().getObjectID().index; }
101
102
103 /// check whether the object is actually available
104 bool isAvailable() const;
105 /// disconnect from MCRecoTrackParticleAssociationObj instance
106 void unlink() { m_obj = podio::utils::MaybeSharedPtr<MCRecoTrackParticleAssociationObj>{nullptr}; }
107
108 bool operator==(const MCRecoTrackParticleAssociation& other) const { return m_obj == other.m_obj; }
109 bool operator==(const MutableMCRecoTrackParticleAssociation& other) const;
110
111 bool operator!=(const MCRecoTrackParticleAssociation& other) const { return !(*this == other); }
112 bool operator!=(const MutableMCRecoTrackParticleAssociation& other) const { return !(*this == other); }
113
114 // less comparison operator, so that objects can be e.g. stored in sets.
116
117 podio::ObjectID id() const { return getObjectID(); }
118
119 const podio::ObjectID getObjectID() const;
120
121 friend std::hash<MCRecoTrackParticleAssociation>;
122
124 using std::swap;
125 swap(a.m_obj, b.m_obj); // swap out the internal pointers
126 }
127
128private:
129 /// constructor from existing MCRecoTrackParticleAssociationObj
130 explicit MCRecoTrackParticleAssociation(podio::utils::MaybeSharedPtr<MCRecoTrackParticleAssociationObj> obj);
132
133 podio::utils::MaybeSharedPtr<MCRecoTrackParticleAssociationObj> m_obj{new MCRecoTrackParticleAssociationObj{}, podio::utils::MarkOwned};
134};
135
136std::ostream& operator<<(std::ostream& o, const MCRecoTrackParticleAssociation& value);
137
138#if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
139void to_json(nlohmann::json& j, const MCRecoTrackParticleAssociation& value);
140#endif
141
142
143} // namespace edm4eic
144
145
146
147template<>
148struct std::hash<edm4eic::MCRecoTrackParticleAssociation> {
150 return std::hash<edm4eic::MCRecoTrackParticleAssociationObj*>{}(obj.m_obj.get());
151 }
152};
153
154
155// This is needed to avoid triggering opening every library in LD_LIBRARY_PATH
156// until it's fixed in ROOT. See https://github.com/root-project/root/issues/18489
157// and https://github.com/AIDASoft/podio/issues/770
158#if defined(__clang__)
159 #pragma clang diagnostic push
160 #pragma clang diagnostic ignored "-Wunknown-warning-option"
161 #pragma clang diagnostic ignored "-Wdeprecated-redundant-constexpr-static-def"
162 #pragma clang diagnostic ignored "-Wdeprecated"
164 #pragma clang diagnostic pop
165#elif defined(__GNUC__)
166 #pragma GCC diagnostic push
167 #pragma GCC diagnostic ignored "-Wdeprecated"
169 #pragma GCC diagnostic pop
170#endif
171
172
173#endif
Definition MCRecoTrackParticleAssociationCollectionData.h:33
Definition MCRecoTrackParticleAssociationCollection.h:138
Definition MCRecoTrackParticleAssociation.h:48
friend class MCRecoTrackParticleAssociationCollection
Definition MCRecoTrackParticleAssociation.h:51
MutableMCRecoTrackParticleAssociation mutable_type
Definition MCRecoTrackParticleAssociation.h:57
const edm4hep::MCParticle getSim() const
Access the reference to the Monte-Carlo particle.
Definition MCRecoTrackParticleAssociation.cc:65
MCRecoTrackParticleAssociation & operator=(MCRecoTrackParticleAssociation other) &&=delete
int getSimID() const
Definition MCRecoTrackParticleAssociation.h:99
bool operator!=(const MutableMCRecoTrackParticleAssociation &other) const
Definition MCRecoTrackParticleAssociation.h:112
friend class MutableMCRecoTrackParticleAssociation
Definition MCRecoTrackParticleAssociation.h:50
static MCRecoTrackParticleAssociation makeEmpty()
Definition MCRecoTrackParticleAssociation.cc:52
friend void swap(MCRecoTrackParticleAssociation &a, MCRecoTrackParticleAssociation &b)
Definition MCRecoTrackParticleAssociation.h:123
bool operator!=(const MCRecoTrackParticleAssociation &other) const
Definition MCRecoTrackParticleAssociation.h:111
MCRecoTrackParticleAssociation()=default
default constructor
MCRecoTrackParticleAssociation & operator=(MCRecoTrackParticleAssociation other) &
copy-assignment operator
Definition MCRecoTrackParticleAssociation.cc:26
bool isAvailable() const
check whether the object is actually available
Definition MCRecoTrackParticleAssociation.cc:77
MutableMCRecoTrackParticleAssociation clone(bool cloneRelations=true) const
Definition MCRecoTrackParticleAssociation.cc:31
friend class MCRecoTrackParticleAssociationCollectionIterator
Definition MCRecoTrackParticleAssociation.h:53
~MCRecoTrackParticleAssociation()=default
destructor
MCRecoTrackParticleAssociation(const MCRecoTrackParticleAssociation &other)=default
copy constructor
static constexpr std::string_view typeName
Definition MCRecoTrackParticleAssociation.h:87
podio::ObjectID id() const
Definition MCRecoTrackParticleAssociation.h:117
float getWeight() const
Access the weight of this association.
Definition MCRecoTrackParticleAssociation.cc:56
const podio::ObjectID getObjectID() const
Definition MCRecoTrackParticleAssociation.cc:81
MCRecoTrackParticleAssociationCollection collection_type
Definition MCRecoTrackParticleAssociation.h:58
int getRecID() const
Definition MCRecoTrackParticleAssociation.h:100
bool operator<(const MCRecoTrackParticleAssociation &other) const
Definition MCRecoTrackParticleAssociation.h:115
bool operator==(const MCRecoTrackParticleAssociation &other) const
Definition MCRecoTrackParticleAssociation.h:108
void unlink()
disconnect from MCRecoTrackParticleAssociationObj instance
Definition MCRecoTrackParticleAssociation.h:106
const edm4eic::Track getRec() const
Access the reference to the track.
Definition MCRecoTrackParticleAssociation.cc:58
Definition MCRecoTrackParticleAssociationObj.h:24
Definition MutableMCRecoTrackParticleAssociation.h:40
Definition MutableTrack.h:40
Definition Track.h:48
const podio::ObjectID getObjectID() const
Definition Track.cc:174
Definition CalorimeterHit.cc:17
std::ostream & operator<<(std::ostream &o, const CalorimeterHit &value)
Definition CalorimeterHit.cc:99
Definition CalorimeterHit.h:25
Definition CalorimeterHit.h:31
OrderKey getOrderKey(const edm4eic::CalorimeterHit &obj)
Definition CalorimeterHit.cc:146
std::size_t operator()(const edm4eic::MCRecoTrackParticleAssociation &obj) const
Definition MCRecoTrackParticleAssociation.h:149