EDM4eic
EIC data model
Loading...
Searching...
No Matches
MutableTrajectory.h
Go to the documentation of this file.
1// AUTOMATICALLY GENERATED FILE - DO NOT EDIT
2
3#ifndef EDM4EIC_MutableTrajectory_H
4#define EDM4EIC_MutableTrajectory_H
5
7// Make the immutable class available from its mutable version but not vice versa
9
12#include "podio/RelationRange.h"
13#include <cstdint>
14#include <vector>
15
16#include "podio/utilities/MaybeSharedPtr.h"
17
18#include <cstdint>
19
20#if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
21#include "nlohmann/json_fwd.hpp"
22#endif
23
24// forward declarations
25namespace edm4eic {
26class TrajectoryCollection;
27class TrackSeed;
28class MutableTrackSeed;
29}
30
31
32namespace edm4eic {
33
34
35/** @class MutableTrajectory
36 * Raw trajectory from the tracking algorithm. What is called hit here is 2d measurement indeed.
37 * @author: S. Joosten, S. Li
38 */
40
43 friend class Trajectory;
44
45public:
48
49 /// default constructor
51
52 /// Constructor initializing all members
53 MutableTrajectory(std::uint32_t type, std::uint32_t nStates, std::uint32_t nMeasurements, std::uint32_t nOutliers, std::uint32_t nHoles, std::uint32_t nSharedHits);
54
55 /// copy constructor
56 MutableTrajectory(const MutableTrajectory& other) = default;
57
58 /// copy-assignment operator
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 MutableTrajectory clone(bool cloneRelations=true) const;
64
65 /// destructor
66 ~MutableTrajectory() = default;
67
68
69public:
70
71 /// Access the 0 (does not have good track fit), 1 (has good track fit)
72 std::uint32_t getType() const;
73
74 /// Access the Number of tracking steps
75 std::uint32_t getNStates() const;
76
77 /// Access the Number of hits used
78 std::uint32_t getNMeasurements() const;
79
80 /// Access the Number of hits not considered
81 std::uint32_t getNOutliers() const;
82
83 /// Access the Number of missing hits
84 std::uint32_t getNHoles() const;
85
86 /// Access the Number of shared hits with other trajectories
87 std::uint32_t getNSharedHits() const;
88
89
90 /// Access the Corresponding track seed
91 const edm4eic::TrackSeed getSeed() const;
92
93 /// Set the 0 (does not have good track fit), 1 (has good track fit)
94 void setType(std::uint32_t value);
95 /// Get mutable reference to 0 (does not have good track fit), 1 (has good track fit)
96 std::uint32_t& getType();
97 /// Get reference to 0 (does not have good track fit), 1 (has good track fit)
98 [[deprecated("use getType instead")]]
99 std::uint32_t& type();
100
101 /// Set the Number of tracking steps
102 void setNStates(std::uint32_t value);
103 /// Get mutable reference to Number of tracking steps
104 std::uint32_t& getNStates();
105 /// Get reference to Number of tracking steps
106 [[deprecated("use getNStates instead")]]
107 std::uint32_t& nStates();
108
109 /// Set the Number of hits used
110 void setNMeasurements(std::uint32_t value);
111 /// Get mutable reference to Number of hits used
112 std::uint32_t& getNMeasurements();
113 /// Get reference to Number of hits used
114 [[deprecated("use getNMeasurements instead")]]
115 std::uint32_t& nMeasurements();
116
117 /// Set the Number of hits not considered
118 void setNOutliers(std::uint32_t value);
119 /// Get mutable reference to Number of hits not considered
120 std::uint32_t& getNOutliers();
121 /// Get reference to Number of hits not considered
122 [[deprecated("use getNOutliers instead")]]
123 std::uint32_t& nOutliers();
124
125 /// Set the Number of missing hits
126 void setNHoles(std::uint32_t value);
127 /// Get mutable reference to Number of missing hits
128 std::uint32_t& getNHoles();
129 /// Get reference to Number of missing hits
130 [[deprecated("use getNHoles instead")]]
131 std::uint32_t& nHoles();
132
133 /// Set the Number of shared hits with other trajectories
134 void setNSharedHits(std::uint32_t value);
135 /// Get mutable reference to Number of shared hits with other trajectories
136 std::uint32_t& getNSharedHits();
137 /// Get reference to Number of shared hits with other trajectories
138 [[deprecated("use getNSharedHits instead")]]
139 std::uint32_t& nSharedHits();
140
141
142 /// Set the Corresponding track seed
143 void setSeed(const edm4eic::TrackSeed& value);
144
146 std::size_t trackParameters_size() const;
148 std::vector<edm4eic::TrackParameters>::const_iterator trackParameters_begin() const;
149 std::vector<edm4eic::TrackParameters>::const_iterator trackParameters_end() const;
150 podio::RelationRange<edm4eic::TrackParameters> getTrackParameters() const;
152 std::size_t measurements_deprecated_size() const;
154 std::vector<edm4eic::Measurement2D>::const_iterator measurements_deprecated_begin() const;
155 std::vector<edm4eic::Measurement2D>::const_iterator measurements_deprecated_end() const;
156 podio::RelationRange<edm4eic::Measurement2D> getMeasurements_deprecated() const;
158 std::size_t outliers_deprecated_size() const;
160 std::vector<edm4eic::Measurement2D>::const_iterator outliers_deprecated_begin() const;
161 std::vector<edm4eic::Measurement2D>::const_iterator outliers_deprecated_end() const;
162 podio::RelationRange<edm4eic::Measurement2D> getOutliers_deprecated() const;
163 void addToMeasurementChi2(const float&);
164 std::size_t measurementChi2_size() const;
165 float getMeasurementChi2(std::size_t) const;
166 std::vector<float>::const_iterator measurementChi2_begin() const;
167 std::vector<float>::const_iterator measurementChi2_end() const;
168 podio::RelationRange<float> getMeasurementChi2() const;
169 void addToOutlierChi2(const float&);
170 std::size_t outlierChi2_size() const;
171 float getOutlierChi2(std::size_t) const;
172 std::vector<float>::const_iterator outlierChi2_begin() const;
173 std::vector<float>::const_iterator outlierChi2_end() const;
174 podio::RelationRange<float> getOutlierChi2() const;
175
176
177
178 /// check whether the object is actually available
179 bool isAvailable() const;
180 /// disconnect from TrajectoryObj instance
181 void unlink() { m_obj = podio::utils::MaybeSharedPtr<TrajectoryObj>{nullptr}; }
182
183 bool operator==(const MutableTrajectory& other) const { return m_obj == other.m_obj; }
184 bool operator==(const Trajectory& other) const;
185
186 bool operator!=(const MutableTrajectory& other) const { return !(*this == other); }
187 bool operator!=(const Trajectory& other) const { return !(*this == other); }
188
189 // less comparison operator, so that objects can be e.g. stored in sets.
190 bool operator<(const MutableTrajectory& other) const { return podio::detail::getOrderKey(*this) < podio::detail::getOrderKey(other); }
191
192 podio::ObjectID id() const { return getObjectID(); }
193
194 const podio::ObjectID getObjectID() const;
195
197 using std::swap;
198 swap(a.m_obj, b.m_obj); // swap out the internal pointers
199 }
200
201private:
202 /// constructor from existing TrajectoryObj
203 explicit MutableTrajectory(podio::utils::MaybeSharedPtr<TrajectoryObj> obj);
204
205 podio::utils::MaybeSharedPtr<TrajectoryObj> m_obj{nullptr};
206};
207
208#if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
209void to_json(nlohmann::json& j, const MutableTrajectory& value);
210#endif
211
212
213} // namespace edm4eic
214
215
216#endif
Definition Measurement2D.h:46
Definition MutableTrajectory.h:39
std::uint32_t getNMeasurements() const
Access the Number of hits used.
Definition MutableTrajectory.cc:64
podio::RelationRange< edm4eic::Measurement2D > getOutliers_deprecated() const
Definition MutableTrajectory.cc:201
std::vector< float >::const_iterator outlierChi2_begin() const
Definition MutableTrajectory.cc:250
podio::RelationRange< float > getMeasurementChi2() const
Definition MutableTrajectory.cc:237
std::size_t outliers_deprecated_size() const
Definition MutableTrajectory.cc:190
podio::RelationRange< edm4eic::TrackParameters > getTrackParameters() const
Definition MutableTrajectory.cc:129
bool operator<(const MutableTrajectory &other) const
Definition MutableTrajectory.h:190
std::uint32_t getNOutliers() const
Access the Number of hits not considered.
Definition MutableTrajectory.cc:65
void setNMeasurements(std::uint32_t value)
Set the Number of hits used.
Definition MutableTrajectory.cc:83
void addToMeasurementChi2(const float &)
Definition MutableTrajectory.cc:209
std::vector< edm4eic::Measurement2D >::const_iterator outliers_deprecated_end() const
Definition MutableTrajectory.cc:184
std::uint32_t & type()
Get reference to 0 (does not have good track fit), 1 (has good track fit)
Definition MutableTrajectory.cc:79
std::size_t measurements_deprecated_size() const
Definition MutableTrajectory.cc:154
std::uint32_t & nSharedHits()
Get reference to Number of shared hits with other trajectories.
Definition MutableTrajectory.cc:94
std::uint32_t & nOutliers()
Get reference to Number of hits not considered.
Definition MutableTrajectory.cc:88
void addToOutliers_deprecated(const edm4eic::Measurement2D &)
Definition MutableTrajectory.cc:173
podio::ObjectID id() const
Definition MutableTrajectory.h:192
bool operator==(const MutableTrajectory &other) const
Definition MutableTrajectory.h:183
MutableTrajectory(const MutableTrajectory &other)=default
copy constructor
void addToMeasurements_deprecated(const edm4eic::Measurement2D &)
Definition MutableTrajectory.cc:137
std::uint32_t & nStates()
Get reference to Number of tracking steps.
Definition MutableTrajectory.cc:82
void setNSharedHits(std::uint32_t value)
Set the Number of shared hits with other trajectories.
Definition MutableTrajectory.cc:92
void addToTrackParameters(const edm4eic::TrackParameters &)
Definition MutableTrajectory.cc:101
void setNStates(std::uint32_t value)
Set the Number of tracking steps.
Definition MutableTrajectory.cc:80
void setNOutliers(std::uint32_t value)
Set the Number of hits not considered.
Definition MutableTrajectory.cc:86
std::vector< edm4eic::Measurement2D >::const_iterator measurements_deprecated_end() const
Definition MutableTrajectory.cc:148
~MutableTrajectory()=default
destructor
const edm4eic::TrackSeed getSeed() const
Access the Corresponding track seed.
Definition MutableTrajectory.cc:69
void setNHoles(std::uint32_t value)
Set the Number of missing hits.
Definition MutableTrajectory.cc:89
MutableTrajectory & operator=(MutableTrajectory other)
copy-assignment operator
Definition MutableTrajectory.cc:32
std::vector< float >::const_iterator measurementChi2_end() const
Definition MutableTrajectory.cc:220
bool operator!=(const Trajectory &other) const
Definition MutableTrajectory.h:187
friend class TrajectoryCollection
Definition MutableTrajectory.h:41
MutableTrajectory clone(bool cloneRelations=true) const
Definition MutableTrajectory.cc:37
MutableTrajectory()
default constructor
Definition MutableTrajectory.cc:19
std::vector< float >::const_iterator outlierChi2_end() const
Definition MutableTrajectory.cc:256
bool isAvailable() const
check whether the object is actually available
Definition MutableTrajectory.cc:286
podio::RelationRange< float > getOutlierChi2() const
Definition MutableTrajectory.cc:273
void setSeed(const edm4eic::TrackSeed &value)
Set the Corresponding track seed.
Definition MutableTrajectory.cc:96
std::uint32_t getType() const
Access the 0 (does not have good track fit), 1 (has good track fit)
Definition MutableTrajectory.cc:62
std::vector< float >::const_iterator measurementChi2_begin() const
Definition MutableTrajectory.cc:214
std::uint32_t getNStates() const
Access the Number of tracking steps.
Definition MutableTrajectory.cc:63
friend class Trajectory
Definition MutableTrajectory.h:43
const podio::ObjectID getObjectID() const
Definition MutableTrajectory.cc:290
std::uint32_t getNHoles() const
Access the Number of missing hits.
Definition MutableTrajectory.cc:66
bool operator!=(const MutableTrajectory &other) const
Definition MutableTrajectory.h:186
std::uint32_t & nMeasurements()
Get reference to Number of hits used.
Definition MutableTrajectory.cc:85
std::size_t measurementChi2_size() const
Definition MutableTrajectory.cc:226
void unlink()
disconnect from TrajectoryObj instance
Definition MutableTrajectory.h:181
std::vector< edm4eic::Measurement2D >::const_iterator measurements_deprecated_begin() const
Definition MutableTrajectory.cc:142
podio::RelationRange< edm4eic::Measurement2D > getMeasurements_deprecated() const
Definition MutableTrajectory.cc:165
std::uint32_t & nHoles()
Get reference to Number of missing hits.
Definition MutableTrajectory.cc:91
void addToOutlierChi2(const float &)
Definition MutableTrajectory.cc:245
void setType(std::uint32_t value)
Set the 0 (does not have good track fit), 1 (has good track fit)
Definition MutableTrajectory.cc:77
std::vector< edm4eic::Measurement2D >::const_iterator outliers_deprecated_begin() const
Definition MutableTrajectory.cc:178
friend void swap(MutableTrajectory &a, MutableTrajectory &b)
Definition MutableTrajectory.h:196
std::size_t outlierChi2_size() const
Definition MutableTrajectory.cc:262
std::vector< edm4eic::TrackParameters >::const_iterator trackParameters_end() const
Definition MutableTrajectory.cc:112
std::uint32_t getNSharedHits() const
Access the Number of shared hits with other trajectories.
Definition MutableTrajectory.cc:67
std::vector< edm4eic::TrackParameters >::const_iterator trackParameters_begin() const
Definition MutableTrajectory.cc:106
std::size_t trackParameters_size() const
Definition MutableTrajectory.cc:118
Definition TrackParameters.h:43
Definition TrackSeed.h:46
Definition TrajectoryCollection.h:91
Definition Trajectory.h:47
Definition TrajectoryCollection.h:62
Definition CalorimeterHit.cc:17
OrderKey getOrderKey(const edm4eic::CalorimeterHit &obj)
Definition CalorimeterHit.cc:150