3#ifndef EDM4EIC_MutableMeasurement2D_H
4#define EDM4EIC_MutableMeasurement2D_H
12#include "edm4hep/Vector2f.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"
75 const edm4hep::Vector2f&
getLoc()
const;
90 [[deprecated(
"use getSurface instead")]]
94 void setLoc(
const edm4hep::Vector2f&
loc);
96 edm4hep::Vector2f&
getLoc();
98 [[deprecated(
"use getLoc instead")]]
99 edm4hep::Vector2f&
loc();
106 [[deprecated(
"use getTime instead")]]
114 [[deprecated(
"use getCovariance instead")]]
122 std::vector<edm4eic::TrackerHit>::const_iterator
hits_begin()
const;
123 std::vector<edm4eic::TrackerHit>::const_iterator
hits_end()
const;
124 podio::RelationRange<edm4eic::TrackerHit>
getHits()
const;
129 std::vector<float>::const_iterator
weights_end()
const;
130 podio::RelationRange<float>
getWeights()
const;
137 void unlink() { m_obj = podio::utils::MaybeSharedPtr<Measurement2DObj>{
nullptr}; }
152 friend std::hash<MutableMeasurement2D>;
156 swap(a.m_obj, b.m_obj);
163 podio::utils::MaybeSharedPtr<Measurement2DObj> m_obj{
new Measurement2DObj{}, podio::utils::MarkOwned};
166#if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
176struct std::hash<
edm4eic::MutableMeasurement2D> {
178 return std::hash<edm4eic::Measurement2DObj*>{}(obj.m_obj.get());
Definition Measurement2DCollection.h:138
Definition Measurement2D.h:46
Definition Measurement2DObj.h:20
Definition MutableMeasurement2D.h:38
Measurement2D object_type
Definition MutableMeasurement2D.h:45
Measurement2DCollection collection_type
Definition MutableMeasurement2D.h:46
void setCovariance(const edm4eic::Cov3f &covariance)
Set the Covariance on location and time.
Definition MutableMeasurement2D.cc:61
std::size_t weights_size() const
Definition MutableMeasurement2D.cc:119
void addToHits(const edm4eic::TrackerHit &)
Definition MutableMeasurement2D.cc:66
friend class Measurement2D
Definition MutableMeasurement2D.h:42
void setSurface(const std::uint64_t surface)
Set the Surface for bound coordinates (geometryID)
Definition MutableMeasurement2D.cc:52
void setLoc(const edm4hep::Vector2f &loc)
Set the 2D location on surface.
Definition MutableMeasurement2D.cc:55
friend class Measurement2DCollection
Definition MutableMeasurement2D.h:40
bool operator!=(const Measurement2D &other) const
Definition MutableMeasurement2D.h:143
friend void swap(MutableMeasurement2D &a, MutableMeasurement2D &b)
Definition MutableMeasurement2D.h:154
float & time()
Get reference to Measurement time.
Definition MutableMeasurement2D.cc:60
std::vector< edm4eic::TrackerHit >::const_iterator hits_begin() const
Definition MutableMeasurement2D.cc:71
friend class Measurement2DMutableCollectionIterator
Definition MutableMeasurement2D.h:41
bool operator!=(const MutableMeasurement2D &other) const
Definition MutableMeasurement2D.h:142
edm4eic::Cov3f & covariance()
Get reference to Covariance on location and time.
Definition MutableMeasurement2D.cc:63
std::vector< edm4eic::TrackerHit >::const_iterator hits_end() const
Definition MutableMeasurement2D.cc:77
MutableMeasurement2D(const MutableMeasurement2D &other)=default
copy constructor
edm4hep::Vector2f & loc()
Get reference to 2D location on surface.
Definition MutableMeasurement2D.cc:57
bool isAvailable() const
check whether the object is actually available
Definition MutableMeasurement2D.cc:143
podio::RelationRange< edm4eic::TrackerHit > getHits() const
Definition MutableMeasurement2D.cc:94
bool operator<(const MutableMeasurement2D &other) const
Definition MutableMeasurement2D.h:146
podio::RelationRange< float > getWeights() const
Definition MutableMeasurement2D.cc:130
std::vector< float >::const_iterator weights_begin() const
Definition MutableMeasurement2D.cc:107
const podio::ObjectID getObjectID() const
Definition MutableMeasurement2D.cc:147
const edm4hep::Vector2f & getLoc() const
Access the 2D location on surface.
Definition MutableMeasurement2D.cc:47
std::uint64_t getSurface() const
Access the Surface for bound coordinates (geometryID)
Definition MutableMeasurement2D.cc:46
void addToWeights(const float &)
Definition MutableMeasurement2D.cc:102
void unlink()
disconnect from Measurement2DObj instance
Definition MutableMeasurement2D.h:137
podio::ObjectID id() const
Definition MutableMeasurement2D.h:148
std::uint64_t & surface()
Get reference to Surface for bound coordinates (geometryID)
Definition MutableMeasurement2D.cc:54
const edm4eic::Cov3f & getCovariance() const
Access the Covariance on location and time.
Definition MutableMeasurement2D.cc:49
MutableMeasurement2D clone(bool cloneRelations=true) const
Definition MutableMeasurement2D.cc:30
bool operator==(const MutableMeasurement2D &other) const
Definition MutableMeasurement2D.h:139
std::vector< float >::const_iterator weights_end() const
Definition MutableMeasurement2D.cc:113
~MutableMeasurement2D()=default
destructor
float getTime() const
Access the Measurement time.
Definition MutableMeasurement2D.cc:48
std::size_t hits_size() const
Definition MutableMeasurement2D.cc:83
MutableMeasurement2D & operator=(MutableMeasurement2D other) &
copy-assignment operator
Definition MutableMeasurement2D.cc:25
MutableMeasurement2D()=default
default constructor
void setTime(const float time)
Set the Measurement time.
Definition MutableMeasurement2D.cc:58
MutableMeasurement2D & operator=(MutableMeasurement2D other) &&=delete
Definition TrackerHit.h:45
Definition CalorimeterHit.cc:17
OrderKey getOrderKey(const edm4eic::CalorimeterHit &obj)
Definition CalorimeterHit.cc:146
std::size_t operator()(const edm4eic::MutableMeasurement2D &obj) const
Definition MutableMeasurement2D.h:177