EDM4eic
EIC data model
Loading...
Searching...
No Matches
MutableMCRecoParticleAssociation.h
Go to the documentation of this file.
1// AUTOMATICALLY GENERATED FILE - DO NOT EDIT
2
3#ifndef EDM4EIC_MutableMCRecoParticleAssociation_H
4#define EDM4EIC_MutableMCRecoParticleAssociation_H
5
7// Make the immutable class available from its mutable version but not vice versa
9
11#include <edm4hep/MCParticle.h>
12
13#include "podio/utilities/MaybeSharedPtr.h"
14
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 {
26}
27namespace edm4hep {
28class MCParticle;
29class MutableMCParticle;
30}
31
32
33namespace edm4eic {
34
35
36/** @class MutableMCRecoParticleAssociation
37 * Used to keep track of the correspondence between MC and reconstructed particles
38 * @author: S. Joosten
39 */
41
45
46public:
49
50 /// default constructor
52
53 /// Constructor initializing all members
55
56 /// copy constructor
58
59 /// copy-assignment operator
60 MutableMCRecoParticleAssociation& operator=(MutableMCRecoParticleAssociation other) &; // Rebind this to other's internal object
61 MutableMCRecoParticleAssociation& operator=(MutableMCRecoParticleAssociation other) && = delete; // Prevent rebinding temporary as the changes wouldn't persist
62
63 /// create a mutable deep-copy of the object with identical relations
64 /// if cloneRelations=false, the relations are not cloned and will be empty
65 MutableMCRecoParticleAssociation clone(bool cloneRelations=true) const;
66
67 /// destructor
69
70
71public:
72
73 /// Access the weight of this association
74 float getWeight() const;
75
76
77 /// Access the reference to the reconstructed particle
79 /// Access the reference to the Monte-Carlo particle
80 const edm4hep::MCParticle getSim() const;
81
82 /// Set the weight of this association
83 void setWeight(const float weight);
84 /// Get mutable reference to weight of this association
85 float& getWeight();
86 /// Get reference to weight of this association
87 [[deprecated("use getWeight instead")]]
88 float& weight();
89
90
91 /// Set the reference to the reconstructed particle
92 void setRec(const edm4eic::ReconstructedParticle& value);
93 /// Set the reference to the Monte-Carlo particle
94 void setSim(const edm4hep::MCParticle& value);
95
96
97 [[deprecated("use getSim().getObjectID().index instead")]] int getSimID() const { return getSim().getObjectID().index; }
98 [[deprecated("use getRec().getObjectID().index instead")]] int getRecID() const { return getRec().getObjectID().index; }
99
100
101 [[deprecated("use setSim() instead; this function does nothing")]] void setSimID(int) { }
102 [[deprecated("use setRec() instead; this function does nothing")]] void setRecID(int) { }
103
104
105 /// check whether the object is actually available
106 bool isAvailable() const;
107 /// disconnect from MCRecoParticleAssociationObj instance
108 void unlink() { m_obj = podio::utils::MaybeSharedPtr<MCRecoParticleAssociationObj>{nullptr}; }
109
110 bool operator==(const MutableMCRecoParticleAssociation& other) const { return m_obj == other.m_obj; }
111 bool operator==(const MCRecoParticleAssociation& other) const;
112
113 bool operator!=(const MutableMCRecoParticleAssociation& other) const { return !(*this == other); }
114 bool operator!=(const MCRecoParticleAssociation& other) const { return !(*this == other); }
115
116 // less comparison operator, so that objects can be e.g. stored in sets.
118
119 podio::ObjectID id() const { return getObjectID(); }
120
121 const podio::ObjectID getObjectID() const;
122
123 friend std::hash<MutableMCRecoParticleAssociation>;
124
126 using std::swap;
127 swap(a.m_obj, b.m_obj); // swap out the internal pointers
128 }
129
130private:
131 /// constructor from existing MCRecoParticleAssociationObj
132 explicit MutableMCRecoParticleAssociation(podio::utils::MaybeSharedPtr<MCRecoParticleAssociationObj> obj);
133
134 podio::utils::MaybeSharedPtr<MCRecoParticleAssociationObj> m_obj{new MCRecoParticleAssociationObj{}, podio::utils::MarkOwned};
135};
136
137#if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
138void to_json(nlohmann::json& j, const MutableMCRecoParticleAssociation& value);
139#endif
140
141
142} // namespace edm4eic
143
144
145
146template<>
147struct std::hash<edm4eic::MutableMCRecoParticleAssociation> {
149 return std::hash<edm4eic::MCRecoParticleAssociationObj*>{}(obj.m_obj.get());
150 }
151};
152
153
154#endif
Definition MCRecoParticleAssociationCollection.h:138
Definition MCRecoParticleAssociation.h:48
Definition MCRecoParticleAssociationObj.h:24
Definition MutableMCRecoParticleAssociation.h:40
void setSimID(int)
Definition MutableMCRecoParticleAssociation.h:101
const edm4hep::MCParticle getSim() const
Access the reference to the Monte-Carlo particle.
Definition MutableMCRecoParticleAssociation.cc:48
bool operator!=(const MutableMCRecoParticleAssociation &other) const
Definition MutableMCRecoParticleAssociation.h:113
MutableMCRecoParticleAssociation(const MutableMCRecoParticleAssociation &other)=default
copy constructor
MutableMCRecoParticleAssociation & operator=(MutableMCRecoParticleAssociation other) &&=delete
const podio::ObjectID getObjectID() const
Definition MutableMCRecoParticleAssociation.cc:78
void setRec(const edm4eic::ReconstructedParticle &value)
Set the reference to the reconstructed particle.
Definition MutableMCRecoParticleAssociation.cc:60
MCRecoParticleAssociationCollection collection_type
Definition MutableMCRecoParticleAssociation.h:48
float & weight()
Get reference to weight of this association.
Definition MutableMCRecoParticleAssociation.cc:58
podio::ObjectID id() const
Definition MutableMCRecoParticleAssociation.h:119
MCRecoParticleAssociation object_type
Definition MutableMCRecoParticleAssociation.h:47
void unlink()
disconnect from MCRecoParticleAssociationObj instance
Definition MutableMCRecoParticleAssociation.h:108
int getRecID() const
Definition MutableMCRecoParticleAssociation.h:98
bool operator<(const MutableMCRecoParticleAssociation &other) const
Definition MutableMCRecoParticleAssociation.h:117
void setSim(const edm4hep::MCParticle &value)
Set the reference to the Monte-Carlo particle.
Definition MutableMCRecoParticleAssociation.cc:64
MutableMCRecoParticleAssociation()=default
default constructor
MutableMCRecoParticleAssociation clone(bool cloneRelations=true) const
Definition MutableMCRecoParticleAssociation.cc:29
friend void swap(MutableMCRecoParticleAssociation &a, MutableMCRecoParticleAssociation &b)
Definition MutableMCRecoParticleAssociation.h:125
void setWeight(const float weight)
Set the weight of this association.
Definition MutableMCRecoParticleAssociation.cc:56
const edm4eic::ReconstructedParticle getRec() const
Access the reference to the reconstructed particle.
Definition MutableMCRecoParticleAssociation.cc:41
friend class MCRecoParticleAssociation
Definition MutableMCRecoParticleAssociation.h:44
bool operator!=(const MCRecoParticleAssociation &other) const
Definition MutableMCRecoParticleAssociation.h:114
void setRecID(int)
Definition MutableMCRecoParticleAssociation.h:102
MutableMCRecoParticleAssociation & operator=(MutableMCRecoParticleAssociation other) &
copy-assignment operator
Definition MutableMCRecoParticleAssociation.cc:24
bool operator==(const MutableMCRecoParticleAssociation &other) const
Definition MutableMCRecoParticleAssociation.h:110
friend class MCRecoParticleAssociationMutableCollectionIterator
Definition MutableMCRecoParticleAssociation.h:43
float getWeight() const
Access the weight of this association.
Definition MutableMCRecoParticleAssociation.cc:39
~MutableMCRecoParticleAssociation()=default
destructor
int getSimID() const
Definition MutableMCRecoParticleAssociation.h:97
bool isAvailable() const
check whether the object is actually available
Definition MutableMCRecoParticleAssociation.cc:74
friend class MCRecoParticleAssociationCollection
Definition MutableMCRecoParticleAssociation.h:42
Definition MutableReconstructedParticle.h:46
Definition ReconstructedParticle.h:54
const podio::ObjectID getObjectID() const
Definition ReconstructedParticle.cc:269
Definition CalorimeterHit.cc:17
Definition CalorimeterHit.h:25
OrderKey getOrderKey(const edm4eic::CalorimeterHit &obj)
Definition CalorimeterHit.cc:146
std::size_t operator()(const edm4eic::MutableMCRecoParticleAssociation &obj) const
Definition MutableMCRecoParticleAssociation.h:148