File indexing completed on 2025-11-03 09:44:54
0001 
0002 
0003 #ifndef EDM4EIC_MutableMCRecoVertexParticleAssociation_H
0004 #define EDM4EIC_MutableMCRecoVertexParticleAssociation_H
0005 
0006 #include "edm4eic/MCRecoVertexParticleAssociationObj.h"
0007 
0008 #include "edm4eic/MCRecoVertexParticleAssociation.h"
0009 
0010 #include <cstdint>
0011 
0012 #include "podio/utilities/MaybeSharedPtr.h"
0013 
0014 #include <cstdint>
0015 
0016 #if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
0017 #include "nlohmann/json_fwd.hpp"
0018 #endif
0019 
0020 
0021 namespace edm4eic {
0022 class MCRecoVertexParticleAssociationCollection;
0023 class Vertex;
0024 class MutableVertex;
0025 }
0026 namespace edm4hep {
0027 class MCParticle;
0028 class MutableMCParticle;
0029 }
0030 
0031 
0032 namespace edm4eic {
0033 
0034 
0035 
0036 
0037 
0038 
0039 class MutableMCRecoVertexParticleAssociation {
0040 
0041   friend class MCRecoVertexParticleAssociationCollection;
0042   friend class MCRecoVertexParticleAssociationMutableCollectionIterator;
0043   friend class MCRecoVertexParticleAssociation;
0044 
0045 public:
0046   using object_type = MCRecoVertexParticleAssociation;
0047   using collection_type = MCRecoVertexParticleAssociationCollection;
0048 
0049   
0050   MutableMCRecoVertexParticleAssociation();
0051 
0052   
0053   MutableMCRecoVertexParticleAssociation(const std::uint32_t simID, const std::uint32_t recID, const float weight);
0054 
0055   
0056   MutableMCRecoVertexParticleAssociation(const MutableMCRecoVertexParticleAssociation& other) = default;
0057 
0058   
0059   MutableMCRecoVertexParticleAssociation& operator=(MutableMCRecoVertexParticleAssociation other) &; 
0060   MutableMCRecoVertexParticleAssociation& operator=(MutableMCRecoVertexParticleAssociation other) && = delete; 
0061 
0062   
0063   
0064   MutableMCRecoVertexParticleAssociation clone(bool cloneRelations=true) const;
0065 
0066   
0067   ~MutableMCRecoVertexParticleAssociation() = default;
0068 
0069 
0070 public:
0071 
0072   
0073   std::uint32_t getSimID() const;
0074 
0075   
0076   std::uint32_t getRecID() const;
0077 
0078   
0079   float getWeight() const;
0080 
0081 
0082   
0083   const edm4eic::Vertex getRec() const;
0084   
0085   const edm4hep::MCParticle getSim() const;
0086 
0087   
0088   void setSimID(const std::uint32_t simID);
0089   
0090   std::uint32_t& getSimID();
0091   
0092   [[deprecated("use getSimID instead")]]
0093   std::uint32_t& simID();
0094 
0095   
0096   void setRecID(const std::uint32_t recID);
0097   
0098   std::uint32_t& getRecID();
0099   
0100   [[deprecated("use getRecID instead")]]
0101   std::uint32_t& recID();
0102 
0103   
0104   void setWeight(const float weight);
0105   
0106   float& getWeight();
0107   
0108   [[deprecated("use getWeight instead")]]
0109   float& weight();
0110 
0111 
0112   
0113   void setRec(const edm4eic::Vertex& value);
0114   
0115   void setSim(const edm4hep::MCParticle& value);
0116 
0117 
0118 
0119 
0120   
0121   bool isAvailable() const;
0122   
0123   void unlink() { m_obj = podio::utils::MaybeSharedPtr<MCRecoVertexParticleAssociationObj>{nullptr}; }
0124 
0125   bool operator==(const MutableMCRecoVertexParticleAssociation& other) const { return m_obj == other.m_obj; }
0126   bool operator==(const MCRecoVertexParticleAssociation& other) const;
0127 
0128   bool operator!=(const MutableMCRecoVertexParticleAssociation& other) const { return !(*this == other); }
0129   bool operator!=(const MCRecoVertexParticleAssociation& other) const { return !(*this == other); }
0130 
0131   
0132   bool operator<(const MutableMCRecoVertexParticleAssociation& other) const { return podio::detail::getOrderKey(*this) < podio::detail::getOrderKey(other); }
0133 
0134   podio::ObjectID id() const { return getObjectID(); }
0135 
0136   const podio::ObjectID getObjectID() const;
0137 
0138   friend std::hash<MutableMCRecoVertexParticleAssociation>;
0139 
0140   friend void swap(MutableMCRecoVertexParticleAssociation& a, MutableMCRecoVertexParticleAssociation& b) {
0141     using std::swap;
0142     swap(a.m_obj, b.m_obj); 
0143   }
0144 
0145 private:
0146   
0147   explicit MutableMCRecoVertexParticleAssociation(podio::utils::MaybeSharedPtr<MCRecoVertexParticleAssociationObj> obj);
0148 
0149   podio::utils::MaybeSharedPtr<MCRecoVertexParticleAssociationObj> m_obj{nullptr};
0150 };
0151 
0152 #if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
0153 void to_json(nlohmann::json& j, const MutableMCRecoVertexParticleAssociation& value);
0154 #endif
0155 
0156 
0157 } 
0158 
0159 
0160 
0161 template<>
0162 struct std::hash<edm4eic::MutableMCRecoVertexParticleAssociation> {
0163   std::size_t operator()(const edm4eic::MutableMCRecoVertexParticleAssociation& obj) const {
0164     return std::hash<edm4eic::MCRecoVertexParticleAssociationObj*>{}(obj.m_obj.get());
0165   }
0166 };
0167 
0168 
0169 #endif