3#ifndef EDM4EIC_Measurement2D_H
4#define EDM4EIC_Measurement2D_H
10#include "edm4hep/Vector2f.h"
11#include "podio/RelationRange.h"
15#include "podio/utilities/MaybeSharedPtr.h"
16#include "podio/detail/OrderKey.h"
21#if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
22#include "nlohmann/json_fwd.hpp"
33OrderKey
getOrderKey(
const edm4eic::Measurement2D& obj);
85 static constexpr std::string_view
typeName =
"edm4eic::Measurement2D";
91 const edm4hep::Vector2f&
getLoc()
const;
103 std::vector<edm4eic::TrackerHit>::const_iterator
hits_begin()
const;
104 std::vector<edm4eic::TrackerHit>::const_iterator
hits_end()
const;
105 podio::RelationRange<edm4eic::TrackerHit>
getHits()
const;
109 std::vector<float>::const_iterator
weights_end()
const;
110 podio::RelationRange<float>
getWeights()
const;
116 void unlink() { m_obj = podio::utils::MaybeSharedPtr<Measurement2DObj>{
nullptr}; }
131 friend std::hash<Measurement2D>;
135 swap(a.m_obj, b.m_obj);
140 explicit Measurement2D(podio::utils::MaybeSharedPtr<Measurement2DObj> obj);
143 podio::utils::MaybeSharedPtr<Measurement2DObj> m_obj{
new Measurement2DObj{}, podio::utils::MarkOwned};
148#if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
160 return std::hash<edm4eic::Measurement2DObj*>{}(obj.m_obj.get());
168#if defined(__clang__)
169 #pragma clang diagnostic push
170 #pragma clang diagnostic ignored "-Wunknown-warning-option"
171 #pragma clang diagnostic ignored "-Wdeprecated-redundant-constexpr-static-def"
172 #pragma clang diagnostic ignored "-Wdeprecated"
174 #pragma clang diagnostic pop
175#elif defined(__GNUC__)
176 #pragma GCC diagnostic push
177 #pragma GCC diagnostic ignored "-Wdeprecated"
179 #pragma GCC diagnostic pop
Definition Measurement2DCollectionData.h:32
Definition Measurement2DCollection.h:138
Definition Measurement2D.h:46
std::uint64_t getSurface() const
Access the Surface for bound coordinates (geometryID)
Definition Measurement2D.cc:73
const edm4eic::Cov3f & getCovariance() const
Access the Covariance on location and time.
Definition Measurement2D.cc:76
bool isAvailable() const
check whether the object is actually available
Definition Measurement2D.cc:147
Measurement2D & operator=(Measurement2D other) &&=delete
friend class Measurement2DCollection
Definition Measurement2D.h:49
void unlink()
disconnect from Measurement2DObj instance
Definition Measurement2D.h:116
const edm4hep::Vector2f & getLoc() const
Access the 2D location on surface.
Definition Measurement2D.cc:74
std::vector< edm4eic::TrackerHit >::const_iterator hits_end() const
Definition Measurement2D.cc:86
MutableMeasurement2D clone(bool cloneRelations=true) const
Definition Measurement2D.cc:32
std::size_t weights_size() const
Definition Measurement2D.cc:124
Measurement2D(const Measurement2D &other)=default
copy constructor
std::vector< float >::const_iterator weights_end() const
Definition Measurement2D.cc:118
Measurement2D & operator=(Measurement2D other) &
copy-assignment operator
Definition Measurement2D.cc:27
podio::RelationRange< edm4eic::TrackerHit > getHits() const
Definition Measurement2D.cc:103
Measurement2D()=default
default constructor
friend class Measurement2DCollectionIterator
Definition Measurement2D.h:51
bool operator==(const Measurement2D &other) const
Definition Measurement2D.h:118
~Measurement2D()=default
destructor
podio::RelationRange< float > getWeights() const
Definition Measurement2D.cc:135
std::size_t hits_size() const
Definition Measurement2D.cc:92
MutableMeasurement2D mutable_type
Definition Measurement2D.h:55
std::vector< edm4eic::TrackerHit >::const_iterator hits_begin() const
Definition Measurement2D.cc:80
bool operator<(const Measurement2D &other) const
Definition Measurement2D.h:125
float getTime() const
Access the Measurement time.
Definition Measurement2D.cc:75
const podio::ObjectID getObjectID() const
Definition Measurement2D.cc:151
static Measurement2D makeEmpty()
Definition Measurement2D.cc:69
friend void swap(Measurement2D &a, Measurement2D &b)
Definition Measurement2D.h:133
static constexpr std::string_view typeName
Definition Measurement2D.h:85
podio::ObjectID id() const
Definition Measurement2D.h:127
bool operator!=(const Measurement2D &other) const
Definition Measurement2D.h:121
Measurement2DCollection collection_type
Definition Measurement2D.h:56
std::vector< float >::const_iterator weights_begin() const
Definition Measurement2D.cc:112
friend class MutableMeasurement2D
Definition Measurement2D.h:48
bool operator!=(const MutableMeasurement2D &other) const
Definition Measurement2D.h:122
Definition Measurement2DObj.h:20
Definition MutableMeasurement2D.h:38
Definition TrackerHit.h:45
Definition CalorimeterHit.cc:17
std::ostream & operator<<(std::ostream &o, const CalorimeterHit &value)
Definition CalorimeterHit.cc:99
Definition CalorimeterHit.h:31
OrderKey getOrderKey(const edm4eic::CalorimeterHit &obj)
Definition CalorimeterHit.cc:146
std::size_t operator()(const edm4eic::Measurement2D &obj) const
Definition Measurement2D.h:159