File indexing completed on 2025-07-05 08:52:34
0001
0002
0003 #ifndef EDM4HEP_MutableCalorimeterHit_H
0004 #define EDM4HEP_MutableCalorimeterHit_H
0005
0006 #include "edm4hep/CalorimeterHitObj.h"
0007
0008 #include "edm4hep/CalorimeterHit.h"
0009
0010 #include "edm4hep/Vector3f.h"
0011 #include <cstdint>
0012
0013 #include "podio/utilities/MaybeSharedPtr.h"
0014
0015 #include <cstdint>
0016
0017 #if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
0018 #include "nlohmann/json_fwd.hpp"
0019 #endif
0020
0021
0022 namespace edm4hep {
0023 class CalorimeterHitCollection;
0024 }
0025
0026 namespace edm4hep {
0027
0028
0029
0030
0031
0032 class MutableCalorimeterHit {
0033
0034 friend class CalorimeterHitCollection;
0035 friend class CalorimeterHitMutableCollectionIterator;
0036 friend class CalorimeterHit;
0037
0038 public:
0039 using object_type = CalorimeterHit;
0040 using collection_type = CalorimeterHitCollection;
0041
0042
0043 MutableCalorimeterHit();
0044
0045
0046 MutableCalorimeterHit(std::uint64_t cellID, float energy, float energyError, float time, edm4hep::Vector3f position,
0047 std::int32_t type);
0048
0049
0050 MutableCalorimeterHit(const MutableCalorimeterHit& other) = default;
0051
0052
0053 MutableCalorimeterHit& operator=(MutableCalorimeterHit other);
0054
0055
0056
0057 MutableCalorimeterHit clone(bool cloneRelations = true) const;
0058
0059
0060 ~MutableCalorimeterHit() = default;
0061
0062 public:
0063
0064 std::uint64_t getCellID() const;
0065
0066
0067 float getEnergy() const;
0068
0069
0070 float getEnergyError() const;
0071
0072
0073 float getTime() const;
0074
0075
0076 const edm4hep::Vector3f& getPosition() const;
0077
0078
0079 std::int32_t getType() const;
0080
0081
0082 void setCellID(std::uint64_t value);
0083
0084 std::uint64_t& getCellID();
0085
0086 [[deprecated("use getCellID instead")]] std::uint64_t& cellID();
0087
0088
0089 void setEnergy(float value);
0090
0091 float& getEnergy();
0092
0093 [[deprecated("use getEnergy instead")]] float& energy();
0094
0095
0096 void setEnergyError(float value);
0097
0098 float& getEnergyError();
0099
0100 [[deprecated("use getEnergyError instead")]] float& energyError();
0101
0102
0103 void setTime(float value);
0104
0105 float& getTime();
0106
0107 [[deprecated("use getTime instead")]] float& time();
0108
0109
0110 void setPosition(edm4hep::Vector3f value);
0111
0112 edm4hep::Vector3f& getPosition();
0113
0114 [[deprecated("use getPosition instead")]] edm4hep::Vector3f& position();
0115
0116
0117 void setType(std::int32_t value);
0118
0119 std::int32_t& getType();
0120
0121 [[deprecated("use getType instead")]] std::int32_t& type();
0122
0123
0124 bool isAvailable() const;
0125
0126 void unlink() {
0127 m_obj = podio::utils::MaybeSharedPtr<CalorimeterHitObj>{nullptr};
0128 }
0129
0130 bool operator==(const MutableCalorimeterHit& other) const {
0131 return m_obj == other.m_obj;
0132 }
0133 bool operator==(const CalorimeterHit& other) const;
0134
0135 bool operator!=(const MutableCalorimeterHit& other) const {
0136 return !(*this == other);
0137 }
0138 bool operator!=(const CalorimeterHit& other) const {
0139 return !(*this == other);
0140 }
0141
0142
0143 bool operator<(const MutableCalorimeterHit& other) const {
0144 return podio::detail::getOrderKey(*this) < podio::detail::getOrderKey(other);
0145 }
0146
0147 podio::ObjectID id() const {
0148 return getObjectID();
0149 }
0150
0151 const podio::ObjectID getObjectID() const;
0152
0153 friend void swap(MutableCalorimeterHit& a, MutableCalorimeterHit& b) {
0154 using std::swap;
0155 swap(a.m_obj, b.m_obj);
0156 }
0157
0158 private:
0159
0160 explicit MutableCalorimeterHit(podio::utils::MaybeSharedPtr<CalorimeterHitObj> obj);
0161
0162 podio::utils::MaybeSharedPtr<CalorimeterHitObj> m_obj{nullptr};
0163 };
0164
0165 #if defined(PODIO_JSON_OUTPUT) && !defined(__CLING__)
0166 void to_json(nlohmann::json& j, const MutableCalorimeterHit& value);
0167 #endif
0168
0169 }
0170
0171 #endif