3#ifndef EDM4EIC_MCRecoTrackParticleAssociation_H
4#define EDM4EIC_MCRecoTrackParticleAssociation_H
10#include "podio/utilities/MaybeSharedPtr.h"
11#include "podio/detail/OrderKey.h"
16#if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
17#include "nlohmann/json_fwd.hpp"
22class MCRecoTrackParticleAssociationCollection;
28class MutableMCParticle;
39class MutableMCRecoTrackParticleAssociation;
40class MCRecoTrackParticleAssociationCollection;
41class MCRecoTrackParticleAssociationCollectionData;
85 static constexpr auto typeName =
"edm4eic::MCRecoTrackParticleAssociation";
100 const edm4hep::MCParticle
getSim()
const;
107 void unlink() { m_obj = podio::utils::MaybeSharedPtr<MCRecoTrackParticleAssociationObj>{
nullptr}; }
124 swap(a.m_obj, b.m_obj);
132 podio::utils::MaybeSharedPtr<MCRecoTrackParticleAssociationObj> m_obj{
nullptr};
135std::ostream&
operator<<(std::ostream& o,
const MCRecoTrackParticleAssociation& value);
137#if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
138void to_json(nlohmann::json& j,
const MCRecoTrackParticleAssociation& value);
Definition MCRecoTrackParticleAssociationCollectionData.h:32
Definition MCRecoTrackParticleAssociationCollection.h:91
Definition MCRecoTrackParticleAssociationCollection.h:36
Definition MCRecoTrackParticleAssociation.h:47
friend class MCRecoTrackParticleAssociationCollection
Definition MCRecoTrackParticleAssociation.h:50
const edm4hep::MCParticle getSim() const
Access the reference to the Monte-Carlo particle.
Definition MCRecoTrackParticleAssociation.cc:73
MCRecoTrackParticleAssociation & operator=(MCRecoTrackParticleAssociation other)
copy-assignment operator
Definition MCRecoTrackParticleAssociation.cc:32
bool operator!=(const MutableMCRecoTrackParticleAssociation &other) const
Definition MCRecoTrackParticleAssociation.h:113
friend class MutableMCRecoTrackParticleAssociation
Definition MCRecoTrackParticleAssociation.h:49
static MCRecoTrackParticleAssociation makeEmpty()
Definition MCRecoTrackParticleAssociation.cc:58
friend void swap(MCRecoTrackParticleAssociation &a, MCRecoTrackParticleAssociation &b)
Definition MCRecoTrackParticleAssociation.h:122
std::uint32_t getSimID() const
Access the Index of corresponding MCParticle (position in MCParticles array)
Definition MCRecoTrackParticleAssociation.cc:62
std::uint32_t getRecID() const
Access the Index of corresponding Track (position in Tracks array)
Definition MCRecoTrackParticleAssociation.cc:63
bool operator!=(const MCRecoTrackParticleAssociation &other) const
Definition MCRecoTrackParticleAssociation.h:112
bool isAvailable() const
check whether the object is actually available
Definition MCRecoTrackParticleAssociation.cc:85
MutableMCRecoTrackParticleAssociation clone(bool cloneRelations=true) const
Definition MCRecoTrackParticleAssociation.cc:37
MCRecoTrackParticleAssociation()
default constructor
Definition MCRecoTrackParticleAssociation.cc:22
~MCRecoTrackParticleAssociation()=default
destructor
MCRecoTrackParticleAssociation(const MCRecoTrackParticleAssociation &other)=default
copy constructor
podio::ObjectID id() const
Definition MCRecoTrackParticleAssociation.h:118
float getWeight() const
Access the weight of this association.
Definition MCRecoTrackParticleAssociation.cc:64
const podio::ObjectID getObjectID() const
Definition MCRecoTrackParticleAssociation.cc:89
static constexpr auto typeName
Definition MCRecoTrackParticleAssociation.h:85
bool operator<(const MCRecoTrackParticleAssociation &other) const
Definition MCRecoTrackParticleAssociation.h:116
bool operator==(const MCRecoTrackParticleAssociation &other) const
Definition MCRecoTrackParticleAssociation.h:109
void unlink()
disconnect from MCRecoTrackParticleAssociationObj instance
Definition MCRecoTrackParticleAssociation.h:107
const edm4eic::Track getRec() const
Access the reference to the track.
Definition MCRecoTrackParticleAssociation.cc:66
Definition MCRecoTrackParticleAssociationObj.h:24
Definition MutableMCRecoTrackParticleAssociation.h:39
Definition CalorimeterHit.cc:17
std::ostream & operator<<(std::ostream &o, const CalorimeterHit &value)
Definition CalorimeterHit.cc:103
Definition CalorimeterHit.h:25
Definition CalorimeterHit.h:31
OrderKey getOrderKey(const edm4eic::CalorimeterHit &obj)
Definition CalorimeterHit.cc:150