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{
nullptr};
 
 
  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:31
 
Definition Measurement2DCollection.h:137
 
Definition Measurement2D.h:46
 
std::uint64_t getSurface() const
Access the Surface for bound coordinates (geometryID)
Definition Measurement2D.cc:77
 
const edm4eic::Cov3f & getCovariance() const
Access the Covariance on location and time.
Definition Measurement2D.cc:80
 
bool isAvailable() const
check whether the object is actually available
Definition Measurement2D.cc:151
 
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:78
 
std::vector< edm4eic::TrackerHit >::const_iterator hits_end() const
Definition Measurement2D.cc:90
 
MutableMeasurement2D clone(bool cloneRelations=true) const
Definition Measurement2D.cc:36
 
std::size_t weights_size() const
Definition Measurement2D.cc:128
 
Measurement2D(const Measurement2D &other)=default
copy constructor
 
std::vector< float >::const_iterator weights_end() const
Definition Measurement2D.cc:122
 
Measurement2D & operator=(Measurement2D other) &
copy-assignment operator
Definition Measurement2D.cc:31
 
podio::RelationRange< edm4eic::TrackerHit > getHits() const
Definition Measurement2D.cc:107
 
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:139
 
std::size_t hits_size() const
Definition Measurement2D.cc:96
 
MutableMeasurement2D mutable_type
Definition Measurement2D.h:55
 
std::vector< edm4eic::TrackerHit >::const_iterator hits_begin() const
Definition Measurement2D.cc:84
 
bool operator<(const Measurement2D &other) const
Definition Measurement2D.h:125
 
float getTime() const
Access the Measurement time.
Definition Measurement2D.cc:79
 
const podio::ObjectID getObjectID() const
Definition Measurement2D.cc:155
 
static Measurement2D makeEmpty()
Definition Measurement2D.cc:73
 
Measurement2D()
default constructor
Definition Measurement2D.cc:20
 
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:116
 
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:103
 
Definition CalorimeterHit.h:31
 
OrderKey getOrderKey(const edm4eic::CalorimeterHit &obj)
Definition CalorimeterHit.cc:150
 
std::size_t operator()(const edm4eic::Measurement2D &obj) const
Definition Measurement2D.h:159