3#ifndef EDM4EIC_MutableTrajectory_H
4#define EDM4EIC_MutableTrajectory_H
12#include "podio/RelationRange.h"
16#include "podio/utilities/MaybeSharedPtr.h"
20#if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
21#include "nlohmann/json_fwd.hpp"
99 [[deprecated(
"use getType instead")]]
100 std::uint32_t&
type();
107 [[deprecated(
"use getNStates instead")]]
115 [[deprecated(
"use getNMeasurements instead")]]
123 [[deprecated(
"use getNOutliers instead")]]
131 [[deprecated(
"use getNHoles instead")]]
139 [[deprecated(
"use getNSharedHits instead")]]
182 void unlink() { m_obj = podio::utils::MaybeSharedPtr<TrajectoryObj>{
nullptr}; }
197 friend std::hash<MutableTrajectory>;
201 swap(a.m_obj, b.m_obj);
208 podio::utils::MaybeSharedPtr<TrajectoryObj> m_obj{
new TrajectoryObj{}, podio::utils::MarkOwned};
211#if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
223 return std::hash<edm4eic::TrajectoryObj*>{}(obj.m_obj.get());
Definition Measurement2D.h:46
Definition MutableTrackSeed.h:38
Definition MutableTrajectory.h:39
std::uint32_t getNMeasurements() const
Access the Number of hits used.
Definition MutableTrajectory.cc:60
podio::RelationRange< edm4eic::Measurement2D > getOutliers_deprecated() const
Definition MutableTrajectory.cc:197
std::vector< float >::const_iterator outlierChi2_begin() const
Definition MutableTrajectory.cc:246
void setNOutliers(const std::uint32_t nOutliers)
Set the Number of hits not considered.
Definition MutableTrajectory.cc:82
podio::RelationRange< float > getMeasurementChi2() const
Definition MutableTrajectory.cc:233
std::size_t outliers_deprecated_size() const
Definition MutableTrajectory.cc:186
podio::RelationRange< edm4eic::TrackParameters > getTrackParameters() const
Definition MutableTrajectory.cc:125
bool operator<(const MutableTrajectory &other) const
Definition MutableTrajectory.h:191
std::uint32_t getNOutliers() const
Access the Number of hits not considered.
Definition MutableTrajectory.cc:61
void addToMeasurementChi2(const float &)
Definition MutableTrajectory.cc:205
std::vector< edm4eic::Measurement2D >::const_iterator outliers_deprecated_end() const
Definition MutableTrajectory.cc:180
void setNStates(const std::uint32_t nStates)
Set the Number of tracking steps.
Definition MutableTrajectory.cc:76
std::uint32_t & type()
Get reference to 0 (does not have good track fit), 1 (has good track fit)
Definition MutableTrajectory.cc:75
std::size_t measurements_deprecated_size() const
Definition MutableTrajectory.cc:150
std::uint32_t & nSharedHits()
Get reference to Number of shared hits with other trajectories.
Definition MutableTrajectory.cc:90
void setType(const std::uint32_t type)
Set the 0 (does not have good track fit), 1 (has good track fit)
Definition MutableTrajectory.cc:73
std::uint32_t & nOutliers()
Get reference to Number of hits not considered.
Definition MutableTrajectory.cc:84
void addToOutliers_deprecated(const edm4eic::Measurement2D &)
Definition MutableTrajectory.cc:169
podio::ObjectID id() const
Definition MutableTrajectory.h:193
bool operator==(const MutableTrajectory &other) const
Definition MutableTrajectory.h:184
MutableTrajectory(const MutableTrajectory &other)=default
copy constructor
void addToMeasurements_deprecated(const edm4eic::Measurement2D &)
Definition MutableTrajectory.cc:133
std::uint32_t & nStates()
Get reference to Number of tracking steps.
Definition MutableTrajectory.cc:78
MutableTrajectory & operator=(MutableTrajectory other) &&=delete
void addToTrackParameters(const edm4eic::TrackParameters &)
Definition MutableTrajectory.cc:97
void setNHoles(const std::uint32_t nHoles)
Set the Number of missing hits.
Definition MutableTrajectory.cc:85
std::vector< edm4eic::Measurement2D >::const_iterator measurements_deprecated_end() const
Definition MutableTrajectory.cc:144
~MutableTrajectory()=default
destructor
const edm4eic::TrackSeed getSeed() const
Access the Corresponding track seed.
Definition MutableTrajectory.cc:65
std::vector< float >::const_iterator measurementChi2_end() const
Definition MutableTrajectory.cc:216
bool operator!=(const Trajectory &other) const
Definition MutableTrajectory.h:188
friend class TrajectoryCollection
Definition MutableTrajectory.h:41
MutableTrajectory clone(bool cloneRelations=true) const
Definition MutableTrajectory.cc:33
std::vector< float >::const_iterator outlierChi2_end() const
Definition MutableTrajectory.cc:252
void setNMeasurements(const std::uint32_t nMeasurements)
Set the Number of hits used.
Definition MutableTrajectory.cc:79
Trajectory object_type
Definition MutableTrajectory.h:46
MutableTrajectory()=default
default constructor
bool isAvailable() const
check whether the object is actually available
Definition MutableTrajectory.cc:282
podio::RelationRange< float > getOutlierChi2() const
Definition MutableTrajectory.cc:269
void setSeed(const edm4eic::TrackSeed &value)
Set the Corresponding track seed.
Definition MutableTrajectory.cc:92
std::uint32_t getType() const
Access the 0 (does not have good track fit), 1 (has good track fit)
Definition MutableTrajectory.cc:58
std::vector< float >::const_iterator measurementChi2_begin() const
Definition MutableTrajectory.cc:210
friend class TrajectoryMutableCollectionIterator
Definition MutableTrajectory.h:42
std::uint32_t getNStates() const
Access the Number of tracking steps.
Definition MutableTrajectory.cc:59
friend class Trajectory
Definition MutableTrajectory.h:43
const podio::ObjectID getObjectID() const
Definition MutableTrajectory.cc:286
std::uint32_t getNHoles() const
Access the Number of missing hits.
Definition MutableTrajectory.cc:62
bool operator!=(const MutableTrajectory &other) const
Definition MutableTrajectory.h:187
std::uint32_t & nMeasurements()
Get reference to Number of hits used.
Definition MutableTrajectory.cc:81
std::size_t measurementChi2_size() const
Definition MutableTrajectory.cc:222
void unlink()
disconnect from TrajectoryObj instance
Definition MutableTrajectory.h:182
std::vector< edm4eic::Measurement2D >::const_iterator measurements_deprecated_begin() const
Definition MutableTrajectory.cc:138
podio::RelationRange< edm4eic::Measurement2D > getMeasurements_deprecated() const
Definition MutableTrajectory.cc:161
TrajectoryCollection collection_type
Definition MutableTrajectory.h:47
std::uint32_t & nHoles()
Get reference to Number of missing hits.
Definition MutableTrajectory.cc:87
void addToOutlierChi2(const float &)
Definition MutableTrajectory.cc:241
void setNSharedHits(const std::uint32_t nSharedHits)
Set the Number of shared hits with other trajectories.
Definition MutableTrajectory.cc:88
MutableTrajectory & operator=(MutableTrajectory other) &
copy-assignment operator
Definition MutableTrajectory.cc:28
std::vector< edm4eic::Measurement2D >::const_iterator outliers_deprecated_begin() const
Definition MutableTrajectory.cc:174
friend void swap(MutableTrajectory &a, MutableTrajectory &b)
Definition MutableTrajectory.h:199
std::size_t outlierChi2_size() const
Definition MutableTrajectory.cc:258
std::vector< edm4eic::TrackParameters >::const_iterator trackParameters_end() const
Definition MutableTrajectory.cc:108
std::uint32_t getNSharedHits() const
Access the Number of shared hits with other trajectories.
Definition MutableTrajectory.cc:63
std::vector< edm4eic::TrackParameters >::const_iterator trackParameters_begin() const
Definition MutableTrajectory.cc:102
std::size_t trackParameters_size() const
Definition MutableTrajectory.cc:114
Definition TrackParameters.h:43
Definition TrackSeed.h:46
Definition TrajectoryCollection.h:138
Definition Trajectory.h:47
Definition TrajectoryObj.h:25
Definition CalorimeterHit.cc:17
OrderKey getOrderKey(const edm4eic::CalorimeterHit &obj)
Definition CalorimeterHit.cc:146
std::size_t operator()(const edm4eic::MutableTrajectory &obj) const
Definition MutableTrajectory.h:222