EDM4eic
EIC data model
Loading...
Searching...
No Matches
MutableVertex.h
Go to the documentation of this file.
1// AUTOMATICALLY GENERATED FILE - DO NOT EDIT
2
3#ifndef EDM4EIC_MutableVertex_H
4#define EDM4EIC_MutableVertex_H
5
6#include "edm4eic/VertexObj.h"
7// Make the immutable class available from its mutable version but not vice versa
8#include "edm4eic/Vertex.h"
9
10#include "edm4eic/Cov4f.h"
12#include "edm4hep/Vector4f.h"
13#include "podio/RelationRange.h"
14#include <cstdint>
15#include <vector>
16
17#include "podio/utilities/MaybeSharedPtr.h"
18
19#include <cstdint>
20
21#if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
22#include "nlohmann/json_fwd.hpp"
23#endif
24
25// forward declarations
26namespace edm4eic {
28}
29
30
31namespace edm4eic {
32
33
34/** @class MutableVertex
35 * EIC vertex
36 * @author: J. Osborn
37 */
39
40 friend class VertexCollection;
42 friend class Vertex;
43
44public:
47
48 /// default constructor
50
51 /// Constructor initializing all members
52 MutableVertex(const std::int32_t type, const float chi2, const int ndf, const edm4hep::Vector4f& position, const edm4eic::Cov4f& positionError);
53
54 /// copy constructor
55 MutableVertex(const MutableVertex& other) = default;
56
57 /// copy-assignment operator
58 MutableVertex& operator=(MutableVertex other) &; // Rebind this to other's internal object
59 MutableVertex& operator=(MutableVertex other) && = delete; // Prevent rebinding temporary as the changes wouldn't persist
60
61 /// create a mutable deep-copy of the object with identical relations
62 /// if cloneRelations=false, the relations are not cloned and will be empty
63 MutableVertex clone(bool cloneRelations=true) const;
64
65 /// destructor
66 ~MutableVertex() = default;
67
68
69public:
70
71 /// Access the Type flag, to identify what type of vertex it is (e.g. primary, secondary, generated, etc.)
72 std::int32_t getType() const;
73
74 /// Access the Chi-squared of the vertex fit
75 float getChi2() const;
76
77 /// Access the NDF of the vertex fit
78 int getNdf() const;
79
80 /// Access the position [mm] + time t0 [ns] of the vertex. Time is 4th component in vector
81 const edm4hep::Vector4f& getPosition() const;
82
83 /// Access the Covariance matrix of the position+time. Time is 4th component, similarly to 4vector
84 const edm4eic::Cov4f& getPositionError() const;
85
86
87
88 /// Set the Type flag, to identify what type of vertex it is (e.g. primary, secondary, generated, etc.)
89 void setType(const std::int32_t type);
90 /// Get mutable reference to Type flag, to identify what type of vertex it is (e.g. primary, secondary, generated, etc.)
91 std::int32_t& getType();
92 /// Get reference to Type flag, to identify what type of vertex it is (e.g. primary, secondary, generated, etc.)
93 [[deprecated("use getType instead")]]
94 std::int32_t& type();
95
96 /// Set the Chi-squared of the vertex fit
97 void setChi2(const float chi2);
98 /// Get mutable reference to Chi-squared of the vertex fit
99 float& getChi2();
100 /// Get reference to Chi-squared of the vertex fit
101 [[deprecated("use getChi2 instead")]]
102 float& chi2();
103
104 /// Set the NDF of the vertex fit
105 void setNdf(const int ndf);
106 /// Get mutable reference to NDF of the vertex fit
107 int& getNdf();
108 /// Get reference to NDF of the vertex fit
109 [[deprecated("use getNdf instead")]]
110 int& ndf();
111
112 /// Set the position [mm] + time t0 [ns] of the vertex. Time is 4th component in vector
113 void setPosition(const edm4hep::Vector4f& position);
114 /// Get mutable reference to position [mm] + time t0 [ns] of the vertex. Time is 4th component in vector
115 edm4hep::Vector4f& getPosition();
116 /// Get reference to position [mm] + time t0 [ns] of the vertex. Time is 4th component in vector
117 [[deprecated("use getPosition instead")]]
118 edm4hep::Vector4f& position();
119
120 /// Set the Covariance matrix of the position+time. Time is 4th component, similarly to 4vector
122 /// Get mutable reference to Covariance matrix of the position+time. Time is 4th component, similarly to 4vector
124 /// Get reference to Covariance matrix of the position+time. Time is 4th component, similarly to 4vector
125 [[deprecated("use getPositionError instead")]]
127
128
129
131 std::size_t associatedParticles_size() const;
133 std::vector<edm4eic::ReconstructedParticle>::const_iterator associatedParticles_begin() const;
134 std::vector<edm4eic::ReconstructedParticle>::const_iterator associatedParticles_end() const;
135 podio::RelationRange<edm4eic::ReconstructedParticle> getAssociatedParticles() const;
136
137
138
139 /// check whether the object is actually available
140 bool isAvailable() const;
141 /// disconnect from VertexObj instance
142 void unlink() { m_obj = podio::utils::MaybeSharedPtr<VertexObj>{nullptr}; }
143
144 bool operator==(const MutableVertex& other) const { return m_obj == other.m_obj; }
145 bool operator==(const Vertex& other) const;
146
147 bool operator!=(const MutableVertex& other) const { return !(*this == other); }
148 bool operator!=(const Vertex& other) const { return !(*this == other); }
149
150 // less comparison operator, so that objects can be e.g. stored in sets.
151 bool operator<(const MutableVertex& other) const { return podio::detail::getOrderKey(*this) < podio::detail::getOrderKey(other); }
152
153 podio::ObjectID id() const { return getObjectID(); }
154
155 const podio::ObjectID getObjectID() const;
156
157 friend std::hash<MutableVertex>;
158
159 friend void swap(MutableVertex& a, MutableVertex& b) {
160 using std::swap;
161 swap(a.m_obj, b.m_obj); // swap out the internal pointers
162 }
163
164private:
165 /// constructor from existing VertexObj
166 explicit MutableVertex(podio::utils::MaybeSharedPtr<VertexObj> obj);
167
168 podio::utils::MaybeSharedPtr<VertexObj> m_obj{nullptr};
169};
170
171#if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
172void to_json(nlohmann::json& j, const MutableVertex& value);
173#endif
174
175
176} // namespace edm4eic
177
178
179
180template<>
181struct std::hash<edm4eic::MutableVertex> {
182 std::size_t operator()(const edm4eic::MutableVertex& obj) const {
183 return std::hash<edm4eic::VertexObj*>{}(obj.m_obj.get());
184 }
185};
186
187
188#endif
Definition Cov4f.h:18
Definition MutableVertex.h:38
void setType(const std::int32_t type)
Set the Type flag, to identify what type of vertex it is (e.g. primary, secondary,...
Definition MutableVertex.cc:55
friend class Vertex
Definition MutableVertex.h:42
int & ndf()
Get reference to NDF of the vertex fit.
Definition MutableVertex.cc:63
void unlink()
disconnect from VertexObj instance
Definition MutableVertex.h:142
float & chi2()
Get reference to Chi-squared of the vertex fit.
Definition MutableVertex.cc:60
void addToAssociatedParticles(const edm4eic::ReconstructedParticle &)
Definition MutableVertex.cc:72
bool operator!=(const MutableVertex &other) const
Definition MutableVertex.h:147
const podio::ObjectID getObjectID() const
Definition MutableVertex.cc:117
friend class VertexMutableCollectionIterator
Definition MutableVertex.h:41
void setPositionError(const edm4eic::Cov4f &positionError)
Set the Covariance matrix of the position+time. Time is 4th component, similarly to 4vector.
Definition MutableVertex.cc:67
const edm4eic::Cov4f & getPositionError() const
Access the Covariance matrix of the position+time. Time is 4th component, similarly to 4vector.
Definition MutableVertex.cc:52
bool operator<(const MutableVertex &other) const
Definition MutableVertex.h:151
edm4eic::Cov4f & positionError()
Get reference to Covariance matrix of the position+time. Time is 4th component, similarly to 4vector.
Definition MutableVertex.cc:69
friend class VertexCollection
Definition MutableVertex.h:40
std::vector< edm4eic::ReconstructedParticle >::const_iterator associatedParticles_end() const
Definition MutableVertex.cc:83
void setPosition(const edm4hep::Vector4f &position)
Set the position [mm] + time t0 [ns] of the vertex. Time is 4th component in vector.
Definition MutableVertex.cc:64
edm4hep::Vector4f & position()
Get reference to position [mm] + time t0 [ns] of the vertex. Time is 4th component in vector.
Definition MutableVertex.cc:66
podio::ObjectID id() const
Definition MutableVertex.h:153
VertexCollection collection_type
Definition MutableVertex.h:46
void setChi2(const float chi2)
Set the Chi-squared of the vertex fit.
Definition MutableVertex.cc:58
float getChi2() const
Access the Chi-squared of the vertex fit.
Definition MutableVertex.cc:49
int getNdf() const
Access the NDF of the vertex fit.
Definition MutableVertex.cc:50
void setNdf(const int ndf)
Set the NDF of the vertex fit.
Definition MutableVertex.cc:61
~MutableVertex()=default
destructor
MutableVertex(const MutableVertex &other)=default
copy constructor
bool operator!=(const Vertex &other) const
Definition MutableVertex.h:148
friend void swap(MutableVertex &a, MutableVertex &b)
Definition MutableVertex.h:159
const edm4hep::Vector4f & getPosition() const
Access the position [mm] + time t0 [ns] of the vertex. Time is 4th component in vector.
Definition MutableVertex.cc:51
std::size_t associatedParticles_size() const
Definition MutableVertex.cc:89
bool isAvailable() const
check whether the object is actually available
Definition MutableVertex.cc:113
std::vector< edm4eic::ReconstructedParticle >::const_iterator associatedParticles_begin() const
Definition MutableVertex.cc:77
MutableVertex & operator=(MutableVertex other) &
copy-assignment operator
Definition MutableVertex.cc:30
bool operator==(const MutableVertex &other) const
Definition MutableVertex.h:144
std::int32_t & type()
Get reference to Type flag, to identify what type of vertex it is (e.g. primary, secondary,...
Definition MutableVertex.cc:57
podio::RelationRange< edm4eic::ReconstructedParticle > getAssociatedParticles() const
Definition MutableVertex.cc:100
MutableVertex()
default constructor
Definition MutableVertex.cc:18
MutableVertex clone(bool cloneRelations=true) const
Definition MutableVertex.cc:35
MutableVertex & operator=(MutableVertex other) &&=delete
std::int32_t getType() const
Access the Type flag, to identify what type of vertex it is (e.g. primary, secondary,...
Definition MutableVertex.cc:48
Vertex object_type
Definition MutableVertex.h:45
Definition ReconstructedParticle.h:54
Definition VertexCollection.h:137
Definition Vertex.h:46
Definition CalorimeterHit.cc:17
OrderKey getOrderKey(const edm4eic::CalorimeterHit &obj)
Definition CalorimeterHit.cc:150
std::size_t operator()(const edm4eic::MutableVertex &obj) const
Definition MutableVertex.h:182