3#ifndef EDM4EIC_TrackSeed_H
4#define EDM4EIC_TrackSeed_H
9#include "edm4hep/Vector3f.h"
10#include "podio/RelationRange.h"
13#include "podio/utilities/MaybeSharedPtr.h"
14#include "podio/detail/OrderKey.h"
19#if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
20#include "nlohmann/json_fwd.hpp"
62 TrackSeed(
const edm4hep::Vector3f& perigee);
85 static constexpr std::string_view
typeName =
"edm4eic::TrackSeed";
96 std::vector<edm4eic::TrackerHit>::const_iterator
hits_begin()
const;
97 std::vector<edm4eic::TrackerHit>::const_iterator
hits_end()
const;
98 podio::RelationRange<edm4eic::TrackerHit>
getHits()
const;
104 void unlink() { m_obj = podio::utils::MaybeSharedPtr<TrackSeedObj>{
nullptr}; }
119 friend std::hash<TrackSeed>;
123 swap(a.m_obj, b.m_obj);
128 explicit TrackSeed(podio::utils::MaybeSharedPtr<TrackSeedObj> obj);
131 podio::utils::MaybeSharedPtr<TrackSeedObj> m_obj{
nullptr};
136#if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
137void to_json(nlohmann::json& j,
const TrackSeed& value);
148 return std::hash<edm4eic::TrackSeedObj*>{}(obj.m_obj.get());
156#if defined(__clang__)
157#pragma clang diagnostic push
158#pragma clang diagnostic ignored "-Wunknown-warning-option"
159#pragma clang diagnostic ignored "-Wdeprecated-redundant-constexpr-static-def"
160#pragma clang diagnostic ignored "-Wdeprecated"
162#pragma clang diagnostic pop
163#elif defined(__GNUC__)
164#pragma GCC diagnostic push
165#pragma GCC diagnostic ignored "-Wdeprecated"
167#pragma GCC diagnostic pop
Definition MutableTrackParameters.h:35
Definition MutableTrackSeed.h:38
Definition TrackParameters.h:43
Definition TrackSeedCollectionData.h:32
Definition TrackSeedCollection.h:137
Definition TrackSeed.h:46
MutableTrackSeed mutable_type
Definition TrackSeed.h:55
bool operator!=(const MutableTrackSeed &other) const
Definition TrackSeed.h:110
friend void swap(TrackSeed &a, TrackSeed &b)
Definition TrackSeed.h:121
podio::ObjectID id() const
Definition TrackSeed.h:115
bool operator<(const TrackSeed &other) const
Definition TrackSeed.h:113
TrackSeed & operator=(TrackSeed other) &
copy-assignment operator
Definition TrackSeed.cc:29
bool isAvailable() const
check whether the object is actually available
Definition TrackSeed.cc:113
static constexpr std::string_view typeName
Definition TrackSeed.h:85
MutableTrackSeed clone(bool cloneRelations=true) const
Definition TrackSeed.cc:34
friend class TrackSeedCollectionIterator
Definition TrackSeed.h:51
TrackSeed()
default constructor
Definition TrackSeed.cc:21
void unlink()
disconnect from TrackSeedObj instance
Definition TrackSeed.h:104
bool operator==(const TrackSeed &other) const
Definition TrackSeed.h:106
std::vector< edm4eic::TrackerHit >::const_iterator hits_begin() const
Definition TrackSeed.cc:78
friend class TrackSeedCollection
Definition TrackSeed.h:49
friend class MutableTrackSeed
Definition TrackSeed.h:48
TrackSeedCollection collection_type
Definition TrackSeed.h:56
const edm4eic::TrackParameters getParams() const
Access the Initial track parameters.
Definition TrackSeed.cc:69
const edm4hep::Vector3f & getPerigee() const
Access the Vector for the perigee (line surface)
Definition TrackSeed.cc:67
podio::RelationRange< edm4eic::TrackerHit > getHits() const
Definition TrackSeed.cc:101
const podio::ObjectID getObjectID() const
Definition TrackSeed.cc:117
TrackSeed(const TrackSeed &other)=default
copy constructor
~TrackSeed()=default
destructor
static TrackSeed makeEmpty()
Definition TrackSeed.cc:63
std::size_t hits_size() const
Definition TrackSeed.cc:90
std::vector< edm4eic::TrackerHit >::const_iterator hits_end() const
Definition TrackSeed.cc:84
TrackSeed & operator=(TrackSeed other) &&=delete
bool operator!=(const TrackSeed &other) const
Definition TrackSeed.h:109
Definition TrackSeedObj.h:24
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::TrackSeed &obj) const
Definition TrackSeed.h:147