3#ifndef EDM4EIC_MCRecoVertexParticleAssociation_H
4#define EDM4EIC_MCRecoVertexParticleAssociation_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 MCRecoVertexParticleAssociationCollection;
28class MutableMCParticle;
39class MutableMCRecoVertexParticleAssociation;
40class MCRecoVertexParticleAssociationCollection;
41class MCRecoVertexParticleAssociationCollectionData;
85 static constexpr auto typeName =
"edm4eic::MCRecoVertexParticleAssociation";
100 const edm4hep::MCParticle
getSim()
const;
107 void unlink() { m_obj = podio::utils::MaybeSharedPtr<MCRecoVertexParticleAssociationObj>{
nullptr}; }
124 swap(a.m_obj, b.m_obj);
132 podio::utils::MaybeSharedPtr<MCRecoVertexParticleAssociationObj> m_obj{
nullptr};
135std::ostream&
operator<<(std::ostream& o,
const MCRecoVertexParticleAssociation& value);
137#if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
138void to_json(nlohmann::json& j,
const MCRecoVertexParticleAssociation& value);
Definition MCRecoVertexParticleAssociationCollectionData.h:32
Definition MCRecoVertexParticleAssociationCollection.h:91
Definition MCRecoVertexParticleAssociationCollection.h:36
Definition MCRecoVertexParticleAssociation.h:47
bool operator<(const MCRecoVertexParticleAssociation &other) const
Definition MCRecoVertexParticleAssociation.h:116
const edm4hep::MCParticle getSim() const
Access the reference to the Monte-Carlo particle.
Definition MCRecoVertexParticleAssociation.cc:73
MCRecoVertexParticleAssociation()
default constructor
Definition MCRecoVertexParticleAssociation.cc:22
podio::ObjectID id() const
Definition MCRecoVertexParticleAssociation.h:118
bool operator!=(const MCRecoVertexParticleAssociation &other) const
Definition MCRecoVertexParticleAssociation.h:112
friend void swap(MCRecoVertexParticleAssociation &a, MCRecoVertexParticleAssociation &b)
Definition MCRecoVertexParticleAssociation.h:122
MCRecoVertexParticleAssociation(const MCRecoVertexParticleAssociation &other)=default
copy constructor
float getWeight() const
Access the weight of this association.
Definition MCRecoVertexParticleAssociation.cc:64
MutableMCRecoVertexParticleAssociation clone(bool cloneRelations=true) const
Definition MCRecoVertexParticleAssociation.cc:37
friend class MCRecoVertexParticleAssociationCollection
Definition MCRecoVertexParticleAssociation.h:50
friend class MutableMCRecoVertexParticleAssociation
Definition MCRecoVertexParticleAssociation.h:49
std::uint32_t getRecID() const
Access the Index of corresponding Vertex (position in Vertices array)
Definition MCRecoVertexParticleAssociation.cc:63
static constexpr auto typeName
Definition MCRecoVertexParticleAssociation.h:85
bool operator==(const MCRecoVertexParticleAssociation &other) const
Definition MCRecoVertexParticleAssociation.h:109
MCRecoVertexParticleAssociation & operator=(MCRecoVertexParticleAssociation other)
copy-assignment operator
Definition MCRecoVertexParticleAssociation.cc:32
static MCRecoVertexParticleAssociation makeEmpty()
Definition MCRecoVertexParticleAssociation.cc:58
void unlink()
disconnect from MCRecoVertexParticleAssociationObj instance
Definition MCRecoVertexParticleAssociation.h:107
bool isAvailable() const
check whether the object is actually available
Definition MCRecoVertexParticleAssociation.cc:85
bool operator!=(const MutableMCRecoVertexParticleAssociation &other) const
Definition MCRecoVertexParticleAssociation.h:113
const podio::ObjectID getObjectID() const
Definition MCRecoVertexParticleAssociation.cc:89
std::uint32_t getSimID() const
Access the Index of corresponding MCParticle (position in MCParticles array)
Definition MCRecoVertexParticleAssociation.cc:62
~MCRecoVertexParticleAssociation()=default
destructor
const edm4eic::Vertex getRec() const
Access the reference to the vertex.
Definition MCRecoVertexParticleAssociation.cc:66
Definition MCRecoVertexParticleAssociationObj.h:24
Definition MutableMCRecoVertexParticleAssociation.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