3#ifndef EDM4EIC_MutableTrack_H
4#define EDM4EIC_MutableTrack_H
12#include "edm4hep/Vector3f.h"
13#include "podio/RelationRange.h"
17#include "podio/utilities/MaybeSharedPtr.h"
21#if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
22#include "nlohmann/json_fwd.hpp"
98 std::uint32_t
getNdf()
const;
101 std::int32_t
getPdg()
const;
112 [[deprecated(
"use getType instead")]]
113 std::int32_t&
type();
120 [[deprecated(
"use getPosition instead")]]
128 [[deprecated(
"use getMomentum instead")]]
136 [[deprecated(
"use getPositionMomentumCovariance instead")]]
144 [[deprecated(
"use getTime instead")]]
152 [[deprecated(
"use getTimeError instead")]]
160 [[deprecated(
"use getCharge instead")]]
168 [[deprecated(
"use getChi2 instead")]]
176 [[deprecated(
"use getNdf instead")]]
177 std::uint32_t&
ndf();
184 [[deprecated(
"use getPdg instead")]]
195 std::vector<edm4eic::Measurement2D>::const_iterator
measurements_end()
const;
200 std::vector<edm4eic::Track>::const_iterator
tracks_begin()
const;
201 std::vector<edm4eic::Track>::const_iterator
tracks_end()
const;
202 podio::RelationRange<edm4eic::Track>
getTracks()
const;
209 void unlink() { m_obj = podio::utils::MaybeSharedPtr<TrackObj>{
nullptr}; }
224 friend std::hash<MutableTrack>;
228 swap(a.m_obj, b.m_obj);
233 explicit MutableTrack(podio::utils::MaybeSharedPtr<TrackObj> obj);
235 podio::utils::MaybeSharedPtr<TrackObj> m_obj{
new TrackObj{}, podio::utils::MarkOwned};
238#if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
239void to_json(nlohmann::json& j,
const MutableTrack& value);
250 return std::hash<edm4eic::TrackObj*>{}(obj.m_obj.get());
Definition Measurement2D.h:46
Definition MutableTrack.h:40
void setTimeError(const float timeError)
Set the Error on the track vertex time.
Definition MutableTrack.cc:87
void setNdf(const std::uint32_t ndf)
Set the Number of degrees of freedom.
Definition MutableTrack.cc:96
void setTrajectory(const edm4eic::Trajectory &value)
Set the Trajectory of this track.
Definition MutableTrack.cc:103
~MutableTrack()=default
destructor
friend class TrackMutableCollectionIterator
Definition MutableTrack.h:43
podio::ObjectID id() const
Definition MutableTrack.h:220
std::int32_t & pdg()
Get reference to PDG particle ID hypothesis.
Definition MutableTrack.cc:101
std::int32_t getPdg() const
Access the PDG particle ID hypothesis.
Definition MutableTrack.cc:62
float & charge()
Get reference to Particle charge.
Definition MutableTrack.cc:92
friend void swap(MutableTrack &a, MutableTrack &b)
Definition MutableTrack.h:226
const edm4eic::Trajectory getTrajectory() const
Access the Trajectory of this track.
Definition MutableTrack.cc:64
const podio::ObjectID getObjectID() const
Definition MutableTrack.cc:189
std::int32_t & type()
Get reference to Flag that defines the type of track.
Definition MutableTrack.cc:74
void setPdg(const std::int32_t pdg)
Set the PDG particle ID hypothesis.
Definition MutableTrack.cc:99
Track object_type
Definition MutableTrack.h:47
float & chi2()
Get reference to Total chi2.
Definition MutableTrack.cc:95
bool operator<(const MutableTrack &other) const
Definition MutableTrack.h:218
bool operator!=(const Track &other) const
Definition MutableTrack.h:215
void setCharge(const float charge)
Set the Particle charge.
Definition MutableTrack.cc:90
std::int32_t getType() const
Access the Flag that defines the type of track.
Definition MutableTrack.cc:53
void setTime(const float time)
Set the Track time at the vertex [ns].
Definition MutableTrack.cc:84
float getChi2() const
Access the Total chi2.
Definition MutableTrack.cc:60
std::size_t measurements_size() const
Definition MutableTrack.cc:125
std::vector< edm4eic::Track >::const_iterator tracks_end() const
Definition MutableTrack.cc:155
podio::RelationRange< edm4eic::Measurement2D > getMeasurements() const
Definition MutableTrack.cc:136
MutableTrack & operator=(MutableTrack other) &&=delete
MutableTrack clone(bool cloneRelations=true) const
Definition MutableTrack.cc:37
edm4hep::Vector3f & position()
Get reference to Track 3-position at the vertex.
Definition MutableTrack.cc:77
const edm4hep::Vector3f & getMomentum() const
Access the Track 3-momentum at the vertex [GeV].
Definition MutableTrack.cc:55
bool operator!=(const MutableTrack &other) const
Definition MutableTrack.h:214
void setPosition(const edm4hep::Vector3f &position)
Set the Track 3-position at the vertex.
Definition MutableTrack.cc:75
podio::RelationRange< edm4eic::Track > getTracks() const
Definition MutableTrack.cc:172
float getTimeError() const
Access the Error on the track vertex time.
Definition MutableTrack.cc:58
void addToTracks(const edm4eic::Track &)
Definition MutableTrack.cc:144
MutableTrack()=default
default constructor
void unlink()
disconnect from TrackObj instance
Definition MutableTrack.h:209
edm4eic::Cov6f & positionMomentumCovariance()
Get reference to Covariance matrix in basis [x,y,z,px,py,pz].
Definition MutableTrack.cc:83
std::vector< edm4eic::Track >::const_iterator tracks_begin() const
Definition MutableTrack.cc:149
TrackCollection collection_type
Definition MutableTrack.h:48
edm4hep::Vector3f & momentum()
Get reference to Track 3-momentum at the vertex [GeV].
Definition MutableTrack.cc:80
void setType(const std::int32_t type)
Set the Flag that defines the type of track.
Definition MutableTrack.cc:72
std::size_t tracks_size() const
Definition MutableTrack.cc:161
MutableTrack(const MutableTrack &other)=default
copy constructor
void setMomentum(const edm4hep::Vector3f &momentum)
Set the Track 3-momentum at the vertex [GeV].
Definition MutableTrack.cc:78
float getCharge() const
Access the Particle charge.
Definition MutableTrack.cc:59
const edm4eic::Cov6f & getPositionMomentumCovariance() const
Access the Covariance matrix in basis [x,y,z,px,py,pz].
Definition MutableTrack.cc:56
std::uint32_t & ndf()
Get reference to Number of degrees of freedom.
Definition MutableTrack.cc:98
bool isAvailable() const
check whether the object is actually available
Definition MutableTrack.cc:185
void addToMeasurements(const edm4eic::Measurement2D &)
Definition MutableTrack.cc:108
void setChi2(const float chi2)
Set the Total chi2.
Definition MutableTrack.cc:93
friend class Track
Definition MutableTrack.h:44
float & timeError()
Get reference to Error on the track vertex time.
Definition MutableTrack.cc:89
std::uint32_t getNdf() const
Access the Number of degrees of freedom.
Definition MutableTrack.cc:61
const edm4hep::Vector3f & getPosition() const
Access the Track 3-position at the vertex.
Definition MutableTrack.cc:54
bool operator==(const MutableTrack &other) const
Definition MutableTrack.h:211
float & time()
Get reference to Track time at the vertex [ns].
Definition MutableTrack.cc:86
float getTime() const
Access the Track time at the vertex [ns].
Definition MutableTrack.cc:57
friend class TrackCollection
Definition MutableTrack.h:42
std::vector< edm4eic::Measurement2D >::const_iterator measurements_end() const
Definition MutableTrack.cc:119
MutableTrack & operator=(MutableTrack other) &
copy-assignment operator
Definition MutableTrack.cc:32
std::vector< edm4eic::Measurement2D >::const_iterator measurements_begin() const
Definition MutableTrack.cc:113
void setPositionMomentumCovariance(const edm4eic::Cov6f &positionMomentumCovariance)
Set the Covariance matrix in basis [x,y,z,px,py,pz].
Definition MutableTrack.cc:81
Definition MutableTrajectory.h:39
Definition TrackCollection.h:138
Definition Trajectory.h:47
Definition CalorimeterHit.cc:17
OrderKey getOrderKey(const edm4eic::CalorimeterHit &obj)
Definition CalorimeterHit.cc:146
std::size_t operator()(const edm4eic::MutableTrack &obj) const
Definition MutableTrack.h:249