3#ifndef EDM4EIC_MutableTrackSegment_H
4#define EDM4EIC_MutableTrackSegment_H
11#include "podio/RelationRange.h"
14#include "podio/utilities/MaybeSharedPtr.h"
18#if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
19#include "nlohmann/json_fwd.hpp"
85 [[deprecated(
"use getLength instead")]]
93 [[deprecated(
"use getLengthError instead")]]
103 std::vector<edm4eic::TrackPoint>::const_iterator
points_begin()
const;
104 std::vector<edm4eic::TrackPoint>::const_iterator
points_end()
const;
105 podio::RelationRange<edm4eic::TrackPoint>
getPoints()
const;
112 void unlink() { m_obj = podio::utils::MaybeSharedPtr<TrackSegmentObj>{
nullptr}; }
127 friend std::hash<MutableTrackSegment>;
131 swap(a.m_obj, b.m_obj);
138 podio::utils::MaybeSharedPtr<TrackSegmentObj> m_obj{
nullptr};
141#if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
151struct std::hash<
edm4eic::MutableTrackSegment> {
153 return std::hash<edm4eic::TrackSegmentObj*>{}(obj.m_obj.get());
Definition MutableTrack.h:40
Definition MutableTrackSegment.h:37
friend class TrackSegmentCollection
Definition MutableTrackSegment.h:39
podio::RelationRange< edm4eic::TrackPoint > getPoints() const
Definition MutableTrackSegment.cc:97
MutableTrackSegment & operator=(MutableTrackSegment other) &&=delete
MutableTrackSegment clone(bool cloneRelations=true) const
Definition MutableTrackSegment.cc:33
MutableTrackSegment()
default constructor
Definition MutableTrackSegment.cc:19
std::vector< edm4eic::TrackPoint >::const_iterator points_begin() const
Definition MutableTrackSegment.cc:74
bool operator<(const MutableTrackSegment &other) const
Definition MutableTrackSegment.h:121
std::vector< edm4eic::TrackPoint >::const_iterator points_end() const
Definition MutableTrackSegment.cc:80
MutableTrackSegment & operator=(MutableTrackSegment other) &
copy-assignment operator
Definition MutableTrackSegment.cc:28
void setLength(const float length)
Set the Pathlength from the first to the last point.
Definition MutableTrackSegment.cc:57
float & lengthError()
Get reference to Error on the segment length.
Definition MutableTrackSegment.cc:62
bool isAvailable() const
check whether the object is actually available
Definition MutableTrackSegment.cc:110
float & length()
Get reference to Pathlength from the first to the last point.
Definition MutableTrackSegment.cc:59
MutableTrackSegment(const MutableTrackSegment &other)=default
copy constructor
friend class TrackSegment
Definition MutableTrackSegment.h:41
friend void swap(MutableTrackSegment &a, MutableTrackSegment &b)
Definition MutableTrackSegment.h:129
friend class TrackSegmentMutableCollectionIterator
Definition MutableTrackSegment.h:40
bool operator!=(const TrackSegment &other) const
Definition MutableTrackSegment.h:118
~MutableTrackSegment()=default
destructor
void unlink()
disconnect from TrackSegmentObj instance
Definition MutableTrackSegment.h:112
void setLengthError(const float lengthError)
Set the Error on the segment length.
Definition MutableTrackSegment.cc:60
TrackSegmentCollection collection_type
Definition MutableTrackSegment.h:45
std::size_t points_size() const
Definition MutableTrackSegment.cc:86
bool operator==(const MutableTrackSegment &other) const
Definition MutableTrackSegment.h:114
const edm4eic::Track getTrack() const
Access the Track used for this projection.
Definition MutableTrackSegment.cc:49
bool operator!=(const MutableTrackSegment &other) const
Definition MutableTrackSegment.h:117
TrackSegment object_type
Definition MutableTrackSegment.h:44
void setTrack(const edm4eic::Track &value)
Set the Track used for this projection.
Definition MutableTrackSegment.cc:64
const podio::ObjectID getObjectID() const
Definition MutableTrackSegment.cc:114
podio::ObjectID id() const
Definition MutableTrackSegment.h:123
float getLengthError() const
Access the Error on the segment length.
Definition MutableTrackSegment.cc:47
float getLength() const
Access the Pathlength from the first to the last point.
Definition MutableTrackSegment.cc:46
void addToPoints(const edm4eic::TrackPoint &)
Definition MutableTrackSegment.cc:69
Definition TrackPoint.h:22
Definition TrackSegmentCollection.h:137
Definition TrackSegment.h:45
Definition CalorimeterHit.cc:17
OrderKey getOrderKey(const edm4eic::CalorimeterHit &obj)
Definition CalorimeterHit.cc:150
std::size_t operator()(const edm4eic::MutableTrackSegment &obj) const
Definition MutableTrackSegment.h:152