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
26
27namespace edm4eic {
28
29
30/** @class MutableVertex
31 * EIC vertex
32 * @author: J. Osborn
33 */
35
36 friend class VertexCollection;
38 friend class Vertex;
39
40public:
43
44 /// default constructor
46
47 /// Constructor initializing all members
48 MutableVertex(std::int32_t type, float chi2, int ndf, edm4hep::Vector4f position, edm4eic::Cov4f positionError);
49
50 /// copy constructor
51 MutableVertex(const MutableVertex& other) = default;
52
53 /// copy-assignment operator
55
56 /// create a mutable deep-copy of the object with identical relations
57 /// if cloneRelations=false, the relations are not cloned and will be empty
58 MutableVertex clone(bool cloneRelations=true) const;
59
60 /// destructor
61 ~MutableVertex() = default;
62
63
64public:
65
66 /// Access the Type flag, to identify what type of vertex it is (e.g. primary, secondary, generated, etc.)
67 std::int32_t getType() const;
68
69 /// Access the Chi-squared of the vertex fit
70 float getChi2() const;
71
72 /// Access the NDF of the vertex fit
73 int getNdf() const;
74
75 /// Access the position [mm] + time t0 [ns] of the vertex. Time is 4th component in vector
76 const edm4hep::Vector4f& getPosition() const;
77
78 /// Access the Covariance matrix of the position+time. Time is 4th component, similarly to 4vector
79 const edm4eic::Cov4f& getPositionError() const;
80
81
82
83 /// Set the Type flag, to identify what type of vertex it is (e.g. primary, secondary, generated, etc.)
84 void setType(std::int32_t value);
85 /// Get mutable reference to Type flag, to identify what type of vertex it is (e.g. primary, secondary, generated, etc.)
86 std::int32_t& getType();
87 /// Get reference to Type flag, to identify what type of vertex it is (e.g. primary, secondary, generated, etc.)
88 [[deprecated("use getType instead")]]
89 std::int32_t& type();
90
91 /// Set the Chi-squared of the vertex fit
92 void setChi2(float value);
93 /// Get mutable reference to Chi-squared of the vertex fit
94 float& getChi2();
95 /// Get reference to Chi-squared of the vertex fit
96 [[deprecated("use getChi2 instead")]]
97 float& chi2();
98
99 /// Set the NDF of the vertex fit
100 void setNdf(int value);
101 /// Get mutable reference to NDF of the vertex fit
102 int& getNdf();
103 /// Get reference to NDF of the vertex fit
104 [[deprecated("use getNdf instead")]]
105 int& ndf();
106
107 /// Set the position [mm] + time t0 [ns] of the vertex. Time is 4th component in vector
108 void setPosition(edm4hep::Vector4f value);
109 /// Get mutable reference to position [mm] + time t0 [ns] of the vertex. Time is 4th component in vector
110 edm4hep::Vector4f& getPosition();
111 /// Get reference to position [mm] + time t0 [ns] of the vertex. Time is 4th component in vector
112 [[deprecated("use getPosition instead")]]
113 edm4hep::Vector4f& position();
114
115 /// Set the Covariance matrix of the position+time. Time is 4th component, similarly to 4vector
117 /// Get mutable reference to Covariance matrix of the position+time. Time is 4th component, similarly to 4vector
119 /// Get reference to Covariance matrix of the position+time. Time is 4th component, similarly to 4vector
120 [[deprecated("use getPositionError instead")]]
122
123
124
126 std::size_t associatedParticles_size() const;
128 std::vector<edm4eic::ReconstructedParticle>::const_iterator associatedParticles_begin() const;
129 std::vector<edm4eic::ReconstructedParticle>::const_iterator associatedParticles_end() const;
130 podio::RelationRange<edm4eic::ReconstructedParticle> getAssociatedParticles() const;
131
132
133
134 /// check whether the object is actually available
135 bool isAvailable() const;
136 /// disconnect from VertexObj instance
137 void unlink() { m_obj = podio::utils::MaybeSharedPtr<VertexObj>{nullptr}; }
138
139 bool operator==(const MutableVertex& other) const { return m_obj == other.m_obj; }
140 bool operator==(const Vertex& other) const;
141
142 bool operator!=(const MutableVertex& other) const { return !(*this == other); }
143 bool operator!=(const Vertex& other) const { return !(*this == other); }
144
145 // less comparison operator, so that objects can be e.g. stored in sets.
146 bool operator<(const MutableVertex& other) const { return m_obj < other.m_obj; }
147
148 podio::ObjectID id() const { return getObjectID(); }
149
150 const podio::ObjectID getObjectID() const;
151
152 friend void swap(MutableVertex& a, MutableVertex& b) {
153 using std::swap;
154 swap(a.m_obj, b.m_obj); // swap out the internal pointers
155 }
156
157private:
158 /// constructor from existing VertexObj
159 explicit MutableVertex(podio::utils::MaybeSharedPtr<VertexObj> obj);
160
161 podio::utils::MaybeSharedPtr<VertexObj> m_obj{nullptr};
162};
163
164#if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
165void to_json(nlohmann::json& j, const MutableVertex& value);
166#endif
167
168
169} // namespace edm4eic
170
171
172#endif
Definition Cov4f.h:18
Definition MutableVertex.h:34
friend class Vertex
Definition MutableVertex.h:38
int & ndf()
Get reference to NDF of the vertex fit.
Definition MutableVertex.cc:63
void unlink()
disconnect from VertexObj instance
Definition MutableVertex.h:137
float & chi2()
Get reference to Chi-squared of the vertex fit.
Definition MutableVertex.cc:60
void setPosition(edm4hep::Vector4f value)
Set the position [mm] + time t0 [ns] of the vertex. Time is 4th component in vector.
Definition MutableVertex.cc:64
MutableVertex & operator=(MutableVertex other)
copy-assignment operator
Definition MutableVertex.cc:30
void addToAssociatedParticles(const edm4eic::ReconstructedParticle &)
Definition MutableVertex.cc:72
bool operator!=(const MutableVertex &other) const
Definition MutableVertex.h:142
const podio::ObjectID getObjectID() const
Definition MutableVertex.cc:117
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:146
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:36
std::vector< edm4eic::ReconstructedParticle >::const_iterator associatedParticles_end() const
Definition MutableVertex.cc:83
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:148
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
~MutableVertex()=default
destructor
MutableVertex(const MutableVertex &other)=default
copy constructor
bool operator!=(const Vertex &other) const
Definition MutableVertex.h:143
friend void swap(MutableVertex &a, MutableVertex &b)
Definition MutableVertex.h:152
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
void setChi2(float value)
Set the Chi-squared of the vertex fit.
Definition MutableVertex.cc:58
void setNdf(int value)
Set the NDF of the vertex fit.
Definition MutableVertex.cc:61
bool operator==(const MutableVertex &other) const
Definition MutableVertex.h:139
void setPositionError(edm4eic::Cov4f value)
Set the Covariance matrix of the position+time. Time is 4th component, similarly to 4vector.
Definition MutableVertex.cc:67
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
void setType(std::int32_t value)
Set the Type flag, to identify what type of vertex it is (e.g. primary, secondary,...
Definition MutableVertex.cc:55
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
Definition ReconstructedParticle.h:47
Definition VertexCollection.h:92
Definition Vertex.h:36
Definition VertexCollection.h:63
Definition CalorimeterHit.cc:17